mirror of
https://github.com/casjaysdevdocker/squidguard
synced 2025-01-18 12:34:24 -05:00
🗃️ modified: bin/entrypoint-squid.sh 🗃️
This commit is contained in:
parent
85958cd3f7
commit
3d192d5ad6
@ -1,69 +1,83 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
|
||||||
|
|
||||||
if [ "$1" = "healthcheck" ]; then
|
SQUID_USER="${SQUID_USER:-root}"
|
||||||
squidclient -h localhost cache_object://localhost/counters
|
|
||||||
exit $?
|
|
||||||
fi
|
|
||||||
|
|
||||||
SQUID_USER="${SQUID_USER:-squid}"
|
|
||||||
SQUID_LOG_DIR="${SQUID_LOG_DIR:-/data/log/squid}"
|
SQUID_LOG_DIR="${SQUID_LOG_DIR:-/data/log/squid}"
|
||||||
SQUID_CACHE_DIR="${SQUID_CACHE_DIR:-/data/cache/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
|
for dir in apache2 e2guardian squid squidguard; do
|
||||||
if [ -f "/usr/local/share/squidFiles/$dir" ]; then
|
if [ -f "/usr/local/share/squidFiles/$dir" ]; then
|
||||||
cp -Rf "/usr/local/share/squidFiles/$dir" "/config/$dir"
|
cp -Rf "/usr/local/share/squidFiles/$dir" "/config/$dir"
|
||||||
elif [ -d "/usr/local/share/squidFiles/$dir" ]; then
|
elif [ -d "/usr/local/share/squidFiles/$dir" ]; then
|
||||||
cp -Rf "/usr/local/share/squidFiles/$dir/." "/config/$dir/"
|
cp -Rf "/usr/local/share/squidFiles/$dir/." "/config/$dir/"
|
||||||
else
|
else
|
||||||
cp -Rf "/usr/local/share/squidFiles/data/." "/data/"
|
cp -Rf "/usr/local/share/squidFiles/data/." "/data/"
|
||||||
cp -Rf "usr/local/share/squidFiles/config/." "/config/"
|
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
|
fi
|
||||||
done
|
|
||||||
|
|
||||||
mkdir -p "${SQUID_LOG_DIR}" "${SQUID_CACHE_DIR}"
|
if [ "${WPAD_IP}" != "" ]; then
|
||||||
mkdir -p "/data/log/squidguard" "/data/log/e2guardian" "/data/squidguard/db"
|
sed 's/{{WPAD_IP}}/'"${WPAD_IP}"'/' -i "/data/htdocs/www/wpad.dat"
|
||||||
chown -Rf ${SQUID_USER}:${SQUID_USER} "/config" "/data"
|
sed 's/{{WPAD_NOPROXY_NET}}/'"${WPAD_NOPROXY_NET}"'/' -i "/data/htdocs/www/wpad.dat"
|
||||||
chmod -Rf 755 "${SQUID_LOG_DIR}"
|
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
|
case "$1" in
|
||||||
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
|
|
||||||
|
|
||||||
if [ "${WPAD_IP}" != "" ]; then
|
healthcheck)
|
||||||
sed 's/{{WPAD_IP}}/'"${WPAD_IP}"'/' -i "/data/htdocs/www/wpad.dat"
|
squidclient -h localhost cache_object://localhost/counters
|
||||||
sed 's/{{WPAD_NOPROXY_NET}}/'"${WPAD_NOPROXY_NET}"'/' -i "/data/htdocs/www/wpad.dat"
|
exit $?
|
||||||
sed 's/{{WPAD_NOPROXY_MASK}}/'"${WPAD_NOPROXY_MASK}"'/' -i "/data/htdocs/www/wpad.dat"
|
;;
|
||||||
fi
|
|
||||||
|
|
||||||
# allow arguments to be passed to squid
|
update)
|
||||||
if [[ ${1:0:1} = '-' ]]; then
|
shift 1
|
||||||
EXTRA_ARGS="$@"
|
/usr/local/bin/create-blocklists.sh
|
||||||
set --
|
exit $?
|
||||||
elif [[ ${1} == squid || ${1} == $(which squid) ]]; then
|
;;
|
||||||
EXTRA_ARGS="${@:2}"
|
|
||||||
set --
|
|
||||||
fi
|
|
||||||
|
|
||||||
# start apache to serve wpad.dat file and or block.html
|
bash | shell | sh)
|
||||||
sudo /etc/init.d/apache2 restart
|
exec /bin/bash -l
|
||||||
|
;;
|
||||||
|
|
||||||
# default behaviour is to launch squid
|
*)
|
||||||
if [[ -z ${1} ]]; then
|
__init "$@"
|
||||||
if [[ ! -d ${SQUID_CACHE_DIR}/00 ]]; then
|
if [[ ! -d ${SQUID_CACHE_DIR}/00 ]]; then
|
||||||
echo "Initializing cache..."
|
echo "Initializing cache..."
|
||||||
$(which squid) -N -f /etc/squid/squid.conf -z
|
$(which squid) -N -f "/config/squid/squid.conf" -z
|
||||||
fi
|
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..."
|
echo "Starting squid..."
|
||||||
exec $(which squid) -f /etc/squid/squid.conf -NYCd 1 ${EXTRA_ARGS}
|
exec $(which squid) -f "/config/squid/squid.conf" -NYCd 1 ${EXTRA_ARGS}
|
||||||
else
|
;;
|
||||||
exec "$@"
|
esac
|
||||||
fi
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user