Initial import of the replacements for /etc/{daily, weekly, monthly}.

Please note: I'm not activating this until I successfully get the changes
back into my local CVS repository to do one final check.  Early adopters
are welcome to send comments.
This commit is contained in:
Paul Traina 1997-08-12 17:51:16 +00:00
parent c0fa6e333d
commit 28dce04d19
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/cvs2svn/branches/PST/; revision=28114
29 changed files with 443 additions and 0 deletions

View File

@ -0,0 +1,15 @@
#!/bin/sh
#
# $Id$
#
# This is a security hole, never use 'find' on a public directory
# with -exec rm -f as root. This can be exploited to delete any file
# on the system.
#
exit 0 # do not run by default
find / \( ! -fstype local -o -fstype rdonly \) -a -prune -o \
\( -name '[#,]*' -o -name '.#*' -o -name a.out -o -name '*.core' \
-o -name '*.CKP' -o -name '.emacs_[0-9]*' \) \
-a -atime +3 -exec rm -f -- {} \;

32
etc/cron.d/daily/110.clean-tmps Executable file
View File

@ -0,0 +1,32 @@
#!/bin/sh
#
# $Id$
#
# This is a security hole, never use 'find' on a public directory
# with -exec rm -f as root. This can be exploited to delete any file
# on the system.
#
# Use at your own risk, but for a long-living system, this might come
# more useful than the boot-time cleaning of /tmp. If /var/tmp and
# /tmp are symlinked together, only one of the below will actually
# run.
#
exit 0 # do not run by default
if [ -d /tmp ]; then
cd /tmp && {
find . -type f -atime +3 -ctime +3 ! -name '.X*-lock' \
-exec rm -f -- {} \;
find -d . ! -name . -type d -mtime +1 -exec rmdir -- {} \; \
>/dev/null 2>&1
}
fi
if [ -d /var/tmp ]; then
cd /var/tmp && {
find . ! -name . -atime +7 -ctime +3 -exec rm -f -- {} \;
find -d . ! -name . -type d -mtime +1 -exec rmdir -- {} \; \
>/dev/null 2>&1
}
fi

View File

@ -0,0 +1,10 @@
#!/bin/sh
#
# $Id$
#
if [ -d /var/preserve ]; then
echo ""
echo "Removing stale files from /var/preserve:"
cd /var/preserve && find . ! -name . -mtime +7 -exec rm -f -- {} \;
fi

11
etc/cron.d/daily/130.clean-msgs Executable file
View File

@ -0,0 +1,11 @@
#!/bin/sh
#
# $Id$
#
# remove system messages older than 21 days
#
if [ -d /var/msgs ] ; then
echo
echo "Cleaning out old system announcements:"
msgs -c
fi

11
etc/cron.d/daily/140.clean-rwho Executable file
View File

@ -0,0 +1,11 @@
#!/bin/sh
#
# $Id$
#
if [ -d /var/rwho ] ; then
echo ""
echo "Removing stale files from /var/rwho"
cd /var/rwho && find . ! -name . -mtime +7 -exec rm -f -- {} \;
fi

View File

@ -0,0 +1,35 @@
#!/bin/sh
#
# $Id$
#
bak=/var/backups
if [ -f /etc/master.passwd -o -f /etc/group ] ; then
echo ""
echo "Backup passwd and group files:"
if [ ! -f $bak/master.passwd.bak ] ; then
echo "no $bak/master.passwd.bak"
cp -p /etc/master.passwd $bak/master.passwd.bak
fi
if cmp -s $bak/master.passwd.bak /etc/master.passwd; then :; else
echo "$host passwd diffs:"
diff $bak/master.passwd.bak /etc/master.passwd |\
sed 's/^\([<>] [^:]*\):[^:]*:/\1:(password):/'
mv $bak/master.passwd.bak $bak/master.passwd.bak2
cp -p /etc/master.passwd $bak/master.passwd.bak
fi
if [ ! -f $bak/group.bak ] ; then
echo "no $bak/group.bak"
cp -p /etc/group $bak/group.bak
fi
if cmp -s $bak/group.bak /etc/group; then :; else
echo "$host group diffs:"
diff $bak/group.bak /etc/group
mv $bak/group.bak $bak/group.bak2
cp -p /etc/group $bak/group.bak
fi
fi

View File

@ -0,0 +1,22 @@
#!/bin/sh
#
# $Id$
#
bak=/var/backups
if [ -f /etc/aliases ] ; then
echo ""
echo "Backing up mail aliases:"
if [ ! -f $bak/aliases.bak ] ; then
echo "no $bak/aliases.bak"
cp -p /etc/aliases $bak/aliases.bak
fi
if cmp -s $bak/aliases.bak /etc/aliases; then :; else
echo "$host aliases diffs:"
diff $bak/aliases.bak /etc/aliases
mv $bak/aliases.bak $bak/aliases.bak2
cp -p /etc/aliases $bak/aliases.bak
fi
fi

