1993-06-20 15:41:45 +02:00
|
|
|
#!/bin/sh -
|
|
|
|
#
|
|
|
|
# @(#)security 5.3 (Berkeley) 5/28/91
|
1996-04-18 12:34:07 +02:00
|
|
|
# $Id: security,v 1.9 1995/09/15 00:22:31 ache Exp $
|
1993-06-20 15:41:45 +02:00
|
|
|
#
|
|
|
|
PATH=/sbin:/bin:/usr/bin
|
1996-04-18 12:34:07 +02:00
|
|
|
LC_ALL=C; export LC_ALL
|
1993-06-20 15:41:45 +02:00
|
|
|
|
|
|
|
host=`hostname -s`
|
|
|
|
echo "Subject: $host security check output"
|
|
|
|
|
|
|
|
LOG=/var/log
|
|
|
|
TMP=/tmp/_secure.$$
|
|
|
|
|
1993-09-07 01:12:04 +02:00
|
|
|
umask 027
|
|
|
|
|
1993-06-20 15:41:45 +02:00
|
|
|
echo "checking setuid files and devices:"
|
1993-09-07 01:12:04 +02:00
|
|
|
|
|
|
|
# don't have ncheck, but this does the equivalent of the commented out block.
|
|
|
|
# note that one of the original problem, the possibility of overrunning
|
|
|
|
# the args to ls, is still here...
|
|
|
|
#
|
1993-10-25 21:13:16 +01:00
|
|
|
MP=`mount -t ufs | sed 's;/dev/;&r;' | awk '{ print $3 }'`
|
|
|
|
set $MP
|
1994-01-22 11:54:13 +01:00
|
|
|
while test $# -ge 1; do
|
1993-10-25 21:13:16 +01:00
|
|
|
mount=$1
|
|
|
|
shift
|
1996-04-18 12:34:07 +02:00
|
|
|
find -X $mount -xdev -type f \
|
|
|
|
\( -perm -u+x -or -perm -g+x -or -perm -o+x \) \
|
|
|
|
\( -perm -u+s -or -perm -g+s \) -or \
|
|
|
|
\( -type c -or -type b \) \
|
|
|
|
| sort
|
|
|
|
# exclude date/time info for devices
|
|
|
|
done | xargs -n 20 ls -lgTd | expand | \
|
|
|
|
sed 's/\(^[cb].*, *[0-9x]*\).*\( \/.*\)$/\1\2/' \
|
|
|
|
> $TMP
|
1993-06-20 15:41:45 +02:00
|
|
|
|
1995-09-15 02:22:31 +02:00
|
|
|
if [ ! -f $LOG/setuid.today ] ; then
|
|
|
|
echo "no $LOG/setuid.today"
|
|
|
|
cp $TMP $LOG/setuid.today
|
|
|
|
fi
|
1993-06-20 15:41:45 +02:00
|
|
|
if cmp $LOG/setuid.today $TMP >/dev/null; then :; else
|
|
|
|
echo "$host setuid/device diffs:"
|
1995-05-27 03:37:44 +02:00
|
|
|
diff -b $LOG/setuid.today $TMP
|
1993-06-20 15:41:45 +02:00
|
|
|
mv $LOG/setuid.today $LOG/setuid.yesterday
|
|
|
|
mv $TMP $LOG/setuid.today
|
|
|
|
fi
|
|
|
|
rm -f $TMP
|
|
|
|
|
|
|
|
echo ""
|
|
|
|
echo ""
|
|
|
|
echo "checking for uids of 0:"
|
|
|
|
awk 'BEGIN {FS=":"} $3=="0" {print $1,$3}' /etc/master.passwd
|