@ -5,7 +5,7 @@ START=50
USE_PROCD=1
USE_PROCD=1
validate_section_addrwatch() {
validate_section_addrwatch() {
uci_validate_section addrwatch addrwatch "${1} " \
uci_load_validate addrwatch addrwatch "$1" "$2 " \
'disabled:bool:0' \
'disabled:bool:0' \
'interface:list(string):lan' \
'interface:list(string):lan' \
'syslog:bool:1' \
'syslog:bool:1' \
@ -17,16 +17,13 @@ validate_section_addrwatch() {
'blacklist:list(or(ip4addr,ip6addr))' \
'blacklist:list(or(ip4addr,ip6addr))' \
'hashsize:range(1,65536):1024'\
'hashsize:range(1,65536):1024'\
'ratelimit:integer:3600'
'ratelimit:integer:3600'
return $?
}
}
start_instance() {
start_instance() {
local cfg="$1"
local cfg="$1"
local disabled interface syslog output quiet verbose ipv4only ipv6only
local blacklist hashsize ratelimit
local netdevs=""
local netdevs=""
validate_section_addrwatch "${cfg}" || {
[ "$2" = 0 ] || {
echo "validation of config $cfg failed"
echo "validation of config $cfg failed"
return 1
return 1
}
}
@ -34,14 +31,14 @@ start_instance() {
for iface in $interface; do
for iface in $interface; do
local netdev
local netdev
network_get_physdev netdev "${ iface} "
append netdevs "${ netdev} "
network_get_physdev netdev "$iface"
append netdevs "$netdev"
done
done
procd_open_instance
procd_open_instance
procd_set_param command /usr/sbin/addrwatch
procd_set_param command /usr/sbin/addrwatch
[ "${ syslog} " -eq 1 ] && procd_append_param command --syslog
[ -n "${ output} " ] && procd_append_param command --output "$output"
[ "$syslog" -eq 1 ] && procd_append_param command --syslog
[ -n "$output" ] && procd_append_param command --output "$output"
[ "$quiet" -eq 1 ] && procd_append_param command --quiet
[ "$quiet" -eq 1 ] && procd_append_param command --quiet
[ "$verbose" -eq 1 ] && procd_append_param command --verbose
[ "$verbose" -eq 1 ] && procd_append_param command --verbose
[ "$ipv4only" -eq 1 ] && procd_append_param command --ipv4only
[ "$ipv4only" -eq 1 ] && procd_append_param command --ipv4only
@ -49,14 +46,14 @@ start_instance() {
[ -n "$hashsize" ] && procd_append_param command --hashsize "$hashsize"
[ -n "$hashsize" ] && procd_append_param command --hashsize "$hashsize"
[ -n "$ratelimit" ] && procd_append_param command --ratelimit "$ratelimit"
[ -n "$ratelimit" ] && procd_append_param command --ratelimit "$ratelimit"
for blitem in $blacklist; do
for blitem in $blacklist; do
procd_append_param command "--blacklist=${ blitem} "
procd_append_param command "--blacklist=$blitem"
done
done
procd_append_param command $netdevs
procd_append_param command $netdevs
procd_set_param netdev $netdevs
procd_set_param netdev $netdevs
procd_set_param respawn
procd_set_param respawn
procd_open_trigger
procd_open_trigger
for iface in $interface; do
for iface in $interface; do
procd_add_interface_trigger "interface.*" ${ iface} /etc/init.d/addrwatch reload
procd_add_interface_trigger "interface.*" $iface /etc/init.d/addrwatch reload
done
done
procd_close_trigger
procd_close_trigger
procd_close_instance
procd_close_instance
@ -65,9 +62,10 @@ start_instance() {
start_service() {
start_service() {
. /lib/functions/network.sh
. /lib/functions/network.sh
config_load 'addrwatch'
config_load 'addrwatch'
config_foreach start_instance 'addrwatch'
config_foreach validate_section_addrwatch 'addrwatch' start_instance
}
}
service_triggers() {
service_triggers() {
procd_add_reload_trigger 'addrwatch'
procd_add_reload_trigger 'addrwatch'
procd_add_validation validate_section_addrwatch
}
}