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 - scripts/cpaddonsup Copyright 2017 cPanel, Inc.
# All rights Reserved.
# copyright@cpanel.net http://cpanel.net
# This code is subject to the cPanel license. Unauthorized copying is prohibited
use strict;
use Cpanel::Logger ();
use Cpanel::Locale ();
use Cpanel::SafeRun::Errors ();
use Whostmgr::Cpaddon::RPMSupport ();
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::RPMSupport::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} '' . $locale->maketext( 'Output from command: [_1] “[_2]”', '/usr/local/cpanel/whostmgr/docroot/cgi/cpaddons.pl', $param ) . "