mirror of
https://github.com/waytotheweb/scripts.git
synced 2026-03-29 15:37:06 +00:00
159 lines
4.9 KiB
Perl
159 lines
4.9 KiB
Perl
#!/usr/local/cpanel/3rdparty/bin/perl
|
|
###############################################################################
|
|
# Copyright (C) 2006-2025 Jonathan Michaelson
|
|
#
|
|
# https://github.com/waytotheweb/scripts
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify it under
|
|
# the terms of the GNU General Public License as published by the Free Software
|
|
# Foundation; either version 3 of the License, or (at your option) any later
|
|
# version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful, but WITHOUT
|
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
# details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along with
|
|
# this program; if not, see <https://www.gnu.org/licenses>.
|
|
###############################################################################
|
|
## no critic (RequireUseWarnings, ProhibitExplicitReturnUndef, ProhibitMixedBooleanOperators, RequireBriefOpen)
|
|
# start main
|
|
use strict;
|
|
use File::Basename;
|
|
use File::Path;
|
|
use Fcntl qw(:DEFAULT :flock);
|
|
use IPC::Open3;
|
|
|
|
my $apachepath = "/usr/local/apache/conf";
|
|
my $apachebin = "/usr/local/apache/bin/httpd";
|
|
my $apachectl = "/usr/local/apache/bin/apachectl";
|
|
my $apachelogs = "/usr/local/apache/logs";
|
|
if (-e "/usr/local/cpanel/version" and -e "/etc/cpanel/ea4/is_ea4" and -e "/etc/cpanel/ea4/paths.conf") {
|
|
$apachepath = "/etc/apache2/conf.d";
|
|
$apachebin = "/usr/sbin/httpd";
|
|
$apachectl = "/usr/sbin/apachectl";
|
|
$apachelogs = "/etc/apache2/logs";
|
|
open (my $IN, "<", "/etc/cpanel/ea4/paths.conf");
|
|
flock ($IN, LOCK_SH);
|
|
my @file = <$IN>;
|
|
close ($IN);
|
|
chomp @file;
|
|
foreach my $line (@file) {
|
|
if ($line =~ /^(\s|\#|$)/) {next}
|
|
if ($line !~ /=/) {next}
|
|
my ($name,$value) = split (/=/,$line,2);
|
|
$value =~ s/^\s+//g;
|
|
$value =~ s/\s+$//g;
|
|
if ($name eq "dir_conf") {$apachepath = $value}
|
|
if ($name eq "bin_httpd") {$apachebin = $value}
|
|
if ($name eq "bin_apachectl") {$apachectl = $value}
|
|
if ($name eq "dir_logs") {$apachelogs = $value}
|
|
}
|
|
}
|
|
|
|
my $httpv = "2";
|
|
my $mypid;
|
|
my ($childin, $childout);
|
|
$mypid = open3($childin, $childout, $childout, $apachebin,"-v");
|
|
my @version = <$childout>;
|
|
waitpid ($mypid, 0);
|
|
chomp @version;
|
|
$version[0] =~ /Apache\/(\d+)\.(\d+)\.(\d+)/;
|
|
my $mas = $1;
|
|
my $maj = $2;
|
|
my $min = $3;
|
|
$httpv = "$mas.$maj";
|
|
|
|
my $stdpath = "$apachepath/userdata/std/2";
|
|
my $sslpath = "$apachepath/userdata/ssl/2";
|
|
if ($httpv eq "2.2") {
|
|
$stdpath = "$apachepath/userdata/std/2_2";
|
|
$sslpath = "$apachepath/userdata/ssl/2_2";
|
|
}
|
|
if ($httpv eq "2.4") {
|
|
$stdpath = "$apachepath/userdata/std/2_4";
|
|
$sslpath = "$apachepath/userdata/ssl/2_4";
|
|
}
|
|
|
|
my $mod = 0;
|
|
print "Checking that modsec.conf files are wrapped in <IfModule mod_security2.c>...</IfModule>:\n";
|
|
foreach my $userdir (glob "$stdpath/*") {
|
|
if (-d $userdir) {
|
|
my ($user, $filedir) = fileparse($userdir);
|
|
my $ssldir = $sslpath."/".$user;
|
|
if (-f "$userdir/modsec.conf") {
|
|
open (my $FH, "<", "$userdir/modsec.conf");
|
|
flock ($FH, LOCK_SH);
|
|
my @data = <$FH>;
|
|
close ($FH);
|
|
unless (grep {$_ =~ /<IfModule mod_security2\.c>/} @data) {
|
|
open (my $OUT, ">", "$userdir/modsec.conf");
|
|
flock ($OUT, LOCK_EX);
|
|
print $OUT "<IfModule mod_security2.c>\n";
|
|
print $OUT @data;
|
|
print $OUT "</IfModule>\n";
|
|
close ($OUT);
|
|
$mod = 1;
|
|
}
|
|
}
|
|
if (-f "$ssldir/modsec.conf") {
|
|
open (my $FH, "<", "$ssldir/modsec.conf");
|
|
flock ($FH, LOCK_SH);
|
|
my @data = <$FH>;
|
|
close ($FH);
|
|
unless (grep {$_ =~ /<IfModule mod_security2\.c>/} @data) {
|
|
open (my $OUT, ">", "$ssldir/modsec.conf");
|
|
flock ($OUT, LOCK_EX);
|
|
print $OUT "<IfModule mod_security2.c>\n";
|
|
print $OUT @data;
|
|
print $OUT "</IfModule>\n";
|
|
close ($OUT);
|
|
$mod = 1;
|
|
}
|
|
}
|
|
foreach my $domaindir (glob "$userdir/*") {
|
|
if (-d $domaindir) {
|
|
my ($domain, $filedir) = fileparse($domaindir);
|
|
my $ssldomaindir = $ssldir."/".$domain;
|
|
if (-f "$domaindir/modsec.conf") {
|
|
open (my $FH, "<", "$domaindir/modsec.conf");
|
|
flock ($FH, LOCK_SH);
|
|
my @data = <$FH>;
|
|
close ($FH);
|
|
unless (grep {$_ =~ /<IfModule mod_security2\.c>/} @data) {
|
|
open (my $OUT, ">", "$domaindir/modsec.conf");
|
|
flock ($OUT, LOCK_EX);
|
|
print $OUT "<IfModule mod_security2.c>\n";
|
|
print $OUT @data;
|
|
print $OUT "</IfModule>\n";
|
|
close ($OUT);
|
|
$mod = 1;
|
|
}
|
|
}
|
|
if (-f "$ssldomaindir/modsec.conf") {
|
|
open (my $FH, "<", "$ssldomaindir/modsec.conf");
|
|
flock ($FH, LOCK_SH);
|
|
my @data = <$FH>;
|
|
close ($FH);
|
|
unless (grep {$_ =~ /<IfModule mod_security2\.c>/} @data) {
|
|
open (my $OUT, ">", "$ssldomaindir/modsec.conf");
|
|
flock ($OUT, LOCK_EX);
|
|
print $OUT "<IfModule mod_security2.c>\n";
|
|
print $OUT @data;
|
|
print $OUT "</IfModule>\n";
|
|
close ($OUT);
|
|
$mod = 1;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($mod) {
|
|
print "Modifications made, restarting apache:\n";
|
|
system ("/scripts/restartsrv_httpd");
|
|
}
|
|
|
|
print "Done.\n"; |