diff options
| author | Christopher Burger <burgerc@freeside.biz> | 2019-03-15 11:29:50 -0400 |
|---|---|---|
| committer | Christopher Burger <burgerc@freeside.biz> | 2019-03-15 14:55:51 -0400 |
| commit | 4021a65b46491615b8577335ab93d4a2eab34c46 (patch) | |
| tree | 0e2036ac564cd1131a15578bc2b98f1f8dd1b10c /FS/bin/freeside-rbc-upload | |
| parent | 30ec7432f51aad8bf7bf1cf4281d40d10c86139c (diff) | |
RT# 83044 - fixed cc refund issues
Conflicts:
httemplate/edit/process/cust_refund.cgi
httemplate/misc/download-batch.cgi
Diffstat (limited to 'FS/bin/freeside-rbc-upload')
| -rwxr-xr-x | FS/bin/freeside-rbc-upload | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/FS/bin/freeside-rbc-upload b/FS/bin/freeside-rbc-upload index 5be31aeee..7c53a391d 100755 --- a/FS/bin/freeside-rbc-upload +++ b/FS/bin/freeside-rbc-upload @@ -33,8 +33,17 @@ my @batches; if($opt_a) { my %criteria = (status => 'O'); $criteria{'payby'} = uc($opt_p) if $opt_p; - $criteria{'type'} = 'DEBIT' unless FS::pay_batch->can_handle_electronic_refunds('RBC'); - @batches = qsearch('pay_batch', \%criteria); + + my $extra_sql; + $extra_sql = " AND ((payby = 'CHEK' AND type != 'CREDIT') OR (payby != 'CHEK'))" unless FS::pay_batch->can_handle_electronic_refunds('RBC'); + + my %hash = ( + table => 'pay_batch', + hashref => \%criteria, + extra_sql => $extra_sql, + ); + + @batches = qsearch(\%hash); die "No open batches found".($opt_p ? " of type '$opt_p'" : '').".\n" if !@batches; } @@ -45,7 +54,7 @@ else { die "Can't find payment batch '$batchnum'\n" if !@batches; if ($batches[0]->type eq "CREDIT") { warn "running credit\n"; - log_and_die( "Batch number $batchnum is a credit (batch refund) batch, and this format can not handle batch refunds.\n" ) + die( "Batch number $batchnum is a credit (batch refund) batch, and this format can not handle batch refunds.\n" ) unless FS::pay_batch->can_handle_electronic_refunds('RBC'); } } |
