summaryrefslogtreecommitdiff
path: root/pcr/dropbear/dropbear-rc.d
blob: 011880b3bf82dfca5b7fe19e2b88d4b3b5ab0d17 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#!/bin/bash
daemon_name=dropbear

. /etc/rc.conf
. /etc/rc.d/functions

. /etc/conf.d/$daemon_name

for port in $DROPBEAR_PORT; do
  daemon_args="$daemon_args -p $port"
done

[ ! -z $DROPBEAR_BANNER ] && daemon_args="$daemon_args -b $DROPBEAR_BANNER"
[ ! -z $DROPBEAR_DSSKEY ] && daemon_args="$daemon_args -d $DROPBEAR_DSSKEY"
[ ! -z $DROPBEAR_RSAKEY ] && daemon_args="$daemon_args -r $DROPBEAR_RSAKEY"
[ ! -z $DROPBEAR_EXTRA_ARGS ] && daemon_args="$daemon_args $DROPBEAR_EXTRA_ARGS"
[ -z $DROPBEAR_PIDFILE ] && DROPBEAR_PIDFILE="/var/run/$daemon_name.pid"
daemon_args="$daemon_args -P $DROPBEAR_PIDFILE"

get_pid() {
  PID=''
  if [ -r $DROPBEAR_PIDFILE -a -f $DROPBEAR_PIDFILE -a -w $DROPBEAR_PIDFILE ]; then
    if kill -0 "`< $DROPBEAR_PIDFILE`" &>/dev/null; then # kill -0 == "exit code indicates if a signal may be sent"
      PID="`< $DROPBEAR_PIDFILE`"
    else # may not send signals to dropbear, because it's probably not running => remove pidfile
      rm -f $DROPBEAR_PIDFILE
    fi
  fi
}

case "$1" in
  start)
    stat_busy "Starting $daemon_name"
    get_pid
    if [ -z "$PID" ]; then
      printhl "Checking for hostkeys"
      if [ ! -z $DROPBEAR_DSSKEY ]; then
        [ ! -f $DROPBEAR_DSSKEY ] && dropbearkey -t dss -f $DROPBEAR_DSSKEY
      fi;
      if [ ! -z $DROPBEAR_RSAKEY ]; then
        [ ! -f $DROPBEAR_RSAKEY ] && dropbearkey -t rsa -f $DROPBEAR_RSAKEY
      fi;

      $daemon_name $daemon_args # Make it Go Joe!
      if [ $? -gt 0 ]; then
        stat_die
      else
        add_daemon $daemon_name
        stat_done
      fi
    else
      stat_die
    fi
    ;;

  stop)
    stat_busy "Stopping $daemon_name"

    get_pid
    [ ! -z "$PID" ] && kill $PID &> /dev/null # Be dead (please), I say!
    if [ $? -gt 0 ]; then
      stat_die
    else
      rm_daemon $daemon_name
      stat_done
    fi
    ;;

  restart)
    $0 stop
    sleep 3
    $0 start
    ;;

  fingerprint)
    stat_busy "Fingerprinting $daemon_name hostkeys"
    if [ ! -z $DROPBEAR_DSSKEY ]; then
      printhl "DSS/DSA Key $(dropbearkey -y -f $DROPBEAR_DSSKEY | grep Fingerprint)"
    fi;
    if [ ! -z $DROPBEAR_RSAKEY ]; then
      printhl "RSA Key $(dropbearkey -y -f $DROPBEAR_RSAKEY | grep Fingerprint)"
    fi;
  ;;

  *)
    echo "usage: $0 {start|stop|restart|fingerprint}"
esac
exit 0