init script
authorChristian Weiske <cweiske@cweiske.de>
Fri, 16 Nov 2012 21:55:39 +0000 (22:55 +0100)
committerChristian Weiske <cweiske@cweiske.de>
Fri, 16 Nov 2012 21:55:39 +0000 (22:55 +0100)
init.d/usb-wde-log [new file with mode: 0755]

diff --git a/init.d/usb-wde-log b/init.d/usb-wde-log
new file mode 100755 (executable)
index 0000000..a8f1158
--- /dev/null
@@ -0,0 +1,114 @@
+#! /bin/sh
+### BEGIN INIT INFO
+# Provides:          usb-wde-log
+# Required-Start:    $remote_fs $syslog
+# Required-Stop:     $remote_fs $syslog
+# Default-Start:     2 3 4 5
+# Default-Stop:      0 1 6
+# Short-Description: Logs temperature data
+### END INIT INFO
+
+# Author: Christian Weiske <cweiske@cweiske.de>
+
+# PATH should only include /usr/* if it runs after the mountnfs.sh script
+PATH=/sbin:/usr/sbin:/bin:/usr/bin
+DESC="Logs temperature data"
+NAME=usb-wde-log
+DAEMON=/bin/sh
+DAEMON_ARGS="/usr/local/src/usb-wde1-tools/munin/usb-wde1-log-last.sh"
+PIDFILE=/var/run/$NAME.pid
+SCRIPTNAME=/etc/init.d/$NAME
+
+# Exit if the package is not installed
+[ -x "$DAEMON" ] || exit 0
+
+. /lib/init/vars.sh
+. /lib/lsb/init-functions
+
+do_start()
+{
+       # Return
+       #   0 if daemon has been started
+       #   1 if daemon was already running
+       #   2 if daemon could not be started
+       start-stop-daemon --start --background --make-pidfile --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \
+               || return 1
+       start-stop-daemon --start --background --make-pidfile --quiet --pidfile $PIDFILE --exec $DAEMON -- \
+               $DAEMON_ARGS \
+               || return 2
+}
+
+do_stop()
+{
+       # Return
+       #   0 if daemon has been stopped
+       #   1 if daemon was already stopped
+       #   2 if daemon could not be stopped
+       #   other if a failure occurred
+       [ ! -f "$PIDFILE" ] && echo "$PIDFILE not found" && return 1
+       #kill all children (socat, line logger)
+       ppid=`cat "$PIDFILE"`
+       for i in `ps -ef| awk '$3 == '${ppid}' { print $2 }'`
+       do
+               kill $i
+       done
+       start-stop-daemon --stop --quiet --retry=TERM/10/KILL/5 --pidfile $PIDFILE
+       RETVAL="$?"
+       [ "$RETVAL" = 2 ] && return 2
+       [ "$RETVAL" = 0 ] && rm -f $PIDFILE
+       return "$RETVAL"
+}
+
+do_reload() {
+       start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME
+       return 0
+}
+
+case "$1" in
+  start)
+       [ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
+       do_start
+       case "$?" in
+               0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
+               2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
+       esac
+       ;;
+  stop)
+       [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
+       do_stop
+       case "$?" in
+               0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
+               2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
+       esac
+       ;;
+  status)
+       pid=`pgrep -f "$DAEMON $DAEMON_ARGS"`
+        [ "$pid" -gt 0 ] && echo "$NAME is running" && exit 0
+        echo "$NAME is NOT running"
+       ;;
+  restart|force-reload)
+       log_daemon_msg "Restarting $DESC" "$NAME"
+       do_stop
+       case "$?" in
+         0|1)
+               do_start
+               case "$?" in
+                       0) log_end_msg 0 ;;
+                       1) log_end_msg 1 ;; # Old process is still running
+                       *) log_end_msg 1 ;; # Failed to start
+               esac
+               ;;
+         *)
+               # Failed to stop
+               log_end_msg 1
+               ;;
+       esac
+       ;;
+  *)
+       #echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
+       echo "Usage: $SCRIPTNAME {start|stop|status|restart|force-reload}" >&2
+       exit 3
+       ;;
+esac
+
+: