#!/bin/sh

### BEGIN INIT INFO
# Provides: i2p i2p-router
# Required-Start: $remote_fs $syslog $named $network $time
# Required-Stop: $remote_fs $syslog $named $network
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: start and stop the i2p router
# Description: i2p is a load-balanced unspoofable packet switching network
### END INIT INFO

# Check permissions
if [ "`id -ur`" != '0' ]; then
   echo 'ERROR: You must be root to start this service.' >&2
   echo
   exit 1
fi

PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="I2P Router"
NAME="i2p"
RUN="/var/run/$NAME"
DAEMON="/usr/sbin/wrapper"
PIDFILE="$RUN/$NAME.pid"
JVMPIDFILE="$RUN/routerjvm.pid"
I2P="/usr/share/i2p"
I2PTEMP="/tmp/${NAME}-daemon"
WRAPPERLOG="/var/log/i2p/wrapper.log"

# Don't touch these, edit /etc/default/i2p
RUN_DAEMON="False"
NICE=0
I2PUSER="i2psvc"

I2P_ARGS="/etc/i2p/wrapper.config \
 wrapper.java.additional.1=-DloggerFilenameOverride=/var/log/i2p/log-router-@.txt \
 wrapper.java.additional.10=-Dwrapper.logfile=$WRAPPERLOG \
 wrapper.java.additional.11=-Di2p.dir.pid=$RUN \
 wrapper.java.additional.12=-Di2p.dir.temp=$I2PTEMP \
 wrapper.logfile=$WRAPPERLOG \
 wrapper.pidfile=$PIDFILE \
 wrapper.java.pidfile=$JVMPIDFILE \
 wrapper.daemonize=TRUE"

. /lib/lsb/init-functions
. /lib/init/vars.sh


for ENV_FILE in /etc/environment /etc/default/locale; do
    [ -r "$ENV_FILE" ] || continue
    [ -s "$ENV_FILE" ] || continue

    for var in LANG LANGUAGE LC_ALL LC_CTYPE; do
        value=`egrep "^${var}=" "$ENV_FILE" | tail -n1 | cut -d= -f2`
        [ -n "$value" ] && eval export $var=$value

    done
done

# read config file
[ -r /etc/default/$NAME ] && . /etc/default/$NAME

if [ -z "$RUN_DAEMON" ]; then
    echo "/etc/default/$NAME is not properly configured. Aborting." >&2
    exit 1
fi

case "$CONFINE_WITH_APPARMOR" in
    [NnFf]*)
        USE_AA="no"
        ;;
    *)
        USE_AA="yes"
        ;;
esac

case "$RUN_DAEMON" in
    [NnFf]*)
        log_action_msg "$DESC daemon disabled in /etc/default/$NAME".
        exit 0
        ;;
esac

# We need the wrapper. If it's not found, abort.
[ -x $DAEMON ] || exit 1

# Even though this script doesn't call it, check for i2prouter.  If it's not
# found, it probably means that the package isn't installed anymore.
[ -x /usr/bin/i2prouter ] || exit 1

do_start()
{
    [ ! -z $ULIMIT ] && ulimit -n $ULIMIT
    start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null 2>&1 \
        || return 1
    [ -d $RUN ] || mkdir $RUN > /dev/null 2>&1
    [ -d $I2PTEMP ] || mkdir $I2PTEMP > /dev/null 2>&1
    if [ -r $PIDFILE ]; then
        PID="$(cat ${PIDFILE})"
        if ! kill -0 $PID > /dev/null 2>&1; then
                rm "$PIDFILE" "$JVMPIDFILE"
        else
                # we shouldn't get here, but...
                echo "ERROR: Another instance of $DESC is already running." >&2
                return 1
        fi
    fi
    chown -Rf $I2PUSER:$I2PUSER  $I2PTEMP $RUN > /dev/null 2>&1
    chown -f -R $I2PUSER:i2psvc /var/log/$NAME > /dev/null 2>&1
    if [ "$USE_AA" = "yes" ] && \
       [ -x /usr/sbin/aa-status ] && \
       [ -x /usr/sbin/aa-exec ] && \
       [ -e /etc/apparmor.d/system_i2p ] && \
       /usr/sbin/aa-status --enabled ; then
            AA="--startas /usr/sbin/aa-exec"
            AA_ARGS="--profile=system_i2p -- $DAEMON"
    else
            AA=""
            AA_ARGS=""
    fi

    TZ=UTC start-stop-daemon --start --quiet --chuid $I2PUSER --pidfile $PIDFILE $AA --exec $DAEMON --nicelevel $NICE -- \
        $AA_ARGS $I2P_ARGS || return 2

    # FIXME Temporary hack
    # Files from /usr/share/i2p should have been copied, if need be, well before the 15 seconds are up.
    if [ ! -f /var/lib/i2p/i2p-config/.perms ] && [ $I2PUSER = "i2psvc" ]; then
        sleep 15
        find /var/lib/i2p/ -type d -exec chmod 770 {} \;
        find /var/lib/i2p/ -type f -exec chmod 660 {} \;
        touch /var/lib/i2p/i2p-config/.perms
    fi
}

do_stop()
{
    start-stop-daemon --stop --quiet --retry=TERM/60/KILL/20 --pidfile $PIDFILE -u $I2PUSER
    RETVAL="$?"
    [ "$RETVAL" = 2 ] && return 2

    start-stop-daemon --stop --quiet --oknodo --retry=0/60/KILL/20 --exec $DAEMON

    rm -rf "$I2PTEMP" > /dev/null 2>&1
    [ -d "$RUN" ] && rm -f "$RUN/*" > /dev/null 2>&1
    [ -d "$RUN" ] && rmdir "$RUN" > /dev/null 2>&1
}

do_dump()
{
    start-stop-daemon --stop --quiet -s 3 --pidfile $PIDFILE -u $I2PUSER
    RETVAL="$?"
    [ "$RETVAL" = 2 ] && return 2
}

do_graceful()
{
    start-stop-daemon --stop --quiet -s HUP --pidfile $PIDFILE -u $I2PUSER
    [ "$RETVAL" = 2 ] && return 2
}

case "$1" in
  start)
        log_daemon_msg "Starting $DESC" "$NAME"
        do_start
        case "$?" in
                0|1) log_end_msg 0 ;;
                2) log_end_msg 1 ;;
        esac
        ;;
  dump)
        log_daemon_msg "Dumping $DESC" "$NAME"
        do_dump
        case "$?" in
                0|1) log_end_msg 0 ;;
                2) log_end_msg 1 ;;
        esac
        ;;
  graceful)
        log_daemon_msg "Attempting graceful shutdown of $DESC" "$NAME"
        log_daemon_msg "(could take up to 11 minutes)"
        do_graceful
        case "$?" in
                0|1) log_end_msg 0 ;;
                2) log_end_msg 1 ;;
        esac
        ;;
  stop)
    log_daemon_msg "Stopping $DESC" "$NAME"
        do_stop
        case "$?" in
                0|1) log_end_msg 0 ;;
                2) log_end_msg 1 ;;
        esac
        ;;
  status)
       status_of_proc -p $PIDFILE "$DAEMON" "$NAME" && exit 0 || exit $?
    ;;
 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
        ;;
*)
    N=/etc/init.d/$NAME
    echo "Usage: $N {start|stop|dump|graceful|status|restart|force-reload}" >&2
    exit 3
    ;;


esac
