webmin/postgresql/save_user.cgi

65 lines
1.6 KiB
Plaintext
Raw Permalink Normal View History

2007-04-12 20:24:50 +00:00
#!/usr/local/bin/perl
# save_user.cgi
# Create, update or delete a postgres user
require './postgresql-lib.pl';
&ReadParse();
$access{'users'} || &error($text{'user_ecannot'});
&error_setup($text{'user_err'});
if ($in{'delete'}) {
# just delete the user
$main::disable_postgresql_escaping = 1;
2007-04-12 20:24:50 +00:00
&execute_sql_logged($config{'basedb'}, "drop user \"$in{'user'}\"");
&webmin_log("delete", "user", $in{'user'});
}
else {
# parse inputs
$version = &get_postgresql_version();
2011-02-12 17:35:31 -08:00
if ($in{'ppass_def'} == 0) {
$in{'ppass'} =~ /^\S+$/ || &error($text{'user_epass'});
$sql .= $version >= 7 ? " with password '$in{'ppass'}'"
: " with password $in{'ppass'}";
2007-04-12 20:24:50 +00:00
}
elsif ($in{'pass_def'} == 1) {
$sql .= " with password ''";
}
if ($in{'db'}) {
$sql .= " createdb";
}
else {
$sql .= " nocreatedb";
}
if (&get_postgresql_version() < 9.5) {
if ($in{'other'}) {
$sql .= " createuser";
}
else {
$sql .= " nocreateuser";
}
2007-04-12 20:24:50 +00:00
}
if (!$in{'until_def'}) {
$sql .= " valid until '$in{'until'}'";
}
if ($in{'new'}) {
2011-02-12 17:35:31 -08:00
$in{'pname'} =~ /^\S+$/ || &error($text{'user_ename'});
2007-04-12 20:24:50 +00:00
&execute_sql_logged($config{'basedb'},
2011-02-12 17:35:31 -08:00
"create user \"$in{'pname'}\" $sql");
&webmin_log("create", "user", $in{'pname'});
2007-04-12 20:24:50 +00:00
}
else {
&execute_sql_logged($config{'basedb'},
"alter user \"$in{'user'}\" $sql");
if (&get_postgresql_version() >= 7.4 &&
2011-02-12 17:35:31 -08:00
$in{'pname'} ne $in{'user'}) {
2007-04-12 20:24:50 +00:00
# Rename too
&execute_sql_logged($config{'basedb'},
"alter user \"$in{'user'}\" ".
2011-02-12 17:35:31 -08:00
"rename to \"$in{'pname'}\"");
2007-04-12 20:24:50 +00:00
}
&webmin_log("modify", "user", $in{'user'});
}
}
&redirect("list_users.cgi");