75 lines
1.5 KiB
Text
75 lines
1.5 KiB
Text
|
#!/bin/sh /etc/rc.common
|
||
|
#
|
||
|
|
||
|
START=30
|
||
|
USE_PROCD=1
|
||
|
|
||
|
EXTRA_COMMANDS="status"
|
||
|
EXTRA_HELP=" status Print runtime information"
|
||
|
|
||
|
ban_init="/etc/init.d/banip"
|
||
|
ban_script="/usr/bin/banip.sh"
|
||
|
ban_pidfile="/var/run/banip.pid"
|
||
|
|
||
|
boot()
|
||
|
{
|
||
|
ban_boot="1"
|
||
|
rc_procd start_service
|
||
|
}
|
||
|
|
||
|
start_service()
|
||
|
{
|
||
|
if [ $("${ban_init}" enabled; printf "%u" ${?}) -eq 0 ]
|
||
|
then
|
||
|
if [ "${ban_boot}" = "1" ]
|
||
|
then
|
||
|
return 0
|
||
|
fi
|
||
|
local nice="$(uci_get banip extra ban_nice)"
|
||
|
procd_open_instance "banip"
|
||
|
procd_set_param command "${ban_script}" "${@}"
|
||
|
procd_set_param pidfile "${ban_pidfile}"
|
||
|
procd_set_param nice ${nice:-0}
|
||
|
procd_set_param stdout 1
|
||
|
procd_set_param stderr 1
|
||
|
procd_close_instance
|
||
|
fi
|
||
|
}
|
||
|
|
||
|
stop_service()
|
||
|
{
|
||
|
rc_procd "${ban_script}" stop
|
||
|
rc_procd start_service
|
||
|
}
|
||
|
|
||
|
status()
|
||
|
{
|
||
|
local key keylist value rtfile="$(uci_get banip global ban_rtfile)"
|
||
|
|
||
|
rtfile="${rtfile:-"/tmp/ban_runtime.json"}"
|
||
|
json_load_file "${rtfile}" >/dev/null 2>&1
|
||
|
json_select data >/dev/null 2>&1
|
||
|
if [ ${?} -eq 0 ]
|
||
|
then
|
||
|
printf "%s\n" "::: banIP runtime information"
|
||
|
json_get_keys keylist
|
||
|
for key in ${keylist}
|
||
|
do
|
||
|
json_get_var value "${key}"
|
||
|
printf " + %-10s : %s\n" "${key}" "${value}"
|
||
|
done
|
||
|
else
|
||
|
printf "%s\n" "::: no banIP runtime information available"
|
||
|
fi
|
||
|
}
|
||
|
|
||
|
service_triggers()
|
||
|
{
|
||
|
local iface="$(uci_get banip global ban_iface)"
|
||
|
local delay="$(uci_get banip extra ban_triggerdelay)"
|
||
|
|
||
|
PROCD_RELOAD_DELAY=$((${delay:-2} * 1000))
|
||
|
procd_add_interface_trigger "interface.*.up" "${iface:-"wan"}" "${ban_init}" start
|
||
|
procd_add_reload_trigger "banip" "firewall"
|
||
|
}
|