From dfbc167a014c2630e07296777c9d75dd2f0f236d Mon Sep 17 00:00:00 2001 From: Byron Jones Date: Thu, 3 Jan 2013 00:31:37 +0800 Subject: Bug 822547: Make jobqueue.pl clear the request cache before sending each mail r=dkl,a=LpSolit --- Bugzilla.pm | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) (limited to 'Bugzilla.pm') diff --git a/Bugzilla.pm b/Bugzilla.pm index 111d567e6..baaf78ff7 100644 --- a/Bugzilla.pm +++ b/Bugzilla.pm @@ -618,6 +618,18 @@ sub request_cache { return $_request_cache; } +sub clear_request_cache { + $_request_cache = {}; + if ($ENV{MOD_PERL}) { + require Apache2::RequestUtil; + my $request = eval { Apache2::RequestUtil->request }; + if ($request) { + my $pnotes = $request->pnotes; + delete @$pnotes{(keys %$pnotes)}; + } + } +} + # This is a per-process cache. Under mod_cgi it's identical to the # request_cache. When using mod_perl, items in this cache live until the # worker process is terminated. @@ -639,7 +651,7 @@ sub _cleanup { $dbh->bz_rollback_transaction() if $dbh->bz_in_transaction; $dbh->disconnect; } - undef $_request_cache; + clear_request_cache(); # These are both set by CGI.pm but need to be undone so that # Apache can actually shut down its children if it needs to. -- cgit v1.2.3-24-g4f1b