#!/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)"
		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
}

refresh()
{
	rc_procd start_service refresh
}

reload_service()
{
	rc_procd start_service reload
}

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 ban_iface="$(uci_get banip global ban_iface)"
	local delay="$(uci_get banip extra ban_triggerdelay)"

	PROCD_RELOAD_DELAY=$((${delay:-2} * 1000))
	for iface in ${ban_iface:-"wan"}
	do
		procd_add_interface_trigger "interface.*.up" "${iface}" "${ban_init}" start
	done
	procd_add_reload_trigger "banip" "firewall"
}