Skip to content

Commit

Permalink
democleanup needs to restart starman after cleaning config files.
Browse files Browse the repository at this point in the history
  • Loading branch information
perlDreamer committed Feb 9, 2012
1 parent 734098b commit 5f4099a
Showing 1 changed file with 27 additions and 18 deletions.
45 changes: 27 additions & 18 deletions wre/sbin/democleanup.pl
Expand Up @@ -16,6 +16,8 @@
use WRE::Config;
use WRE::File;
use WRE::Mysql;
use WRE::Starman;
use 5.010.;

my ($all, $help, $verbose);
$|=1;
Expand All @@ -27,7 +29,7 @@
);

if ($help) {
print <<STOP;
say <<STOP;
Usage: $0
Expand All @@ -42,34 +44,34 @@
STOP
}

print "START UP.\n" if ($verbose);
print "Reading demo config.\n" if ($verbose);
say "START UP." if ($verbose);
say "Reading demo config." if ($verbose);
my $config = WRE::Config->new;
my $file = WRE::File->new(wreConfig=>$config);
print "Getting the list of demo sites.\n" if ($verbose);
say "Getting the list of demo sites." if ($verbose);
opendir(my $demodir, $config->getWebguiRoot("/etc"));
my @demos = ();
foreach my $file (readdir($demodir)) {
next unless $file =~ m/^demo/;
my $config = eval {Config::JSON->new($config->getWebguiRoot("/etc/".$file)) };
if ($@) {
print "Error reading $file\n" if ($verbose);
say "Error reading $file" if ($verbose);
}
else {
push @demos, $config;
}
}
closedir($demodir);

print "Deleting demos.\n" if ($verbose);
say "Deleting demos." if ($verbose);
foreach my $demo (@demos) {
my $demoId = $demo->getFilename;
$demoId =~ s/(demo.*)\.conf/$1/;
if ($all || time() - $demo->get("demoCreated") > $config->get("demo/duration") * 60 * 60 * 24) {
print "Deleting Site: ".$demoId."\n" if ($verbose);
say "Deleting Site: ".$demoId."" if ($verbose);

# database
print "\tConnecting to database.\n" if ($verbose);
say "\tConnecting to database." if ($verbose);
my $databaseName = $demo->get("dsn");
$databaseName =~ s/^DBI\:mysql\:(\w+).*$/$1/i;
my $databaseUser = $demo->get("dbuser");
Expand All @@ -79,31 +81,38 @@
username=>$config->get("demo/user")
)};
if ($@) {
print "\tCan't connect to database, so can't delete site.\n" if ($verbose);
say "\tCan't connect to database, so can't delete site." if ($verbose);
}
else {
print "\tDropping database.\n" if ($verbose);
say "\tDropping database." if ($verbose);
eval{$db->do("drop database $databaseName")};
print "\tError: $@\n" if ($@ && $verbose);
print "\tRevoking database privileges.\n" if ($verbose);
say "\tError: $@" if ($@ && $verbose);
say "\tRevoking database privileges." if ($verbose);
eval{$db->do("revoke all privileges on ".$databaseName.".* from '".$databaseUser."'\@'%'")};
print "\tError: $@\n" if ($@ && $verbose);
say "\tError: $@" if ($@ && $verbose);
$db->disconnect;

# web root
print "\tDeleting Web Root.\n" if ($verbose);
say "\tDeleting Web Root." if ($verbose);
$file->delete($config->getDomainRoot("/demo/".$demoId));

# webgui
print "\tDeleting WebGUI Config.\n" if ($verbose);
say "\tDeleting WebGUI Config." if ($verbose);
$file->delete($demo->getFilePath);

print "\tFinished deleting $demoId\n" if ($verbose);
say "\tFinished deleting $demoId" if ($verbose);
}
}
else {
print "Skipping Site: ".$demoId."\n" if ($verbose);
say "Skipping Site: ".$demoId if ($verbose);
}
}
print "COMPLETE.\n" if ($verbose);
say "Restarting Starman" if $verbose;
if (eval { WRE::Starman->new(wreConfig=>$config)->restart; }) {
say "OK" if $verbose;
}
else {
say "Failed: $@";
}
say "COMPLETE." if ($verbose);

0 comments on commit 5f4099a

Please sign in to comment.