projects
/
freeside.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
20bd8de
)
prevent B:BP batches from being marked in-transit if uploading the batch fails, ...
author
Mark Wells
<mark@freeside.biz>
Fri, 16 Dec 2016 19:57:52 +0000
(11:57 -0800)
committer
Mark Wells
<mark@freeside.biz>
Fri, 16 Dec 2016 19:57:52 +0000
(11:57 -0800)
FS/FS/pay_batch.pm
patch
|
blob
|
history
diff --git
a/FS/FS/pay_batch.pm
b/FS/FS/pay_batch.pm
index
528b0d5
..
1c0a28a
100644
(file)
--- a/
FS/FS/pay_batch.pm
+++ b/
FS/FS/pay_batch.pm
@@
-14,6
+14,7
@@
use Scalar::Util 'blessed';
use IO::Scalar;
use FS::Misc qw(send_email); # for error notification
use List::Util qw(sum);
use IO::Scalar;
use FS::Misc qw(send_email); # for error notification
use List::Util qw(sum);
+use Try::Tiny;
@ISA = qw(FS::Record);
@ISA = qw(FS::Record);
@@
-1080,16
+1081,21
@@
sub export_to_gateway {
my $processor = $gateway->batch_processor(%proc_opt);
my @items = map { $_->request_item } $self->cust_pay_batch;
my $processor = $gateway->batch_processor(%proc_opt);
my @items = map { $_->request_item } $self->cust_pay_batch;
- my $batch = Business::BatchPayment->create(Batch =>
- batch_id => $self->batchnum,
- items => \@items
- );
- $processor->submit($batch);
+ try {
+ my $batch = Business::BatchPayment->create(Batch =>
+ batch_id => $self->batchnum,
+ items => \@items
+ );
+ $processor->submit($batch);
- if ($batch->processor_id) {
- $self->set('processor_id',$batch->processor_id);
- $self->replace;
- }
+ if ($batch->processor_id) {
+ $self->set('processor_id',$batch->processor_id);
+ $self->replace;
+ }
+ } catch {
+ $dbh->rollback if $oldAutoCommit;
+ die $_;
+ };
$dbh->commit or die $dbh->errstr if $oldAutoCommit;
'';
$dbh->commit or die $dbh->errstr if $oldAutoCommit;
'';