X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=LinkPoint.pm;h=71015f776a8c1745a030643fdf6b8673069919dc;hb=bae4cd5aaec29c73eeff2250ec21af5d46d2fe9d;hp=0621ea036865fb55e0960ef56b7b94d39849714f;hpb=b0ba3efda840c1932881c5438c9a66b807a8e2ae;p=Business-OnlinePayment-LinkPoint.git diff --git a/LinkPoint.pm b/LinkPoint.pm index 0621ea0..71015f7 100644 --- a/LinkPoint.pm +++ b/LinkPoint.pm @@ -1,9 +1,9 @@ package Business::OnlinePayment::LinkPoint; -# $Id: LinkPoint.pm,v 1.15 2004-06-24 14:56:27 ivan Exp $ +# $Id: LinkPoint.pm,v 1.25 2007-04-05 23:12:06 jeff Exp $ use strict; -use vars qw($VERSION @ISA @EXPORT @EXPORT_OK); +use vars qw($VERSION @ISA $DEBUG @EXPORT @EXPORT_OK); use Carp qw(croak); use AutoLoader; use Business::OnlinePayment; @@ -13,11 +13,12 @@ require Exporter; @ISA = qw(Exporter AutoLoader Business::OnlinePayment); @EXPORT = qw(); @EXPORT_OK = qw(); -$VERSION = '0.04'; +$VERSION = '0.06'; +$DEBUG = 0; -use lpperl; #3; #lperl.pm from LinkPoint +use lpperl; #3; #lpperl.pm from LinkPoint $LPPERL::VERSION =~ /^(\d+\.\d+)/ - or die "can't parse lperl.pm version: $LPPERL::VERSION"; + or die "can't parse lpperl.pm version: $LPPERL::VERSION"; die "lpperl.pm minimum version 3 required\n" unless $1 >= 3; sub set_defaults { @@ -27,6 +28,8 @@ sub set_defaults { $self->server('secure.linkpt.net'); $self->port('1129'); + $self->build_subs(qw(order_number avs_code)); + } sub map_fields { @@ -97,7 +100,11 @@ sub submit { my %content = $self->content; my($month, $year); - unless ( $content{action} eq 'POSTAUTH' ) { + unless ( $content{action} eq 'POSTAUTH' + || ( $content{'action'} =~ /^(CREDIT|VOID)$/ + && exists $content{'order_number'} ) + || $self->transaction_type() =~ /^check$/i + ) { if ( $self->transaction_type() =~ /^(cc|visa|mastercard|american express|discover)$/i @@ -112,7 +119,6 @@ sub submit { ( $month, $year ) = ( $1, $2 ); $month = '0'. $month if $month =~ /^\d$/; - $year += 2000 if $year < 2000; #not y4k safe, oh shit } $content{'address'} =~ /^(\S+)\s/; @@ -126,6 +132,11 @@ sub submit { $result ||= 'LIVE'; } + #docs disagree with lpperl.pm here + $content{'voidcheck'} = 1 + if ($self->transaction_type() =~ /^check$/i + && $content{'action'} =~ /^VOID$/); + $self->revmap_fields( host => \( $self->server ), port => \( $self->port ), @@ -134,33 +145,52 @@ sub submit { keyfile => \( $self->keyfile ), addrnum => \$addrnum, result => \$result, - cardNumber => 'card_number', - cardExpMonth => \$month, - cardExpYear => \$year, + cardnumber => 'card_number', + cardexpmonth => \$month, + cardexpyear => \$year, chargetotal => 'amount', + oid => 'order_number', + bankname => 'bank_name', + routing => 'routing_code', + account => 'account_number', + accounttype => 'account_type', + name => 'account_name', + dl => 'state_id', + dlstate => 'state_id_state', ); my $lperl = new LPPERL; - $self->required_fields(qw/ - host port configfile keyfile amount cardNumber cardExpMonth cardExpYear - /); + my @required_fields = qw(host port configfile keyfile amount); + if ($self->transaction_type() =~ /^(cc|visa|mastercard|american express|discover)$/i) { + push @required_fields, qw(cardnumber cardexpmonth cardexpyear); + }elsif ($self->transaction_type() =~ /^check$/i) { + push @required_fields, qw( + dl dlstate routing account accounttype bankname bankstate name + ); + } + $self->required_fields(@required_fields); my %post_data = $self->get_fields(qw/ host port configfile keyfile result - chargetotal cardNumber cardExpMonth cardExpYear - name email phone address city state zip country + chargetotal cardnumber cardexpmonth cardexpyear + name email phone addrnum city state zip country + oid + dl dlstate routing account accounttype bankname bankstate name void + /); - $post_data{'order_type'} = $content{action}; + $post_data{'ordertype'} = $content{action}; if ( $content{'cvv2'} ) { $post_data{cvmindicator} = 'provided'; $post_data{cvmvalue} = $content{'cvv2'}; } - warn "$_ => $post_data{$_}\n" foreach keys %post_data; + if ( $DEBUG ) { + warn "$_ => $post_data{$_}\n" foreach keys %post_data; + } my %response; #{ @@ -169,11 +199,16 @@ sub submit { #} %response = $lperl->curl_process(\%post_data); + if ( $DEBUG ) { + warn "$_ => $response{$_}\n" for keys %response; + } + if ( $response{'r_approved'} eq 'APPROVED' ) { $self->is_success(1); $self->result_code($response{'r_code'}); $self->authorization($response{'r_ref'}); $self->order_number($response{'r_ordernum'}); + $self->avs_code($response{'r_avs'}); } else { $self->is_success(0); $self->result_code(''); @@ -235,8 +270,8 @@ For detailed information see L. This module implements an interface to the LinkPoint Perl Wrapper http://www.linkpoint.com/product_solutions/internet/lperl/lperl_main.html -Version 0.4 of this module has been updated for the LinkPoint Perl Wrapper -version 3.5. +Versions 0.4 and on of this module support the LinkPoint Perl Wrapper version +3.5. =head1 BUGS