source: trunk/third/moira/gen/acl.sh @ 24319

Revision 24319, 2.5 KB checked in by broder, 15 years ago (diff)
New Moira snapshot from SVN.
  • Property svn:executable set to *
RevLine 
[23095]1#!/bin/sh
[24319]2# $Id: acl.sh 3956 2010-01-05 20:56:56Z zacheiss $
[23095]3if [ -d /var/athena ] && [ -w /var/athena ]; then
4    exec >/var/athena/moira_update.log 2>&1
5else
6    exec >/tmp/moira_update.log 2>&1
7fi
8
9# The following exit codes are defined and MUST BE CONSISTENT with the
10# error codes the library uses:
11MR_NOCRED=47836470
12MR_MISSINGFILE=47836473
13MR_MKCRED=47836474
14MR_TARERR=47836476
15
16status=0
17
18PATH=/bin:/usr/bin
19TARFILE=/var/tmp/acl.out
20SRCDIR=/var/tmp/acltmp
21
22# Alert if the tar file does not exist
23test -r $TARFILE || exit $MR_MISSINGFILE
24
25# Make a temporary directory to unpack the tar file into
26rm -rf $SRCDIR
27mkdir $SRCDIR || exit $MR_MKCRED
28cd $SRCDIR || exit $MR_MKCRED
29tar xpf $TARFILE || exit $MR_TARERR
30
31# Copy over each file which is new or has changed
32for file in `find . -type f -print | sed -e 's/^\.//'`; do
33    if [ $file = /etc/passwd -o $file = /etc/passwd.local ]; then
34        # Make sure that there is a head file, or that the generated
35        # file contains an entry for root.
36        if [ ! -f $file.head ]; then
37            if egrep -s ^root: .$file; then
38                :
39            else
40                status=$MR_MISSINGFILE
41                break
42            fi
43        fi
44    elif [ $file = /etc/group -o $file = /etc/group.local ]; then
45        # Make sure that there is a head file, or that the generated
46        # file contains a group with gid 0.
47        if [ ! -f $file.head ]; then
48            if awk -F: '$3 == "0" { exit 1; }' $file; then
49                status=$MR_MISSINGFILE
50                break
51            fi
52        fi
53    fi
54
55    if [ -f $file.head ]; then
56        head=$file.head
57    else
58        head=
59    fi
60    if [ -f $file.tail ]; then
61        tail=$file.tail
62    else
63        tail=
64    fi
65
66    # Note that "$file" is a full pathname, and so ".$file" means
67    # the copy of file in the directory hierarchy rooted at ".",
68    # not "$file with a . prepended to its basename".
69
70    # Create a tmp file with the correct owner and mode
71    if [ -f $file ]; then
72        cp -p $file $file.$$
73    else
74        cp -p .$file $file.$$
75    fi
76
77    # Now dump the correct data into the tmp file without changing its
78    # owner and mode
79    cat $head .$file $tail > $file.$$
80
81    if cmp -s $file.$$ $file; then
82        rm -f $file.$$
83    else
84        mv $file.$$ $file
85    fi
86done
87
88# Test if a site-specific post dcm script exists, and run it if it does
89if [ -x /etc/athena/postacldcm ]; then
90    /etc/athena/postacldcm >/dev/null 2>&1
91    if [ $? != 0 ]; then
92        exit $MR_NOCRED
93    fi
94elif [ -x /usr/local/sbin/postacldcm ]; then
95    /usr/local/sbin/postacldcm >/dev/null 2>&1
96    if [ $? != 0 ]; then
97        exit $MR_NOCRED
98    fi
99fi
100
101# cleanup
102cd /
103rm -rf $SRCDIR
104test -f $TARFILE && rm -f $TARFILE
105test -f $0 && rm -f $0
106
107exit $status
Note: See TracBrowser for help on using the repository browser.