#!/bin/sh
# Init script for {{ name }}
# Maintained by {{ author }}
# Generated by pleaserun.
# Implemented based on LSB Core 3.1:
#   * Sections: 20.2, 20.3
#
### BEGIN INIT INFO
# Provides:          {{ name }}
# Required-Start:    $remote_fs $syslog
# Required-Stop:     $remote_fs $syslog
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
{# # Short-Description: {{ one_line_description }} #}
# Description:       {{ description }}
### END INIT INFO

PATH=/sbin:/usr/sbin:/bin:/usr/bin
export PATH

name={{ name }}
program={{ cmd }}
args="{{ args }}"
pidfile="/var/run/$name.pid"

[ -r /etc/default/$name.defaults ] && . /etc/default/$name.defaults
[ -r /etc/sysconfig/$name.defaults ] && . /etc/sysconfig/$name.defaults

trace() {
  logger -t "/etc/init.d/{{name}}" "$@"
}

emit() {
  trace "$@"
  echo "$@"
}

start() {
  {# {{! I don't use 'su' here to run as a different user because the process 'su'
      stays as the parent, causing our pidfile to contain the pid of 'su' not the
      program we intended to run. Luckily, the 'chroot' program on OSX, FreeBSD, and Linux
      all support switching users and it invokes execve immediately after chrooting. }}
  {{#sysv_log_directory?}}
  # Ensure the log directory is setup correctly.
  [ ! -d "{{{sysv_log_path}}}" ] && mkdir "{{{sysv_log_path}}}"
  chown "$user":"$group" "{{{sysv_log_path}}}"
  chmod 755 "{{{sysv_log_path}}}"
  {{/sysv_log_directory?}}
  {{#prestart}}
  if [ "$PRESTART" != "no" ] ; then
    # If prestart fails, abort start.
    prestart || return $?
  fi
  {{/prestart}} #}
  # Setup any environmental stuff beforehand
  {% if ulimits %}ulimit {{ ulimits }}{% endif %}
  # Run the program!{% if nice %}
  nice -n "$nice" \{% endif %}
  chroot --userspec "$user":"$group" "$chroot" sh -c "
    {% if ulimits %}ulimit {{ ulimits }}{% endif %}
    cd \"$chdir\"
    exec \"$program\" $args" &
  # TODO: dunno if we want this.
  {# " >> {{{ sysv_log_path }}}.stdout 2>> {{{ sysv_log }}}.stderr #}
  # Generate the pidfile from here. If we instead made the forked process
  # generate it there will be a race condition between the pidfile writing
  # and a process possibly asking for status.
  echo $! > $pidfile
  emit "$name started"
  return 0
}
stop() {
  # Try a few times to kill TERM the program
  if status ; then
    pid=$(cat "$pidfile")
    trace "Killing $name [pid $pid] with SIGTERM"
    kill -TERM $pid
    # Wait for it to exit.
    for i in 1 2 3 4 5 ; do
      trace "Waiting $name [pid $pid] to die..."
      status || break
      sleep 1
    done
    if status ; then
      if [ "$KILL_ON_STOP_TIMEOUT" -eq 1 ] ; then
        trace "Timeout reached. Killing $name [pid $pid] with SIGKILL.  This may result in data loss."
        kill -KILL $pid
        emit "$name killed with SIGKILL."
      else
        emit "$name stop failed; still running."
      fi
    else
      emit "$name stopped."
    fi
  fi
}
status() {
  if [ -f "$pidfile" ] ; then
    pid=$(cat "$pidfile")
    if ps -p $pid > /dev/null 2> /dev/null ; then
      # process by this pid is running.
      # It may not be our pid, but that's what you get with just pidfiles.
      # TODO: Check if this process seems to be the same as the one we
      # expect. It'd be nice to use flock here, but flock uses fork, not exec,
      # so it makes it quite awkward to use in this case.
      return 0
    else
      return 2 # program is dead but pid file exists
    fi
  else
    return 3 # program is not running
  fi
}

force_stop() {
  if status ; then
    stop
    status && kill -KILL $(cat "$pidfile")
  fi
}

case "$1" in
  force-start|start|stop|force-stop|restart)
    trace "Attempting '$1' on {{ name }}"
    ;;
esac

case "$1" in
  force-start)
    PRESTART=no
    exec "$0" start
    ;;
  start)
    status
    code=$?
    if [ $code -eq 0 ]; then
      emit "$name is already running"
      exit $code
    else
      start
      exit $?
    fi
    ;;
  stop) stop ;;
  force-stop) force_stop ;;
  status)
    status
    code=$?
    if [ $code -eq 0 ] ; then
      emit "$name is running"
    else
      emit "$name is not running"
    fi
    exit $code
    ;;
  restart)
{#     {{#prestart}}if [ "$PRESTART" != "no" ] ; then
      prestart || exit $?
    fi{{/prestart}} #}
    stop && start
    ;;
  *)
    echo "Usage: $SCRIPTNAME {start|force-start|stop|force-start|force-stop|status|restart}" >&2
    exit 3
  ;;
esac

exit $?