diff options
| author | ivan <ivan> | 2010-07-02 00:25:46 +0000 | 
|---|---|---|
| committer | ivan <ivan> | 2010-07-02 00:25:46 +0000 | 
| commit | 18a83827b277113d1a5603b084e0d978253e9932 (patch) | |
| tree | c3da494143541cbe40bd160e1f720153e7ef80f1 | |
| parent | 60e979f9e9b555a978faa977c998a94c5021d770 (diff) | |
fix bad transactional decisions that made it possible to abort and rollback a gateway payment, RT#8995
| -rw-r--r-- | FS/FS/cust_event.pm | 3 | ||||
| -rw-r--r-- | FS/FS/cust_main.pm | 33 | 
2 files changed, 14 insertions, 22 deletions
| diff --git a/FS/FS/cust_event.pm b/FS/FS/cust_event.pm index 52b5911dc..1407f43c8 100644 --- a/FS/FS/cust_event.pm +++ b/FS/FS/cust_event.pm @@ -222,9 +222,6 @@ sub do_event {         " (". $part_event->action. ") $for\n"      if $DEBUG; -  my $oldAutoCommit = $FS::UID::AutoCommit; -  local $FS::UID::AutoCommit = 0; -    my $error;    {      local $SIG{__DIE__}; # don't want Mason __DIE__ handler active diff --git a/FS/FS/cust_main.pm b/FS/FS/cust_main.pm index de398743a..e22f7eec1 100644 --- a/FS/FS/cust_main.pm +++ b/FS/FS/cust_main.pm @@ -3492,19 +3492,17 @@ sub collect {      }    } -  my $error = $self->do_cust_event( +  $dbh->commit or die $dbh->errstr if $oldAutoCommit; + +  #never want to roll back an event just because it returned an error +  local $FS::UID::AutoCommit = 1; #$oldAutoCommit; + +  $self->do_cust_event(      'debug'      => ( $options{'debug'} || 0 ),      'time'       => $invoice_time,      'check_freq' => $options{'check_freq'},      'stage'      => 'collect',    ); -  if ( $error ) { -    $dbh->rollback if $oldAutoCommit; -    return $error; -  } - -  $dbh->commit or die $dbh->errstr if $oldAutoCommit; -  '';  } @@ -3599,6 +3597,11 @@ sub do_cust_event {      return $due_cust_event;    } +  $dbh->commit or die $dbh->errstr if $oldAutoCommit; +  #never want to roll back an event just because it or a different one +  # returned an error +  local $FS::UID::AutoCommit = 1; #$oldAutoCommit; +    foreach my $cust_event ( @$due_cust_event ) {      #XXX lock event @@ -3607,11 +3610,7 @@ sub do_cust_event {      unless ( $cust_event->test_conditions( 'time' => $time ) ) {        #don't leave stray "new/locked" records around        my $error = $cust_event->delete; -      if ( $error ) { -        #gah, even with transactions -        $dbh->commit if $oldAutoCommit; #well. -        return $error; -      } +      return $error if $error;        next;      } @@ -3620,20 +3619,16 @@ sub do_cust_event {        warn "  running cust_event ". $cust_event->eventnum. "\n"          if $DEBUG > 1; -              #if ( my $error = $cust_event->do_event(%options) ) { #XXX %options?        if ( my $error = $cust_event->do_event() ) {          #XXX wtf is this?  figure out a proper dealio with return value          #from do_event -	  # gah, even with transactions. -	  $dbh->commit if $oldAutoCommit; #well. -	  return $error; -	} +        return $error; +      }      }    } -  $dbh->commit or die $dbh->errstr if $oldAutoCommit;    '';  } | 