View File

@ -0,0 +1,15 @@
#!/bin/sh
#
# $Id$
#
bak=/var/backups
if [ -f /etc/Distfile ]; then
echo ""
echo "Backing up /etc/Distfile"
if cmp -s $bak/Distfile.bak /etc/Distfile; then :; else
mv $bak/Distfile.bak $bak/Distfile.bak2
cp /etc/Distfile $bak/Distfile.bak
fi
fi

17
etc/cron.d/daily/300.calendar Executable file
View File

@ -0,0 +1,17 @@
#!/bin/sh
#
# $Id$
#
# `calendar -a' needs to die. Why? Because it's a bad idea, particular
# with networked home directories, but also in general. If you want the
# output of `calendar' mailed to you, set up a cron job to do it,
# or run it from your ~/.profile or ~/.login.
#
exit 0 # do not run by default
if [ -f /usr/bin/calendar ] ; then
echo ""
echo "Running calendar:"
calendar -a
fi

15
etc/cron.d/daily/310.accounting Executable file
View File

@ -0,0 +1,15 @@
#!/bin/sh
#
# $Id$
#
if [ -f /var/account/acct ] ; then
echo ""
echo "Rotating accounting logs and gathering statistics:"
cd /var/account
if [ -f acct.2 ] ; then mv -f acct.2 acct.3 ; fi
if [ -f acct.1 ] ; then mv -f acct.1 acct.2 ; fi
if [ -f acct.0 ] ; then mv -f acct.0 acct.1 ; fi
cp -pf acct acct.0
sa -s > /dev/null
fi

10
etc/cron.d/daily/320.rdist Executable file
View File

@ -0,0 +1,10 @@
#!/bin/sh
#
# $Id$
#
if [ -f /etc/Distfile ]; then
echo ""
echo "Running rdist with /etc/Distfile:"
rdist -f /etc/Distfile
fi

11
etc/cron.d/daily/330.news Executable file
View File

@ -0,0 +1,11 @@
#!/bin/sh
#
# $Id$
#
# Expire news articles
# (This is present only for backwards compatibility, usually the news
# system handles this on its own).
if [ -f /etc/news.expire ]; then
/etc/news.expire
fi

13
etc/cron.d/daily/340.uucp Executable file
View File

@ -0,0 +1,13 @@
#!/bin/sh
#
# $Id$
#
# Local cleanup of UUCP files. This is for backwards compatibility,
# /etc/uuclean.daily doesn't exist by default.
#
if [ -d /var/spool/uucp -a -f /etc/uuclean.daily ]; then
echo ""
echo "Cleaning up UUCP:"
echo /etc/uuclean.daily | su daemon
fi

View File

@ -0,0 +1,14 @@
#!/bin/sh
#
# $Id$
#
echo ""
echo "Disk status:"
df -k -t nonfs
# display which filesystems need backing up
echo ""
dump W

View File

@ -0,0 +1,10 @@
#!/bin/sh
#
# $Id$
#
if [ -d /var/spool/uucp -a -x /usr/bin/uustat ]; then
echo ""
echo "uucp status:"
uustat -a
fi

View File

@ -0,0 +1,10 @@
#!/bin/sh
#
# $Id$
#
if [ -x /usr/bin/netstat ] ; then
echo ""
echo "Network interface status:"
netstat -i
fi

View File

@ -0,0 +1,10 @@
#!/bin/sh
#
# $Id$
#
if [ -d /var/rwho -a -x /usr/bin/rwho ] ; then
echo ""
echo "Local network system status:"
ruptime
fi

View File

@ -0,0 +1,10 @@
#!/bin/sh
#
# $Id$
#
if [ -x /usr/sbin/mailq -a -d /var/spool/mqueue ] ; then
echo ""
echo "Mail in local queue:"
mailq
fi

View File

@ -0,0 +1,11 @@
#!/bin/sh
#
# $Id$
#
if [ -f /etc/security -a -x /usr/sbin/sendmail ] ; then
echo ""
echo "Security check (output mailed separately)"
sh /etc/security 2>&1 | sendmail root
fi

13
etc/cron.d/daily/999.local Executable file
View File

@ -0,0 +1,13 @@
#!/bin/sh
#
# $Id$
#
# Run the old /etc/daily.local script. This is really for backwards
# compatibility more than anything else.
#
if [ -f /etc/daily.local ]; then
echo ""
echo "Running daily.local:"
sh /etc/daily.local
fi

