2 # Create the LDAP base DN
4 require './acl-lib.pl';
5 $access{'pass'} || &error($text{'sql_ecannot'});
6 &get_miniserv_config(\%miniserv);
8 &error_setup($text{'makedn_err'});
10 $dbh = &connect_userdb($in{'userdb'});
11 ref($dbh) || &error($dbh);
13 &ui_print_unbuffered_header(undef, $text{'makedn_title'}, "");
15 # Work out object class for the DN
16 ($proto, $user, $pass, $host, $prefix, $argstr) =
17 &split_userdb_string($in{'userdb'});
18 $schema = $dbh->schema();
19 @allocs = map { $_->{'name'} }
20 grep { $_->{'structural'} }
21 $schema->all_objectclasses();
23 foreach my $poc ("top", "domain") {
24 if (&indexof($poc, @allocs) >= 0) {
28 @ocs || &error(&text('makedn_eoc'));
31 print &text('makedn_exec', "<tt>$prefix</tt>"),"<br>\n";
32 @attrs = ( "objectClass", \@ocs );
33 if (&indexof("domain", @ocs) >= 0 && $prefix =~ /^([^=]+)=([^, ]+)/) {
34 # Domain class needs dc
37 $rv = $dbh->add($prefix, attr => \@attrs);
38 if (!$rv || $rv->code) {
39 print &text('makedn_failed',
40 $rv ? $rv->error : "Unknown error"),"<p>\n";
43 print &text('makedn_done'),"<p>\n";
45 &disconnect_userdb($in{'userdb'}, $dbh);
48 $err = &validate_userdb($in{'userdb'}, 0);
50 print "<b>",&text('makedn_still', $err),"</b><p>\n";
53 &lock_file($ENV{'MINISERV_CONFIG'});
54 $miniserv{'userdb'} = $in{'userdb'};
55 $miniserv{'userdb_addto'} = $in{'addto'};
56 &put_miniserv_config(\%miniserv);
57 &unlock_file($ENV{'MINISERV_CONFIG'});
61 &ui_print_footer("", $text{'index_return'});