Current File : //usr/share/webmin/postgresql/edit_group.cgi
#!/usr/bin/perl
# edit_group.cgi
# Display a form for editing or creating a group

require './postgresql-lib.pl';
&ReadParse();
$access{'users'} || &error($text{'group_ecannot'});
if ($in{'new'}) {
	&ui_print_header(undef, $text{'group_create'}, "");
	}
else {
	&ui_print_header(undef, $text{'group_edit'}, "");
	$s = &execute_sql_safe($config{'basedb'}, "select * from pg_group ".
					     "where grosysid = '$in{'gid'}'");
	@group = @{$s->{'data'}->[0]};
	}

# Start of form block
print &ui_form_start("save_group.cgi");
print &ui_hidden("new", $in{'new'});
print &ui_table_start($text{'group_header'}, undef, 2);

# Group name
print &ui_table_row($text{'group_name'},
	&ui_textbox("name", $group[0], 40));

# Group ID, dynamically selected for new ones
if ($in{'new'}) {
	$s = &execute_sql($config{'basedb'},
			  "select max(grosysid) from pg_group");
	$gid = $s->{'data'}->[0]->[0] + 1;
	print &ui_table_row($text{'group_id'},
		&ui_textbox("gid", $gid, 10));
	}
else {
	print &ui_table_row($text{'group_id'}, $group[1]);
	print &ui_hidden("gid", $in{'gid'});
	print &ui_hidden("oldname", $group[0]);
	}

# Group members
($pg_table, $pg_cols) = &get_pg_shadow_table();
$s = &execute_sql($config{'basedb'}, "select $pg_cols from $pg_table");
%uidtouser = map { $_->[1], $_->[0] } @{$s->{'data'}};
if (!$in{'new'}) {
	@mems = map { [ $_, $uidtouser{$_} || $_ ] } &split_array($group[2]);
	}
@users = map { [ $_->[1], $_->[0] ] } @{$s->{'data'}};
print &ui_table_row($text{'group_mems'},
	&ui_multi_select("mems", \@mems, \@users, 10, 1, 0,
			 $text{'group_memsopts'}, $text{'group_memsvals'}));

# End of the form buttons
print &ui_table_end();
if ($in{'new'}) {
	print &ui_form_end([ [ undef, $text{'create'} ] ]);
	}
else {
	print &ui_form_end([ [ undef, $text{'save'} ],
			     [ 'delete', $text{'delete'} ] ]);
	}

&ui_print_footer("list_groups.cgi", $text{'group_return'});