3,14 → 3,12 |
# lsh-utils Start/stop secure shell server. |
# Written by Timshel Knoll <timshel@debian.org> |
# Updated by Stefan Pfetzing <dreamind@dreamind.de> |
# Updated by Magnus Holmgren <magnus@debian.org> |
# |
|
### BEGIN INIT INFO |
# Provides: lsh-server |
# Provides: sshd |
# Required-Start: $local_fs $remote_fs $syslog $named $network |
# Required-Stop: $local_fs $remote_fs $syslog $named $network |
# X-Start-Before: cman drbd smokeping vz |
# X-Stop-After: cman drbd smokeping vz |
# Default-Start: 2 3 4 5 |
# Default-Stop: 0 1 6 |
# Short-Description: lsh secure shell server |
21,7 → 19,6 |
NAME=lshd |
DESC="secure shell v2 server" |
CONFIG=/etc/default/lsh-server |
PIDFILE=/var/run/$NAME.pid |
|
RANDOM_SEED="/var/spool/lsh/yarrow-seed-file" |
HOST_KEY="/etc/lsh_host_key" |
28,10 → 25,8 |
|
test -f $DAEMON || exit 0 |
|
. /lib/lsb/init-functions |
set -e |
|
set +e |
|
if [ -r "$CONFIG" ]; then |
. "$CONFIG" |
fi |
49,64 → 44,77 |
;; |
esac |
|
create_seed_and_key() { |
if [ "$1" != "stop" -a "$1" != "graceful-stop" ]; then |
if [ ! -f "$RANDOM_SEED" ]; then |
log_action_begin_msg "Creating lsh random seed file (this only needs to be done once)" |
echo -n "Creating lsh random seed file (this only needs to be done once): $RANDOM_SEED" |
DIR=$(dirname "$RANDOM_SEED") |
if install -d -m 700 "$DIR" && |
dd if=/dev/random "of=$RANDOM_SEED" bs=1 count=32 2>/dev/null && |
chmod 600 "$RANDOM_SEED"; then |
log_action_end_msg 0 |
else |
log_action_end_msg 1 |
exit 1 |
fi |
mkdir -p "$DIR" |
chmod 700 "$DIR" |
dd if=/dev/random "of=$RANDOM_SEED" bs=1 count=32 2>/dev/null |
chmod 600 "$RANDOM_SEED" |
echo "." |
fi |
|
if [ ! -f "$HOST_KEY" ]; then |
log_action_begin_msg "Creating lsh host key (this only needs to be done once)" |
lsh-keygen --server | lsh-writekey --server --output-file "$HOST_KEY" |
echo -n "Creating lsh host key (this only needs to be done once): $HOST_KEY" |
lsh-keygen --server | \ |
lsh-writekey --server --output-file "$HOST_KEY" |
|
if [ ! -f "$HOST_KEY" ]; then |
log_action_end_msg 1 |
exit 1 |
echo " failed! not starting lshd" |
exit 0 |
fi |
|
log_action_end_msg 0 |
echo "." |
fi |
} |
fi |
|
|
case "$1" in |
start) |
create_seed_and_key |
[ "$VERBOSE" = no ] || log_daemon_msg "Starting $DESC" "$NAME" |
start-stop-daemon --start --quiet --oknodo --pidfile $PIDFILE --exec $DAEMON \ |
-- --daemonic --port "$LSHD_PORT" $SFTP_FLAG |
[ "$VERBOSE" = no ] || log_end_msg $? |
echo -n "Starting $DESC: $NAME" |
start-stop-daemon --start --quiet --pidfile /var/run/$NAME.pid \ |
--background --make-pidfile --exec $DAEMON -- \ |
--port "$LSHD_PORT" $SFTP_FLAG |
echo "." |
;; |
stop|graceful-stop) |
[ "$VERBOSE" = no ] || log_daemon_msg "Gracefully stopping $DESC" "$NAME" |
echo -n "Gracefully stopping $DESC: $NAME" |
# Signal 1 causes the "old" lsh to close up shop on its port, but |
# keeps running until all active connections have been closed |
start-stop-daemon --stop --retry HUP/1 --quiet --pidfile $PIDFILE \ |
--oknodo --exec $DAEMON |
[ "$VERBOSE" = no ] || log_end_msg $? |
start-stop-daemon --stop --signal 1 --quiet --pidfile \ |
/var/run/$NAME.pid --oknodo --exec $DAEMON |
# Remove the old pid file, the server will exit when ready |
rm -f /var/run/$NAME.pid |
echo "." |
;; |
#reload) |
# Signal 1 causes the "old" lsh to close up shop on its port, but |
# keeps running until all active connections have been closed |
#echo -n "Reloading $DESC configuration files." |
#start-stop-daemon --stop --signal 1 --quiet --pidfile \ |
# /var/run/$NAME.pid --exec $DAEMON |
#;; |
restart|force-reload) |
create_seed_and_key |
[ "$VERBOSE" = no ] || log_daemon_msg "Restarting $DESC" "$NAME" |
start-stop-daemon --stop --retry HUP/1 --quiet --pidfile $PIDFILE \ |
--oknodo --exec $DAEMON && |
start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON \ |
-- --daemonic --port "$LSHD_PORT" $SFTP_FLAG |
[ "$VERBOSE" = no ] || log_end_msg $? |
# |
# If the "reload" option is implemented, move the "force-reload" |
# option to the "reload" entry above. If not, "force-reload" is |
# just the same as "restart". |
# |
echo -n "Restarting $DESC: $NAME" |
start-stop-daemon --stop --signal 1 --quiet --pidfile \ |
/var/run/$NAME.pid --oknodo --exec $DAEMON |
# Remove the old pid file, the old server will exit when ready |
rm -f /var/run/$NAME.pid |
sleep 1 |
start-stop-daemon --start --quiet --pidfile /var/run/$NAME.pid \ |
--background --make-pidfile --exec $DAEMON -- \ |
--port "$LSHD_PORT" $SFTP_FLAG |
echo "." |
;; |
status) |
status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $? |
;; |
*) |
echo "Usage: /etc/init.d/lsh-utils {start|stop|restart|force-reload}" >&2 |
exit 3 |
exit 1 |
;; |
esac |
|
exit 0 |