Server IP : 195.201.23.43 / Your IP : 3.144.46.149 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/virtual-server/ |
Upload File : |
#!/usr/bin/perl =head1 disconnect-database.pl Removes a database from the control of a virtual server. This command removes access to a database from the virtual server that owns it, but does not actually delete the database itself. You must provide the C<--domain> flag followed by a virtual server name, C<--type> followed by the DB type (like mysql or postgres), and C<--name> followed by the database name. =cut package virtual_server; if (!$module_name) { $main::no_acl_check++; $ENV{'WEBMIN_CONFIG'} ||= "/etc/webmin"; $ENV{'WEBMIN_VAR'} ||= "/var/webmin"; if ($0 =~ /^(.*)\/[^\/]+$/) { chdir($pwd = $1); } else { chop($pwd = `pwd`); } $0 = "$pwd/disconnect-database.pl"; require './virtual-server-lib.pl'; $< == 0 || die "delete-database.pl must be run as root"; } @OLDARGV = @ARGV; # Parse command-line args while(@ARGV > 0) { local $a = shift(@ARGV); if ($a eq "--domain") { $domain = shift(@ARGV); } elsif ($a eq "--name") { $name = shift(@ARGV); } elsif ($a eq "--type") { $type = shift(@ARGV); } elsif ($a eq "--multiline") { $multiline = 1; } elsif ($a eq "--help") { &usage(); } else { &usage("Unknown parameter $a"); } } $domain || &usage("No domain specified"); $name || &usage("No database name specified"); $type || &usage("No database type specified"); $d = &get_domain_by("dom", $domain); $d || usage("Virtual server $domain does not exist"); @dbs = &domain_databases($d); # Find the database object ($db) = grep { $_->{'name'} eq $name && $_->{'type'} eq $type } @dbs; $db || &usage("The specified database is not associated with this server"); # Do it $first_print = \&null_print; $second_print = \&null_print; if (&indexof($type, &list_database_plugins()) >= 0) { &plugin_call($type, "database_revoke", $d, $name); } else { $dfunc = "revoke_".$type."_database"; &$dfunc($d, $name); } # Save domain object @dbs = split(/\s+/, $d->{'db_'.$type}); @dbs = grep { $_ ne $name } @dbs; $d->{'db_'.$type} = join(" ", @dbs); &save_domain($d); &refresh_webmin_user($d); &run_post_actions(); &virtualmin_api_log(\@OLDARGV, $d); print "Database $name disconnected successfully\n"; sub usage { print "$_[0]\n\n" if ($_[0]); print "Removes a database from the control of a virtual server.\n"; print "\n"; print "virtualmin disconnect-database --domain domain.name\n"; print " --name database-name\n"; print " --type mysql|postgres\n"; exit(1); }Private