2015-11-22 23:44:01 +02:00
|
|
|
####################################################################################################################################
|
|
|
|
# DOC MANIFEST MODULE
|
|
|
|
####################################################################################################################################
|
|
|
|
package BackRestDoc::Common::DocManifest;
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings FATAL => qw(all);
|
|
|
|
use Carp qw(confess);
|
|
|
|
|
|
|
|
use Cwd qw(abs_path);
|
|
|
|
use Exporter qw(import);
|
|
|
|
our @EXPORT = qw();
|
|
|
|
use File::Basename qw(dirname);
|
2016-06-02 15:32:56 +02:00
|
|
|
use JSON::PP;
|
2015-11-22 23:44:01 +02:00
|
|
|
|
2016-04-14 15:30:54 +02:00
|
|
|
use pgBackRest::Common::Log;
|
|
|
|
use pgBackRest::Common::String;
|
2015-11-22 23:44:01 +02:00
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# File constants
|
|
|
|
####################################################################################################################################
|
|
|
|
use constant FILE_MANIFEST => 'manifest.xml';
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# Render constants
|
|
|
|
####################################################################################################################################
|
|
|
|
use constant RENDER => 'render';
|
2016-11-07 17:06:35 +02:00
|
|
|
use constant RENDER_COMPACT => 'compact';
|
|
|
|
push @EXPORT, qw(RENDER_COMPACT);
|
2015-11-22 23:44:01 +02:00
|
|
|
use constant RENDER_FILE => 'file';
|
2016-11-07 17:06:35 +02:00
|
|
|
use constant RENDER_MENU => 'menu';
|
|
|
|
push @EXPORT, qw(RENDER_MENU);
|
|
|
|
use constant RENDER_PRETTY => 'pretty';
|
|
|
|
push @EXPORT, qw(RENDER_PRETTY);
|
2015-11-22 23:44:01 +02:00
|
|
|
|
|
|
|
use constant RENDER_TYPE => 'type';
|
|
|
|
use constant RENDER_TYPE_HTML => 'html';
|
|
|
|
push @EXPORT, qw(RENDER_TYPE_HTML);
|
2015-12-23 18:04:26 +02:00
|
|
|
use constant RENDER_TYPE_MARKDOWN => 'markdown';
|
|
|
|
push @EXPORT, qw(RENDER_TYPE_MARKDOWN);
|
2015-11-22 23:44:01 +02:00
|
|
|
use constant RENDER_TYPE_PDF => 'pdf';
|
|
|
|
push @EXPORT, qw(RENDER_TYPE_PDF);
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# CONSTRUCTOR
|
|
|
|
####################################################################################################################################
|
|
|
|
sub new
|
|
|
|
{
|
|
|
|
my $class = shift; # Class name
|
|
|
|
|
|
|
|
# Create the class hash
|
|
|
|
my $self = {};
|
|
|
|
bless $self, $class;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
(
|
|
|
|
my $strOperation,
|
2017-06-09 23:51:41 +02:00
|
|
|
$self->{oStorage},
|
2015-11-22 23:44:01 +02:00
|
|
|
$self->{stryRequire},
|
2016-11-17 23:35:11 +02:00
|
|
|
$self->{stryInclude},
|
2016-06-02 15:32:56 +02:00
|
|
|
$self->{stryExclude},
|
2018-12-01 19:40:01 +02:00
|
|
|
$self->{rhKeyVariableOverride},
|
|
|
|
my $rhVariableOverride,
|
2016-06-02 15:32:56 +02:00
|
|
|
$self->{strDocPath},
|
|
|
|
$self->{bDeploy},
|
|
|
|
$self->{bCacheOnly},
|
2018-11-29 21:45:15 +02:00
|
|
|
$self->{bPre},
|
2015-11-22 23:44:01 +02:00
|
|
|
) =
|
|
|
|
logDebugParam
|
|
|
|
(
|
2016-05-26 15:09:42 +02:00
|
|
|
__PACKAGE__ . '->new', \@_,
|
2017-06-09 23:51:41 +02:00
|
|
|
{name => 'oStorage'},
|
2015-11-22 23:44:01 +02:00
|
|
|
{name => 'stryRequire'},
|
2016-11-17 23:35:11 +02:00
|
|
|
{name => 'stryInclude'},
|
2016-06-02 15:32:56 +02:00
|
|
|
{name => 'stryExclude'},
|
2018-12-01 19:40:01 +02:00
|
|
|
{name => 'rhKeyVariableOverride', required => false},
|
|
|
|
{name => 'rhVariableOverride', required => false},
|
2015-11-22 23:44:01 +02:00
|
|
|
{name => 'strDocPath', required => false},
|
2016-06-02 15:32:56 +02:00
|
|
|
{name => 'bDeploy', required => false},
|
|
|
|
{name => 'bCacheOnly', required => false},
|
2018-11-29 21:45:15 +02:00
|
|
|
{name => 'bPre', required => false, default => false},
|
2015-11-22 23:44:01 +02:00
|
|
|
);
|
|
|
|
|
2018-02-16 22:09:37 +02:00
|
|
|
# Set the bin path
|
|
|
|
$self->{strBinPath} = abs_path(dirname($0));
|
|
|
|
|
2015-11-22 23:44:01 +02:00
|
|
|
# Set the base path if it was not passed in
|
|
|
|
if (!defined($self->{strDocPath}))
|
|
|
|
{
|
2018-02-16 22:09:37 +02:00
|
|
|
$self->{strDocPath} = $self->{strBinPath};
|
2015-11-22 23:44:01 +02:00
|
|
|
}
|
|
|
|
|
2016-06-02 15:32:56 +02:00
|
|
|
# Set cache file names
|
|
|
|
$self->{strExeCacheLocal} = $self->{strDocPath} . "/output/exe.cache";
|
|
|
|
$self->{strExeCacheDeploy} = $self->{strDocPath} . "/resource/exe.cache";
|
|
|
|
|
2015-11-22 23:44:01 +02:00
|
|
|
# Load the manifest
|
|
|
|
$self->{oManifestXml} = new BackRestDoc::Common::Doc("$self->{strDocPath}/manifest.xml");
|
|
|
|
|
|
|
|
# Iterate the sources
|
|
|
|
$self->{oManifest} = {};
|
|
|
|
|
|
|
|
foreach my $oSource ($self->{oManifestXml}->nodeGet('source-list')->nodeList('source'))
|
|
|
|
{
|
|
|
|
my $oSourceHash = {};
|
|
|
|
my $strKey = $oSource->paramGet('key');
|
2016-05-19 23:10:34 +02:00
|
|
|
my $strSourceType = $oSource->paramGet('type', false);
|
2015-11-22 23:44:01 +02:00
|
|
|
|
|
|
|
logDebugMisc
|
|
|
|
(
|
|
|
|
$strOperation, 'load source',
|
2016-05-19 23:10:34 +02:00
|
|
|
{name => 'strKey', value => $strKey},
|
|
|
|
{name => 'strSourceType', value => $strSourceType}
|
2015-11-22 23:44:01 +02:00
|
|
|
);
|
|
|
|
|
2016-06-02 15:32:56 +02:00
|
|
|
# Skip sources in exclude list
|
|
|
|
if (grep(/^$strKey$/, @{$self->{stryExclude}}))
|
|
|
|
{
|
|
|
|
next;
|
|
|
|
}
|
|
|
|
|
2015-11-22 23:44:01 +02:00
|
|
|
$$oSourceHash{doc} = new BackRestDoc::Common::Doc("$self->{strDocPath}/xml/${strKey}.xml");
|
|
|
|
|
|
|
|
# Read variables from source
|
2018-12-01 19:40:01 +02:00
|
|
|
$self->variableListParse($$oSourceHash{doc}->nodeGet('variable-list', false), $rhVariableOverride);
|
2015-11-22 23:44:01 +02:00
|
|
|
|
|
|
|
${$self->{oManifest}}{source}{$strKey} = $oSourceHash;
|
2016-05-19 23:10:34 +02:00
|
|
|
${$self->{oManifest}}{source}{$strKey}{strSourceType} = $strSourceType;
|
2015-11-22 23:44:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
# Iterate the renderers
|
|
|
|
foreach my $oRender ($self->{oManifestXml}->nodeGet('render-list')->nodeList('render'))
|
|
|
|
{
|
|
|
|
my $oRenderHash = {};
|
|
|
|
my $strType = $oRender->paramGet(RENDER_TYPE);
|
|
|
|
|
|
|
|
# Only one instance of each render type can be defined
|
|
|
|
if (defined(${$self->{oManifest}}{&RENDER}{$strType}))
|
|
|
|
{
|
|
|
|
confess &log(ERROR, "render ${strType} has already been defined");
|
|
|
|
}
|
|
|
|
|
|
|
|
# Get the file param
|
|
|
|
$${oRenderHash}{file} = $oRender->paramGet(RENDER_FILE, false);
|
2016-11-07 17:06:35 +02:00
|
|
|
$${oRenderHash}{&RENDER_COMPACT} = $oRender->paramGet(RENDER_COMPACT, false, 'n') eq 'y' ? true : false;
|
|
|
|
$${oRenderHash}{&RENDER_PRETTY} = $oRender->paramGet(RENDER_PRETTY, false, 'n') eq 'y' ? true : false;
|
|
|
|
$${oRenderHash}{&RENDER_MENU} = false;
|
2015-11-22 23:44:01 +02:00
|
|
|
|
|
|
|
logDebugMisc
|
|
|
|
(
|
|
|
|
$strOperation, ' load render',
|
|
|
|
{name => 'strType', value => $strType},
|
|
|
|
{name => 'strFile', value => $${oRenderHash}{file}}
|
|
|
|
);
|
|
|
|
|
|
|
|
# Error if file is set and render type is not pdf
|
|
|
|
if (defined($${oRenderHash}{file}) && $strType ne RENDER_TYPE_PDF)
|
|
|
|
{
|
|
|
|
confess &log(ERROR, 'only the pdf render type can have file set')
|
|
|
|
}
|
|
|
|
|
|
|
|
# Iterate the render sources
|
|
|
|
foreach my $oRenderOut ($oRender->nodeList('render-source'))
|
|
|
|
{
|
|
|
|
my $oRenderOutHash = {};
|
|
|
|
my $strKey = $oRenderOut->paramGet('key');
|
|
|
|
my $strSource = $oRenderOut->paramGet('source', false, $strKey);
|
|
|
|
|
2016-06-02 15:32:56 +02:00
|
|
|
# Skip sources in exclude list
|
|
|
|
if (grep(/^$strSource$/, @{$self->{stryExclude}}))
|
|
|
|
{
|
|
|
|
next;
|
|
|
|
}
|
|
|
|
|
2016-11-17 23:35:11 +02:00
|
|
|
# Skip sources not in include list
|
|
|
|
if (@{$self->{stryInclude}} > 0 && !grep(/^$strSource$/, @{$self->{stryInclude}}))
|
|
|
|
{
|
|
|
|
next;
|
|
|
|
}
|
|
|
|
|
2018-12-15 01:46:12 +02:00
|
|
|
# Preserve natural order
|
|
|
|
push(@{$${oRenderHash}{stryOrder}}, $strKey);
|
|
|
|
|
2015-11-22 23:44:01 +02:00
|
|
|
$$oRenderOutHash{source} = $strSource;
|
|
|
|
|
2015-12-23 18:04:26 +02:00
|
|
|
# Get the filename
|
|
|
|
if (defined($oRenderOut->paramGet('file', false)))
|
|
|
|
{
|
|
|
|
if ($strType eq RENDER_TYPE_HTML || $strType eq RENDER_TYPE_MARKDOWN)
|
|
|
|
{
|
|
|
|
$$oRenderOutHash{file} = $oRenderOut->paramGet('file');
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
confess &log(ERROR, "file is only valid with html or markdown render types");
|
|
|
|
}
|
|
|
|
}
|
2015-11-22 23:44:01 +02:00
|
|
|
|
2016-11-07 17:06:35 +02:00
|
|
|
# Get the menu caption
|
|
|
|
if (defined($oRenderOut->paramGet('menu', false)) && $strType ne RENDER_TYPE_HTML)
|
|
|
|
{
|
|
|
|
confess &log(ERROR, "menu is only valid with html render type");
|
|
|
|
}
|
|
|
|
|
2015-12-23 18:04:26 +02:00
|
|
|
if (defined($oRenderOut->paramGet('menu', false)))
|
2015-11-22 23:44:01 +02:00
|
|
|
{
|
2016-11-07 17:06:35 +02:00
|
|
|
$${oRenderHash}{&RENDER_MENU} = true;
|
|
|
|
|
2015-12-23 18:04:26 +02:00
|
|
|
if ($strType eq RENDER_TYPE_HTML)
|
|
|
|
{
|
|
|
|
$$oRenderOutHash{menu} = $oRenderOut->paramGet('menu', false);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
confess &log(ERROR, 'only the html render type can have menu set');
|
|
|
|
}
|
2015-11-22 23:44:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
logDebugMisc
|
|
|
|
(
|
|
|
|
$strOperation, ' load render source',
|
|
|
|
{name => 'strKey', value => $strKey},
|
|
|
|
{name => 'strSource', value => $strSource},
|
|
|
|
{name => 'strMenu', value => $${oRenderOutHash}{menu}}
|
|
|
|
);
|
|
|
|
|
|
|
|
$${oRenderHash}{out}{$strKey} = $oRenderOutHash;
|
|
|
|
}
|
|
|
|
|
|
|
|
${$self->{oManifest}}{render}{$strType} = $oRenderHash;
|
|
|
|
}
|
|
|
|
|
2016-05-26 20:17:50 +02:00
|
|
|
# Set the doc path variable
|
|
|
|
$self->variableSet('doc-path', $self->{strDocPath});
|
|
|
|
|
2015-11-22 23:44:01 +02:00
|
|
|
# Read variables from manifest
|
2018-12-01 19:40:01 +02:00
|
|
|
$self->variableListParse($self->{oManifestXml}->nodeGet('variable-list', false), $rhVariableOverride);
|
2015-11-22 23:44:01 +02:00
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
{name => 'self', value => $self}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# isBackRest
|
|
|
|
#
|
|
|
|
# Until all the backrest specific code can be abstracted, this function will identify when BackRest docs are being built.
|
|
|
|
####################################################################################################################################
|
|
|
|
sub isBackRest
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
2016-04-14 15:30:54 +02:00
|
|
|
return($self->variableTest('project-exe', 'pgbackrest'));
|
2015-11-22 23:44:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
2018-12-01 19:40:01 +02:00
|
|
|
# Evaluate the if condition for a node
|
2015-11-22 23:44:01 +02:00
|
|
|
####################################################################################################################################
|
2018-12-01 19:40:01 +02:00
|
|
|
sub evaluateIf
|
2015-11-22 23:44:01 +02:00
|
|
|
{
|
|
|
|
my $self = shift;
|
2018-12-01 19:40:01 +02:00
|
|
|
my $oNode = shift;
|
|
|
|
|
|
|
|
my $bIf = true;
|
2015-11-22 23:44:01 +02:00
|
|
|
|
2018-12-01 19:40:01 +02:00
|
|
|
# Evaluate if condition
|
|
|
|
if (defined($oNode->paramGet('if', false)))
|
2015-11-22 23:44:01 +02:00
|
|
|
{
|
2018-12-01 19:40:01 +02:00
|
|
|
my $strIf = $self->variableReplace($oNode->paramGet('if'));
|
2015-11-22 23:44:01 +02:00
|
|
|
|
2018-12-01 19:40:01 +02:00
|
|
|
# In this case we really do want to evaluate the contents and not treat it as a literal
|
|
|
|
$bIf = eval($strIf); ## no critic (BuiltinFunctions::ProhibitStringyEval)
|
|
|
|
|
|
|
|
# Error if the eval failed
|
|
|
|
if ($@)
|
|
|
|
{
|
|
|
|
confess &log(ERROR, "unable to evaluate '${strIf}': $@");
|
2015-11-22 23:44:01 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-01 19:40:01 +02:00
|
|
|
return $bIf;
|
2015-11-22 23:44:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# variableListParse
|
|
|
|
#
|
|
|
|
# Parse a variable list and store variables.
|
|
|
|
####################################################################################################################################
|
|
|
|
sub variableListParse
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
$oVariableList,
|
2018-12-01 19:40:01 +02:00
|
|
|
$rhVariableOverride
|
2015-11-22 23:44:01 +02:00
|
|
|
) =
|
|
|
|
logDebugParam
|
|
|
|
(
|
2016-05-26 15:09:42 +02:00
|
|
|
__PACKAGE__ . '->variableListParse', \@_,
|
2015-11-22 23:44:01 +02:00
|
|
|
{name => '$oVariableList', required => false},
|
2018-12-01 19:40:01 +02:00
|
|
|
{name => '$rhVariableOverride', required => false}
|
2015-11-22 23:44:01 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
if (defined($oVariableList))
|
|
|
|
{
|
|
|
|
foreach my $oVariable ($oVariableList->nodeList('variable'))
|
|
|
|
{
|
2018-12-01 19:40:01 +02:00
|
|
|
if ($self->evaluateIf($oVariable))
|
2015-11-22 23:44:01 +02:00
|
|
|
{
|
|
|
|
my $strKey = $oVariable->paramGet('key');
|
2016-06-02 15:32:56 +02:00
|
|
|
my $strValue = $self->variableReplace($oVariable->valueGet());
|
2015-11-22 23:44:01 +02:00
|
|
|
|
|
|
|
if ($oVariable->paramTest('eval', 'y'))
|
|
|
|
{
|
2016-02-23 16:39:37 +02:00
|
|
|
# In this case we really do want to evaluate the contents of strValue and not treat it as a literal.
|
|
|
|
$strValue = eval($strValue); ## no critic (BuiltinFunctions::ProhibitStringyEval)
|
2015-11-22 23:44:01 +02:00
|
|
|
|
|
|
|
if ($@)
|
|
|
|
{
|
|
|
|
confess &log(ERROR, "unable to evaluate ${strKey}: $@\n" . $oVariable->valueGet());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-01 19:40:01 +02:00
|
|
|
$self->variableSet($strKey, defined($rhVariableOverride->{$strKey}) ? $rhVariableOverride->{$strKey} : $strValue);
|
2015-11-22 23:44:01 +02:00
|
|
|
|
|
|
|
logDebugMisc
|
|
|
|
(
|
|
|
|
$strOperation, ' load variable',
|
|
|
|
{name => 'strKey', value => $strKey},
|
|
|
|
{name => 'strValue', value => $strValue}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn($strOperation);
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# variableReplace
|
|
|
|
#
|
|
|
|
# Replace variables in the string.
|
|
|
|
####################################################################################################################################
|
|
|
|
sub variableReplace
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
my $strBuffer = shift;
|
|
|
|
my $strType = shift;
|
|
|
|
|
|
|
|
if (!defined($strBuffer))
|
|
|
|
{
|
2016-02-23 16:25:22 +02:00
|
|
|
return;
|
2015-11-22 23:44:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
foreach my $strName (sort(keys(%{$self->{oVariable}})))
|
|
|
|
{
|
|
|
|
my $strValue = $self->{oVariable}{$strName};
|
|
|
|
|
|
|
|
$strBuffer =~ s/\{\[$strName\]\}/$strValue/g;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (defined($strType) && $strType eq 'latex')
|
|
|
|
{
|
|
|
|
$strBuffer =~ s/\\\_/\_/g;
|
|
|
|
$strBuffer =~ s/\_/\\\_/g;
|
|
|
|
$strBuffer =~ s/\\\#/\#/g;
|
|
|
|
$strBuffer =~ s/\#/\\\#/g;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $strBuffer;
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# variableSet
|
|
|
|
#
|
|
|
|
# Set a variable to be replaced later.
|
|
|
|
####################################################################################################################################
|
|
|
|
sub variableSet
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
my $strKey = shift;
|
|
|
|
my $strValue = shift;
|
|
|
|
my $bForce = shift;
|
|
|
|
|
|
|
|
if (defined(${$self->{oVariable}}{$strKey}) && (!defined($bForce) || !$bForce))
|
|
|
|
{
|
|
|
|
confess &log(ERROR, "${strKey} variable is already defined");
|
|
|
|
}
|
|
|
|
|
|
|
|
${$self->{oVariable}}{$strKey} = $self->variableReplace($strValue);
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# variableGet
|
|
|
|
#
|
|
|
|
# Get the current value of a variable.
|
|
|
|
####################################################################################################################################
|
|
|
|
sub variableGet
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
my $strKey = shift;
|
|
|
|
|
|
|
|
return ${$self->{oVariable}}{$strKey};
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# variableTest
|
|
|
|
#
|
|
|
|
# Test that a variable is defined or has an expected value.
|
|
|
|
####################################################################################################################################
|
|
|
|
sub variableTest
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
my $strKey = shift;
|
|
|
|
my $strExpectedValue = shift;
|
|
|
|
|
|
|
|
# Get the variable
|
|
|
|
my $strValue = ${$self->{oVariable}}{$strKey};
|
|
|
|
|
|
|
|
# Return false if it is not defined
|
|
|
|
if (!defined($strValue))
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
# Return false if it does not equal the expected value
|
|
|
|
if (defined($strExpectedValue) && $strValue ne $strExpectedValue)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2018-07-23 13:49:15 +02:00
|
|
|
####################################################################################################################################
|
|
|
|
# Get list of source documents
|
|
|
|
####################################################################################################################################
|
|
|
|
sub sourceList
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my ($strOperation) = logDebugParam(__PACKAGE__ . '->sourceList');
|
|
|
|
|
|
|
|
# Check that sources exist
|
|
|
|
my @strySource;
|
|
|
|
|
|
|
|
if (defined(${$self->{oManifest}}{source}))
|
|
|
|
{
|
|
|
|
@strySource = sort(keys(%{${$self->{oManifest}}{source}}));
|
|
|
|
}
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
{name => 'strySource', value => \@strySource}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-11-22 23:44:01 +02:00
|
|
|
####################################################################################################################################
|
|
|
|
# sourceGet
|
|
|
|
####################################################################################################################################
|
|
|
|
sub sourceGet
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
$strSource
|
|
|
|
) =
|
|
|
|
logDebugParam
|
|
|
|
(
|
2016-05-26 15:09:42 +02:00
|
|
|
__PACKAGE__ . '->sourceGet', \@_,
|
2015-11-22 23:44:01 +02:00
|
|
|
{name => 'strSource', trace => true}
|
|
|
|
);
|
|
|
|
|
|
|
|
if (!defined(${$self->{oManifest}}{source}{$strSource}))
|
|
|
|
{
|
|
|
|
confess &log(ERROR, "source ${strSource} does not exist");
|
|
|
|
}
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
{name => 'oSource', value => ${$self->{oManifest}}{source}{$strSource}}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# renderList
|
|
|
|
####################################################################################################################################
|
|
|
|
sub renderList
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
2016-05-26 15:09:42 +02:00
|
|
|
my ($strOperation) = logDebugParam(__PACKAGE__ . '->renderList');
|
2015-11-22 23:44:01 +02:00
|
|
|
|
|
|
|
# Check that the render output exists
|
|
|
|
my @stryRender;
|
|
|
|
|
|
|
|
if (defined(${$self->{oManifest}}{render}))
|
|
|
|
{
|
2016-05-19 16:25:04 +02:00
|
|
|
@stryRender = sort(keys(%{${$self->{oManifest}}{render}}));
|
2015-11-22 23:44:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
{name => 'stryRender', value => \@stryRender}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# renderGet
|
|
|
|
####################################################################################################################################
|
|
|
|
sub renderGet
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
$strType
|
|
|
|
) =
|
|
|
|
logDebugParam
|
|
|
|
(
|
2016-05-26 15:09:42 +02:00
|
|
|
__PACKAGE__ . '->renderGet', \@_,
|
2015-11-22 23:44:01 +02:00
|
|
|
{name => 'strType', trace => true}
|
|
|
|
);
|
|
|
|
|
|
|
|
# Check that the render exists
|
|
|
|
if (!defined(${$self->{oManifest}}{render}{$strType}))
|
|
|
|
{
|
|
|
|
confess &log(ERROR, "render type ${strType} does not exist");
|
|
|
|
}
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
{name => 'oRenderOut', value => ${$self->{oManifest}}{render}{$strType}}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# renderOutList
|
|
|
|
####################################################################################################################################
|
|
|
|
sub renderOutList
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
$strType
|
|
|
|
) =
|
|
|
|
logDebugParam
|
|
|
|
(
|
2016-05-26 15:09:42 +02:00
|
|
|
__PACKAGE__ . '->renderOutList', \@_,
|
2015-11-22 23:44:01 +02:00
|
|
|
{name => 'strType'}
|
|
|
|
);
|
|
|
|
|
|
|
|
# Check that the render output exists
|
|
|
|
my @stryRenderOut;
|
|
|
|
|
|
|
|
if (defined(${$self->{oManifest}}{render}{$strType}))
|
|
|
|
{
|
2016-05-19 16:25:04 +02:00
|
|
|
@stryRenderOut = sort(keys(%{${$self->{oManifest}}{render}{$strType}{out}}));
|
2015-11-22 23:44:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
{name => 'stryRenderOut', value => \@stryRenderOut}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# renderOutGet
|
|
|
|
####################################################################################################################################
|
|
|
|
sub renderOutGet
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
$strType,
|
2016-06-02 15:32:56 +02:00
|
|
|
$strKey,
|
|
|
|
$bIgnoreMissing,
|
2015-11-22 23:44:01 +02:00
|
|
|
) =
|
|
|
|
logDebugParam
|
|
|
|
(
|
2016-05-26 15:09:42 +02:00
|
|
|
__PACKAGE__ . '->renderOutGet', \@_,
|
2015-11-22 23:44:01 +02:00
|
|
|
{name => 'strType', trace => true},
|
2016-06-02 15:32:56 +02:00
|
|
|
{name => 'strKey', trace => true},
|
|
|
|
{name => 'bIgnoreMissing', default => false, trace => true},
|
2015-11-22 23:44:01 +02:00
|
|
|
);
|
|
|
|
|
2016-06-02 15:32:56 +02:00
|
|
|
if (!defined(${$self->{oManifest}}{render}{$strType}{out}{$strKey}) && !$bIgnoreMissing)
|
2015-11-22 23:44:01 +02:00
|
|
|
{
|
|
|
|
confess &log(ERROR, "render out ${strKey} does not exist");
|
|
|
|
}
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
{name => 'oRenderOut', value => ${$self->{oManifest}}{render}{$strType}{out}{$strKey}}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2016-06-02 15:32:56 +02:00
|
|
|
####################################################################################################################################
|
|
|
|
# cacheKey
|
|
|
|
####################################################################################################################################
|
|
|
|
sub cacheKey
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my ($strOperation) = logDebugParam(__PACKAGE__ . '->cacheKey');
|
|
|
|
|
2018-12-01 19:40:01 +02:00
|
|
|
# Generate a cache key from the variable override
|
|
|
|
my $strVariableKey = JSON::PP->new()->canonical()->allow_nonref()->encode($self->{rhKeyVariableOverride});
|
|
|
|
|
|
|
|
if ($strVariableKey eq '{}')
|
|
|
|
{
|
|
|
|
$strVariableKey = 'default';
|
|
|
|
}
|
|
|
|
|
2016-06-02 15:32:56 +02:00
|
|
|
my $strRequire = defined($self->{stryRequire}) && @{$self->{stryRequire}} > 0 ?
|
|
|
|
join("\n", @{$self->{stryRequire}}) : 'all';
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn
|
|
|
|
(
|
|
|
|
$strOperation,
|
2018-12-01 19:40:01 +02:00
|
|
|
{name => 'strVariableKey', value => $strVariableKey},
|
2016-06-02 15:32:56 +02:00
|
|
|
{name => 'strRequire', value => $strRequire},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# cacheRead
|
|
|
|
####################################################################################################################################
|
|
|
|
sub cacheRead
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my ($strOperation) = logDebugParam(__PACKAGE__ . '->cacheRead');
|
|
|
|
|
|
|
|
$self->{hCache} = undef;
|
|
|
|
|
|
|
|
my $strCacheFile = $self->{bDeploy} ? $self->{strExeCacheDeploy} : $self->{strExeCacheLocal};
|
|
|
|
|
2017-06-09 23:51:41 +02:00
|
|
|
if (!$self->storage()->exists($strCacheFile) && !$self->{bDeploy})
|
2016-06-02 15:32:56 +02:00
|
|
|
{
|
|
|
|
$strCacheFile = $self->{strExeCacheDeploy};
|
|
|
|
}
|
|
|
|
|
2017-06-09 23:51:41 +02:00
|
|
|
if ($self->storage()->exists($strCacheFile))
|
2016-06-02 15:32:56 +02:00
|
|
|
{
|
2018-12-01 19:40:01 +02:00
|
|
|
my ($strCacheKey, $strRequire) = $self->cacheKey();
|
2016-06-02 15:32:56 +02:00
|
|
|
my $oJSON = JSON::PP->new()->allow_nonref();
|
2017-06-09 23:51:41 +02:00
|
|
|
$self->{hCache} = $oJSON->decode(${$self->storage()->get($strCacheFile)});
|
2016-06-02 15:32:56 +02:00
|
|
|
|
|
|
|
foreach my $strSource (sort(keys(%{${$self->{oManifest}}{source}})))
|
|
|
|
{
|
|
|
|
my $hSource = ${$self->{oManifest}}{source}{$strSource};
|
|
|
|
|
2018-12-01 19:40:01 +02:00
|
|
|
if (defined(${$self->{hCache}}{$strCacheKey}{$strRequire}{$strSource}))
|
2016-06-02 15:32:56 +02:00
|
|
|
{
|
2018-12-01 19:40:01 +02:00
|
|
|
$$hSource{hyCache} = ${$self->{hCache}}{$strCacheKey}{$strRequire}{$strSource};
|
|
|
|
&log(DETAIL, "cache load $strSource (key = ${strCacheKey}, require = ${strRequire})");
|
2016-06-02 15:32:56 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn($strOperation);
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# cacheWrite
|
|
|
|
####################################################################################################################################
|
|
|
|
sub cacheWrite
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my ($strOperation) = logDebugParam(__PACKAGE__ . '->cacheWrite');
|
|
|
|
|
|
|
|
my $strCacheFile = $self->{bDeploy} ? $self->{strExeCacheDeploy} : $self->{strExeCacheLocal};
|
2018-12-01 19:40:01 +02:00
|
|
|
my ($strCacheKey, $strRequire) = $self->cacheKey();
|
2016-06-02 15:32:56 +02:00
|
|
|
|
|
|
|
foreach my $strSource (sort(keys(%{${$self->{oManifest}}{source}})))
|
|
|
|
{
|
|
|
|
my $hSource = ${$self->{oManifest}}{source}{$strSource};
|
|
|
|
|
|
|
|
if (defined($$hSource{hyCache}))
|
|
|
|
{
|
2018-12-01 19:40:01 +02:00
|
|
|
${$self->{hCache}}{$strCacheKey}{$strRequire}{$strSource} = $$hSource{hyCache};
|
|
|
|
&log(DETAIL, "cache load $strSource (key = ${strCacheKey}, require = ${strRequire})");
|
2016-06-02 15:32:56 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (defined($self->{hCache}))
|
|
|
|
{
|
|
|
|
my $oJSON = JSON::PP->new()->canonical()->allow_nonref()->pretty();
|
2017-06-09 23:51:41 +02:00
|
|
|
$self->storage()->put($strCacheFile, $oJSON->encode($self->{hCache}));
|
2016-06-02 15:32:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn($strOperation);
|
|
|
|
}
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# cacheReset
|
|
|
|
####################################################################################################################################
|
|
|
|
sub cacheReset
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
$strSource
|
|
|
|
) =
|
|
|
|
logDebugParam
|
|
|
|
(
|
|
|
|
__PACKAGE__ . '->cacheReset', \@_,
|
|
|
|
{name => 'strSource', trace => true}
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($self->{bCacheOnly})
|
|
|
|
{
|
|
|
|
confess &log(ERROR, 'Cache reset disabled by --cache-only option');
|
|
|
|
}
|
|
|
|
|
|
|
|
&log(WARN, "Cache will be reset for source ${strSource} and rendering retried automatically");
|
|
|
|
delete(${$self->{oManifest}}{source}{$strSource}{hyCache});
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn($strOperation);
|
|
|
|
}
|
|
|
|
|
2017-06-09 23:51:41 +02:00
|
|
|
####################################################################################################################################
|
|
|
|
# Getters
|
|
|
|
####################################################################################################################################
|
|
|
|
sub storage {shift->{oStorage}};
|
|
|
|
|
2015-11-22 23:44:01 +02:00
|
|
|
1;
|