mirror of
				https://github.com/casjaysdevdocker/squidguard
				synced 2025-10-26 08:02:16 -04:00 
			
		
		
		
	🗃️ modified: bin/entrypoint-squid.sh 🗃️
This commit is contained in:
		| @@ -1,69 +1,83 @@ | ||||
| #!/usr/bin/env bash | ||||
| set -e | ||||
|  | ||||
| if [ "$1" = "healthcheck" ]; then | ||||
|   squidclient -h localhost cache_object://localhost/counters | ||||
|   exit $? | ||||
| fi | ||||
|  | ||||
| SQUID_USER="${SQUID_USER:-squid}" | ||||
| SQUID_USER="${SQUID_USER:-root}" | ||||
| SQUID_LOG_DIR="${SQUID_LOG_DIR:-/data/log/squid}" | ||||
| SQUID_CACHE_DIR="${SQUID_CACHE_DIR:-/data/cache/squid}" | ||||
| HOSTNAME="${HOSTNAME:-$(hostname -f)}" | ||||
| export HOSTNAME="${HOSTNAME:-$(hostname -f)}" | ||||
|  | ||||
| mkdir -p "/config" "/data" | ||||
| __init() { | ||||
|   mkdir -p "/config" "/data" | ||||
|  | ||||
| for dir in apache2 e2guardian squid squidguard; do | ||||
|   if [ -f "/usr/local/share/squidFiles/$dir" ]; then | ||||
|     cp -Rf "/usr/local/share/squidFiles/$dir" "/config/$dir" | ||||
|   elif [ -d "/usr/local/share/squidFiles/$dir" ]; then | ||||
|     cp -Rf "/usr/local/share/squidFiles/$dir/." "/config/$dir/" | ||||
|   else | ||||
|     cp -Rf "/usr/local/share/squidFiles/data/." "/data/" | ||||
|     cp -Rf "usr/local/share/squidFiles/config/." "/config/" | ||||
|   for dir in apache2 e2guardian squid squidguard; do | ||||
|     if [ -f "/usr/local/share/squidFiles/$dir" ]; then | ||||
|       cp -Rf "/usr/local/share/squidFiles/$dir" "/config/$dir" | ||||
|     elif [ -d "/usr/local/share/squidFiles/$dir" ]; then | ||||
|       cp -Rf "/usr/local/share/squidFiles/$dir/." "/config/$dir/" | ||||
|     else | ||||
|       cp -Rf "/usr/local/share/squidFiles/data/." "/data/" | ||||
|       cp -Rf "usr/local/share/squidFiles/config/." "/config/" | ||||
|     fi | ||||
|   done | ||||
|  | ||||
|   mkdir -p "${SQUID_LOG_DIR}" "${SQUID_CACHE_DIR}" "/data/log/apache2" | ||||
|   mkdir -p "/data/log/squidguard" "/data/log/e2guardian" "/data/squidguard/db" | ||||
|   chown -Rf ${SQUID_USER}:${SQUID_USER} "/config" "/data" | ||||
|   chmod -Rf 777 "${SQUID_LOG_DIR}" "${SQUID_CACHE_DIR}" | ||||
|  | ||||
|   cp -Rf "/config/." "/etc/" | ||||
|  | ||||
|   if [ "${UPDATE_BLACKLIST_URL}" != "" ]; then | ||||
|     sudo wget -O /tmp/backlist.tar.gz ${UPDATE_BLACKLIST_URL} && | ||||
|       tar -xzf /tmp/backlist.tar.gz -C "/data/squidguard/db" && | ||||
|       rm -Rf /tmp/backlist.tar.gz && | ||||
|       chown -Rf ${SQUID_USER}:${SQUID_USER} "/data/squidguard/db" | ||||
|   fi | ||||
| done | ||||
|  | ||||
| mkdir -p "${SQUID_LOG_DIR}" "${SQUID_CACHE_DIR}" | ||||
| mkdir -p "/data/log/squidguard" "/data/log/e2guardian" "/data/squidguard/db" | ||||
| chown -Rf ${SQUID_USER}:${SQUID_USER} "/config" "/data" | ||||
| chmod -Rf 755 "${SQUID_LOG_DIR}" | ||||
|   if [ "${WPAD_IP}" != "" ]; then | ||||
|     sed 's/{{WPAD_IP}}/'"${WPAD_IP}"'/' -i "/data/htdocs/www/wpad.dat" | ||||
|     sed 's/{{WPAD_NOPROXY_NET}}/'"${WPAD_NOPROXY_NET}"'/' -i "/data/htdocs/www/wpad.dat" | ||||
|     sed 's/{{WPAD_NOPROXY_MASK}}/'"${WPAD_NOPROXY_MASK}"'/' -i "/data/htdocs/www/wpad.dat" | ||||
|   fi | ||||
|  | ||||
| cp -Rf "/config/." "/etc/" | ||||
|   # allow arguments to be passed to squid | ||||
|   if [[ ${1:0:1} = '-' ]]; then | ||||
|     EXTRA_ARGS="$@" | ||||
|     set -- | ||||
|   elif [[ ${1} == squid || ${1} == $(which squid) ]]; then | ||||
|     EXTRA_ARGS="${@:2}" | ||||
|     set -- | ||||
|   fi | ||||
| } | ||||
|  | ||||
| if [ "${UPDATE_BLACKLIST_URL}" != "" ]; then | ||||
|   sudo wget -O backlist.tar.gz ${UPDATE_BLACKLIST_URL} && | ||||
|     tar -xzf backlist.tar.gz -C "/data/squidguard/db" && | ||||
|     rm -Rf backlist.tar.gz && | ||||
|     chown -Rf ${SQUID_USER}:${SQUID_USER} "/data/squidguard/db" | ||||
| fi | ||||
| case "$1" in | ||||
|  | ||||
| if [ "${WPAD_IP}" != "" ]; then | ||||
|   sed 's/{{WPAD_IP}}/'"${WPAD_IP}"'/' -i "/data/htdocs/www/wpad.dat" | ||||
|   sed 's/{{WPAD_NOPROXY_NET}}/'"${WPAD_NOPROXY_NET}"'/' -i "/data/htdocs/www/wpad.dat" | ||||
|   sed 's/{{WPAD_NOPROXY_MASK}}/'"${WPAD_NOPROXY_MASK}"'/' -i "/data/htdocs/www/wpad.dat" | ||||
| fi | ||||
| healthcheck) | ||||
|   squidclient -h localhost cache_object://localhost/counters | ||||
|   exit $? | ||||
|   ;; | ||||
|  | ||||
| # allow arguments to be passed to squid | ||||
| if [[ ${1:0:1} = '-' ]]; then | ||||
|   EXTRA_ARGS="$@" | ||||
|   set -- | ||||
| elif [[ ${1} == squid || ${1} == $(which squid) ]]; then | ||||
|   EXTRA_ARGS="${@:2}" | ||||
|   set -- | ||||
| fi | ||||
| update) | ||||
|   shift 1 | ||||
|   /usr/local/bin/create-blocklists.sh | ||||
|   exit $? | ||||
|   ;; | ||||
|  | ||||
| # start apache to serve wpad.dat file and or block.html | ||||
| sudo /etc/init.d/apache2 restart | ||||
| bash | shell | sh) | ||||
|   exec /bin/bash -l | ||||
|   ;; | ||||
|  | ||||
| # default behaviour is to launch squid | ||||
| if [[ -z ${1} ]]; then | ||||
| *) | ||||
|   __init "$@" | ||||
|   if [[ ! -d ${SQUID_CACHE_DIR}/00 ]]; then | ||||
|     echo "Initializing cache..." | ||||
|     $(which squid) -N -f /etc/squid/squid.conf -z | ||||
|     $(which squid) -N -f "/config/squid/squid.conf" -z | ||||
|   fi | ||||
|  | ||||
|   echo "Starting apache web server..." | ||||
|   [ -f "/var/run/apache2.pid" ] && rm -R /var/run/apache2.pid | ||||
|   apache2 -D FOREGROUND -f "/config/apache2/apache2.conf" & | ||||
|  | ||||
|   echo "Starting squid..." | ||||
|   exec $(which squid) -f /etc/squid/squid.conf -NYCd 1 ${EXTRA_ARGS} | ||||
| else | ||||
|   exec "$@" | ||||
| fi | ||||
|   exec $(which squid) -f "/config/squid/squid.conf" -NYCd 1 ${EXTRA_ARGS} | ||||
|   ;; | ||||
| esac | ||||
|   | ||||
		Reference in New Issue
	
	Block a user