]> git.pld-linux.org Git - packages/openssh.git/blame - opensshd.init
- add try-restart
[packages/openssh.git] / opensshd.init
CommitLineData
cf3b46d6
AF
1#!/bin/sh
2#
3# sshd sshd (secure shell daemon)
4#
fd04e715 5# chkconfig: 345 21 89
cf3b46d6 6#
4a9f24b4 7# description: sshd (secure shell daemon) is a server part of the ssh suite. \
8# Ssh can be used for remote login, remote file copying, TCP port \
cf3b46d6
AF
9# forwarding etc. Ssh offers strong encryption and authentication.
10
cf3b46d6
AF
11# Source function library
12. /etc/rc.d/init.d/functions
13
c303393a
ER
14upstart_controlled --except init configtest
15
cf3b46d6
AF
16# Get network config
17. /etc/sysconfig/network
18
3cd7ffe2
ER
19SSHD_OOM_ADJUST=-1000
20
cf3b46d6
AF
21# Get service config
22[ -f /etc/sysconfig/sshd ] && . /etc/sysconfig/sshd
23
24# Check that networking is up.
7d58fbb0 25if is_yes "${NETWORKING}"; then
224aaee1 26 if [ ! -f /var/lock/subsys/network -a "$1" != stop -a "$1" != status -a "$1" != init ]; then
e6635719 27 msg_network_down "OpenSSH"
7d58fbb0 28 exit 1
29 fi
30else
31 exit 0
cf3b46d6 32fi
a1c37c17 33
32322335 34adjust_oom() {
141073f0
ER
35 if [ -e /var/run/sshd.pid ]; then
36 for pid in $(cat /var/run/sshd.pid); do
9172cbe8 37 echo "$SSHD_OOM_ADJUST" 2>/dev/null > /proc/$pid/oom_score_adj
141073f0
ER
38 done
39 fi
32322335
AM
40}
41
945a8076
ER
42checkconfig() {
43 /usr/sbin/sshd -t || exit 1
44}
45
e6635719 46ssh_gen_keys() {
3c573fc0 47 # generate new keys with empty passwords if they do not exist
48 if [ ! -f /etc/ssh/ssh_host_key -o ! -s /etc/ssh/ssh_host_key ]; then
e6635719 49 /usr/bin/ssh-keygen -t rsa1 -f /etc/ssh/ssh_host_key -N '' >&2
7d58fbb0 50 chmod 600 /etc/ssh/ssh_host_key
e6635719 51 [ -x /sbin/restorecon ] && /sbin/restorecon /etc/ssh/ssh_host_key
3c573fc0 52 fi
53 if [ ! -f /etc/ssh/ssh_host_rsa_key -o ! -s /etc/ssh/ssh_host_rsa_key ]; then
e6635719 54 /usr/bin/ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key -N '' >&2
7d58fbb0 55 chmod 600 /etc/ssh/ssh_host_rsa_key
e6635719 56 [ -x /sbin/restorecon ] && /sbin/restorecon /etc/ssh/ssh_host_rsa_key
3c573fc0 57 fi
58 if [ ! -f /etc/ssh/ssh_host_dsa_key -o ! -s /etc/ssh/ssh_host_dsa_key ]; then
e6635719 59 /usr/bin/ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key -N '' >&2
7d58fbb0 60 chmod 600 /etc/ssh/ssh_host_dsa_key
e6635719
ER
61 [ -x /sbin/restorecon ] && /sbin/restorecon /etc/ssh/ssh_host_dsa_key
62 fi
7b384e20
AM
63 if [ ! -f /etc/ssh/ssh_host_ecdsa_key -o ! -s /etc/ssh/ssh_host_ecdsa_key ]; then
64 /usr/bin/ssh-keygen -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key -N '' >&2
65 chmod 600 /etc/ssh/ssh_host_ecdsa_key
66 [ -x /sbin/restorecon ] && /sbin/restorecon /etc/ssh/ssh_host_ecdsa_key
67 fi
e6635719
ER
68}
69
70start() {
71 # Check if the service is already running?
72 if [ -f /var/lock/subsys/sshd ]; then
73 msg_already_running "OpenSSH"
74 return
3c573fc0 75 fi
76
e6635719 77 ssh_gen_keys
945a8076
ER
78 checkconfig
79
e6635719
ER
80 if [ ! -s /etc/ssh/ssh_host_key ]; then
81 msg_not_running "OpenSSH"
7d58fbb0 82 nls "No SSH host key found! You must run \"%s init\" first." "$0"
01d1f289 83 exit 1
84 fi
3c573fc0 85
1292c55e
ER
86 if is_yes "$IPV4_NETWORKING" && is_no "$IPV6_NETWORKING"; then
87 OPTIONS="$OPTIONS -4"
88 fi
89 if is_yes "$IPV6_NETWORKING" && is_no "$IPV4_NETWORKING"; then
90 OPTIONS="$OPTIONS -6"
91 fi
92
e6635719 93 msg_starting "OpenSSH"
1292c55e 94 daemon --pidfile /var/run/sshd.pid /usr/sbin/sshd $OPTIONS
e6635719
ER
95 RETVAL=$?
96 adjust_oom
97 [ $RETVAL -eq 0 ] && touch /var/lock/subsys/sshd
b10eed65
ER
98}
99
100stop() {
3cd7ffe2 101 if [ ! -f /var/lock/subsys/sshd ]; then
e6635719 102 msg_not_running "OpenSSH"
3cd7ffe2 103 return
a1c37c17 104 fi
3cd7ffe2
ER
105
106 msg_stopping "OpenSSH"
107 # we use start-stop-daemon to stop sshd, as it is unacceptable for such
108 # critical service as sshd to kill it by procname, but unfortunately
109 # rc-scripts does not provide way to kill *only* by pidfile
110 start-stop-daemon --stop --quiet --pidfile /var/run/sshd.pid && ok || fail
111 rm -f /var/lock/subsys/sshd >/dev/null 2>&1
112}
113
114reload() {
115 if [ ! -f /var/lock/subsys/sshd ]; then
116 msg_not_running "OpenSSH"
117 RETVAL=7
118 return
119 fi
120
fde7c3ba 121 ssh_gen_keys
3cd7ffe2
ER
122 checkconfig
123 msg_reloading "OpenSSH"
124 killproc sshd -HUP
125 RETVAL=$?
b10eed65
ER
126}
127
8e8276e5
ER
128condrestart() {
129 if [ ! -f /var/lock/subsys/sshd ]; then
130 msg_not_running "OpenSSH"
131 RETVAL=$1
132 return
133 fi
134
135 checkconfig
136 stop
137 start
138}
139
b10eed65
ER
140RETVAL=0
141# See how we were called.
142case "$1" in
143 start)
144 start
145 ;;
146 stop)
147 stop
cf3b46d6 148 ;;
cbd44157 149 restart)
945a8076 150 checkconfig
b10eed65
ER
151 stop
152 start
cf3b46d6 153 ;;
8e8276e5
ER
154 try-restart)
155 condrestart 0
156 ;;
3cd7ffe2
ER
157 reload|force-reload)
158 reload
159 ;;
160 configtest)
161 checkconfig
cf3b46d6 162 ;;
01d1f289 163 init)
0d883194 164 nls "Now the SSH host key will be generated. Please note, that if you"
165 nls "will use password for the key, you will need to type it on each"
166 nls "reboot."
e6635719 167 ssh_gen_keys
36f63877 168 ;;
3cd7ffe2
ER
169 status)
170 status sshd
171 exit $?
36f63877 172 ;;
cf3b46d6 173 *)
8e8276e5 174 msg_usage "$0 {start|stop|restart|try-restart|reload|force-reload|configtest|init|status}"
bff0c7f8 175 exit 3
cf3b46d6
AF
176esac
177
cbd44157 178exit $RETVAL
This page took 0.077154 seconds and 4 git commands to generate.