NetBSD/etc/rc.d/sshd
lukem e512d5dcf7 Set command_args to '-f ${sshd_conf_dir}/${name}.conf'.
This occurs before the first load_rc_config() so that it may be
overridden by the user, and appears in single quotes so the
variables don't get evaluated until the eval in run_rc_command().
Problem noted by Patrick Welche <prlw1@cam.ac.uk> in [bin/15912].
2002-03-27 09:15:54 +00:00

60 lines
1.4 KiB
Bash
Executable File

#!/bin/sh
#
# $NetBSD: sshd,v 1.14 2002/03/27 09:15:54 lukem Exp $
#
# PROVIDE: sshd
# REQUIRE: LOGIN
. /etc/rc.subr
name="sshd"
rcvar=$name
command="/usr/sbin/${name}"
command_args='-f ${sshd_conf_dir}/${name}.conf'
pidfile="/var/run/${name}.pid"
load_rc_config $name
required_files="${sshd_conf_dir}/${name}.conf"
extra_commands="keygen reload"
sshd_keygen()
{
(
umask 022
if [ -f ${sshd_conf_dir}/ssh_host_key ]; then
echo "You already have an RSA host key in ${sshd_conf_dir}/ssh_host_key"
echo "Skipping protocol version 1 RSA Key Generation"
else
/usr/bin/ssh-keygen -t rsa1 -b 1024 -f ${sshd_conf_dir}/ssh_host_key -N ''
fi
if [ -f ${sshd_conf_dir}/ssh_host_dsa_key ]; then
echo "You already have a DSA host key in ${sshd_conf_dir}/ssh_host_dsa_key"
echo "Skipping protocol version 2 DSA Key Generation"
else
/usr/bin/ssh-keygen -t dsa -f ${sshd_conf_dir}/ssh_host_dsa_key -N ''
fi
if [ -f ${sshd_conf_dir}/ssh_host_rsa_key ]; then
echo "You already have a RSA host key in ${sshd_conf_dir}/ssh_host_rsa_key"
echo "Skipping protocol version 2 RSA Key Generation"
else
/usr/bin/ssh-keygen -t rsa -f ${sshd_conf_dir}/ssh_host_rsa_key -N ''
fi
)
}
sshd_precmd()
{
if [ ! -f ${sshd_conf_dir}/ssh_host_key -o ! -f ${sshd_conf_dir}/ssh_host_dsa_key -o \
! -f ${sshd_conf_dir}/ssh_host_rsa_key ]; then
$0 keygen
fi
}
keygen_cmd=sshd_keygen
start_precmd=sshd_precmd
load_rc_config $name
run_rc_command "$1"