blob: 0db60caa75119ca287261eca9f696b792a150a15 [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
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000024
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000025
26checkkeys() {
27 if [ ! -f $HOST_KEY_RSA1 ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110028 ${SSH_KEYGEN} -t rsa1 -f ${HOST_KEY_RSA1} -N ""
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000029 fi
30 if [ ! -f $HOST_KEY_DSA ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110031 ${SSH_KEYGEN} -t dsa -f ${HOST_KEY_DSA} -N ""
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000032 fi
33 if [ ! -f $HOST_KEY_RSA ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110034 ${SSH_KEYGEN} -t rsa -f ${HOST_KEY_RSA} -N ""
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000035 fi
Tim Rice9b87a5c2011-01-12 22:35:43 -080036@COMMENT_OUT_ECC@ if [ ! -f $HOST_KEY_ECDSA ]; then
37@COMMENT_OUT_ECC@ ${SSH_KEYGEN} -t ecdsa -f ${HOST_KEY_ECDSA} -N ""
38@COMMENT_OUT_ECC@ fi
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000039}
40
41stop_service() {
42 if [ -r $PIDFILE -a ! -z ${PIDFILE} ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110043 PID=`${CAT} ${PIDFILE}`
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000044 fi
45 if [ ${PID:=0} -gt 1 -a ! "X$PID" = "X " ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110046 ${KILL} ${PID}
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000047 else
Damien Millera8e06ce2003-11-21 23:48:55 +110048 echo "Unable to read PID file"
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000049 fi
50}
51
52start_service() {
53 # XXX We really should check if the service is already going, but
54 # XXX we will opt out at this time. - Bal
55
56 # Check to see if we have keys that need to be made
57 checkkeys
58
59 # Start SSHD
60 echo "starting $SSHD... \c" ; $SSHD
61
62 sshd_rc=$?
63 if [ $sshd_rc -ne 0 ]; then
Damien Millera8e06ce2003-11-21 23:48:55 +110064 echo "$0: Error ${sshd_rc} starting ${SSHD}... bailing."
65 exit $sshd_rc
Ben Lindstrom8b5ba1c2001-10-12 20:30:52 +000066 fi
67 echo done.
68}
69
70case $1 in
71
72'start')
73 start_service
74 ;;
75
76'stop')
77 stop_service
78 ;;
79
80'restart')
81 stop_service
82 start_service
83 ;;
84
85*)
86 echo "$0: usage: $0 {start|stop|restart}"
87 ;;
88esac