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
|