lite2 daily + our changes. We can remove old tmp files now that fts(3)
authormillert <millert@openbsd.org>
Fri, 17 Jan 1997 06:18:19 +0000 (06:18 +0000)
committermillert <millert@openbsd.org>
Fri, 17 Jan 1997 06:18:19 +0000 (06:18 +0000)
is safe and we have -execdir.

etc/daily

index 4fb4376..115ddc4 100644 (file)
--- a/etc/daily
+++ b/etc/daily
@@ -1,10 +1,12 @@
 #!/bin/sh -
 #
-#      $OpenBSD: daily,v 1.16 1997/01/03 22:51:26 millert Exp $
+#      $OpenBSD: daily,v 1.17 1997/01/17 06:18:19 millert Exp $
+#      From: @(#)daily 8.2 (Berkeley) 1/25/94
 #
-PATH=/bin:/usr/bin:/sbin:/usr/sbin:/usr/local
+PATH=/bin:/usr/bin:/sbin:/usr/sbin:/usr/local/bin
 host=`hostname -s`
 echo "Subject: $host daily run output"
+bak=/var/backups
 
 if [ -f /etc/daily.local ];then
        echo ""
@@ -17,75 +19,98 @@ TMP=`mktemp /tmp/_daily.XXXXXX` || exit 1
 trap 'rm -f $TMP' 0 1 15
 
 echo ""
-echo "NOT Removing scratch and junk files."
-#echo "Removing scratch and junk files:"
-# XXX NOT REMOVING UNTIL SECURITY BUG IS FIXED" 
-#if [ -d /tmp -a ! -h /tmp ]; then
-#      cd /tmp && {
-#      find . -type f -atime +3 -exec rm -f -- {} \;
-#      find . ! -name . -type d -mtime +1 -exec rmdir -- {} \; \
-#          >/dev/null 2>&1; }
-#fi
+echo "Removing scratch and junk files:"
+if [ -d /tmp -a ! -h /tmp ]; then
+       cd /tmp && {
+       find . -type f -atime +3 -execdir rm -f -- {} \;
+       find . ! -name . -type d -mtime +1 -execdir rmdir -- {} \; \
+           >/dev/null 2>&1; }
+fi
 
-# XXX NOT REMOVING UNTIL SECURITY BUG IS FIXED 
-#if [ -d /var/tmp -a ! -h /var/tmp ]; then
-#      cd /var/tmp && {
-#      find . ! -name . -atime +7 -exec rm -f -- {} \;
-#      find . ! -name . -type d -mtime +1 -exec rmdir -- {} \; \
-#          >/dev/null 2>&1; }
-#fi
+if [ -d /var/tmp -a ! -h /var/tmp ]; then
+       cd /var/tmp && {
+       find . ! -name . -atime +7 -execdir rm -f -- {} \;
+       find . ! -name . -type d -mtime +1 -execdir rmdir -- {} \; \
+           >/dev/null 2>&1; }
+fi
 
 # Additional junk directory cleanup would go like this:
 #if [ -d /scratch -a ! -h /scratch ]; then
 #      cd /scratch && {
-#      find . ! -name . -atime +1 -exec rm -f -- {} \;
-#      find . ! -name . -type d -mtime +1 -exec rmdir -- {} \; \
+#      find . ! -name . -atime +1 -execdir rm -f -- {} \;
+#      find . ! -name . -type d -mtime +1 -execdir rmdir -- {} \; \
 #          >/dev/null 2>&1; }
 #fi
 
-#if [ -d /var/rwho -a ! -h /var/rwho ] ; then
-#      cd /var/rwho && {
-# XXX NOT REMOVING UNTIL SECURITY BUG IS FIXED 
-#      find . ! -name . -mtime +7 -exec rm -f -- {} \; ; }
-#fi
+if [ -d /var/preserve -a ! -h /var/preserve ]; then
+       cd /var/preserve && {
+       find . ! -name . -mtime +7 -execdir rm -f -- {} \; ; }
+fi
+
+if [ -d /var/rwho -a ! -h /var/rwho ] ; then
+       cd /var/rwho && {
+       find . ! -name . -mtime +7 -execdir rm -f -- {} \; ; }
+fi
 
 find / \( ! -fstype local -o -fstype rdonly -o -fstype fdesc \
                -o -fstype kernfs -o -fstype procfs \) -a -prune -o \
        -name 'lost+found' -a -prune -o \
