exit 0
fi
+checkconfig() {
+ /usr/sbin/sshd -t || exit 1
+}
+
RETVAL=0
# See how we were called.
case "$1" in
[ -x /sbin/restorecon ] && /sbin/restorecon /etc/ssh/ssh_host_dsa_key || :
fi
+ checkconfig
+
if [ ! -f /etc/ssh/ssh_host_key ]; then
msg_not_running OpenSSH
nls "No SSH host key found! You must run \"%s init\" first." "$0"
stop)
if [ -f /var/lock/subsys/sshd ]; then
msg_stopping OpenSSH
- killproc sshd
- rm -f /var/run/sshd.pid /var/lock/subsys/sshd >/dev/null 2>&1
+ # we use start-stop-daemon to stop sshd, as it is unacceptable for such
+ # critical service as sshd to kill it by procname, but unfortunately
+ # rc-scripts does not provide way to kill *only* by pidfile
+ start-stop-daemon --stop --quiet --pidfile /var/run/sshd.pid && ok || fail
+ rm -f /var/lock/subsys/sshd >/dev/null 2>&1
else
msg_not_running OpenSSH
fi
;;
restart)
+ checkconfig
$0 stop
$0 start
exit $?