3 # Create, update or delete a postgres user
5 require './postgresql-lib.pl';
7 $access{'users'} || &error($text{'user_ecannot'});
8 &error_setup($text{'user_err'});
11 # just delete the user
12 &execute_sql_logged($config{'basedb'}, "drop user \"$in{'user'}\"");
13 &webmin_log("delete", "user", $in{'user'});
17 $version = &get_postgresql_version();
18 if ($in{'ppass_def'} == 0) {
19 $in{'ppass'} =~ /^\S+$/ || &error($text{'user_epass'});
20 $sql .= $version >= 7 ? " with password '$in{'ppass'}'"
21 : " with password $in{'ppass'}";
23 elsif ($in{'pass_def'} == 1) {
24 $sql .= " with password ''";
30 $sql .= " nocreatedb";
33 $sql .= " createuser";
36 $sql .= " nocreateuser";
38 if (!$in{'until_def'}) {
39 $sql .= " valid until '$in{'until'}'";
42 $in{'pname'} =~ /^\S+$/ || &error($text{'user_ename'});
43 &execute_sql_logged($config{'basedb'},
44 "create user \"$in{'pname'}\" $sql");
45 &webmin_log("create", "user", $in{'pname'});
48 &execute_sql_logged($config{'basedb'},
49 "alter user \"$in{'user'}\" $sql");
50 if (&get_postgresql_version() >= 7.4 &&
51 $in{'pname'} ne $in{'user'}) {
53 &execute_sql_logged($config{'basedb'},
54 "alter user \"$in{'user'}\" ".
55 "rename to \"$in{'pname'}\"");
57 &webmin_log("modify", "user", $in{'user'});
60 &redirect("list_users.cgi");