fdfae48a9319474a25594b5fab1c69087ea8caed
[public/mirror.git] / csc-sync-debian-cd
1 #! /bin/bash
2
3 set -e
4
5 RSYNC="rsync"
6 TOP_DIR=/mirror
7 TO=$TOP_DIR/root/debian-cd
8 RSYNC_HOST=cdimage.debian.org
9 RSYNC_DIR=debian-cd
10 LOGDIR=/var/log/mirror/debian-cd_cdimage.debian.org
11 ADDRESS=129.97.134.71
12
13 mkdir -p $LOGDIR
14
15 # LOCK_TIMEOUT is a timeout in minutes.  Defaults to 360 (6 hours).
16 # This program creates a lock to ensure that only one copy
17 # of it is mirroring any one archive at any one time.
18 # Locks held for longer than the timeout are broken, unless
19 # a running rsync process appears to be connected to $RSYNC_HOST.
20
21 LOCK_TIMEOUT=360
22
23 # There should be no need to edit anything below this point, unless there
24 # are problems.
25
26 #-----------------------------------------------------------------------------#
27
28 # If you are accessing a rsync server/module which is password-protected,
29 # uncomment the following lines (and edit the other file).
30
31 # . ftpsync.conf
32 export RSYNC_PASSWORD
33 if [[ "$RSYNC_USER" != "" ]]; then
34     RSYNC_HOST=$RSYNC_USER@$RSYNC_HOST
35 fi
36
37 #-----------------------------------------------------------------------------#
38
39 # Check for some environment variables
40 if [ -z $TO ] || [ -z $RSYNC_HOST ] || [ -z $RSYNC_DIR ] || [ -z $LOGDIR ]; then
41         echo "One of the following variables seems to be empty:"
42         echo "TO, RSYNC_HOST, RSYNC_DIR or LOGDIR"
43         exit 2
44 fi
45
46 # Note: on some non-Debian systems, hostname doesn't accept -f option.
47 # If that's the case on your system, make sure hostname prints the full
48 # hostname, and remove the -f option. If there's no hostname command,
49 # explicitly replace `hostname -f` with the hostname.
50
51 HOSTNAME=`hostname -f`
52
53 # The hostname must match the "Site" field written in the list of mirrors.
54 # If hostname doesn't returns the correct value, fill and uncomment below 
55 HOSTNAME=mirror.csclub.uwaterloo.ca
56  
57 LOCK="${TO}/Archive-Update-in-Progress-${HOSTNAME}"
58
59 # The temp directory used by rsync --delay-updates is not
60 # world-readable remotely. It must be excluded to avoid errors. 
61 TMP_EXCLUDE="--exclude .~tmp~/"
62
63 # Logfile
64 LOGFILE=$LOGDIR/mirror.log
65
66 # Get in the right directory and set the umask to be group writable
67
68 cd $HOME
69 umask 002
70
71 # Check to see if another sync is in progress
72 if [ -f "$LOCK" ]; then
73 # Note: this requires the findutils find; for other finds, adjust as necessary
74   if [ "`find $LOCK -maxdepth 1 -amin -$LOCK_TIMEOUT`" = "" ]; then
75 # Note: this requires the procps ps; for other ps', adjust as necessary
76     if ps ax | grep '[r]'sync | grep -q $RSYNC_HOST; then
77       echo "stale lock found, but a rsync is still running, aiee!" > /dev/stderr
78       exit 1
79     else
80       echo "stale lock found (not accessed in the last $LOCK_TIMEOUT minutes), forcing update!"
81       rm -f $LOCK
82     fi
83   else
84     echo "current lock file exists, unable to start rsync!"
85     exit 1
86   fi
87 fi
88
89 touch $LOCK
90 # Note: on some non-Debian systems, trap doesn't accept "exit" as signal
91 # specification. If that's the case on your system, try using "0".
92 trap "rm -f $LOCK" exit
93
94 set +e
95
96 # Now sync the remaining stuff
97 $RSYNC -rlHtv --delete \
98      --include='*businesscard*.iso' --include='*netinst*.iso' \
99      --exclude='*.iso' --timeout=3600 --address=$ADDRESS $TMP_EXCLUDE \
100      --exclude "Archive-Update-in-Progress-${HOSTNAME}" \
101      $RSYNC_HOST::$RSYNC_DIR $TO >> $LOGFILE 2>&1
102 if [[ "$?" != "0" ]]; then
103     echo "ERROR: Help, something weird happened" | tee -a $LOGFILE
104     echo "mirroring /pool exited with exitcode" $result | tee -a $LOGFILE
105 fi
106
107 savelog $LOGFILE >/dev/null
108
109 rm $LOCK