package/radvd: improve startup script
authorCarlos Santos <unixmania@gmail.com>
Thu, 2 May 2019 02:01:52 +0000 (23:01 -0300)
committerPeter Korsgaard <peter@korsgaard.com>
Sun, 5 May 2019 19:14:48 +0000 (21:14 +0200)
- Add start, stop and restart/reload options, following the logic used
  in other init scripts (e.g. S01syslogd).

- Do nothing if /etc/radvd.conf does not exist instead of printing an
  error message. It is valid to install radvd without a configuration
  file. The daemon may be started later by another service with a
  configuration created at run-time.

- Print an error message if the kernel does not support IPv6 forwarding,
  which is required by radvd.

Signed-off-by: Carlos Santos <unixmania@gmail.com>
Signed-off-by: Peter Korsgaard <peter@korsgaard.com>
package/radvd/S50radvd

index 9f1407c95a9ca24e38110a0462a5e18d0924e68f..f73ce24ed597efc72edd91e73a8f011894f8b715 100644 (file)
@@ -1,18 +1,59 @@
 #!/bin/sh
 
-RADVD=/usr/sbin/radvd
+DAEMON="radvd"
+PIDFILE="/var/run/$DAEMON.pid"
 
-echo "1" > /proc/sys/net/ipv6/conf/all/forwarding
+RADVD_ARGS="-m syslog"
 
-printf "Starting radvd: "
-if [ ! -x "${RADVD}" ]; then
-       echo "missing"
-       exit 1
-fi
+# shellcheck source=/dev/null
+[ -r "/etc/default/$DAEMON" ] && . "/etc/default/$DAEMON"
+
+[ -f /etc/radvd.conf ] || exit 0
 
-if ${RADVD} ; then
-       echo "done"
-else
-       echo "failed"
+[ -f /proc/sys/net/ipv6/conf/all/forwarding ] || {
+       echo "Error: radvd requires IPv6 forwarding support."
        exit 1
-fi
+}
+
+start() {
+       printf 'Starting %s: ' "$DAEMON"
+       echo "1" > /proc/sys/net/ipv6/conf/all/forwarding
+       # shellcheck disable=SC2086 # we need the word splitting
+       start-stop-daemon -S -q -p "$PIDFILE" -x "/usr/sbin/$DAEMON" \
+               -- $RADVD_ARGS
+       status=$?
+       if [ "$status" -eq 0 ]; then
+               echo "OK"
+       else
+               echo "FAIL"
+       fi
+       return "$status"
+}
+
+stop() {
+       printf 'Stopping %s: ' "$DAEMON"
+       start-stop-daemon -K -q -p "$PIDFILE" -x "/usr/sbin/$DAEMON"
+       status=$?
+       if [ "$status" -eq 0 ]; then
+               echo "OK"
+       else
+               echo "FAIL"
+       fi
+       return "$status"
+}
+
+restart() {
+       stop
+       sleep 1
+       start
+}
+
+case "$1" in
+       start|stop)
+               "$1";;
+       restart|reload)
+               restart;;
+       *)
+               echo "Usage: $0 {start|stop|restart|reload}"
+               exit 1
+esac