View File

@ -0,0 +1,11 @@
#!/bin/sh -
#
# $Id$
#
if [ -x /usr/sbin/ac ] ; then
echo ""
echo "Doing login accounting:"
ac -p | sort -nr +1
fi

View File

@ -0,0 +1,10 @@
#!/bin/sh -
#
# $Id$
#
if [ -f /etc/monthly.local ]; then
echo ""
echo "Running monthly.local:"
sh /etc/monthly.local
fi

42
etc/cron.d/weekly/100.clean-src Executable file
View File

@ -0,0 +1,42 @@
#!/bin/sh -
#
# $Id$
#
# Clean up /usr/src
#
# This really hasn't been used in generations, it's just here for
# backwards compatibility -- we don't even use SCCS anymore
#
exit 0 # do not run by default
# see if /usr/src exists and is local before doing anything
if [ -d /usr/src -a \
X"`find -f /usr/src ! -fstype local -prune -or -type d -print -prune`" != X ];
then
echo ""
echo "Removing old .o files from /usr/src:"
find /usr/src -name '*.o' -atime +21 -print -a -exec rm -f {} \;
echo "looking for checked out files in /usr/src:"
TDIR=/tmp/_checkout$$
mkdir $TDIR
for file in `find -f /usr/src ! -fstype local -prune -or \
-name 'p.*' -print | egrep 'SCCS/p\.'`; do
owner=`awk '{ print $3 }' $file`
echo "$owner $file"
echo $file >> $TDIR/$owner
done | sed -e 's,SCCS/p.,,'
for file in $TDIR/*; do
sed -e 's,SCCS/p.,,' $file | \
Mail -s 'checked out files' `basename $file`
done
rm -rf $TDIR
fi

View File

@ -0,0 +1,15 @@
#!/bin/sh -
#
# $Id$
#
if [ -d /var/db -a -x /usr/sbin/sysctl ] ; then
echo ""
echo "Cleaning up kernel database files:"
kernel=`sysctl -n kern.bootfile`
kernel=kvm_`basename ${kernel}`.db
find /var/db -name "kvm_*.db" -a ! -name ${kernel} -a \
-atime +7 -exec rm -f -- {} \;
fi

12
etc/cron.d/weekly/300.uucp Executable file
View File

@ -0,0 +1,12 @@
#!/bin/sh -
#
# $Id$
#
# This is really here for backwards compatibility, clean.weekly is not
# created by default anymore.
if [ -d /var/spool/uucp -a -f /usr/libexec/uucp/clean.weekly ]; then
echo ""
echo "Cleaning up UUCP:"
echo /usr/libexec/uucp/clean.weekly | su daemon
fi

18
etc/cron.d/weekly/310.locate Executable file
View File

@ -0,0 +1,18 @@
#!/bin/sh -
#
# $Id$
#
locdb=/var/db/locate.database
if [ -x /usr/libexec/locate.updatedb -a -f $locdb ] ; then
echo ""
echo "Rebuilding locate database:"
touch ${locdb}; chown nobody ${locdb}; chmod 644 ${locdb}
echo /usr/libexec/locate.updatedb | nice -5 su -fm nobody 2>&1 |\
fgrep -v 'Permission denied'
chmod 444 ${locdb}
fi

18
etc/cron.d/weekly/320.whatis Executable file
View File

@ -0,0 +1,18 @@
#!/bin/sh -
#
# $Id$
#
if [ -x /usr/libexec/makewhatis.local -a -d /usr/share/man ] ; then
echo ""
echo "Rebuilding whatis database:"
if [ -d /usr/X11R6/man ] ; then
MANPATH=${MANPATH:-/usr/share/man:/usr/X11R6/man:/usr/local/man}
else
MANPATH=${MANPATH:-/usr/share/man:/usr/local/man}
fi
/usr/libexec/makewhatis.local "${MANPATH}"
fi

12
etc/cron.d/weekly/330.catman Executable file
View File

@ -0,0 +1,12 @@
#!/bin/sh -
#
# $Id$
#
exit 0 # do not run by default
if [ -x /usr/libexec/catman.local -a -d /usr/share/man/cat1 ] ; then
echo ""
echo "Reformatting manual pages:"
echo /usr/libexec/catman.local "${MANPATH}" | su -fm man
fi

10
etc/cron.d/weekly/999.local Executable file
View File

@ -0,0 +1,10 @@
#!/bin/sh -
#
# $Id$
#
if [ -f /etc/weekly.local ]; then
echo ""
echo "Running weekly.local:"
sh /etc/weekly.local
fi