Server : Apache System : Linux server1.cgrithy.com 3.10.0-1160.95.1.el7.x86_64 #1 SMP Mon Jul 24 13:59:37 UTC 2023 x86_64 User : nobody ( 99) PHP Version : 8.1.23 Disable Function : NONE Directory : /scripts/ |
#!/usr/local/cpanel/3rdparty/bin/perl # cpanel - scripts/spamassassindisable 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; use warnings; use Cpanel::AccessIds::ReducedPrivileges (); use Cpanel::Config::CpConfGuard (); use Cpanel::FileUtils::TouchFile (); use Cpanel::LoginDefs (); use Cpanel::PwCache::Build (); use Cpanel::Usage (); local $| = 1; my $quiet = 0; my $force = 0; my $undo = 0; my %opts = ( 'q' => \$quiet, 'quiet' => \$quiet, 'f' => \$force, 'force' => \$force, 'undo' => \$undo ); Cpanel::Usage::wrap_options( \@ARGV, \&usage, \%opts ); unless ($quiet) { print "??????????????????????????????????????????????????????????????????\n"; print "This will disable SpamAssassin filtering for all accounts\n"; print "on the server. If you do not wish to do this, then hit Ctrl-C now.\n"; print "??????????????????????????????????????????????????????????????????\n\n"; } unless ($force) { print "Sleeping for 5 seconds ... (Ctrl-C to abort)\n"; sleep 5; } Cpanel::PwCache::Build::init_passwdless_pwcache(); my $pwcache_ref = Cpanel::PwCache::Build::fetch_pwcache(); my $uid_min = Cpanel::LoginDefs::get_uid_min(); my ( $useruid, $usergid, $homedir ); foreach my $pwref ( grep { $_->[2] >= $uid_min } @{$pwcache_ref} ) { ( $useruid, $usergid, $homedir ) = ( ( @{$pwref} )[ 2, 3, 7 ] ); # Drop privileges to read/write the directory as the user my $reduced_privs_guard = Cpanel::AccessIds::ReducedPrivileges->new( $useruid, $usergid, ); if ($undo) { my $old_touchfile = $homedir . '/.spamassassinboxdisabled'; my $new_touchfile = $homedir . '/.spamassassinboxenable'; replace_touchfile( $old_touchfile, $new_touchfile, $quiet ); $old_touchfile = $homedir . '/.spamassassindisabled'; $new_touchfile = $homedir . '/.spamassassinenable'; replace_touchfile( $old_touchfile, $new_touchfile, $quiet ); } else { my $old_touchfile = $homedir . '/.spamassassinboxenable'; my $new_touchfile = $homedir . '/.spamassassinboxdisabled'; replace_touchfile( $old_touchfile, $new_touchfile, $quiet ); $old_touchfile = $homedir . '/.spamassassinenable'; $new_touchfile = $homedir . '/.spamassassindisabled'; replace_touchfile( $old_touchfile, $new_touchfile, $quiet ); } } exit if $undo; unless ($quiet) { print "Updating /var/cpanel/cpanel.config\n"; } my $cpconf_guard = Cpanel::Config::CpConfGuard->new(); $cpconf_guard->{'data'}->{'skipspamassassin'} = 1; $cpconf_guard->{'data'}->{'skipspambox'} = 1; $cpconf_guard->save(); sub replace_touchfile { my ( $old_touchfile, $new_touchfile, $quiet ) = @_; if ( -e $old_touchfile ) { unless ($quiet) { print "Creating $new_touchfile\n"; print "Unlinking $old_touchfile\n"; } if ( !-e $new_touchfile ) { Cpanel::FileUtils::TouchFile::touchfile($new_touchfile); } unlink($old_touchfile); } return; } sub usage { print <<EOM; spamassassindisable - disable spamassassin for all accounts Options: --force bypass 5 second sleep --quiet do not provide any output on STDOUT --help display this message and exit --undo re-enable spamassassin for all the users for which this has been disabled by this script The force and quiet are useful when running this script as a part of an automated process (e.g. cron). EOM exit; }