1 1.1 cgd #!/bin/sh - 2 1.1 cgd # 3 1.29 abs # $NetBSD: daily,v 1.29 1999/01/06 03:24:06 abs Exp $ 4 1.21 mikel # @(#)daily 8.2 (Berkeley) 1/25/94 5 1.1 cgd # 6 1.18 mrg 7 1.27 mycroft export PATH=/bin:/usr/bin:/sbin:/usr/sbin 8 1.28 lukem umask 077 9 1.28 lukem 10 1.28 lukem if [ -s /etc/daily.conf ]; then 11 1.28 lukem . /etc/daily.conf 12 1.28 lukem fi 13 1.28 lukem 14 1.20 mikel host=`hostname` 15 1.28 lukem date=`date` 16 1.1 cgd 17 1.28 lukem echo "To: ${MAILTO:-root}" 18 1.28 lukem echo "Subject: $host daily output for $date" 19 1.28 lukem echo "" 20 1.18 mrg 21 1.25 lukem if [ -f /etc/rc.subr ]; then 22 1.25 lukem . /etc/rc.subr 23 1.25 lukem else 24 1.25 lukem echo "Can't read /etc/rc.subr; aborting." 25 1.25 lukem exit 1; 26 1.25 lukem fi 27 1.25 lukem 28 1.23 phil if [ -z "$MAILTO" -o "$USER" != "root" ]; then 29 1.27 mycroft MAILTO=root 30 1.23 phil fi 31 1.23 phil 32 1.22 lukem echo "" 33 1.22 lukem echo "Uptime: " `uptime` 34 1.18 mrg 35 1.29 abs # Uncommenting any of the finds below would open up a race condition attack 36 1.29 abs # based on symlinks, potentially allowing removal of any file on the system. 37 1.29 abs # 38 1.17 jtc #echo "" 39 1.17 jtc #echo "Removing scratch and junk files:" 40 1.17 jtc #if [ -d /tmp -a ! -h /tmp ]; then 41 1.17 jtc # cd /tmp && { 42 1.17 jtc # find . -type f -atime +3 -exec rm -f -- {} \; 43 1.17 jtc # find . ! -name . -type d -mtime +1 -exec rmdir -- {} \; \ 44 1.17 jtc # >/dev/null 2>&1; } 45 1.17 jtc #fi 46 1.1 cgd 47 1.17 jtc #if [ -d /var/tmp -a ! -h /var/tmp ]; then 48 1.17 jtc # cd /var/tmp && { 49 1.17 jtc # find . ! -name . -atime +7 -exec rm -f -- {} \; 50 1.17 jtc # find . ! -name . -type d -mtime +1 -exec rmdir -- {} \; \ 51 1.17 jtc # >/dev/null 2>&1; } 52 1.17 jtc #fi 53 1.10 cgd 54 1.15 pk # Additional junk directory cleanup would go like this: 55 1.15 pk #if [ -d /scratch -a ! -h /scratch ]; then 56 1.15 pk # cd /scratch && { 57 1.15 pk # find . ! -name . -atime +1 -exec rm -f -- {} \; 58 1.15 pk # find . ! -name . -type d -mtime +1 -exec rmdir -- {} \; \ 59 1.15 pk # >/dev/null 2>&1; } 60 1.15 pk #fi 61 1.10 cgd 62 1.17 jtc #if [ -d /var/rwho -a ! -h /var/rwho ] ; then 63 1.17 jtc # cd /var/rwho && { 64 1.17 jtc # find . ! -name . -mtime +7 -exec rm -f -- {} \; ; } 65 1.17 jtc #fi 66 1.10 cgd 67 1.18 mrg TMPDIR=/tmp/_daily.$$ 68 1.18 mrg 69 1.18 mrg if ! mkdir $TMPDIR; then 70 1.18 mrg echo can not create $TMPDIR. 71 1.18 mrg exit 1 72 1.18 mrg fi 73 1.18 mrg 74 1.18 mrg if ! cd $TMPDIR; then 75 1.18 mrg echo can not cd to $TMPDIR. 76 1.18 mrg exit 1 77 1.18 mrg fi 78 1.18 mrg 79 1.10 cgd TMP=daily.$$ 80 1.18 mrg TMP2=daily2.$$ 81 1.18 mrg 82 1.25 lukem if checkyesno find_core; then 83 1.18 mrg find / \( ! -fstype local -o -fstype rdonly -o -fstype fdesc \ 84 1.14 mycroft -o -fstype kernfs -o -fstype procfs \) -a -prune -o \ 85 1.18 mrg -name 'lost+found' -a -prune -o \ 86 1.26 nathanw \( -name '*.core' -o -name 'core' \) -a -print > $TMP 87 1.18 mrg # \( -name '[#,]*' -o -name '.#*' -o -name a.out \ 88 1.18 mrg # -o -name '*.CKP' -o -name '.emacs_[0-9]*' \) \ 89 1.18 mrg # -a -atime +3 -exec rm -f -- {} \; -a -print > $TMP 90 1.18 mrg 91 1.26 nathanw egrep '\.core$|^core$' $TMP > $TMP2 92 1.18 mrg if [ -s $TMP2 ]; then 93 1.18 mrg echo "" 94 1.18 mrg echo "Possible core dumps:" 95 1.18 mrg cat $TMP2 96 1.18 mrg fi 97 1.18 mrg 98 1.18 mrg # egrep -v '\.core' $TMP > $TMP2 99 1.18 mrg # if [ -s $TMP2 ]; then 100 1.18 mrg # echo "" 101 1.18 mrg # echo "Deleted files:" 102 1.18 mrg # cat $TMP2 103 1.18 mrg # fi 104 1.10 cgd 105 1.18 mrg rm -f $TMP $TMP2 106 1.18 mrg fi 107 1.10 cgd 108 1.25 lukem if checkyesno run_msgs; then 109 1.18 mrg msgs -c 110 1.18 mrg fi 111 1.1 cgd 112 1.25 lukem if checkyesno expire_news && [ -f /etc/news.expire ]; then 113 1.1 cgd /etc/news.expire 114 1.1 cgd fi 115 1.1 cgd 116 1.25 lukem if checkyesno purge_accounting && [ -f /var/account/acct ]; then 117 1.21 mikel echo "" 118 1.21 mikel echo "Purging accounting records:" 119 1.21 mikel mv /var/account/acct.2 /var/account/acct.3 120 1.21 mikel mv /var/account/acct.1 /var/account/acct.2 121 1.21 mikel mv /var/account/acct.0 /var/account/acct.1 122 1.21 mikel cp /var/account/acct /var/account/acct.0 123 1.21 mikel sa -sq 124 1.1 cgd fi 125 1.1 cgd 126 1.25 lukem if checkyesno run_calendar; then 127 1.18 mrg calendar -a > $TMP 128 1.18 mrg if [ -s $TMP ]; then 129 1.18 mrg echo "" 130 1.18 mrg echo "Running calendar:" 131 1.18 mrg cat $TMP 132 1.18 mrg fi 133 1.18 mrg rm -f $TMP 134 1.18 mrg fi 135 1.1 cgd 136 1.25 lukem if checkyesno check_uucp && \ 137 1.25 lukem [ -d /var/spool/uucp -a -f /usr/libexec/uucp/clean.daily ]; then 138 1.1 cgd echo "" 139 1.1 cgd echo "Cleaning up UUCP:" 140 1.24 lukem su daemon -c /usr/libexec/uucp/clean.daily 141 1.1 cgd fi 142 1.1 cgd 143 1.25 lukem if checkyesno check_disks; then 144 1.18 mrg df -k > $TMP 145 1.18 mrg dump W > $TMP2 146 1.18 mrg if [ -s $TMP -o -s $TMP2 ]; then 147 1.18 mrg echo "" 148 1.18 mrg echo "Checking subsystem status:" 149 1.18 mrg echo "" 150 1.18 mrg echo "disks:" 151 1.18 mrg if [ -s $TMP ]; then 152 1.18 mrg cat $TMP 153 1.18 mrg echo "" 154 1.18 mrg fi 155 1.18 mrg if [ -s $TMP2 ]; then 156 1.18 mrg cat $TMP2 157 1.18 mrg echo "" 158 1.18 mrg fi 159 1.18 mrg echo "" 160 1.18 mrg fi 161 1.18 mrg fi 162 1.18 mrg 163 1.18 mrg rm -f $TMP $TMP2 164 1.18 mrg 165 1.25 lukem if checkyesno check_mailq; then 166 1.18 mrg mailq > $TMP 167 1.18 mrg if ! grep -q "^Mail queue is empty$" $TMP; then 168 1.18 mrg echo "" 169 1.18 mrg echo "mail:" 170 1.18 mrg cat $TMP 171 1.18 mrg fi 172 1.18 mrg fi 173 1.18 mrg 174 1.18 mrg rm -f $TMP 175 1.1 cgd 176 1.25 lukem if checkyesno check_uucp && [ -d /var/spool/uucp ]; then 177 1.18 mrg uustat -a > $TMP 178 1.18 mrg if [ -s $TMP ]; then 179 1.18 mrg echo "" 180 1.18 mrg echo "uucp:" 181 1.21 mikel cat $TMP 182 1.18 mrg fi 183 1.18 mrg fi 184 1.1 cgd 185 1.18 mrg rm -f $TMP 186 1.1 cgd 187 1.25 lukem if checkyesno check_network; then 188 1.18 mrg echo "" 189 1.18 mrg echo "network:" 190 1.18 mrg netstat -i 191 1.1 cgd echo "" 192 1.18 mrg t=/var/rwho/* 193 1.18 mrg if [ "$t" != '/var/rwho/*' ]; then 194 1.18 mrg ruptime 195 1.18 mrg fi 196 1.1 cgd fi 197 1.1 cgd 198 1.25 lukem if checkyesno run_fsck; then 199 1.18 mrg echo "" 200 1.18 mrg echo "Checking filesystems:" 201 1.18 mrg fsck -n | grep -v '^\*\* Phase' 202 1.18 mrg fi 203 1.1 cgd 204 1.1 cgd echo "" 205 1.25 lukem if checkyesno run_rdist && [ -f /etc/Distfile ]; then 206 1.1 cgd echo "Running rdist:" 207 1.20 mikel if [ -d /var/log/rdist ]; then 208 1.21 mikel logf=`date +%Y.%b.%e` 209 1.20 mikel rdist -f /etc/Distfile 2>&1 | tee /var/log/rdist/$logf 210 1.20 mikel else 211 1.20 mikel rdist -f /etc/Distfile 212 1.20 mikel fi 213 1.1 cgd fi 214 1.1 cgd 215 1.25 lukem if checkyesno run_security; then 216 1.28 lukem SECOUT=$TMPDIR/sec 217 1.28 lukem sh /etc/security 2>&1 > $SECOUT 218 1.28 lukem if [ ! -s $SECOUT ]; then 219 1.28 lukem echo "Nothing to report on $date" > $SECOUT 220 1.28 lukem fi 221 1.28 lukem mail -s "$host daily insecurity output for $date" $MAILTO < $SECOUT 222 1.18 mrg fi 223 1.18 mrg 224 1.18 mrg rm -rf $TMPDIR 225