relayd: remove old start-stop-service related code
[openwrt/staging/lynxis/omap.git] / package / network / services / relayd / files / relay.init
index d73df6ab5522ab58a0d46f6b4137fdd54f4fa97e..ac10f48b70acaed3213d2f207a3bdea7f7575a06 100644 (file)
@@ -6,10 +6,21 @@ START=80
 USE_PROCD=1
 PROG=/usr/sbin/relayd
 
+validate_proto_relayd()
+{
+       uci_validate_section network "interface" "${1}" \
+               'network:list(string)' \
+               'expiry:uinteger:30' \
+               'retry:uinteger:5' \
+               'table:range(0, 65535):16800' \
+               'forward_bcast:bool:1' \
+               'forward_dhcp:bool:1'
+}
+
 resolve_ifname() {
        grep -qs "^ *$1:" /proc/net/dev && {
                procd_append_param command -I "$1"
-               append ifaces "$1"
+               procd_append_param netdev "$1"
        }
 }
 
@@ -24,22 +35,11 @@ resolve_network() {
 start_relay() {
        local cfg="$1"
 
-       local args=""
-       local ifaces=""
-
        config_get proto "$cfg" proto
-       [[ "$proto" == relay ]] || return 0
-
-       SERVICE_DAEMONIZE=1
-       SERVICE_WRITE_PID=1
-       SERVICE_PID_FILE="/var/run/relay-$cfg.pid"
-       [ -f "$SERVICE_PID_FILE" ] && {
-               if grep -q relayd "/proc/$(cat $SERVICE_PID_FILE)/cmdline"; then
-                       return 0
-               else
-                       rm -f "$SERVICE_PID_FILE"
-               fi
-       }
+       [ "$proto" = "relay" ] || return 0
+
+       config_get_bool disabled "$cfg" disabled 0
+       [ "$disabled" -gt 0 ] && return 0
 
        procd_open_instance
        procd_set_param command "$PROG"
@@ -68,7 +68,7 @@ start_relay() {
 
        local expiry # = 30
        config_get expiry "$cfg" expiry
-       [ -n "$expiry" ] && procd_append_param command "$expiry"
+       [ -n "$expiry" ] && procd_append_param command -t "$expiry"
 
        local retry # = 5
        config_get retry "$cfg" retry
@@ -92,6 +92,7 @@ start_relay() {
 service_triggers()
 {
        procd_add_reload_trigger "network"
+       procd_add_raw_trigger "interface.*" 2000 /etc/init.d/relayd reload
 }
 
 start_service() {