2019-01-04 16:55:56 +01:00
|
|
|
#!/bin/sh
|
2019-01-07 14:47:05 +01:00
|
|
|
#
|
|
|
|
# Update firewall rules of <jailname> or all
|
|
|
|
# Usage: firewall <jailname>|all
|
|
|
|
#
|
2019-01-04 16:55:56 +01:00
|
|
|
|
2020-04-01 07:31:33 +02:00
|
|
|
# shellcheck source=config
|
2019-01-04 16:55:56 +01:00
|
|
|
LIBDIR="$(dirname $0)" && . "${LIBDIR}/config"
|
|
|
|
|
|
|
|
jail="${1:-}"
|
2019-01-07 14:47:05 +01:00
|
|
|
if [ ! -n "${jail}" ]; then
|
|
|
|
"${LIBDIR}/bkctld-help" && exit 1
|
|
|
|
fi
|
2019-01-04 16:55:56 +01:00
|
|
|
|
|
|
|
if [ -n "${FIREWALL_RULES}" ]; then
|
|
|
|
[ -f "${FIREWALL_RULES}" ] && sed -i "/#${jail}$/d" "${FIREWALL_RULES}"
|
2019-01-07 16:41:29 +01:00
|
|
|
if [ -d "${JAILDIR}/${jail}" ]; then
|
2019-01-04 16:55:56 +01:00
|
|
|
port=$("${LIBDIR}/bkctld-port" "${jail}")
|
|
|
|
for ip in $("${LIBDIR}/bkctld-ip" "${jail}"); do
|
|
|
|
echo "/sbin/iptables -A INPUT -p tcp --sport 1024: --dport ${port} -s ${ip} -j ACCEPT #${jail}" >> "${FIREWALL_RULES}"
|
|
|
|
done
|
|
|
|
[ -f /etc/init.d/minifirewall ] && /etc/init.d/minifirewall restart >/dev/null
|
|
|
|
fi
|
|
|
|
notice "${jail} : firewall rules updated"
|
|
|
|
fi
|