X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=rt%2Flib%2FRT%2FUtil.pm;h=70b557bb9600ea451c85eb6159606802d0302324;hp=bd3a22803c736cc4321f42dbf6c880b46086b47d;hb=7322f2afedcc2f427e997d1535a503613a83f088;hpb=919e930aa9279b3c5cd12b593889cd6de79d67bf diff --git a/rt/lib/RT/Util.pm b/rt/lib/RT/Util.pm index bd3a22803..70b557bb9 100644 --- a/rt/lib/RT/Util.pm +++ b/rt/lib/RT/Util.pm @@ -2,7 +2,7 @@ # # COPYRIGHT: # -# This software is Copyright (c) 1996-2015 Best Practical Solutions, LLC +# This software is Copyright (c) 1996-2016 Best Practical Solutions, LLC # # # (Except where explicitly superseded by other copyright notices) @@ -66,11 +66,11 @@ sub safe_run_child (&) { # on failure and reset values only in our original # process my ($oldv_dbh, $oldv_rth); - my $dbh = $RT::Handle->dbh; + my $dbh = $RT::Handle ? $RT::Handle->dbh : undef; $oldv_dbh = $dbh->{'InactiveDestroy'} if $dbh; $dbh->{'InactiveDestroy'} = 1 if $dbh; - $oldv_rth = $RT::Handle->{'DisconnectHandleOnDestroy'}; - $RT::Handle->{'DisconnectHandleOnDestroy'} = 0; + $oldv_rth = $RT::Handle->{'DisconnectHandleOnDestroy'} if $RT::Handle; + $RT::Handle->{'DisconnectHandleOnDestroy'} = 0 if $RT::Handle; my ($reader, $writer); pipe( $reader, $writer ); @@ -94,7 +94,7 @@ sub safe_run_child (&) { $err =~ s/^Stack:.*$//ms; if ( $our_pid == $$ ) { $dbh->{'InactiveDestroy'} = $oldv_dbh if $dbh; - $RT::Handle->{'DisconnectHandleOnDestroy'} = $oldv_rth; + $RT::Handle->{'DisconnectHandleOnDestroy'} = $oldv_rth if $RT::Handle; die "System Error: $err"; } else { print $writer "System Error: $err"; @@ -108,7 +108,7 @@ sub safe_run_child (&) { warn $response if $response; $dbh->{'InactiveDestroy'} = $oldv_dbh if $dbh; - $RT::Handle->{'DisconnectHandleOnDestroy'} = $oldv_rth; + $RT::Handle->{'DisconnectHandleOnDestroy'} = $oldv_rth if $RT::Handle; return $want? (@res) : $res[0]; }