[Pkg-privacy-commits] [onioncat] 257/340: Mostly rewrite the initscript.

Ximin Luo infinity0 at moszumanska.debian.org
Sat Aug 22 13:04:45 UTC 2015


This is an automated email from the git hooks/post-receive script.

infinity0 pushed a commit to branch debian
in repository onioncat.

commit a3ea521448bbc2aebd649649b71292cfdeeca7b5
Author: intrigeri <intrigeri at boum.org>
Date:   Thu Aug 18 00:57:00 2011 +0200

    Mostly rewrite the initscript.
---
 debian/init.d | 329 ++++++++++++++++------------------------------------------
 1 file changed, 88 insertions(+), 241 deletions(-)

diff --git a/debian/init.d b/debian/init.d
index 93a69e0..1e81036 100644
--- a/debian/init.d
+++ b/debian/init.d
@@ -1,4 +1,5 @@
 #!/bin/bash
+
 ### BEGIN INIT INFO
 # Provides:          onioncat
 # Required-Start:    $network $local_fs $remote_fs tor
@@ -7,273 +8,119 @@
 # Should-Stop:
 # Default-Start:     2 3 4 5
 # Default-Stop:      0 1 6
-# Short-Description: <OnionCat An IP-Transparent Tor Hidden Service Connector>
-# Description:  OnionCat creates a transparent IP layer on top of Tor's Hidden Service
-#                    
-#                   
+# Short-Description: IP-Transparent Tor hidden service connector
+# Description:       OnionCat creates a transparent IP layer on top of Tor hidden
+#                    services.
 ### END INIT INFO
 
-PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
+# Do NOT "set -e"
 
+PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
 DAEMON=/usr/bin/ocat
 NAME=ocat
 NAMEL=onioncat
-DESC="OnionCat Hidden Service Connector"
-LOGDIR=/var/log/tor
-
+DESC="OnionCat Tor hidden service connector"
+SCRIPTNAME=/etc/init.d/$NAMEL
 PIDFILE=/var/run/$NAME.pid
 
 test -x $DAEMON || exit 0
 
 . /lib/lsb/init-functions
 
-# Default options, these can be overriden by the information
-# at /etc/default/$NAME
-DAEMON_OPTS=""          # Additional options given to the server
-
-DIETIME=10              # Time to wait for the server to die, in seconds
-                        # If this value is set too low you might not
-                        # let some servers to die gracefully and
-                        # 'restart' will not work
-
-STARTTIME=1             # Time to wait for the server to start, in seconds
-                        # If this value is set each time the server is
-                        # started (on start or restart) the script will
-                        # stall to try to determine if it is running
-                        # If it is not set and the server takes time
-                        # to setup a pid file the log message might
-                        # be a false positive (says it did not start
-                        # when it actually did)
-
-LOGFILE=$LOGDIR/$NAMEL.log
-DAEMON_USER="debian-tor" # Users to run the daemons as. If this value
-                        # is set start-stop-daemon will chuid the server
-
-# Defaults - don't touch, edit /etc/default/onioncat
+# Default options - overriden by /etc/default/onioncat
+DAEMON_OPTS=""
+DIETIME=10
+STARTTIME=1
+DAEMON_USER="debian-tor"
 ENABLED=0
 
-
-
-# Include defaults if available
 if [ -f /etc/default/$NAMEL ] ; then
-    . /etc/default/$NAMEL
-fi
-
-
-
-
-if [ "$ENABLED" = "0" ]; then
-    echo "$DESC: disabled, see /etc/default/onioncat"
-    exit 0
+   . /etc/default/$NAMEL
 fi
 
