[freeside-commits] freeside/FS/FS/pay_batch eft_canada.pm, NONE, 1.1.2.2
Mark Wells
mark at wavetail.420.am
Fri Jul 22 12:19:58 PDT 2011
Update of /home/cvs/cvsroot/freeside/FS/FS/pay_batch
In directory wavetail.420.am:/tmp/cvs-serv19394/FS/FS/pay_batch
Added Files:
Tag: FREESIDE_2_3_BRANCH
eft_canada.pm
Log Message:
EFT Canada batch format and scripts, #13628
--- NEW FILE: eft_canada.pm ---
package FS::pay_batch::eft_canada;
use strict;
use vars qw(@ISA %import_info %export_info $name);
use FS::Record 'qsearch';
use FS::Conf;
use FS::cust_pay_batch;
use Date::Format 'time2str';
use Time::Local 'timelocal';
my $conf;
my $origid;
$name = 'eft_canada';
%import_info = ( filetype => 'NONE' ); # see FS/bin/freeside-eftca-download
my ($trans_code, $process_date);
%export_info = (
init => sub {
my $conf = shift;
my @config = $conf->config('batchconfig-eft_canada');
# SFTP login, password, trans code, delay time
my $process_delay;
($trans_code, $process_delay) = @config[2,3];
$process_delay ||= 1; # days
$process_date = time2str('%D', time + ($process_delay * 86400));
},
delimiter => '', # avoid blank lines for header/footer
# EFT Upload Specification for .CSV Files, Rev. 2.0
# not a true CSV format--strings aren't quoted, so be careful
row => sub {
my ($cust_pay_batch, $pay_batch) = @_;
my @fields;
# company + empty or first + last
my $company = sprintf('%.64s', $cust_pay_batch->cust_main->company);
if ( $company ) {
push @fields, $company, ''
}
else {
push @fields, map { sprintf('%.64s', $_) }
$cust_pay_batch->first, $cust_pay_batch->last;
}
my ($account, $aba) = split('@', $cust_pay_batch->payinfo);
# standard format for Canadian bank ID
$aba =~ /^0(\d{3})(\d{5})$/
or die "invalid routing number '$aba'\n";
push @fields, sprintf('%05s', $2),
sprintf('%03s', $1),
sprintf('%012s', $account),
sprintf('%.02f', $cust_pay_batch->amount);
# DB = debit
push @fields, 'DB', $trans_code, $process_date;
push @fields, $cust_pay_batch->paybatchnum; # reference
# strip illegal characters that might occur in customer name
s/[,|']//g foreach @fields; # better substitution for these?
return join(',', @fields) . "\n";
},
);
1;
More information about the freeside-commits
mailing list