App-MBUtiny
view release on metacpan or search on metacpan
lib/App/MBUtiny/Storage/SFTP.pm view on Meta::CPAN
package App::MBUtiny::Storage::SFTP; # $Id: SFTP.pm 131 2019-07-16 18:45:44Z abalama $
use strict;
use utf8;
=encoding utf-8
=head1 NAME
App::MBUtiny::Storage::SFTP - App::MBUtiny::Storage subclass for SFTP storage support
=head1 VIRSION
Version 1.01
=head1 SYNOPSIS
<Host "foo">
<SFTP>
FixUP on
URL sftp://user@example.com:22/path/to/backup/dir1
URL sftp://user@example.com:22/path/to/backup/dir2
Set timeout 180
Set key_path /path/to/private/file.key
Comment SFTP storage said blah-blah-blah # Optional for collector
</SFTP>
# . . .
</Host>
=head1 DESCRIPTION
App::MBUtiny::Storage subclass for SFTP storage support
B<NOTE!> For initialization SSH connection please run follow commands first:
ssh-keygen -t rsa
ssh-copy-id -i /path/to/private/file.pub user@example.com
=head2 del
Removes the specified file.
This is backend method of L<App::MBUtiny::Storage/del>
=head2 get
Gets the backup file from storage and saves it to specified path.
This is backend method of L<App::MBUtiny::Storage/get>
=head2 init
The method performs initialization of storage.
This is backend method of L<App::MBUtiny::Storage/init>
=head2 list
Gets backup file list on storage.
This is backend method of L<App::MBUtiny::Storage/list>
=head2 sftp_storages
my @list = $storage->sftp_storages;
Returns list of SFTP storage nodes
=head2 put
Sends backup file to storage.
This is backend method of L<App::MBUtiny::Storage/put>
=head2 test
Storage testing.
This is backend method of L<App::MBUtiny::Storage/test>
=head1 HISTORY
See C<Changes> file
=head1 TO DO
See C<TODO> file
=head1 BUGS
* none noted
=head1 SEE ALSO
L<App::MBUtiny::Storage>
=head1 AUTHOR
Serż Minus (Sergey Lepenkov) L<http://www.serzik.com> E<lt>abalama@cpan.orgE<gt>
=head1 COPYRIGHT
Copyright (C) 1998-2019 D&D Corporation. All Rights Reserved
=head1 LICENSE
This program is free software; you can redistribute it and/or
modify it under the same terms as Perl itself.
See C<LICENSE> file and L<https://dev.perl.org/licenses/>
=cut
use vars qw/ $VERSION /;
$VERSION = '1.01';
use Storable qw/dclone/;
use Fcntl ':mode';
use URI;
use List::Util qw/uniq/;
use CTK::ConfGenUtil;
use CTK::TFVals qw/ :ALL /;
use App::MBUtiny::Util qw/ node2anode set2attr hide_password filesize /;
my $NET_SFTP_FOREIGN = 1; # Loaded!
my $NET_SFTP_FOREIGN_MESSAGE = "SFTP storage type is available";
eval { require Net::SFTP::Foreign; 1 } or do {
$NET_SFTP_FOREIGN = 0;
$NET_SFTP_FOREIGN_MESSAGE = "SFTP storage type is not available, Net::SFTP::Foreign is not installed or failed to load: $@";
};
use constant {
( run in 0.760 second using v1.01-cache-2.11-cpan-39bf76dae61 )