test041-aci revision 1.1.1.2 1 1.1 lukem #! /bin/sh
2 1.1.1.2 lukem # OpenLDAP: pkg/ldap/tests/scripts/test041-aci,v 1.9.2.5 2009/01/22 00:01:20 kurt Exp
3 1.1 lukem ## This work is part of OpenLDAP Software <http://www.openldap.org/>.
4 1.1 lukem ##
5 1.1.1.2 lukem ## Copyright 1998-2009 The OpenLDAP Foundation.
6 1.1 lukem ## All rights reserved.
7 1.1 lukem ##
8 1.1 lukem ## Redistribution and use in source and binary forms, with or without
9 1.1 lukem ## modification, are permitted only as authorized by the OpenLDAP
10 1.1 lukem ## Public License.
11 1.1 lukem ##
12 1.1 lukem ## A copy of this license is available in the file LICENSE in the
13 1.1 lukem ## top-level directory of the distribution or, alternatively, at
14 1.1 lukem ## <http://www.OpenLDAP.org/license.html>.
15 1.1 lukem
16 1.1 lukem case "$BACKEND" in
17 1.1 lukem bdb|hdb)
18 1.1 lukem ;;
19 1.1 lukem *)
20 1.1 lukem echo "Test does not support $BACKEND backend"
21 1.1 lukem exit 0
22 1.1 lukem ;;
23 1.1 lukem esac
24 1.1 lukem
25 1.1 lukem echo "running defines.sh"
26 1.1 lukem . $SRCDIR/scripts/defines.sh
27 1.1 lukem
28 1.1 lukem if test "$ACI" = "acino" ; then
29 1.1 lukem echo "ACI not enabled, test skipped"
30 1.1 lukem exit 0
31 1.1 lukem fi
32 1.1 lukem
33 1.1 lukem mkdir -p $TESTDIR $DBDIR1
34 1.1 lukem
35 1.1 lukem echo "Running slapadd to build slapd database..."
36 1.1 lukem . $CONFFILTER $BACKEND $MONITORDB < $ACICONF > $CONF1
37 1.1 lukem $SLAPADD -f $CONF1 -l $LDIFORDERED
38 1.1 lukem RC=$?
39 1.1 lukem if test $RC != 0 ; then
40 1.1 lukem echo "slapadd failed ($RC)!"
41 1.1 lukem exit $RC
42 1.1 lukem fi
43 1.1 lukem
44 1.1 lukem echo "Starting slapd on TCP/IP port $PORT1..."
45 1.1 lukem $SLAPD -f $CONF1 -h $URI1 -d $LVL $TIMING > $LOG1 2>&1 &
46 1.1 lukem PID=$!
47 1.1 lukem if test $WAIT != 0 ; then
48 1.1 lukem echo PID $PID
49 1.1 lukem read foo
50 1.1 lukem fi
51 1.1 lukem KILLPIDS="$PID"
52 1.1 lukem
53 1.1 lukem sleep 1
54 1.1 lukem
55 1.1 lukem echo "Testing slapd ACI access control..."
56 1.1 lukem for i in 0 1 2 3 4 5; do
57 1.1 lukem $LDAPSEARCH -s base -b "$MONITOR" -h $LOCALHOST -p $PORT1 \
58 1.1 lukem 'objectclass=*' > /dev/null 2>&1
59 1.1 lukem RC=$?
60 1.1 lukem if test $RC = 0 ; then
61 1.1 lukem break
62 1.1 lukem fi
63 1.1 lukem echo "Waiting 5 seconds for slapd to start..."
64 1.1 lukem sleep 5
65 1.1 lukem done
66 1.1 lukem
67 1.1 lukem if test $RC != 0 ; then
68 1.1 lukem echo "ldapsearch failed ($RC)!"
69 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
70 1.1 lukem exit $RC
71 1.1 lukem fi
72 1.1 lukem
73 1.1 lukem cat /dev/null > $SEARCHOUT
74 1.1 lukem cat /dev/null > $TESTOUT
75 1.1 lukem
76 1.1 lukem # Search must fail
77 1.1 lukem BASEDN="dc=example,dc=com"
78 1.1 lukem echo "Searching \"$BASEDN\" (should fail)..."
79 1.1 lukem echo "# Searching \"$BASEDN\" (should fail)..." >> $SEARCHOUT
80 1.1 lukem $LDAPSEARCH -s base -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
81 1.1 lukem '(objectclass=*)' >> $SEARCHOUT 2>> $TESTOUT
82 1.1 lukem RC=$?
83 1.1 lukem if test $RC != 32 ; then
84 1.1 lukem echo "ldapsearch should have failed with noSuchObject ($RC)!"
85 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
86 1.1 lukem if test $RC = 0 ; then
87 1.1 lukem exit -1
88 1.1 lukem fi
89 1.1 lukem exit $RC
90 1.1 lukem fi
91 1.1 lukem
92 1.1 lukem # Bind must fail
93 1.1 lukem BINDDN="cn=Barbara Jensen,ou=Information Technology Division,ou=People,dc=example,dc=com"
94 1.1 lukem BINDPW=bjensen
95 1.1 lukem echo "Testing ldapwhoami as ${BINDDN} (should fail)..."
96 1.1 lukem $LDAPWHOAMI -h $LOCALHOST -p $PORT1 -D "$BINDDN" -w $BINDPW
97 1.1 lukem RC=$?
98 1.1 lukem if test $RC = 0 ; then
99 1.1 lukem echo "ldapwhoami should have failed!"
100 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
101 1.1 lukem exit -1
102 1.1 lukem fi
103 1.1 lukem
104 1.1 lukem # Populate ACIs
105 1.1 lukem echo "Writing ACIs as \"$MANAGERDN\"..."
106 1.1 lukem $LDAPMODIFY -D "$MANAGERDN" -w $PASSWD -h $LOCALHOST -p $PORT1 \
107 1.1 lukem >> $TESTOUT 2>&1 << EOMODS0
108 1.1 lukem dn: dc=example,dc=com
109 1.1 lukem changetype: modify
110 1.1 lukem add: OpenLDAPaci
111 1.1 lukem OpenLDAPaci: 0#subtree#grant;d,c,s,r;[all]#group/groupOfUniqueNames/uniqueMe
112 1.1 lukem mber#cn=ITD Staff,ou=Groups,dc=example,dc=com
113 1.1 lukem OpenLDAPaci: 1#entry#grant;d;[all]#public#
114 1.1 lukem
115 1.1 lukem dn: ou=People,dc=example,dc=com
116 1.1 lukem changetype: modify
117 1.1 lukem add: OpenLDAPaci
118 1.1 lukem OpenLDAPaci: 0#subtree#grant;x;userPassword#public#
119 1.1 lukem OpenLDAPaci: 1#subtree#grant;w;userPassword#self#
120 1.1 lukem OpenLDAPaci: 2#subtree#grant;w;userPassword#access-id#cn=Bjorn Jensen,ou=Inf
121 1.1 lukem ormation Technology Division,ou=People,dc=example,dc=com
122 1.1 lukem
123 1.1 lukem dn: ou=Groups,dc=example,dc=com
124 1.1 lukem changetype: modify
125 1.1 lukem add: OpenLDAPaci
126 1.1 lukem OpenLDAPaci: 0#entry#grant;s;[all]#public#
127 1.1 lukem OpenLDAPaci: 1#children#grant;r;member;r;uniqueMember#access-id#cn=Bjorn Jen
128 1.1 lukem sen,ou=Information Technology Division,ou=People,dc=example,dc=com
129 1.1 lukem EOMODS0
130 1.1 lukem RC=$?
131 1.1 lukem if test $RC != 0 ; then
132 1.1 lukem echo "ldapmodify failed ($RC)!"
133 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
134 1.1 lukem exit $RC
135 1.1 lukem fi
136 1.1 lukem
137 1.1 lukem # Search must succeed with no results
138 1.1 lukem BASEDN="dc=example,dc=com"
139 1.1 lukem echo "Searching \"$BASEDN\" (should succeed with no results)..."
140 1.1 lukem echo "# Searching \"$BASEDN\" (should succeed with no results)..." >> $SEARCHOUT
141 1.1 lukem $LDAPSEARCH -s base -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
142 1.1 lukem '(objectclass=*)' >> $SEARCHOUT 2>> $TESTOUT
143 1.1 lukem RC=$?
144 1.1 lukem if test $RC != 0 ; then
145 1.1 lukem ### TEMPORARY (see ITS#3963)
146 1.1 lukem echo "ldapsearch failed ($RC)! IGNORED..."
147 1.1 lukem ###echo "ldapsearch failed ($RC)!"
148 1.1 lukem ###test $KILLSERVERS != no && kill -HUP $KILLPIDS
149 1.1 lukem ###exit $RC
150 1.1 lukem fi
151 1.1 lukem
152 1.1 lukem BINDDN="cn=Barbara Jensen,ou=Information Technology Division,ou=People,dc=example,dc=com"
153 1.1 lukem BINDPW=bjensen
154 1.1 lukem echo "Testing ldapwhoami as ${BINDDN}..."
155 1.1 lukem $LDAPWHOAMI -h $LOCALHOST -p $PORT1 -D "$BINDDN" -w $BINDPW
156 1.1 lukem RC=$?
157 1.1 lukem if test $RC != 0 ; then
158 1.1 lukem echo "ldapwhoami failed ($RC)!"
159 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
160 1.1 lukem exit $RC
161 1.1 lukem fi
162 1.1 lukem
163 1.1 lukem # Search must succeed
164 1.1 lukem BINDDN="cn=Bjorn Jensen,ou=Information Technology Division,ou=People,dc=example,dc=com"
165 1.1 lukem BINDPW=bjorn
166 1.1 lukem BASEDN="dc=example,dc=com"
167 1.1 lukem echo "Searching \"$BASEDN\" as \"$BINDDN\" (should succeed)..."
168 1.1 lukem echo "# Searching \"$BASEDN\" as \"$BINDDN\" (should succeed)..." >> $SEARCHOUT
169 1.1 lukem $LDAPSEARCH -s base -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
170 1.1 lukem -D "$BINDDN" -w "$BINDPW" \
171 1.1 lukem '(objectClass=*)' >> $SEARCHOUT 2>> $TESTOUT
172 1.1 lukem RC=$?
173 1.1 lukem if test $RC != 0 ; then
174 1.1 lukem echo "ldapsearch failed ($RC)!"
175 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
176 1.1 lukem exit $RC
177 1.1 lukem fi
178 1.1 lukem
179 1.1 lukem # Passwd must succeed
180 1.1 lukem BINDDN="cn=Bjorn Jensen,ou=Information Technology Division,ou=People,dc=example,dc=com"
181 1.1 lukem BINDPW=bjorn
182 1.1 lukem TGT="cn=John Doe,ou=Information Technology Division,ou=People,dc=example,dc=com"
183 1.1 lukem NEWPW=jdoe
184 1.1 lukem echo "Setting \"$TGT\" password..."
185 1.1 lukem $LDAPPASSWD -h $LOCALHOST -p $PORT1 \
186 1.1 lukem -w "$BINDPW" -s "$NEWPW" \
187 1.1 lukem -D "$BINDDN" "$TGT" >> $TESTOUT 2>&1
188 1.1 lukem RC=$?
189 1.1 lukem if test $RC != 0 ; then
190 1.1 lukem echo "ldappasswd failed ($RC)!"
191 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
192 1.1 lukem exit $RC
193 1.1 lukem fi
194 1.1 lukem
195 1.1 lukem # Re-change as self...
196 1.1 lukem echo "Changing self password..."
197 1.1 lukem BINDDN="$TGT"
198 1.1 lukem BINDPW=$NEWPW
199 1.1 lukem TGT="cn=John Doe,ou=Information Technology Division,ou=People,dc=example,dc=com"
200 1.1 lukem NEWPW=newcred
201 1.1 lukem $LDAPPASSWD -h $LOCALHOST -p $PORT1 \
202 1.1 lukem -w "$BINDPW" -s "$NEWPW" \
203 1.1 lukem -D "$BINDDN" "$TGT" >> $TESTOUT 2>&1
204 1.1 lukem RC=$?
205 1.1 lukem if test $RC != 0 ; then
206 1.1 lukem echo "ldappasswd failed ($RC)!"
207 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
208 1.1 lukem exit $RC
209 1.1 lukem fi
210 1.1 lukem
211 1.1 lukem # Searching groups
212 1.1 lukem BINDPW=$NEWPW
213 1.1 lukem BASEDN="ou=Groups,dc=example,dc=com"
214 1.1 lukem echo "Searching \"$BASEDN\" as \"$BINDDN\" (should succeed)..."
215 1.1 lukem echo "# Searching \"$BASEDN\" as \"$BINDDN\" (should succeed)..." >> $SEARCHOUT
216 1.1 lukem $LDAPSEARCH -s one -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
217 1.1 lukem -D "$BINDDN" -w "$BINDPW" \
218 1.1 lukem '(objectClass=*)' >> $SEARCHOUT 2>> $TESTOUT
219 1.1 lukem RC=$?
220 1.1 lukem if test $RC != 0 ; then
221 1.1 lukem echo "ldapsearch failed ($RC)!"
222 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
223 1.1 lukem exit $RC
224 1.1 lukem fi
225 1.1 lukem
226 1.1 lukem # Search must fail
227 1.1 lukem BINDDN="cn=Barbara Jensen,ou=Information Technology Division,ou=People,dc=example,dc=com"
228 1.1 lukem BINDPW=bjensen
229 1.1 lukem echo "Searching \"$BASEDN\" as \"$BINDDN\" (should succeed with no results)..."
230 1.1 lukem echo "# Searching \"$BASEDN\" as \"$BINDDN\" (should succeed with no results)..." >> $SEARCHOUT
231 1.1 lukem $LDAPSEARCH -s one -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
232 1.1 lukem -D "$BINDDN" -w "$BINDPW" \
233 1.1 lukem '(objectClass=*)' >> $SEARCHOUT 2>> $TESTOUT
234 1.1 lukem RC=$?
235 1.1 lukem if test $RC != 0 ; then
236 1.1 lukem echo "ldapsearch failed ($RC)!"
237 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
238 1.1 lukem exit $RC
239 1.1 lukem fi
240 1.1 lukem
241 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
242 1.1 lukem
243 1.1 lukem LDIF=$ACIOUT
244 1.1 lukem
245 1.1 lukem echo "Filtering ldapsearch results..."
246 1.1 lukem . $LDIFFILTER < $SEARCHOUT > $SEARCHFLT
247 1.1 lukem echo "Filtering original ldif used to create database..."
248 1.1 lukem . $LDIFFILTER < $LDIF > $LDIFFLT
249 1.1 lukem echo "Comparing filter output..."
250 1.1 lukem $CMP $SEARCHFLT $LDIFFLT > $CMPOUT
251 1.1 lukem
252 1.1 lukem if test $? != 0 ; then
253 1.1 lukem echo "comparison failed - operations did not complete correctly"
254 1.1 lukem exit 1
255 1.1 lukem fi
256 1.1 lukem
257 1.1 lukem echo ">>>>> Test succeeded"
258 1.1 lukem
259 1.1 lukem test $KILLSERVERS != no && wait
260 1.1 lukem
261 1.1 lukem exit 0
262