diff options
| author | Mark Wells <mark@freeside.biz> | 2015-08-11 17:05:16 -0700 | 
|---|---|---|
| committer | Mark Wells <mark@freeside.biz> | 2015-08-11 17:05:16 -0700 | 
| commit | 56cfb20bc9c9771b66007fabe1e15cbaa153624c (patch) | |
| tree | 757dd50e41057e6f9fa9309b82cec30c2f3ec946 | |
| parent | f888466b118f5f433cc123d455e611291f596466 (diff) | |
throw an error during RBC batch import if the batch has the wrong account number, #37476
| -rw-r--r-- | FS/FS/pay_batch/RBC.pm | 27 | 
1 files changed, 21 insertions, 6 deletions
| diff --git a/FS/FS/pay_batch/RBC.pm b/FS/FS/pay_batch/RBC.pm index 53f810852..644c73c8b 100644 --- a/FS/FS/pay_batch/RBC.pm +++ b/FS/FS/pay_batch/RBC.pm @@ -5,6 +5,7 @@ use vars qw(@ISA %import_info %export_info $name);  use Date::Format 'time2str';  use FS::Conf;  use Encode 'encode'; +use feature 'state';  my $conf;  my ($client_num, $shortname, $longname, $trans_code, $testmode, $i, $declined, $totaloffset); @@ -30,9 +31,10 @@ $name = 'RBC';    'filetype'    => 'fixed',    #this only really applies to Debit Detail, but we otherwise only need first char    'formatre'    =>  -  '^(.).{18}(.{4}).{3}(.).{11}(.{19}).{6}(.{30}).{17}(.{9})(.{18}).{6}(.{14}).{23}(.).{9}\r?$', +  '^(.).{3}(.{10}).{5}(.{4}).{3}(.).{11}(.{19}).{6}(.{30}).{17}(.{9})(.{18}).{6}(.{14}).{23}(.).{9}\r?$',    'fields' => [ qw(      recordtype +    clientnum      batchnum      subtype      paybatchnum @@ -43,11 +45,24 @@ $name = 'RBC';      status      ) ],    'hook' => sub { -      my $hash = shift; -      $hash->{'paid'} = sprintf("%.2f", $hash->{'paid'} / 100 ); -      $hash->{'_date'} = time; -      $hash->{'payinfo'} =~ s/^(\S+).*/$1/; # these often have trailing spaces -      $hash->{'payinfo'} = $hash->{'payinfo'} . '@' . $hash->{'bank'}; +    # pull client_num from config and check it against what's in the batch +    state $clientnum ||= do { +      my $conf = FS::Conf->new; +      my @config = $conf->config("batchconfig-RBC"); +      $config[0]; +    }; + +    my $hash = shift; +    $hash->{'paid'} = sprintf("%.2f", $hash->{'paid'} / 100 ); +    $hash->{'_date'} = time; +    $hash->{'payinfo'} =~ s/^(\S+).*/$1/; # these often have trailing spaces +    $hash->{'payinfo'} = $hash->{'payinfo'} . '@' . $hash->{'bank'}; + +    if ( $clientnum and $hash->{clientnum} ne $clientnum ) { +      die "RBC client number in batch (".$hash->{clientnum}.") does not ". +        "match configuration.\n"; +    } +    '';    },    'approved'    => sub {         my $hash = shift; | 
