Viewing file: delete-database.pl (2.24 KB) -rwxrwxr-x Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#!/usr/bin/perl
=head1 delete-database.pl
Deletes one database
To remove a single database from a virtual server and delete all of its contents, you can use this command. It takes the exact same parameters as the C<create-database> command : C<--domain>, C<--name> and C<--type>. Be careful using it, as the complete contents of the specified database will be removed without any prompting for confirmation.
=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/delete-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 &set_all_null_print(); if (&indexof($type, &list_database_plugins()) >= 0) { &plugin_call($type, "database_delete", $d, $name); } else { $dfunc = "delete_".$type."_database"; &$dfunc($d, $name); } &save_domain($d); &refresh_webmin_user($d); &run_post_actions(); &virtualmin_api_log(\@OLDARGV, $d); print "Database $name deleted successfully\n";
sub usage { print "$_[0]\n\n" if ($_[0]); print "Deletes a database associated with some virtual server.\n"; print "\n"; print "virtualmin delete-database --domain domain.name\n"; print " --name database-name\n"; print " --type mysql|postgres\n"; exit(1); }
|