* Remove the OS specific bits, since NetBSD isn't interested in
porting this stuff back. * Test /etc/motd for writability before trying to update it. This is especially useful when /etc/ is mounted ro, like on a diskless boot. (Thanks to phk for the idea on this one.) * Make the "updating" message reflect what actually happens.
This commit is contained in:
parent
a75a7409ef
commit
4c4eba0e00
@ -16,14 +16,7 @@ rcvar="update_motd"
|
||||
start_cmd="motd_start"
|
||||
stop_cmd=":"
|
||||
|
||||
case ${OSTYPE} in
|
||||
FreeBSD)
|
||||
PERMS="644"
|
||||
;;
|
||||
NetBSD)
|
||||
PERMS="664"
|
||||
;;
|
||||
esac
|
||||
PERMS="644"
|
||||
|
||||
motd_start()
|
||||
{
|
||||
@ -31,28 +24,27 @@ motd_start()
|
||||
# Must be done *before* interactive logins are possible
|
||||
# to prevent possible race conditions.
|
||||
#
|
||||
echo "Updating motd."
|
||||
echo -n 'Updating motd'
|
||||
if [ ! -f /etc/motd ]; then
|
||||
install -c -o root -g wheel -m ${PERMS} /dev/null /etc/motd
|
||||
fi
|
||||
|
||||
case ${OSTYPE} in
|
||||
FreeBSD)
|
||||
T=`mktemp -t motd`
|
||||
uname -v | sed -e 's,^\([^#]*\) #\(.* [1-2][0-9][0-9][0-9]\).*/\([^\]*\) $,\1 (\3) #\2,' > ${T}
|
||||
awk '{if (NR == 1) {if ($1 == "FreeBSD") {next} else {print "\n"$0}} else {print}}' < /etc/motd >> ${T}
|
||||
;;
|
||||
NetBSD)
|
||||
T='/etc/_motd'
|
||||
sysctl -n kern.version | while read i; do echo $i; break; done > $T
|
||||
sed '1{/^NetBSD.*/{d;};};' < /etc/motd >> $T
|
||||
;;
|
||||
esac
|
||||
if [ ! -w /etc/motd ]; then
|
||||
echo ' ... /etc/motd is not writable, update failed.'
|
||||
return
|
||||
fi
|
||||
|
||||
T=`mktemp -t motd`
|
||||
uname -v | sed -e 's,^\([^#]*\) #\(.* [1-2][0-9][0-9][0-9]\).*/\([^\]*\) $,\1 (\3) #\2,' > ${T}
|
||||
awk '{if (NR == 1) {if ($1 == "FreeBSD") {next} else {print "\n"$0}} else {print}}' < /etc/motd >> ${T}
|
||||
|
||||
cmp -s $T /etc/motd || {
|
||||
cp $T /etc/motd
|
||||
chmod ${PERMS} /etc/motd
|
||||
}
|
||||
rm -f $T
|
||||
|
||||
echo .
|
||||
}
|
||||
|
||||
load_rc_config $name
|
||||
|
Loading…
Reference in New Issue
Block a user