blob: 3908566b793beedfaa93a65e4ca210ae17cd9564 [file] [log] [blame]
Darren Tuckerfbea7642006-01-30 00:22:39 +11001#!@STARTUP_SCRIPT_SHELL@
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +00002# Donated code that was put under PD license.
3#
4# Stripped PRNGd out of it for the time being.
5
Tim Rice748fcf92002-11-13 15:50:04 -08006umask 022
7
Tim Rice5af9db92004-06-19 19:31:06 -07008CAT=@CAT@
9KILL=@KILL@
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000010
Tim Rice5af9db92004-06-19 19:31:06 -070011prefix=@prefix@
12sysconfdir=@sysconfdir@
13piddir=@piddir@
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000014
Ben Lindstrom7a973392001-10-12 21:52:39 +000015SSHD=$prefix/sbin/sshd
Ben Lindstromf2366b52001-10-19 20:36:23 +000016PIDFILE=$piddir/sshd.pid
Tim Rice53e99742009-11-20 19:32:15 -080017PidFile=`grep "^PidFile" ${sysconfdir}/sshd_config | tr "=" " " | awk '{print $2}'`
18[ X$PidFile = X ] || PIDFILE=$PidFile
Ben Lindstrom7a973392001-10-12 21:52:39 +000019SSH_KEYGEN=$prefix/bin/ssh-keygen
Tim Rice5af9db92004-06-19 19:31:06 -070020HOST_KEY_RSA1=$sysconfdir/ssh_host_key
21HOST_KEY_DSA=$sysconfdir/ssh_host_dsa_key
22HOST_KEY_RSA=$sysconfdir/ssh_host_rsa_key
Tim Rice9b87a5c2011-01-12 22:35:43 -080023@COMMENT_OUT_ECC@HOST_KEY_ECDSA=$sysconfdir/ssh_host_ecdsa_key
Tim Rice9c366982014-03-14 12:45:01 -070024HOST_KEY_ED25519=$sysconfdir/ssh_host_ed25519_key
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000025
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000026
27checkkeys() {
Tim Ricecf3e0be2016-08-01 14:31:52 -070028@COMMENT_OUT_RSA1@ if [ ! -f $HOST_KEY_RSA1 ]; then
29@COMMENT_OUT_RSA1@ ${SSH_KEYGEN} -t rsa1 -f ${HOST_KEY_RSA1} -N ""
30@COMMENT_OUT_RSA1@ fi
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000031 if [ ! -f $HOST_KEY_DSA ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110032 ${SSH_KEYGEN} -t dsa -f ${HOST_KEY_DSA} -N ""
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000033 fi
34 if [ ! -f $HOST_KEY_RSA ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110035 ${SSH_KEYGEN} -t rsa -f ${HOST_KEY_RSA} -N ""
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000036 fi
Tim Rice9b87a5c2011-01-12 22:35:43 -080037@COMMENT_OUT_ECC@ if [ ! -f $HOST_KEY_ECDSA ]; then
38@COMMENT_OUT_ECC@ ${SSH_KEYGEN} -t ecdsa -f ${HOST_KEY_ECDSA} -N ""
39@COMMENT_OUT_ECC@ fi
Tim Rice9c366982014-03-14 12:45:01 -070040 if [ ! -f $HOST_KEY_ED25519 ]; then
41 ${SSH_KEYGEN} -t ed25519 -f ${HOST_KEY_ED25519} -N ""
42 fi
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000043}
44
45stop_service() {
46 if [ -r $PIDFILE -a ! -z ${PIDFILE} ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110047 PID=`${CAT} ${PIDFILE}`
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000048 fi
49 if [ ${PID:=0} -gt 1 -a ! "X$PID" = "X " ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110050 ${KILL} ${PID}
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000051 else
Damien Millera8e06ce2003-11-21 23:48:55 +110052 echo "Unable to read PID file"
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000053 fi
54}
55
56start_service() {
57 # XXX We really should check if the service is already going, but
58 # XXX we will opt out at this time. - Bal
59
60 # Check to see if we have keys that need to be made
61 checkkeys
62
63 # Start SSHD
64 echo "starting $SSHD... \c" ; $SSHD
65
66 sshd_rc=$?
67 if [ $sshd_rc -ne 0 ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110068 echo "$0: Error ${sshd_rc} starting ${SSHD}... bailing."
69 exit $sshd_rc
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000070 fi
71 echo done.
72}
73
74case $1 in
75
76'start')
77 start_service
78 ;;
79
80'stop')
81 stop_service
82 ;;
83
84'restart')
85 stop_service
86 start_service
87 ;;
88
89*)
90 echo "$0: usage: $0 {start|stop|restart}"
91 ;;
92esac