Private
Server IP : 195.201.23.43  /  Your IP : 3.147.78.134
Web Server : Apache
System : Linux webserver2.vercom.be 5.4.0-192-generic #212-Ubuntu SMP Fri Jul 5 09:47:39 UTC 2024 x86_64
User : kdecoratie ( 1041)
PHP Version : 7.1.33-63+ubuntu20.04.1+deb.sury.org+1
Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : OFF  |  Sudo : ON  |  Pkexec : ON
Directory :  /usr/share/webmin/postgresql/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME SHELL ]     

Current File : /usr/share/webmin/postgresql/delete_grants.cgi
#!/usr/bin/perl
# Reset privilege grants on some table/view/index

require './postgresql-lib.pl';
&ReadParse();
&error_setup($text{'dgrant_err'});
$access{'users'} || &error($text{'grant_ecannot'});
@d = split(/\0/, $in{'d'});
@d || &error($text{'dgrant_enone'});

foreach $d (@d) {
	($db, $table, $ns, $type) = split(/\//, $d, -1);
	$ss = &supports_schemas($db);

	# Get old privileges
	if ($ss) {
		$s = &execute_sql($db, 'select relname, relacl, nspname from pg_class, pg_namespace where relnamespace = pg_namespace.oid and (relkind = \'r\' OR relkind = \'S\') and relname !~ \'^pg_\' order by relname');
		$ss = 1;
		}
	else {
		$s = &execute_sql($db, 'select relname, relacl, \'public\' from pg_class where (relkind = \'r\' OR relkind = \'S\') and relname !~ \'^pg_\' order by relname');
		$ss = 0;
		}
	foreach $g (@{$s->{'data'}}) {
		if ($g->[0] eq $table &&
		    $g->[2] eq $ns) {
			$g->[1] =~ s/^\{//; $g->[1] =~ s/\}$//;
			@grant = map { /^"(.*)=(.*)"$/ || /^(.*)=(.*)$/; [ $1, $2 ] }
				     split(/,/, $g->[1]);
			}
		}

	# Revoke them
	$qt = $ss ? &quote_table($ns.".".$table)
		  : &quote_table($table);
	foreach $g (@grant) {
		next if (!$g->[1]);
		if ($g->[0] eq '') {
			$who = "public";
			}
		elsif ($g->[0] =~ /group\s+(\S+)/) {
			$who = "group \"$1\"";
			}
		else {
			$who = "\"$g->[0]\"";
			}
		&execute_sql_logged($db, "revoke all on $qt from $who");
		}
	}

&webmin_log("degrant", undef, scalar(@d));
&redirect("list_grants.cgi?search=".&urlize($in{'search'}));

Private