1 |
diff -up e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-delete.better-ldap e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-delete |
diff -Nur -x '*.orig' -x '*.rej' e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-delete mezzanine_patched_e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-delete |
2 |
--- e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-delete.better-ldap 2010-11-02 13:37:55.000000000 -0600 |
--- e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-delete 2010-11-04 16:43:36.000000000 +0100 |
3 |
+++ e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-delete 2010-11-02 13:38:04.000000000 -0600 |
+++ mezzanine_patched_e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-delete 2010-11-04 16:42:13.000000000 +0100 |
4 |
@@ -25,6 +25,7 @@ |
@@ -25,6 +25,7 @@ |
5 |
|
|
6 |
event=$1 |
event=$1 |
9 |
if [ -z "$ibay" ] |
if [ -z "$ibay" ] |
10 |
then |
then |
11 |
echo ibayName argument missing |
echo ibayName argument missing |
12 |
@@ -32,12 +33,15 @@ then |
@@ -32,12 +33,17 @@ |
13 |
fi |
fi |
14 |
|
|
15 |
ldapauth=$(/sbin/e-smith/config getprop ldap Authentication || echo disabled) |
ldapauth=$(/sbin/e-smith/config getprop ldap Authentication || echo disabled) |
19 |
-if [ "$ldapauth" == "enabled" ] |
-if [ "$ldapauth" == "enabled" ] |
20 |
+if [ "$ldapauth" != "enabled" ] |
+if [ "$ldapauth" != "enabled" ] |
21 |
then |
then |
|
- /usr/sbin/cpu userdel "$ibay" |
|
|
- /usr/sbin/cpu -C/etc/cpu-system.conf groupdel "$ibay" |
|
|
-else |
|
|
- exec /usr/sbin/userdel "$ibay" |
|
22 |
+ /usr/sbin/userdel "$ibay" || x=1 |
+ /usr/sbin/userdel "$ibay" || x=1 |
23 |
|
/usr/sbin/cpu -C/etc/cpu-system.conf userdel "$ibay" |
24 |
|
/usr/sbin/cpu -C/etc/cpu-system.conf groupdel "$ibay" |
25 |
|
else |
26 |
|
- exec /usr/sbin/userdel "$ibay" |
27 |
|
+ /usr/sbin/cpu userdel "$ibay" || x=1 |
28 |
|
+ /usr/sbin/cpu -C/etc/cpu-system.conf groupdel "$ibay" || x=1 |
29 |
fi |
fi |
30 |
+ |
+ |
|
+/usr/sbin/cpu userdel "$ibay" || x=1 |
|
|
+/usr/sbin/cpu -C/etc/cpu-system.conf groupdel "$ibay" || x=1 |
|
|
+ |
|
31 |
+exit $x |
+exit $x |
32 |
diff -up e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-modify.better-ldap e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-modify |
diff -Nur -x '*.orig' -x '*.rej' e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-modify mezzanine_patched_e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-modify |
33 |
--- e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-modify.better-ldap 2010-11-02 13:37:55.000000000 -0600 |
--- e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-modify 2010-11-04 16:43:36.000000000 +0100 |
34 |
+++ e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-modify 2010-11-02 13:38:56.000000000 -0600 |
+++ mezzanine_patched_e-smith-ibays-2.2.0/root/etc/e-smith/events/actions/ibay-modify 2010-11-04 16:43:26.000000000 +0100 |
35 |
@@ -32,6 +32,7 @@ my $conf = esmith::ConfigDB->open_ro |
@@ -32,6 +32,7 @@ |
36 |
or die "Could not open Config DB"; |
or die "Could not open Config DB"; |
37 |
|
|
38 |
my $ldapauth = $conf->get('ldap')->prop('Authentication') || 'disabled'; |
my $ldapauth = $conf->get('ldap')->prop('Authentication') || 'disabled'; |
40 |
|
|
41 |
$ENV{'PATH'} = "/bin"; |
$ENV{'PATH'} = "/bin"; |
42 |
|
|
43 |
@@ -55,41 +56,14 @@ if ($event eq 'ibay-create') |
@@ -55,41 +56,14 @@ |
44 |
|
|
45 |
# Create the ibay's unique group first |
# Create the ibay's unique group first |
46 |
|
|
84 |
|
|
85 |
system( |
system( |
86 |
"/usr/sbin/useradd", |
"/usr/sbin/useradd", |
87 |
@@ -108,16 +82,41 @@ if ($event eq 'ibay-create') |
@@ -108,16 +82,41 @@ |
88 |
"-s", |
"-s", |
89 |
"/bin/false", |
"/bin/false", |
90 |
"$ibayName" |
"$ibayName" |
91 |
- ) == 0 or die "Failed to create account $ibayName.\n"; |
- ) == 0 or die "Failed to create account $ibayName.\n"; |
92 |
+ ) == 0 or ( $x = 255, warn "Failed to create (unix) account $ibayName.\n"; |
+ ) == 0 or ( $x = 255, warn "Failed to create (unix) account $ibayName.\n" ); |
93 |
} |
} |
94 |
|
|
95 |
+ system( |
+ system( |
97 |
+ "-g", |
+ "-g", |
98 |
+ $ibay->prop("Gid"), |
+ $ibay->prop("Gid"), |
99 |
+ $ibayName |
+ $ibayName |
100 |
+ ) == 0 or ( $x = 255, warn "Failed to create (ldap) group $ibayName.\n" ); |
+ ) == 0 or ( $x = $ldapauth ne 'enabled' ? $x : 255, warn "Failed to create (ldap) group $ibayName.\n" ); |
101 |
+ |
+ |
102 |
+ system( |
+ system( |
103 |
+ "/usr/sbin/cpu", "useradd", |
+ "/usr/sbin/cpu", "-C/etc/cpu-system.conf", "useradd", |
104 |
+ "-u", |
+ "-u", |
105 |
+ $ibay->prop("Uid"), |
+ $ibay->prop("Uid"), |
106 |
+ "-g", |
+ "-g", |
115 |
+ "-s", |
+ "-s", |
116 |
+ "/bin/false", |
+ "/bin/false", |
117 |
+ "$ibayName" |
+ "$ibayName" |
118 |
+ ) == 0 or ( $x = 255, warn "Failed to create (ldap) account $ibayName.\n" ); |
+ ) == 0 or ( $x = $ldapauth ne 'enabled' ? $x : 255, warn "Failed to create (ldap) account $ibayName.\n" ); |
119 |
+ |
+ |
120 |
#------------------------------------------------------------ |
#------------------------------------------------------------ |
121 |
# Create the ibay files and set the password. |
# Create the ibay files and set the password. |
128 |
|
|
129 |
processTemplate( { |
processTemplate( { |
130 |
TEMPLATE_PATH=>"/home/e-smith/files/ibays/html/index.html", |
TEMPLATE_PATH=>"/home/e-smith/files/ibays/html/index.html", |
131 |
@@ -125,16 +124,14 @@ if ($event eq 'ibay-create') |
@@ -125,16 +124,14 @@ |
132 |
MORE_DATA=>{IBAY_NAME=>$ibayName}, |
MORE_DATA=>{IBAY_NAME=>$ibayName}, |
133 |
} ); |
} ); |
134 |
|
|
145 |
+ or ( $x = 255, warn "Error locking (unix) account $ibayName" ); |
+ or ( $x = 255, warn "Error locking (unix) account $ibayName" ); |
146 |
} |
} |
147 |
+ |
+ |
148 |
+ system("/usr/sbin/cpu", "usermod", "-L", $ibayName) == 0 |
+ system("/usr/sbin/cpu", "-C/etc/cpu-system.conf", "usermod", "-L", $ibayName) == 0 |
149 |
+ or ( $x = 255, warn "Error locking (ldap) account $ibayName" ); |
+ or ( $x = $ldapauth ne 'enabled' ? $x : 255, warn "Error locking (ldap) account $ibayName" ); |
150 |
} |
} |
151 |
elsif ($event eq 'ibay-modify') |
elsif ($event eq 'ibay-modify') |
152 |
{ |
{ |
153 |
@@ -142,19 +139,16 @@ elsif ($event eq 'ibay-modify') |
@@ -142,19 +139,16 @@ |
154 |
# Modify ibay description in /etc/passwd using "usermod" |
# Modify ibay description in /etc/passwd using "usermod" |
155 |
#------------------------------------------------------------ |
#------------------------------------------------------------ |
156 |
|
|
169 |
+ or ( $x = 255, warn "Failed to modify (unix) account $ibayName.\n" ); |
+ or ( $x = 255, warn "Failed to modify (unix) account $ibayName.\n" ); |
170 |
} |
} |
171 |
|
|
172 |
+ system("/usr/sbin/cpu", "usermod", "-c", $ibay->prop("Name"), |
+ system("/usr/sbin/cpu", "-C/etc/cpu-system.conf", "usermod", "-c", $ibay->prop("Name"), |
173 |
+ "-G", "shared," . $ibay->prop("Group"), "$ibayName") == 0 |
+ "-G", "shared," . $ibay->prop("Group"), "$ibayName") == 0 |
174 |
+ or ( $x = 255, warn "Failed to modify (ldap) account $ibayName.\n" ); |
+ or ( $x = $ldapauth ne 'enabled' ? $x : 255, warn "Failed to modify (ldap) account $ibayName.\n" ); |
175 |
} |
} |
176 |
|
|
177 |
#------------------------------------------------------------ |
#------------------------------------------------------------ |
178 |
@@ -166,7 +160,7 @@ elsif ($event eq 'ibay-modify') |
@@ -166,7 +160,7 @@ |
179 |
#-------------------------------------------------- |
#-------------------------------------------------- |
180 |
|
|
181 |
chdir "/home/e-smith/files/ibays/$ibayName" |
chdir "/home/e-smith/files/ibays/$ibayName" |
184 |
|
|
185 |
mkdir '.AppleDesktop' unless (-d '.AppleDesktop'); |
mkdir '.AppleDesktop' unless (-d '.AppleDesktop'); |
186 |
|
|
187 |
@@ -237,3 +231,5 @@ sub process |
@@ -237,3 +231,5 @@ |
188 |
} |
} |
189 |
|
|
190 |
find(\&process, glob("* .AppleDesktop")); |
find(\&process, glob("* .AppleDesktop")); |