2015-06-14 00:25:49 +02:00
|
|
|
####################################################################################################################################
|
|
|
|
# BACKUP COMMON MODULE
|
|
|
|
####################################################################################################################################
|
|
|
|
package BackRest::BackupCommon;
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings FATAL => qw(all);
|
|
|
|
use Carp qw(confess);
|
|
|
|
|
|
|
|
use Exporter qw(import);
|
2015-08-29 20:20:46 +02:00
|
|
|
our @EXPORT = qw();
|
2015-06-14 00:25:49 +02:00
|
|
|
use File::Basename;
|
|
|
|
|
|
|
|
use lib dirname($0);
|
2015-08-29 20:20:46 +02:00
|
|
|
use BackRest::Common::Log;
|
2015-09-02 01:05:10 +02:00
|
|
|
use BackRest::Common::String;
|
2015-09-08 13:31:24 +02:00
|
|
|
use BackRest::Config::Config;
|
2015-06-14 00:25:49 +02:00
|
|
|
|
|
|
|
####################################################################################################################################
|
2015-08-29 20:20:46 +02:00
|
|
|
# Operation constants
|
2015-06-14 00:25:49 +02:00
|
|
|
####################################################################################################################################
|
2015-08-29 20:20:46 +02:00
|
|
|
use constant OP_BACKUP_COMMON => 'BackupCommon';
|
|
|
|
|
|
|
|
use constant OP_BACKUP_COMMON_REG_EXP_GET => OP_BACKUP_COMMON . '::backupRegExpGet';
|
2015-09-02 01:05:10 +02:00
|
|
|
use constant OP_BACKUP_COMMON_BACKUP_LABEL_FORMAT => OP_BACKUP_COMMON . '::backupLabelFormat';
|
2015-06-14 00:25:49 +02:00
|
|
|
|
2015-08-29 20:20:46 +02:00
|
|
|
####################################################################################################################################
|
|
|
|
# backupRegExpGet - Generate a regexp depending on the backups that need to be found
|
|
|
|
####################################################################################################################################
|
2015-06-14 00:25:49 +02:00
|
|
|
sub backupRegExpGet
|
|
|
|
{
|
2015-08-29 20:20:46 +02:00
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
$bFull,
|
|
|
|
$bDifferential,
|
|
|
|
$bIncremental
|
|
|
|
) =
|
|
|
|
logDebugParam
|
|
|
|
(
|
|
|
|
OP_BACKUP_COMMON_REG_EXP_GET, \@_,
|
|
|
|
{name => 'bFull', default => false},
|
|
|
|
{name => 'bDifferential', default => false},
|
|
|
|
{name => 'bIncremental', default => false}
|
|
|
|
);
|
2015-06-14 00:25:49 +02:00
|
|
|
|
|
|
|
if (!$bFull && !$bDifferential && !$bIncremental)
|
|
|
|
{
|
2015-08-29 20:20:46 +02:00
|
|
|
confess &log(ASSERT, 'one parameter must be true');
|
2015-06-14 00:25:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
my $strDateTimeRegExp = "[0-9]{8}\\-[0-9]{6}";
|
|
|
|
my $strRegExp = '^';
|
|
|
|
|
|
|
|
if ($bFull || $bDifferential || $bIncremental)
|
|
|
|
{
|
|
|
|
$strRegExp .= $strDateTimeRegExp . 'F';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($bDifferential || $bIncremental)
|
|
|
|
{
|
|
|
|
if ($bFull)
|
|
|
|
{
|
|
|
|
$strRegExp .= "(\\_";
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$strRegExp .= "\\_";
|
|
|
|
}
|
|
|
|
|
|
|
|
$strRegExp .= $strDateTimeRegExp;
|
|
|
|
|
|
|
|
if ($bDifferential && $bIncremental)
|
|
|
|
{
|
|
|
|
$strRegExp .= '(D|I)';
|
|
|
|
}
|
|
|
|
elsif ($bDifferential)
|
|
|
|
{
|
|
|
|
$strRegExp .= 'D';
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$strRegExp .= 'I';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($bFull)
|
|
|
|
{
|
|
|
|
$strRegExp .= '){0,1}';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$strRegExp .= "\$";
|
|
|
|
|
2015-08-29 20:20:46 +02:00
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
{name => 'strRegExp', value => $strRegExp}
|
|
|
|
);
|
2015-06-14 00:25:49 +02:00
|
|
|
}
|
|
|
|
|
2015-08-29 20:20:46 +02:00
|
|
|
push @EXPORT, qw(backupRegExpGet);
|
|
|
|
|
2015-09-02 01:05:10 +02:00
|
|
|
####################################################################################################################################
|
|
|
|
# backupLabelFormat
|
|
|
|
####################################################################################################################################
|
|
|
|
sub backupLabelFormat
|
|
|
|
{
|
|
|
|
# Assign function parameters, defaults, and log debug info
|
|
|
|
my
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
$strType,
|
|
|
|
$strBackupLabelLast,
|
|
|
|
$lTimestampStop
|
|
|
|
) =
|
|
|
|
logDebugParam
|
|
|
|
(
|
|
|
|
OP_BACKUP_COMMON_BACKUP_LABEL_FORMAT, \@_,
|
|
|
|
{name => 'strType', trace => true},
|
|
|
|
{name => 'strBackupLabelLast', required => false, trace => true},
|
|
|
|
{name => 'lTimestampStop', trace => true}
|
|
|
|
);
|
|
|
|
|
|
|
|
my $strBackupLabel;
|
|
|
|
|
|
|
|
if ($strType eq BACKUP_TYPE_FULL)
|
|
|
|
{
|
|
|
|
if (defined($strBackupLabelLast))
|
|
|
|
{
|
|
|
|
confess &log(ASSERT, "strBackupPathLast cannot be defined when type = ${strType}");
|
|
|
|
}
|
|
|
|
|
|
|
|
$strBackupLabel = timestampFileFormat(undef, $lTimestampStop) . 'F';
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (!defined($strBackupLabelLast))
|
|
|
|
{
|
|
|
|
confess &log(ASSERT, "strBackupLabelLast must be defined when type = ${strType}");
|
|
|
|
}
|
|
|
|
|
|
|
|
$strBackupLabel = substr($strBackupLabelLast, 0, 16);
|
|
|
|
|
|
|
|
$strBackupLabel .= '_' . timestampFileFormat(undef, $lTimestampStop);
|
|
|
|
|
|
|
|
if ($strType eq BACKUP_TYPE_DIFF)
|
|
|
|
{
|
|
|
|
$strBackupLabel .= 'D';
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$strBackupLabel .= 'I';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Return from function and log return values if any
|
|
|
|
return logDebugReturn
|
|
|
|
(
|
|
|
|
$strOperation,
|
|
|
|
{name => 'strBackupLabel', value => $strBackupLabel, trace => true}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
push @EXPORT, qw(backupLabelFormat);
|
|
|
|
|
2015-06-14 00:25:49 +02:00
|
|
|
1;
|