HEX
Server: nginx/1.29.3
System: Linux 11979.bigscoots-wpo.com 6.8.0-88-generic #89-Ubuntu SMP PREEMPT_DYNAMIC Sat Oct 11 01:02:46 UTC 2025 x86_64
User: nginx (1068)
PHP: 7.4.33
Disabled: exec,system,passthru,shell_exec,proc_open,proc_close,popen,show_source,cmd# Do not modify this line # 1684243876
Upload Files
File: //usr/local/src/centminmod/tools/csfcf.sh
#!/bin/bash
export PATH="/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin"
###############################
# written by George Liu (eva2000)
# centminmod.com
###############################
CFIPLOG='/root/cfips.txt'
CFIP6LOG='/root/cfips6.txt'
CFIPNGINXLOG='/root/cfnginxlog.log'
CFIPCSFLOG='/root/csf_log.log'
CFINCLUDEFILE='/usr/local/nginx/conf/cloudflare.conf'
CFINCLUDEFILE_APACHE='/etc/httpd/conf/extra/httpd-includes-remoteip.conf'
CURL_TIMEOUTS='--max-time 20 --connect-timeout 20'
FORCE_IPVFOUR='y' # curl/wget commands through script force IPv4
###############################
if [ ! -f /usr/bin/curl ]; then
	echo "Installing curl please wait..."
	yum -y -q install curl
fi
if [ ! -f /usr/bin/ipcalc ]; then
	echo "Installing ipcalc please wait..."
	yum -y -q install ipcalc
fi
###############################
# set locale temporarily to english
# due to some non-english locale issues
export LC_ALL=en_US.UTF-8
export LANG=en_US.UTF-8
export LANGUAGE=en_US.UTF-8
export LC_CTYPE=en_US.UTF-8
# disable systemd pager so it doesn't pipe systemctl output to less
export SYSTEMD_PAGER=''
ARCH_CHECK="$(uname -m)"

shopt -s expand_aliases
for g in "" e f; do
    alias ${g}grep="LC_ALL=C ${g}grep"  # speed-up grep, egrep, fgrep
done

if [ -f /etc/centminmod/custom_config.inc ]; then
  source /etc/centminmod/custom_config.inc
fi
if [[ "$FORCE_IPVFOUR" != [yY] ]]; then
  ipv_forceopt=""
  ipv_forceopt_wget=""
  WGETOPT="-cnv --no-dns-cache${ipv_forceopt_wget}"
else
  ipv_forceopt='4'
  ipv_forceopt_wget=' -4'
  WGETOPT="-cnv --no-dns-cache${ipv_forceopt_wget}"
fi

csf_switch_downloads() {
		mkdir -p /svr-setup
		rm -f /svr-setup/csf_final_update.sh
		wget -O /svr-setup/csf_final_update.sh https://download.centminmod.com/scripts/csf_final_update.sh
		chmod +x /svr-setup/csf_final_update.sh
		# update to Centmin Mod CSF edition and skip checksum/gpg checks for now
		# as csf.tgz isn't being repackaged with checksum/gpg optional checks
		/svr-setup/csf_final_update.sh --skip-security
		echo
}

