8c0a105d |
1 | #!/bin/bash |
2 | |
3 | # invoke this as root on mire |
4 | |
5 | exec 2>&1 |
6 | |
7 | # drop any tokens; use only users' cgi tokens |
0ca8794c |
8 | kdestroy > /dev/null 2>&1 |
8c0a105d |
9 | unlog |
10 | |
0ca8794c |
11 | #VERBOSE=true |
12 | VERBOSE=false |
13 | |
9b2935e9 |
14 | LOCAL_LOG_DIR=/var/log/apache2/user |
0ca8794c |
15 | KEYTAB_DIR=/etc/keytabs/user.daemon |
16 | AFS_USER_DIR=/afs/hcoop.net/user |
db4b486c |
17 | ERROR=no |
0ca8794c |
18 | |
9b2935e9 |
19 | # Sanify permissions so that we can safely create tmp directories and |
20 | # run rsync. |
21 | chmod -R u=rwX,g=rX,o=X $LOCAL_LOG_DIR |
22 | |
23 | # Iterate through logs for each user |
24 | for A in $(find $LOCAL_LOG_DIR -mindepth 3 -maxdepth 3 -print); do |
0ca8794c |
25 | USER=`basename $A` |
26 | PATHBITS=`echo $USER | head -c 1`/`echo $USER | head -c 2`/$USER |
dd381d21 |
27 | LOG_SRC=$A/apache/log |
d139bb2a |
28 | LOG_DEST=$AFS_USER_DIR/$PATHBITS/.logs/apache/ |
dd381d21 |
29 | TMP_DEST=$LOG_SRC.tmp |
0ca8794c |
30 | |
29f492e6 |
31 | # Skip deleted or empty log directories |
32 | if test ! -d "$LOG_SRC" || ! ls "$LOG_SRC"/*/*/*.log >/dev/null 2>&1; then |
33 | continue |
34 | fi |
35 | |
36 | if test "$VERBOSE" = "true"; then |
0ca8794c |
37 | echo |
38 | echo "==============================================================================" |
39 | echo "syncing logs for $USER from $A" |
40 | echo " to $LOG_DEST ..." |
41 | fi |
42 | |
29f492e6 |
43 | if test ! -d "$LOG_DEST"; then |
0ca8794c |
44 | echo "Error: $LOG_DEST does not exist, please make it" |
db4b486c |
45 | ERROR=yes |
0ca8794c |
46 | else |
dd381d21 |
47 | rm -fr $TMP_DEST |
1fc074fb |
48 | cp -r $LOG_SRC $TMP_DEST |
9b2935e9 |
49 | chown -R $USER:nogroup $TMP_DEST |
d78a78af |
50 | chmod -R u=rwX,go=X $TMP_DEST |
0ca8794c |
51 | k5start -qtU -f $KEYTAB_DIR/$USER \ |
9b2935e9 |
52 | -- su $USER -c "rsync -a $TMP_DEST/ $LOG_DEST/" |
dd381d21 |
53 | rm -fr $TMP_DEST |
29f492e6 |
54 | test "$VERBOSE" = "true" && echo " done." |
0ca8794c |
55 | fi |
8c0a105d |
56 | done |
db4b486c |
57 | |
29f492e6 |
58 | if test "$ERROR" = "yes"; then |
db4b486c |
59 | exit 1 |
60 | else |
61 | exit 0 |
62 | fi |
63 | |