Server IP : 184.154.167.98 / Your IP : 18.118.138.113 Web Server : Apache System : Linux pink.dnsnetservice.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64 User : puertode ( 1767) PHP Version : 7.2.34 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /sbin/ |
Upload File : |
#!/bin/bash # Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2019 All Rights Reserved # # Licensed under CLOUD LINUX LICENSE AGREEMENT # http://cloudlinux.com/docs/LICENSE.TXT # CageFS script to patch and rebuild Apache's suexec . /opt/cloudlinux/venv/usr/share/python-cllib/scripts/cl-common common_path_of_cpanel="/usr/share/cagefs/cpanel" if [ -z "$1" ] then MIN_UID=500 else MIN_UID=$1 fi ROOT_UID=0 if [ "$UID" -ne "$ROOT_UID" ] then echo "ERROR: root privileges required" exit fi if is_ea4; then writeToLog "[CageFS] EasyApache 4 is active. Skip rebuilding suexec" "$common_path_of_cpanel" exit 0 fi writeToLog "[CageFS] rebuild suexec" "$common_path_of_cpanel" # patch apache's suexec log=$(getLogFile "$common_path_of_cpanel") easyApacheDir=$(getEasyApacheDir) currentpath=$(pwd) cd $common_path_of_cpanel if [ -e "httpd2-cagefs_jail.patch" ];then cd $easyApacheDir/src for dirname in ./httpd*; do if [ -d "$dirname/support" ];then echo $dirname >>$log cd $dirname/support if [ "$2" == "restore" ]; then # apply patch if it has not been applied yet patch -N -i $common_path_of_cpanel/httpd2-cagefs_jail.patch >/dev/null patch -R -N -i $common_path_of_cpanel/httpd2-cagefs_jail.patch 1>>$log 2>>$log else # reverse patch if it is already applied patch -R -N -i $common_path_of_cpanel/httpd2-cagefs_jail.patch >/dev/null patch -N -i $common_path_of_cpanel/httpd2-cagefs_jail.patch 1>>$log 2>>$log fi if [ $? != 0 ];then echo "Error applying patch. Please, contact support at http://www.cloudlinux.com/support/" >>$log cd $currentpath exit 1 else echo "Patch was applied correctly..." >>$log fi #../srclib/apr/libtool --mode=compile gcc -pthread -I/opt/pcre/include -DLINUX=2 -D_REENTRANT -D_GNU_SOURCE -D_LARGEFILE64_SOURCE -DSECURELVE_MIN_UID=$MIN_UID -I. -I"$easyApacheDir"/src/httpd-2.2.19/os/unix -I$easyApacheDir/src/httpd-2.2.19/server/mpm/prefork -I$easyApacheDir/src/httpd-2.2.19/modules/http -I$easyApacheDir/src/httpd-2.2.19/modules/filters -I$easyApacheDir/src/httpd-2.2.19/modules/proxy -I$easyApacheDir/src/httpd-2.2.19/include -I$easyApacheDir/src/httpd-2.2.19/modules/generators -I$easyApacheDir/src/httpd-2.2.19/modules/mappers -I$easyApacheDir/src/httpd-2.2.19/modules/database -I$easyApacheDir/src/httpd-2.2.19/srclib/apr/include -I$easyApacheDir/src/httpd-2.2.19/srclib/apr-util/include -I$easyApacheDir/src/httpd-2.2.19/modules/proxy/../generators -I/usr/include -I/usr/kerberos/include -I$easyApacheDir/src/httpd-2.2.19/modules/ssl -I$easyApacheDir/src/httpd-2.2.19/modules/dav/main -prefer-non-pic -static -c suexec.c && touch suexec.lo #../srclib/apr/libtool --mode=link gcc -pthread -I/opt/pcre/include -L/opt/pcre/lib -lpcre -L/usr/lib -L/usr/kerberos/lib -ldl -o suexec suexec.lo cd .. CFLAGS='-O0' ./configure --enable-expires --enable-headers --enable-info --enable-logio --enable-proxy --enable-rewrite --enable-ssl --enable-suexec --prefix=/usr/local/apache --with-included-apr --with-pcre=/opt/pcre --with-ssl=/usr --with-suexec-caller=nobody --with-suexec-docroot=/ --with-suexec-gidmin=100 --with-suexec-logfile=/usr/local/apache/logs/suexec_log --with-suexec-uidmin=100 --with-suexec-userdir=public_html LDFLAGS="-Wl,-rpath,/opt/pcre/lib" 1>>$log 2>>$log cd ./support make suexec 1>>$log 2>>$log if [ "$2" != "restore" ]; then # check that suexec is correct if grep lve_jail ./suexec 1>>$log 2>>$log && grep "or trusted user" ./suexec 1>>$log 2>>$log ; then # install suexec cp -f ./suexec /usr/local/apache/bin/suexec 1>>$log 2>>$log chown root:root /usr/local/apache/bin/suexec 1>>$log 2>>$log chmod ug+s /usr/local/apache/bin/suexec 1>>$log 2>>$log break else echo "Error while rebuilding suexec" echo "Please, try to rebuild suexec manually" echo "If you use CPanel, you should run:" echo "/scripts/upcp --force" echo "/scripts/easyapache" echo "" cd $currentpath exit 1 fi else cp -f ./suexec /usr/local/apache/bin/suexec 1>>$log 2>>$log chown root:root /usr/local/apache/bin/suexec 1>>$log 2>>$log chmod ug+s /usr/local/apache/bin/suexec 1>>$log 2>>$log fi cd $easyApacheDir/src fi done else echo "Cannot find httpd2-cagefs_jail.patch. Contact support at http://www.cloudlinux.com/support/" >>$log cd $currentpath exit 1 fi cd $currentpath writeToLog "[CageFS] suexec was rebuilt successfully" "$common_path_of_cpanel" exit 0