-       -name '*.core' -a -print > $TMP
-#      \( -name '[#,]*' -o -name '.#*' -o -name a.out \
-#         -o -name '*.CKP' -o -name '.emacs_[0-9]*' \) \
-#              -a -atime +3 -exec rm -f -- {} \; -a -print > $TMP
+       -name '*.core' -a -print -o \
+       \( -name '[#,]*' -o -name '.#*' -o -name a.out \
+          -o -name '*.CKP' -o -name '.emacs_[0-9]*' \) \
+               -a -atime +3 -a -execdir rm -f -- {} \; -a -print > $TMP
 
 if egrep -q '\.core$' $TMP; then
-    echo ""
-    echo "Possible core dumps:"
-    egrep '\.core$' $TMP
-
-    # XXX - we aren't deleting files due to security bug mentioned above
-    #echo ""
-    #echo "Deleted files:"
-    #egrep -v '\.core$' $TMP
+       echo ""
+       echo "Possible core dumps:"
+       egrep '\.core$' $TMP
+fi
+
+if egrep -qv '\.core$' $TMP; then
+       echo ""
+       echo "Deleted files:"
+       egrep -v '\.core$' $TMP
 fi
 
 msgs -c
 
-if [ -f /etc/news.expire ]; then
+if [ -s /etc/news.expire ]; then
        /etc/news.expire
 fi
 
 if [ -f /var/account/acct ]; then
-       echo "" ;
-       echo "Purging accounting records:" ;
-       mv /var/account/acct.2 /var/account/acct.3 ;
-       mv /var/account/acct.1 /var/account/acct.2 ;
-       mv /var/account/acct.0 /var/account/acct.1 ;
-       cp /var/account/acct /var/account/acct.0 ;
-       sa -sq ;
+       echo ""
+       echo "Purging accounting records:"
+       mv /var/account/acct.2 /var/account/acct.3
+       mv /var/account/acct.1 /var/account/acct.2
+       mv /var/account/acct.0 /var/account/acct.1
+       cp /var/account/acct /var/account/acct.0
+       sa -sq
 fi
 
+# If ROOTBACKUP is set to 1 in the environment, and
+# if filesystem named /altroot is type ffs, on /dev/* and mounted "xx",
+# use it as a backup root filesystem to be updated daily.
+[ "X$ROOTBACKUP" = X1 ] && {
+       rootdev=`awk '$2 == "/" && $1 ~ /^\/dev\// && $3 == "ffs" && \
+           $4 == "rw" \
+                { print substr($1, 6) }' < /etc/fstab`
+       rootbak=`awk '$2 == "/altroot" && $1 ~ /^\/dev\// && $3 == "ffs" && \
+           $4 == "xx" \
+               { print substr($1, 6) }' < /etc/fstab`
+       [ X$rootdev != X -a X$rootbak != X ] && {
+               sync
+               echo ""
+               echo "Backing up root filesystem:"
+               echo "copying /dev/r$rootdev to /dev/r$rootbak"
+               dd if=/dev/r$rootdev of=/dev/r$rootbak bs=16b seek=1 skip=1 \
+                       conv=noerror,sync
+               fsck -y /dev/r$rootbak
+       }
+}
+
 echo ""
-if [ -d /var/yp/binding -a ! -d /var/yp/`domainname` ]; then 
+if [ -d /var/yp/binding -a ! -d /var/yp/`domainname` ]; then
        echo "Not running calendar, (yp client)."
 else
        echo "Running calendar."
@@ -132,18 +157,27 @@ echo ""
 
 t=/var/rwho/*
 if [ "$t" != '/var/rwho/*' ]; then
+       echo ""
        ruptime
 fi
 
-echo ""
-echo "NOT checking filesystems."
-#echo "Checking filesystems:"
-#fsck -n | grep -v '^\*\* Phase'
+# If CHECKFILESYSTEMS is set to 1 in the environment, run fsck
+# with the no-write flag.
+[ "X$CHECKFILESYSTEMS" = X1 ] && {
+       echo ""
+       echo "Checking filesystems:"
+       fsck -n | grep -v '^\*\* Phase'
+}
 
-echo ""
 if [ -f /etc/Distfile ]; then
+       echo ""
        echo "Running rdist:"
-       rdist -f /etc/Distfile
+       if [ -d /var/log/rdist ]; then
+               logf=`date | awk '{printf "%s.%s.%s", $6, $2, $3}'`
+               rdist -f /etc/Distfile 2>&1 | tee /var/log/rdist/$logf
+       else
+               rdist -f /etc/Distfile 
+       fi
 fi
 
 sh /etc/security 2>&1 | mail -s "$host daily insecurity output" root