# XXX test with postgresql
# XXX LDAP support
+# XXX infinite loop on failure
=head2 list_users
{
my ($str) = @_;
my ($key, $auto, $idattrkey);
-if ($str =~ /^(mysql|postgresql):/) {
- $key = "primary key";
- }
if ($str =~ /^mysql:/) {
- $auto = "auto_increment";
- $idattrkey = ", primary key(id, attr)";
- $idattrmodulekey = ", primary key(id, module, attr)";
+ return ( "create table webmin_user ".
+ "(id int(20) not null primary key auto_increment, ".
+ "name varchar(255) not null, pass varchar(255))",
+ "create table webmin_group ".
+ "(id int(20) not null primary key auto_increment, ".
+ "name varchar(255) not null, ".
+ "description varchar(255))",
+ "create table webmin_user_attr ".
+ "(id int(20) not null, ".
+ "attr varchar(32) not null, ".
+ "value varchar(255), ".
+ "primary key(id, attr))",
+ "create table webmin_group_attr ".
+ "(id int(20) not null, ".
+ "attr varchar(32) not null, ".
+ "value varchar(255), ".
+ "primary key(id, attr))",
+ "create table webmin_user_acl ".
+ "(id int(20) not null, ".
+ "module varchar(32) not null, ".
+ "attr varchar(32) not null, ".
+ "value varchar(255), ".
+ "primary key(id, module, attr))",
+ "create table webmin_group_acl ".
+ "(id int(20) not null, ".
+ "module varchar(32) not null, ".
+ "attr varchar(32) not null, ".
+ "value varchar(255), ".
+ "primary key(id, module, attr))",
+ );
+ }
+elsif ($str =~ /^postgresql:/) {
+ return ( "create table webmin_user ".
+ "(id int8 not null primary key, ".
+ "name varchar(255), ".
+ "pass varchar(255))",
+ "create table webmin_group ".
+ "(id int8 not null primary key, ".
+ "name varchar(255), ".
+ "description varchar(255))",
+ "create table webmin_user_attr ".
+ "(id int8 not null, ".
+ "attr varchar(255) not null, ".
+ "value varchar(255), ".
+ "primary key(id, attr))",
+ "create table webmin_group_attr ".
+ "(id int8 not null, ".
+ "attr varchar(255) not null, ".
+ "value varchar(255), ".
+ "primary key(id, attr))",
+ "create table webmin_user_acl ".
+ "(id int8 not null, ".
+ "module varchar(255) not null, ".
+ "attr varchar(255) not null, ".
+ "value varchar(255), ".
+ "primary key(id, module, attr))",
+ "create table webmin_group_acl ".
+ "(id int8 not null, ".
+ "module varchar(255) not null, ".
+ "attr varchar(255) not null, ".
+ "value varchar(255), ".
+ "primary key(id, module, attr))",
+ );
}
-return ( "create table webmin_user (id int(20) not null $key $auto, name varchar(255) not null, pass varchar(255))",
- "create table webmin_group (id int(20) not null $key $auto, name varchar(255) not null, description varchar(255))",
- "create table webmin_user_attr (id int(20) not null, attr varchar(32) not null, value varchar(255) $idattrkey)",
- "create table webmin_group_attr (id int(20) not null, attr varchar(32) not null, value varchar(255) $idattrkey)",
- "create table webmin_user_acl (id int(20) not null, module varchar(32) not null, attr varchar(32) not null, value varchar(255) $idattrmodulekey)",
- "create table webmin_group_acl (id int(20) not null, module varchar(32) not null, attr varchar(32) not null, value varchar(255) $idattrmodulekey)",
- );
}
1;
&ReadParse();
&error_setup($text{'make_err'});
-$str = $miniserv{'userdb'};
-$dbh = &connect_userdb($str);
+$dbh = &connect_userdb($in{'userdb'});
ref($dbh) || &error($dbh);
&ui_print_unbuffered_header(undef, $text{'make_title'}, "");
-foreach $sql (&userdb_table_sql($str)) {
+# Create the tables
+foreach $sql (&userdb_table_sql($in{'userdb'})) {
print &text('make_exec', "<tt>".&html_escape($sql)."</tt>"),"<br>\n";
$cmd = $dbh->prepare($sql);
if (!$cmd || !$cmd->execute()) {
}
}
+# Check again if OK
+$err = &validate_userdb($in{'userdb'}, 0);
+if ($err) {
+ print "<b>",&text('make_still', $err),"</b><p>\n";
+ }
+else {
+ &lock_file($ENV{'MINISERV_CONFIG'});
+ $miniserv{'userdb'} = $in{'userdb'};
+ $miniserv{'userdb_addto'} = $in{'addto'};
+ &put_miniserv_config(\%miniserv);
+ &unlock_file($ENV{'MINISERV_CONFIG'});
+ &reload_miniserv();
+ }
+
&ui_print_footer("", $text{'index_return'});
&error($err) if ($err);
}
-&lock_file($ENV{'MINISERV_CONFIG'});
-$miniserv{'userdb'} = $str;
-$miniserv{'userdb_addto'} = $in{'addto'};
-&put_miniserv_config(\%miniserv);
-&unlock_file($ENV{'MINISERV_CONFIG'});
-&reload_miniserv();
&webmin_log("sql");
# Make sure tables exist
$err = &validate_userdb($str, 0);
if ($err) {
+ # Tables are missing, need to create first
&ui_print_header(undef, $text{'sql_title2'}, "");
print &text('sql_tableerr', $err),"<p>\n";
print $text{'sql_tableerr2'},"<p>\n";
print &ui_form_start("maketables.cgi");
+ print &ui_hidden("userdb", $str);
+ print &ui_hidden("userdb_addto", $in{'addto'});
print &ui_form_end([ [ undef, $text{'sql_make'} ] ]);
print &ui_table_start(undef, undef, 2);
&ui_print_footer("", $text{'index_return'});
}
else {
+ # Tables are OK, can save now
+ &lock_file($ENV{'MINISERV_CONFIG'});
+ $miniserv{'userdb'} = $str;
+ $miniserv{'userdb_addto'} = $in{'addto'};
+ &put_miniserv_config(\%miniserv);
+ &unlock_file($ENV{'MINISERV_CONFIG'});
+ &reload_miniserv();
&redirect("");
}