mirror of
git://slackware.nl/current.git
synced 2025-01-14 08:01:11 +01:00
36 lines
879 B
Bash
36 lines
879 B
Bash
|
config() {
|
||
|
NEW="$1"
|
||
|
OLD="`dirname $NEW`/`basename $NEW .new`"
|
||
|
# If there's no config file by that name, mv it over:
|
||
|
if [ ! -r $OLD ]; then
|
||
|
mv $NEW $OLD
|
||
|
elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then # toss the redundant copy
|
||
|
rm $NEW
|
||
|
fi
|
||
|
# Otherwise, we leave the .new copy for the admin to consider...
|
||
|
}
|
||
|
|
||
|
config etc/ssh/ssh_config.new
|
||
|
config etc/ssh/sshd_config.new
|
||
|
config etc/rc.d/rc.sshd.new
|
||
|
|
||
|
# If the sshd user/group/shadow don't exist, add them:
|
||
|
|
||
|
if ! grep -q "^sshd:" etc/passwd ; then
|
||
|
echo "sshd:x:33:33:sshd:/:" >> etc/passwd
|
||
|
fi
|
||
|
|
||
|
if ! grep -q "^sshd:" etc/group ; then
|
||
|
echo "sshd::33:sshd" >> etc/group
|
||
|
fi
|
||
|
|
||
|
if ! grep -q "^sshd:" etc/shadow ; then
|
||
|
echo "sshd:*:9797:0:::::" >> etc/shadow
|
||
|
fi
|
||
|
|
||
|
# Add a btmp file to store login failure if one doesn't exist:
|
||
|
if [ ! -r var/log/btmp ]; then
|
||
|
( cd var/log ; umask 077 ; touch btmp )
|
||
|
fi
|
||
|
|