From 518df535b020606f1357e706bbd23f3a43e15f96 Mon Sep 17 00:00:00 2001 From: "lpsolit%gmail.com" <> Date: Fri, 7 Oct 2005 03:54:49 +0000 Subject: Bug 309796: Whining needs to check for shutdown (silently) before trying database access - Patch by Frédéric Buclin r=joel a=justdave MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Bugzilla.pm | 14 ++++++++++++++ whine.pl | 6 ------ 2 files changed, 14 insertions(+), 6 deletions(-) diff --git a/Bugzilla.pm b/Bugzilla.pm index 99e5c3add..71e29a222 100644 --- a/Bugzilla.pm +++ b/Bugzilla.pm @@ -49,6 +49,11 @@ use constant SHUTDOWNHTML_EXEMPT => [ 'checksetup.pl', ]; +# Non-cgi scripts that should silently exit. +use constant SHUTDOWNHTML_EXIT_SILENTLY => [ + 'whine.pl' +]; + ##################################################################### # Global Code ##################################################################### @@ -62,6 +67,15 @@ use constant SHUTDOWNHTML_EXEMPT => [ if (Param("shutdownhtml") && lsearch(SHUTDOWNHTML_EXEMPT, basename($0)) == -1) { + # Allow non-cgi scripts to exit silently (without displaying any + # message), if desired. At this point, no DBI call has been made + # yet, and no error will be returned if the DB is inaccessible. + if (lsearch(SHUTDOWNHTML_EXIT_SILENTLY, basename($0)) > -1 + && !i_am_cgi()) + { + exit; + } + # For security reasons, log out users when Bugzilla is down. # Bugzilla->login() is required to catch the logincookie, if any. my $user = Bugzilla->login(LOGIN_OPTIONAL); diff --git a/whine.pl b/whine.pl index f24db855d..937cbbace 100755 --- a/whine.pl +++ b/whine.pl @@ -93,12 +93,6 @@ my $sth_schedules_by_event = $dbh->prepare( # After that, it looks over each user to see if they have schedules that need # running, then runs those and generates the email messages. -# exit quietly if the system is shut down -if (Param('shutdownhtml')) { - exit; -} - - # Send whines from the address in the 'maintainer' Parameter so that all # Bugzilla-originated mail appears to come from a single address. my $fromaddress = Param('maintainer'); -- cgit v1.2.3-24-g4f1b