App-SimpleBackuper
view release on metacpan or search on metacpan
bin/simple-backuper view on Meta::CPAN
#!/usr/bin/perl
package App::SimpleBackuper;
use strict;
use warnings;
use feature ':5.14';
use Getopt::Long;
use JSON::PP;
use Try::Tiny;
use Crypt::OpenSSL::RSA;
use POSIX qw(strftime);
use Data::Dumper;
use Time::HiRes;
use App::SimpleBackuper::DB;
use App::SimpleBackuper::StorageLocal;
use App::SimpleBackuper::StorageSFTP;
use App::SimpleBackuper::Backup;
use App::SimpleBackuper::Info;
use App::SimpleBackuper::RestoreDB;
use App::SimpleBackuper::Restore;
use App::SimpleBackuper::StorageCheck;
use App::SimpleBackuper::_format;
$| = 1;
# libcrypt-openssl-rsa-perl
# libdigest-sha-perl
# libnet-sftp-foreign-perl
sub usage {
say foreach @_;
print foreach <DATA>;
exit -1;
}
GetOptions(
\my %options,
'cfg=s', 'db=s', 'backup-name=s', 'path=s', 'storage=s', 'destination=s', 'priv-key=s', 'write', 'verbose', 'quiet'
) or usage();
my $command = shift;
$options{cfg} //= '~/.simple-backuper/config' if $command and grep {$command eq $_} qw(backup storage-check storage-fix stats);
my %state = (profile => {total => - Time::HiRes::time});
if($options{cfg}) {
$options{cfg} =~ s/^~/(getpwuid($>))[7]/e;
open(my $h, "<", $options{cfg}) or usage("Can't read config '$options{cfg}': $!");
my $config;
try {
$config = JSON::PP->new->utf8->relaxed(1)->decode(join('', <$h>));
} catch {
usage("Error while parsing json in config '$options{cfg}': $!");
};
close($h);
$options{$_} ||= $config->{$_} foreach qw(db storage compression_level public_key space_limit files);
exists $options{compression_level} or usage("Config doesn't contains 'compression_level'");
$options{compression_level} =~ /^\d$/
and $options{compression_level} >= 1
and $options{compression_level} <= 9
or usage("Bad value of 'compression_level' in config. Must be 1 to 9");
exists $options{public_key} or usage("Config doesn't contains 'public_key'");
$options{public_key} =~ s/^~/(getpwuid($>))[7]/e;
open($h, '<', $options{public_key}) or usage("Can't read public_key file '$options{public_key}': $!");
$state{rsa} = Crypt::OpenSSL::RSA->new_public_key( join('', <$h>) );
close($h);
( run in 1.213 second using v1.01-cache-2.11-cpan-39bf76dae61 )