#!/bin/sh /etc/rc.common # START=30 USE_PROCD=1 EXTRA_COMMANDS="refresh status" EXTRA_HELP=" refresh Refresh ipsets only (no new download!) 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 "0")" procd_open_instance "banip" procd_set_param command "${ban_script}" "${@}" procd_set_param pidfile "${ban_pidfile}" procd_set_param nice "${nice}" procd_set_param stdout 1 procd_set_param stderr 1 procd_close_instance fi } refresh() { [ -s "${ban_pidfile}" ] && return 1 rc_procd start_service refresh } reload_service() { rc_procd start_service reload } stop_service() { rc_procd "${ban_script}" stop } status() { local key keylist value local rtfile="$(uci_get banip global ban_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 ban_iface="$(uci_get banip global ban_iface)" local delay="$(uci_get banip extra ban_triggerdelay "2")" local type="$(uci_get banip extra ban_starttype "start")" PROCD_RELOAD_DELAY=$((${delay}*1000)) if [ -n "${ban_iface}" ] then for iface in ${ban_iface} do procd_add_interface_trigger "interface.*.up" "${iface}" "${ban_init}" "${type}" done else procd_add_raw_trigger "interface.*.up" ${PROCD_RELOAD_DELAY} "${ban_init}" "${type}" fi procd_add_reload_trigger "banip" }