-
-
-# Check that the user exists (if we set a user)
-# Does the user exist?
-if [ -n "$DAEMON_USER" ] ; then
-    if getent passwd | grep -q "^$DAEMON_USER:"; then
-        # Obtain the uid and gid
-        DAEMONUID=`getent passwd |grep "^$DAEMON_USER:" | awk -F : '{print $3}'`
-        DAEMONGID=`getent passwd |grep "^$DAEMON_USER:" | awk -F : '{print $4}'`
+is_true() {
+    if [ "x$1" = "xtrue" -o "x$1" = "xyes" -o "x$1" = "x0" ] ; then
+        return 0
     else
-        log_failure_msg "The user $DAEMON_USER, required to run $NAME does not exist."
-        exit 1
+        return 1
     fi
-fi
-
-
-set -e
-
-running_pid() {
-# Check if a given process pid's cmdline matches a given name
-    pid=$1
-    name=$2
-    [ -z "$pid" ] && return 1
-    [ ! -d /proc/$pid ] &&  return 1
-    cmd=`cat /proc/$pid/cmdline | tr "\000" "\n"|head -n 1 |cut -d : -f 1`
-    # Is this the expected server
-    [ "$cmd" != "$name" ] &&  return 1
-    return 0
-}
-
-running() {
-# Check if the process is running looking at /proc
-# (works for all users)
-
-    # No pidfile, probably no daemon present
-    [ ! -f "$PIDFILE" ] && return 1
-    pid=`cat $PIDFILE`
-    running_pid $pid $DAEMON || return 1
-    return 0
-}
-
-start_server() {
-# Start the process using the wrapper
-        if [ -z "$DAEMON_USER" ] ; then
-            start_daemon -p $PIDFILE $DAEMON $DAEMON_OPTS
-            errcode=$?
-        else
-# if we are using a daemonuser then change the user id
-            start-stop-daemon --start --quiet --pidfile $PIDFILE \
-                        --exec $DAEMON -- -u $DAEMON_USER -P $PIDFILE $DAEMON_OPTS
-            errcode=$?
-        fi
-        return $errcode
-}
-
-stop_server() {
-# Stop the process using the wrapper
-        if [ -z "$DAEMON_USER" ] ; then
-            killproc -p $PIDFILE $DAEMON
-            errcode=$?
-        else
-# if we are using a daemonuser then look for process that match
-            start-stop-daemon --stop --quiet --pidfile $PIDFILE \
-                        --exec $DAEMON
-            errcode=$?
-        fi
-
-        return $errcode
 }
 
-reload_server() {
-    [ ! -f "$PIDFILE" ] && return 1
-    pid=pidofproc $PIDFILE # This is the daemon's pid
-    # Send a SIGHUP
-    kill -1 $pid
-    return $?
+do_start() {
+   if is_true "$ENABLED"; then
+      start-stop-daemon --start --quiet --pidfile $PIDFILE \
+         --exec $DAEMON -- -u $DAEMON_USER -P $PIDFILE $DAEMON_OPTS \
+	 || return 2
+   else
+      log_warning_msg " $NAMEL disabled, edit /etc/default/$NAMEL to enable."
+      exit 0
+   fi
 }
 
-force_stop() {
-# Force the process to die killing it manually
-    [ ! -e "$PIDFILE" ] && return
-    if running ; then
-        kill -15 $pid
-        # Is it really dead?
-        sleep "$DIETIME"s
-        if running ; then
-            kill -9 $pid
-            sleep "$DIETIME"s
-            if running ; then
-                echo "Cannot kill $NAME (pid=$pid)!"
-                exit 1
-            fi
-        fi
-    fi
-    rm -f $PIDFILE
+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
+   start-stop-daemon --stop --quiet --retry=INT/30/KILL/5 \
+      --user $RUN_AS --pidfile $PIDFILE --name $NAME
+   RETVAL="$?"
+   [ "$RETVAL" = 2 ] && return 2
+   return "$RETVAL"
 }
 
-
 case "$1" in
-  start)
-        log_daemon_msg "Starting $DESC " "$NAME"
-        # Check if it's running first
-        if running ;  then
-            log_progress_msg "apparently already running"
-            log_end_msg 0
-            exit 0
-        fi
-        if start_server ; then
-            # NOTE: Some servers might die some time after they start,
-            # this code will detect this issue if STARTTIME is set
-            # to a reasonable value
-            [ -n "$STARTTIME" ] && sleep $STARTTIME # Wait some time 
-            if  running ;  then
-                # It's ok, the server started and is running
-                log_end_msg 0
-            else
-                # It is not running after we did start
-                log_end_msg 1
-            fi
-        else
-            # Either we could not start it
-            log_end_msg 1
-        fi
-        ;;
-  stop)
-        log_daemon_msg "Stopping $DESC" "$NAME"
-        if running ; then
-            # Only stop the server if we see it running
-            errcode=0
-            stop_server || errcode=$?
-            log_end_msg $errcode
-        else
-            # If it's not running don't do anything
-            log_progress_msg "apparently not running"
-            log_end_msg 0
-            exit 0
-        fi
-        ;;
-  force-stop)
-        # First try to stop gracefully the program
-        $0 stop
-        if running; then
-            # If it's still running try to kill it more forcefully
-            log_daemon_msg "Stopping (force) $DESC" "$NAME"
-            errcode=0
-            force_stop || errcode=$?
-            log_end_msg $errcode
-        fi
-        ;;
-  restart|force-reload)
-        log_daemon_msg "Restarting $DESC" "$NAME"
-        errcode=0
-        stop_server || errcode=$?
-        # Wait some sensible amount, some server need this
-        [ -n "$DIETIME" ] && sleep $DIETIME
-        start_server || errcode=$?
-        [ -n "$STARTTIME" ] && sleep $STARTTIME
-        running || errcode=$?
-        log_end_msg $errcode
-        ;;
-  status)
-
-        log_daemon_msg "Checking status of $DESC" "$NAME"
-        if running ;  then
-            log_progress_msg "running"
-            log_end_msg 0
-        else
-            log_progress_msg "apparently not running"
-            log_end_msg 1
-            exit 1
-        fi
-        ;;
-  # Use this if the daemon cannot reload
-  reload)
-        log_warning_msg "Reloading $NAME daemon: not implemented, as the daemon"
-        log_warning_msg "cannot re-read the config file (use restart)."
-        ;;
-  # And this if it cann
-  #reload)
-          #
-          # If the daemon can reload its config files on the fly
-          # for example by sending it SIGHUP, do it here.
-          #
-          # If the daemon responds to changes in its config file
-          # directly anyway, make this a do-nothing entry.
-          #
-          # log_daemon_msg "Reloading $DESC configuration files" "$NAME"
-          # if running ; then
-          #    reload_server
-          #    if ! running ;  then
-          # Process died after we tried to reload
-          #       log_progress_msg "died on reload"
-          #       log_end_msg 1
-          #       exit 1
-          #    fi
-          # else
-          #    log_progress_msg "server is not running"
-          #    log_end_msg 1
-          #    exit 1
-          # fi
-                                                                                    #;;
-
-  *)
-        N=/etc/init.d/$NAME
-        echo "Usage: $N {start|stop|force-stop|restart|force-reload|status}" >&2
-        exit 1
-        ;;
+   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
+      ;;
+
+   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
+      ;;
+
+   status)
+      if is_true "$ENABLED" ; then
+         status_of_proc -p "${PIDFILE}" "${DAEMON}" "${NAME}"
+      else
+	 echo ""
+	 echo "$NAMEL not configured to start"
+      fi
+      ;;
+
+   *)
+      echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload|status}" >&2
+      exit 3
+      ;;
 esac
 
 exit 0

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-privacy/packages/onioncat.git



More information about the Pkg-privacy-commits mailing list