2 # Delete a bunch of access control rules
4 require './ldap-server-lib.pl';
5 &error_setup($text{'dacl_err'});
6 &local_ldap_server() == 1 || &error($text{'slapd_elocal'});
7 $access{'acl'} || &error($text{'acl_ecannot'});
10 # Filter out un-wanted rules
13 if (&get_config_type() == 1) {
14 $conf = &get_config();
15 @access = &find("access", $conf);
18 $defdb = &get_default_db();
19 $conf = &get_ldif_config();
20 @access = &find_ldif("olcAccess", $conf, $defdb);
23 %d = map { $_, 1 } split(/\0/, $in{'d'});
24 keys(%d) || &error($text{'dacl_enone'});
25 for($i=0; $i<@access; $i++) {
26 push(@newaccess, $access[$i]) if (!$d{$i});
30 if (&get_config_type() == 1) {
31 &save_directive($conf, "access", @newaccess);
34 &save_ldif_directive($conf, "olcAccess", $defdb, @newaccess);
37 &unlock_slapd_files();
39 &webmin_log("delete", "accesses", scalar(keys(%d)));
40 &redirect("edit_acl.cgi");