Give sshd a secure startup, but with a tweakable timeout so that
the box won't hang forever at startup.
This commit is contained in:
parent
89b748ced7
commit
7a1da9e0e3
@ -17,6 +17,30 @@ start_precmd="sshd_precmd"
|
||||
pidfile="/var/run/${name}.pid"
|
||||
extra_commands="keygen reload"
|
||||
|
||||
timeout=300
|
||||
|
||||
user_reseed()
|
||||
{
|
||||
(
|
||||
seeded=`sysctl -n kern.random.sys.seeded 2>/dev/null`
|
||||
if [ "${seeded}" != "" ] ; then
|
||||
warn "Setting entropy source to blocking mode."
|
||||
echo "===================================================="
|
||||
echo "Type a full screenful of random junk to unblock"
|
||||
echo "it and remember to finish with <enter>. This will"
|
||||
echo "timeout in ${timeout} seconds, but waiting for"
|
||||
echo "the timeout without typing junk may make the"
|
||||
echo "entropy source deliver predictable output."
|
||||
echo ""
|
||||
echo "Just hit <enter> for fast+insecure startup."
|
||||
echo "===================================================="
|
||||
sysctl kern.random.sys.seeded=0 2>/dev/null
|
||||
read -t ${timeout} junk
|
||||
echo "${junk}" `sysctl -a` `date` > /dev/random
|
||||
fi
|
||||
)
|
||||
}
|
||||
|
||||
sshd_keygen()
|
||||
{
|
||||
(
|
||||
@ -60,6 +84,7 @@ sshd_precmd()
|
||||
if [ ! -f /etc/ssh/ssh_host_key -o \
|
||||
! -f /etc/ssh/ssh_host_dsa_key -o \
|
||||
! -f /etc/ssh/ssh_host_rsa_key ]; then
|
||||
user_reseed
|
||||
run_rc_command keygen
|
||||
fi
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user