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