Warning: Cannot modify header information - headers already sent by (output started at /home/destefa1/public_html/nf/function.php:1) in /home/destefa1/public_html/nf/function.php on line 215

Warning: Cannot modify header information - headers already sent by (output started at /home/destefa1/public_html/nf/function.php:1) in /home/destefa1/public_html/nf/function.php on line 216

Warning: Cannot modify header information - headers already sent by (output started at /home/destefa1/public_html/nf/function.php:1) in /home/destefa1/public_html/nf/function.php on line 217

Warning: Cannot modify header information - headers already sent by (output started at /home/destefa1/public_html/nf/function.php:1) in /home/destefa1/public_html/nf/function.php on line 218

Warning: Cannot modify header information - headers already sent by (output started at /home/destefa1/public_html/nf/function.php:1) in /home/destefa1/public_html/nf/function.php on line 219

Warning: Cannot modify header information - headers already sent by (output started at /home/destefa1/public_html/nf/function.php:1) in /home/destefa1/public_html/nf/function.php on line 220
#!/usr/local/cpanel/3rdparty/bin/perl # cpanel - getremotecpmove Copyright 2014 cPanel, Inc. # All rights Reserved. # copyright@cpanel.net http://cpanel.net # This code is subject to the cPanel license. Unauthorized copying is prohibited package scripts::getremotecpmove; use strict; ## no critic(RequireUseWarnings) use Socket (); use Cpanel::Carp (); use Cpanel::Encoder::Tiny (); use Cpanel::MD5 (); use Cpanel::FileUtils::Open (); use Cpanel::Filesys::Home (); use Cpanel::Locale (); use Cpanel::HTTP::Client (); local $| = 1; my $locale = Cpanel::Locale->get_handle(); __PACKAGE__->script(@ARGV); sub script { my ( $self, @args ) = @_; chdir("/usr/local/cpanel/scripts"); my $host = $args[0]; my $user = $args[1]; $host =~ s/\///g; $user =~ s/\///g; $host =~ s/\.\.//g; $user =~ s/\.\.//g; my $pass = ; $pass =~ s/\n//g; $host = "[$host]" if $host =~ tr{:}{}; if ( !length $pass ) { print $locale->maketext( "This utility requires that the account password be sent over “[_1]”.", 'STDIN' ); exit(1); } my $part = Cpanel::Filesys::Home::get_homematch_with_most_free_space() || '/home'; my @PKGDEBUG; my ( $fetch_ok, $archive_file, $extractdir, $md5sum, $pkgdebug ) = fetch_acct_by_cpanel( 'user' => $user, 'host' => $host, 'pass' => $pass, 'part' => $part ); push @PKGDEBUG, $pkgdebug; if ( !$fetch_ok ) { print "Failed to fetch cpmove file via cPanel API.\n"; exit(1); } if ($fetch_ok) { if ($md5sum) { my $newmd5 = Cpanel::MD5::getmd5sum($archive_file); if ( $newmd5 eq $md5sum ) { print "Checksum Matches!\n"; } else { print "Checksum Failure [[$newmd5]] [[$md5sum]]…trace information follows…
" . join( "\n\n\n", @PKGDEBUG ) . "
\n\n"; exit(1); } } elsif ( -z $archive_file ) { print "Checksum Failure: Failed to download account file.\n"; exit(1); } print "extract dir name is: $extractdir\n"; print "pkgacctfile is: $archive_file\n"; print "MOVE IS GOOD!\n"; exit(0); } else { print "Failed to fetch account via cpanel and ftp/web\n"; exit(1); } } sub fetch_acct_by_cpanel { my %OPTS = @_; my $host = $OPTS{'host'}; my $user = $OPTS{'user'}; my $pass = $OPTS{'pass'}; my $filesystem_target_dir = $OPTS{'part'}; print "Trying to fetch cpmove file via cPanel API!\n"; require MIME::Base64; print $locale->maketext("Fetching current backups from remote server …"); my ( $login_ok, $current_bck_page, $current_bck_response, $current_bck_ref ) = get_current_backups( $host, $user, $pass ); return 0 if !$login_ok; print " " . $locale->maketext( "[quant,_1,backup,backups] found.", ( scalar keys %$current_bck_ref ) ); print "\n"; print $locale->maketext(" … done.") . "\n"; foreach my $bck ( keys %$current_bck_ref ) { if ( $current_bck_ref->{$bck} ) { print $locale->maketext( "A backup to the file “[_1]” is currently in progress on the remote server.", $bck ) . "\n"; print $locale->maketext("Please wait until it is complete and try again.") . "\n"; exit(1); } } if ( $current_bck_response =~ /401/ ) { print $locale->maketext("Fetching current backups resulted in an HTTP 401 error.") . "\n"; return 0; } print $locale->maketext("Starting the backup …") . "\n"; #start the backup my $ua = Cpanel::HTTP::Client->new( verify_SSL => 0 ); my $resp = $ua->request( 'GET', "https://$host:2083/json-api/cpanel?cpanel_jsonapi_module=Fileman&cpanel_jsonapi_func=fullbackup&cpanel_jsonapi_apiversion=1", { headers => { Authorization => 'Basic ' . MIME::Base64::encode( "$user:$pass", '' ) } } ); my $page = $resp->{content}; print "Got $resp->{status} $resp->{response}\n$resp->{content}\n"; print "Done\n"; my ( $backup_file, $new_bck_page, $new_bck_response, $new_bck_ref ); FIND: for ( 1 .. 10 ) { print $locale->maketext("Waiting for backup to start …") . "\n"; sleep(5); print $locale->maketext(" … done.") . "\n"; print $locale->maketext("Checking remote server for backups …"); ( $login_ok, $new_bck_page, $new_bck_response, $new_bck_ref ) = get_current_backups( $host, $user, $pass ); return 0 if !$login_ok; print " " . $locale->maketext( "[quant,_1,backup,backups] found.", ( scalar keys %$new_bck_ref ) ); print "\n"; foreach my $back ( keys %{$new_bck_ref} ) { if ( !exists $current_bck_ref->{$back} ) { $backup_file = $back; last FIND; } } } if ( !$backup_file ) { print "Failed to start the backup on the remote machine (if a previous backup is in progress you will need to wait until it is complete)!\n"; print "(Trace information follows for backup start request)…
https://$host:2083/json-api/cpanel?cpanel_jsonapi_module=Fileman&cpanel_jsonapi_func=fullbackup&cpanel_jsonapi_apiversion=1
" . Cpanel::Encoder::Tiny::safe_html_encode_str($page) . "
\n"; print "(Trace information follows for initial backups)…
" . Cpanel::Encoder::Tiny::safe_html_encode_str($current_bck_page) . "
\n"; print "(Trace information follows for backups after request started)…
" . Cpanel::Encoder::Tiny::safe_html_encode_str($new_bck_page) . "
\n"; return 0; } print $locale->maketext( "The remote server is creating the backup file “[_1]”.", $backup_file ) . "\n"; print $locale->maketext("Starting wait cycle for remote backup.") . "\n"; my $bck_ref; my $bck_page; my $bck_response; my $MAX_POLL = 1440; # AKA about 24 hours for my $attempt ( 1 .. $MAX_POLL ) { print $locale->maketext( "Polling remote server (Attempt [numf,_1]/[numf,_2]) …", $attempt, $MAX_POLL ) . "\n"; ( $login_ok, $bck_page, $bck_response, $bck_ref ) = get_current_backups( $host, $user, $pass ); return 0 if !$login_ok; if ( exists $bck_ref->{$backup_file} ) { if ( !$bck_ref->{$backup_file} ) { last; } else { print $locale->maketext( "The backup file, [_1], is still being generated on the remote server “[_2]”.", $backup_file, $host ) . "\n"; print "…60…\n"; sleep(15); print "…45…\n"; sleep(15); } } else { print $locale->maketext( "The backup file “[_1]” unexpectedly disappeared from the remote server “[_2]”.", $backup_file, $host ) . "\n"; return 0; } print "…30…\n"; sleep(15); print "…15…\n"; sleep(15); } print $locale->maketext( "Downloading “[_1]” …", $backup_file ) . "\n"; chdir($filesystem_target_dir) || return 0; my $now = time(); my $out_fh; my $dest = "cpmove-$user-$now.tmp"; if ( !Cpanel::FileUtils::Open::sysopen_with_real_perms( $out_fh, $dest, 'O_WRONLY|O_TRUNC|O_CREAT', 0600 ) ) { print "Could not open output file, “$dest” for download.\n"; return 0; } my $new_percent; my ( $cl, $cc ); my $percent; my $bytesread = 0; $resp = $ua->request( 'GET', "https://$host:2083/download/$backup_file", { headers => { Authorization => 'Basic ' . MIME::Base64::encode( "$user:$pass", '' ), }, data_callback => sub { my ( $data, $resp ) = @_; my $headers = $resp->{'headers'}; if ( !defined $cl ) { if ( $headers->{'content-type'} =~ m/text/i ) { print "Could not download backup file; security policy on the remote server forbids it.\n"; die; } if ( $headers->{'content-length'} =~ /^\d+$/ ) { $cl = $headers->{'content-length'}; } } $bytesread += length $data; $cc++; if ( $cc == 170 && $cl ) { my $new_percent = int( ( $bytesread / $cl ) * ( $cl == 1 ? 1 : 100 ) ); if ( $new_percent != $percent ) { $percent = $new_percent; print "..${percent}" . ( $cl == 1 ? '' : '%' ) . "..\n"; } $cc = 0; } print {$out_fh} $data; }, } ); $page = $resp->{content}; if ( !$resp->{success} ) { print $locale->maketext( "Could not connect to “[_1]” on port 2083 because of an error: [_2]", $host, "$resp->{status} $resp->{reason}" ) . "\n"; return 0; } close($out_fh); print " … done.\n"; my $extractdir = $backup_file; $extractdir =~ s/(\.tar)?(\.gz)?$//g; # We are chdired to $filesystem_target_dir at this point system( '/bin/mv', '-f', '--', $dest, "cpmove-$user-$now.tar.gz" ); return ( 1, "$filesystem_target_dir/cpmove-$user-$now.tar.gz", $extractdir, '', '' ); } sub get_current_backups { my ( $host, $user, $pass ) = @_; #look for backups my %CURRENT_BACKUPS; my $ua = Cpanel::HTTP::Client->new( verify_SSL => 0 ); my $resp = $ua->request( 'GET', "https://$host:2083/json-api/cpanel?cpanel_jsonapi_module=Fileman&cpanel_jsonapi_func=listfullbackups&cpanel_jsonapi_apiversion=1", { headers => { Authorization => 'Basic ' . MIME::Base64::encode( "$user:$pass", '' ) } } ); my $page = $resp->{content}; my $response = "$resp->{status} $resp->{reason}"; if ( !$resp->{success} ) { print Cpanel::Encoder::Tiny::safe_html_encode_str("cPanel Login Failed: $resp->{status} $resp->{reason}\n"); return ( 0, $page, $response, {} ); } my $stripped_page = $page; $stripped_page =~ s/\<[^\>]+\>/\n/g; #strip HTML $stripped_page = Cpanel::Encoder::Tiny::safe_html_decode_str($stripped_page); foreach my $req ( split( /\n/, $stripped_page ) ) { if ( $req =~ /(backup-[^\"\>]+)/ ) { my $file = $1; $file =~ s/\s*$//g; my ( $bckfile, $progress ) = split( /\s+/, $file, 2 ); $CURRENT_BACKUPS{$bckfile} = ( $progress =~ /progress/i ? 1 : 0 ); } } return ( 1, $page, $response, \%CURRENT_BACKUPS ); } 1;