Hacked By AnonymousFox

Current Path : /scripts/
Upload File :
Current File : //scripts/cpaddonsup

#!/usr/local/cpanel/3rdparty/bin/perl

# cpanel - scripts/cpaddonsup                      Copyright 2022 cPanel, L.L.C.
#                                                           All rights reserved.
# copyright@cpanel.net                                         http://cpanel.net
# This code is subject to the cPanel license. Unauthorized copying is prohibited

use strict;
## no critic qw(TestingAndDebugging::RequireUseWarnings)

use Cpanel::Logger          ();
use Cpanel::Locale          ();
use Cpanel::SafeRun::Errors ();
use Whostmgr::Cpaddon       ();

exit if -e '/etc/cpaddonsupdisable';

my $logger = Cpanel::Logger->new();
my $locale = Cpanel::Locale->get_handle();

my $cpaddons_dir   = '/usr/local/cpanel/cpaddons';
my $cpanel_log_dir = '/var/cpanel/logs';

if ( !-d $cpaddons_dir ) {
    mkdir $cpaddons_dir or $logger->die( $locale->maketext( 'Failed to create “[_1]”: [_2]', $cpaddons_dir, $! ) );
}

require $cpaddons_dir . '/cPAddonsAvailable.pm';
die $@ if $@;

my @current;

{
    no warnings 'once';
    foreach my $namespace ( keys %cPAddonsAvailable::list, keys %{ Whostmgr::Cpaddon::get_installed_addons() } ) {
        my $dirver = $namespace;
        $dirver =~ s{[:]{2}}{/}g;
        push @current, $namespace if -d "$cpaddons_dir/$dirver/";
    }
}

my $force = ( grep { $_ eq '--force' } @ARGV )  ? 1 : 0;
my $html  = ( grep { $_ eq '--nohtml' } @ARGV ) ? 0 : 1;

if ( !-d $cpanel_log_dir ) {
    mkdir $cpanel_log_dir or $logger->warn( $locale->maketext( 'Failed to create “[_1]”: [_2]', $cpanel_log_dir, $! ) );
}

# Clear log files older than 30 days
my $thirty_days = 30 * 24 * 60 * 60;
if ( opendir my $log_dh, $cpanel_log_dir ) {
    my $now = time();
    while ( my $file = readdir $log_dh ) {
        next if $file !~ m/^cpaddonsup\.(\d+)/;
        my $age = $1;
        if ( ( $age + $thirty_days ) < $now ) {
            unlink $cpanel_log_dir . '/' . $file;
        }
    }
    closedir $log_dh;
}

if ( @current || $force ) {
    my $param = !$html ? 'action=update-nohtml' : 'action=update';
    $param .= '&force=1' if $force;

    foreach my $cpaddon (@current) {
        $param = join '&', $param, qq{$cpaddon=1};
    }

    $ENV{'REMOTE_USER'} = "root";
    my $now       = time();
    my $old_umask = umask(0077);    # Case 92381: Logs should not be world-readable.
    if ( open my $out_fh, '>', $cpanel_log_dir . '/cpaddonsup.' . $now . '.txt' ) {
        umask($old_umask);
        print {$out_fh} scalar Cpanel::SafeRun::Errors::saferunallerrors( '/usr/local/cpanel/whostmgr/docroot/cgi/cpaddons.pl', qq{$param} );
        if ($html) {
            print {$out_fh} '<p>' . $locale->maketext( 'Output from command: [_1] “[_2]”', '/usr/local/cpanel/whostmgr/docroot/cgi/cpaddons.pl', $param ) . "</p></body></html>\n\n";
        }
        else {
            print {$out_fh} $locale->maketext( 'Output from command: [_1] “[_2]”', '/usr/local/cpanel/whostmgr/docroot/cgi/cpaddons.pl', $param ) . "\n\n";
        }
        close $out_fh;
    }
    else {
        umask($old_umask);
        $logger->warn( $locale->maketext( 'Could not write log file “[_1]”: [_2]', "${cpanel_log_dir}/cpaddonsup.${now}.txt", $! ) );
        print scalar Cpanel::SafeRun::Errors::saferunallerrors( '/usr/local/cpanel/whostmgr/docroot/cgi/cpaddons.pl', qq{$param} );
    }
}

Hacked By AnonymousFox1.0, Coded By AnonymousFox