ipv4get() {
	only=$1
	/usr/bin/curl -${ipv_forceopt}s ${CURL_TIMEOUTS} https://www.cloudflare.com/ips-v4/ > $CFIPLOG
	
	CFIPS=$(cat $CFIPLOG)
	
	if [[ "$only" != 'only' ]]; then
		echo "--------------------------------------------"
		echo " Downloading Cloudflare IP list"
		echo " from: https://www.cloudflare.com/ips-v4/"
		echo "--------------------------------------------"
		echo ""
		echo "--------------------------------------------"
		echo " Format for Centminmod.com Nginx Installer"
		echo "  1). add to nginx.conf"
		echo "  2). add to /etc/csf/csf.allow"
		echo "--------------------------------------------"
		
		for ip in $CFIPS; 
		do
			if [[ "$(ipcalc -c "$ip" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
				echo "set_real_ip_from $ip;" >> $CFIPNGINXLOG
				echo "csf -a $ip cloudflare" >> $CFIPCSFLOG
			fi
		done
		echo "real_ip_header X-Forwarded-For;" >> $CFIPNGINXLOG
		
		echo "--------------------------------------------"
		echo "  1). add to nginx.conf"
		echo "--------------------------------------------"
		cat $CFIPNGINXLOG
		
		echo ""
		
		echo "--------------------------------------------"
		echo "  2). add to /etc/csf/csf.allow"
		echo "--------------------------------------------"
		cat $CFIPCSFLOG
		
		rm -rf $CFIPLOG
		rm -rf $CFIPNGINXLOG
		rm -rf $CFIPCSFLOG
		
		echo "--------------------------------------------"
	elif [[ "$only" = 'only' ]]; then
		for ip in $CFIPS; 
		do
			if [[ "$(ipcalc -c "$ip" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
				echo "$ip"
			fi
		done
	fi
}

###############################
ipv6get() {
	only=$1

	/usr/bin/curl -${ipv_forceopt}s ${CURL_TIMEOUTS} https://www.cloudflare.com/ips-v6/ > $CFIP6LOG
	
	CFIPS=$(cat $CFIP6LOG)

	if [[ "$only" != 'only' ]]; then
		echo "--------------------------------------------"
		echo " Downloading Cloudflare IP list"
		echo " from: https://www.cloudflare.com/ips-v6/"
		echo "--------------------------------------------"
		echo ""
		echo "--------------------------------------------"
		echo " Format for Centminmod.com Nginx Installer"
		echo "  1). add to nginx.conf"
		echo "  2). add to /etc/csf/csf.allow"
		echo "--------------------------------------------"
		
		for ip in $CFIPS; 
		do
			if [[ "$(ipcalc -c "$ip" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
				echo "set_real_ip_from $ip;" >> $CFIPNGINXLOG
				echo "csf -a $ip cloudflare" >> $CFIPCSFLOG
			fi
		done
		echo "real_ip_header X-Forwarded-For;" >> $CFIPNGINXLOG
		
		echo "--------------------------------------------"
		echo "  1). add to nginx.conf"
		echo "--------------------------------------------"
		cat $CFIPNGINXLOG
		
		echo ""
		
		echo "--------------------------------------------"
		echo "  2). add to /etc/csf/csf.allow"
		echo "--------------------------------------------"
		cat $CFIPCSFLOG
		
		rm -rf $CFIPLOG
		rm -rf $CFIPNGINXLOG
		rm -rf $CFIPCSFLOG
		
		echo "--------------------------------------------"
	elif [[ "$only" = 'only' ]]; then
		for ip in $CFIPS; 
		do
			if [[ "$(ipcalc -c "$ip" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
				echo "$ip"
			fi
		done
	fi
}

###############################
csfadd() {
	/usr/bin/curl -${ipv_forceopt}s ${CURL_TIMEOUTS} https://www.cloudflare.com/ips-v4/ > $CFIPLOG
	/usr/bin/curl -${ipv_forceopt}s ${CURL_TIMEOUTS} https://www.cloudflare.com/ips-v6/ > $CFIP6LOG
	
	CFIPS=$(cat $CFIPLOG)
	CFIP6S=$(cat $CFIP6LOG)
	
	echo "--------------------------------------------"
	echo " Add Cloudflare IP list to CSF"
	echo " from: https://www.cloudflare.com/ips-v4/"
	echo " from: https://www.cloudflare.com/ips-v6/"
	echo "--------------------------------------------"
	echo ""


	echo "--------------------------------------------"
	echo "  Add to /etc/csf/csf.allow"
	echo "--------------------------------------------"

	for ip in $CFIPS; 
	do
		if [[ "$(grep "$ip" /etc/csf/csf.allow >/dev/null 2>&1; echo $?)" = '1' ]] || [[ "$(grep "$ip" /etc/csf/csf.ignore >/dev/null 2>&1; echo $?)" = '1' ]]; then
			if [[ "$(ipcalc -c "$ip" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
				csf -a "$ip" cloudflare
				echo "$ip" >> /etc/csf/csf.ignore
			fi
		fi
	done

	if [[ "$(awk -F '= ' '/^IPV6 =/ {print $2}' /etc/csf/csf.conf | sed -e 's|\"||g')" = '1' ]]; then
	for ip in $CFIP6S; 
	do
		if [[ "$(grep "$ip" /etc/csf/csf.allow >/dev/null 2>&1; echo $?)" = '1' ]] || [[ "$(grep "$ip" /etc/csf/csf.ignore >/dev/null 2>&1; echo $?)" = '1' ]]; then
			if [[ "$(ipcalc -c "$ip" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
				csf -a "$ip" cloudflare
				echo "$ip" >> /etc/csf/csf.ignore
			fi
		fi
	done
	fi

	# auto fix previous bug
	# https://community.centminmod.com/posts/45907/
	sed -i '/^ip/d' /etc/csf/csf.ignore

	# remove changed CF IPs from https://www.cloudflare.com/ips/
	sed -i '/^104.16.0.0\/12/d' /etc/csf/csf.ignore
	sed -i '/^199.27.128.0\/21/d' /etc/csf/csf.ignore
	sed -i '/^104.16.0.0\/12/d' /etc/csf/csf.allow
	sed -i '/^199.27.128.0\/21/d' /etc/csf/csf.allow
}

###############################
nginxsetup() {
	echo
	# echo "create $CFINCLUDEFILE include file"
	if [ -f "$CFINCLUDEFILE" ]; then
		\cp -af "$CFINCLUDEFILE" "${CFINCLUDEFILE}.bak"
	fi
	echo > $CFINCLUDEFILE
	cflista=$(/usr/bin/curl -${ipv_forceopt}s ${CURL_TIMEOUTS} https://www.cloudflare.com/ips-v4/)
	cflistb=$(/usr/bin/curl -${ipv_forceopt}s ${CURL_TIMEOUTS} https://www.cloudflare.com/ips-v6/)
	if [ ! -f /usr/local/nginx/conf/cloudflare_customips.conf ]; then
		touch /usr/local/nginx/conf/cloudflare_customips.conf
		echo -e "# http://nginx.org/en/docs/http/ngx_http_realip_module.html#real_ip_recursive\nreal_ip_recursive off;" >> /usr/local/nginx/conf/cloudflare_customips.conf
	fi
	echo "include /usr/local/nginx/conf/cloudflare_customips.conf;" >> $CFINCLUDEFILE
	for i in $cflista; do
      if [[ "$(ipcalc -c "$i" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
        	echo "set_real_ip_from $i;" >> $CFINCLUDEFILE
      fi
	done
	if [[ -f /etc/sysconfig/network && "$(awk -F "=" '/NETWORKING_IPV6/ {print $2}' /etc/sysconfig/network | grep 'yes' >/dev/null 2>&1; echo $?)" = '0' ]]; then
		for i in $cflistb; do
      if [[ "$(ipcalc -c "$i" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
        		echo "set_real_ip_from $i;" >> $CFINCLUDEFILE
      fi
		done
	else
		for i in $cflistb; do
      if [[ "$(ipcalc -c "$i" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
        		echo "#set_real_ip_from $i;" >> $CFINCLUDEFILE
      fi
		done
	fi
	echo "real_ip_header X-Forwarded-For;" >> $CFINCLUDEFILE
	if [[ "$(diff -u "${CFINCLUDEFILE}.bak" "$CFINCLUDEFILE" >/dev/null 2>&1; echo $?)" -ne '0' ]]; then
		service nginx reload >/dev/null 2>&1
	fi
	rm -rf "${CFINCLUDEFILE}.bak"
	echo "created $CFINCLUDEFILE include file"
}

###############################
apachesetup() {
	# mod_remoteip
	# https://support.cloudflare.com/hc/en-us/articles/360029696071
	if [ -d /etc/httpd/conf/extra ]; then
		echo
		# echo "create $CFINCLUDEFILE_APACHE include file"
		if [ -f "$CFINCLUDEFILE_APACHE" ]; then
			\cp -af "$CFINCLUDEFILE_APACHE" "${CFINCLUDEFILE_APACHE}.bak"
		fi
		echo > $CFINCLUDEFILE_APACHE
		cflista=$(/usr/bin/curl -${ipv_forceopt}s ${CURL_TIMEOUTS} https://www.cloudflare.com/ips-v4/)
		cflistb=$(/usr/bin/curl -${ipv_forceopt}s ${CURL_TIMEOUTS} https://www.cloudflare.com/ips-v6/)
		if [ ! -f /etc/httpd/conf/extra/cloudflare_customips.conf ]; then
			touch /etc/httpd/conf/extra/cloudflare_customips.conf
		fi
		echo "Include /etc/httpd/conf/extra/cloudflare_customips.conf" >> $CFINCLUDEFILE_APACHE
		for i in $cflista; do
      	if [[ "$(ipcalc -c "$i" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
        		echo "RemoteIPTrustedProxy $i" >> $CFINCLUDEFILE_APACHE
      	fi
		done
		if [[ -f /etc/sysconfig/network && "$(awk -F "=" '/NETWORKING_IPV6/ {print $2}' /etc/sysconfig/network | grep 'yes' >/dev/null 2>&1; echo $?)" = '0' ]]; then
			for i in $cflistb; do
      	if [[ "$(ipcalc -c "$i" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
        			echo "RemoteIPTrustedProxy $i" >> $CFINCLUDEFILE_APACHE
      	fi
			done
		else
			for i in $cflistb; do
      	if [[ "$(ipcalc -c "$i" >/dev/null 2>&1; echo $?)" -eq '0' ]]; then
        			echo "#RemoteIPTrustedProxy $i" >> $CFINCLUDEFILE_APACHE
      	fi
			done
		fi
		echo "RemoteIPHeader CF-Connecting-IP" >> $CFINCLUDEFILE_APACHE
		# echo 'LogFormat "%{CF-Connecting-IP}i %l %u %t "%r" %>s %O "%{Referer}i" "%{User-Agent}i"" cfproxy'  >> $CFINCLUDEFILE_APACHE
		if [[ "$(diff -u "${CFINCLUDEFILE_APACHE}.bak" "$CFINCLUDEFILE_APACHE" >/dev/null 2>&1; echo $?)" -ne '0' ]]; then
			service httpd reload >/dev/null 2>&1
		fi
		rm -rf "${CFINCLUDEFILE_APACHE}.bak"
		echo "created $CFINCLUDEFILE_APACHE include file"
	fi
}

haproxy_ips() {
  if [[ -f /usr/local/src/centminmod/tools/csfcf.sh && -d /etc/haproxy/ ]]; then
  	echo "populate cloudflare IPs in /etc/haproxy/cfips"
    echo -n > /etc/haproxy/cfips
    /usr/local/src/centminmod/tools/csfcf.sh ipv4-only >> /etc/haproxy/cfips
    /usr/local/src/centminmod/tools/csfcf.sh ipv6-only >> /etc/haproxy/cfips
    cat /etc/haproxy/cfips
  fi
}

###############################
case "$1" in
ipv4)
	ipv4get
;;
ipv6)
	ipv6get
;;
ipv4-only)
	ipv4get only
;;
ipv6-only)
	ipv6get only
;;
csf)
	csfadd
;;
nginx)
	nginxsetup
;;
apache)
	apachesetup
;;
haproxy)
	haproxy_ips
;;
auto)
	csf_switch_downloads
	csfadd
	nginxsetup
	haproxy_ips
;;
auto-apache)
	csfadd
	apachesetup
;;
*)
echo "$0 {ipv4|ipv6|ipv4-only|ipv6-only|csf|nginx|apache|haproxy|auto}"
;;
esac
exit