[freeside-commits]
freeside/httemplate/misc download-batch.cgi, 1.20, 1.21
Jeff Finucane,420,,
jeff at wavetail.420.am
Tue Mar 20 21:01:54 PDT 2007
Update of /home/cvs/cvsroot/freeside/httemplate/misc
In directory wavetail:/tmp/cvs-serv29768/httemplate/misc
Modified Files:
download-batch.cgi
Log Message:
ticket 1436, ACH export format, return processing and autopost
Index: download-batch.cgi
===================================================================
RCS file: /home/cvs/cvsroot/freeside/httemplate/misc/download-batch.cgi,v
retrieving revision 1.20
retrieving revision 1.21
diff -u -d -r1.20 -r1.21
--- download-batch.cgi 5 Feb 2007 09:45:45 -0000 1.20
+++ download-batch.cgi 21 Mar 2007 04:01:52 -0000 1.21
@@ -23,6 +23,8 @@
<% sprintf( '$$E-xactBatchFileV1.0$$%s:%03u$$%s',$sdate,$pay_batch->batchnum, $origid)
%>
%
+%}elsif ($format eq "ach-spiritone"){
+%# 1;
%}else{
% die "Unknown format for batch in batchconfig. \n";
%}
@@ -93,6 +95,16 @@
<% $cust_pay_batch->paybatchnum %>,<% $cust_pay_batch->custnum %>,<% $cust_pay_batch->invnum %>,"<% $payname %>",00,<% $cust_pay_batch->payinfo %>,<% $cust_pay_batch->amount %>,<% $exp %>,,
%
%
+% }elsif ($format eq "ach-spiritone"){
+%
+% my( $account, $aba ) = split( '@', $cust_pay_batch->payinfo );
+% my $payname=$cust_pay_batch->payname; $payname =~ tr/",/ /; #payinfo too?
+% my $batchline = qq!"$payname","!.$cust_pay_batch->paybatchnum.
+% qq!","$aba","$account","27","!.$cust_pay_batch->amount.
+% qq!","27","0.00"!;
+% push @batchlines, $batchline;
+<% $batchline %>
+%
% } else {
% die "I'm already dead, but you did not know that.\n";
% }
@@ -116,11 +128,12 @@
% #1;
%} elsif ($format eq "csv-chase_canada-E-xactBatch"){
% #1;
+%} elsif ($format eq "ach-spiritone"){
+% #1;
%} else {
% die "I'm already dead (again), but you did not know that.\n";
%}
%
-%$dbh->commit or die $dbh->errstr if $oldAutoCommit;
<%init>
my $conf=new FS::Conf;
@@ -142,6 +155,13 @@
$format = $conf->config('batch-default_format');
}
+my $autopost;
+if ( $format eq 'ach-spiritone' ) {
+ $autopost = 1;
+}else{
+ $autopost = 0;
+}
+
my $oldAutoCommit = $FS::UID::AutoCommit;
local $FS::UID::AutoCommit = 0;
my $dbh = dbh;
@@ -168,4 +188,25 @@
my $sdate = sprintf("%02d", $date[5] % 100).'/'.sprintf("%02d", $date[4] + 1).
'/'.sprintf("%02d", $date[3]);
+my @batchlines = ();
</%init>
+<%cleanup>
+if ($autopost) {
+ my $dir = $FS::UID::conf_dir. "cache.". $FS::UID::datasrc;
+ my $fh = new File::Temp(
+ TEMPLATE => 'paybatch.'. $batchnum .'.XXXXXXXX',
+ DIR => $dir,
+ ) or die "can't open temp file: $!\n";
+
+ print $fh map{ "$_\n" } @batchlines;
+ seek $fh, 0, 0;
+
+ $error = $pay_batch->import_results( 'filehandle' => $fh,
+ 'format' => $format,
+ );
+ die $error if $error;
+}
+
+$dbh->commit or die $dbh->errstr if $oldAutoCommit;
+
+</%cleanup>
More information about the freeside-commits
mailing list