X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=LinkPoint.pm;h=ac7881b23441a46c9bbd0ea3041f75f36f2a5de2;hb=adc846c4090e948135e1c07b13233a2374e435bc;hp=11a3c5236530d8004e6ecf9748175889dd519f2f;hpb=f2f934d98517bfd6661cdb2190186f7ac1f1c17c;p=Business-OnlinePayment-LinkPoint.git diff --git a/LinkPoint.pm b/LinkPoint.pm index 11a3c52..ac7881b 100644 --- a/LinkPoint.pm +++ b/LinkPoint.pm @@ -1,6 +1,6 @@ package Business::OnlinePayment::LinkPoint; -# $Id: LinkPoint.pm,v 1.12 2004-06-24 14:53:35 ivan Exp $ +# $Id: LinkPoint.pm,v 1.21 2004-06-24 15:31:58 ivan Exp $ use strict; use vars qw($VERSION @ISA @EXPORT @EXPORT_OK); @@ -27,6 +27,8 @@ sub set_defaults { $self->server('secure.linkpt.net'); $self->port('1129'); + $self->build_subs(qw(order_number avs_code)); + } sub map_fields { @@ -112,7 +114,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/; @@ -127,37 +128,37 @@ sub submit { } $self->revmap_fields( - hostname => \( $self->server ), + host => \( $self->server ), port => \( $self->port ), #storename => \( $self->storename ), configfile => \( $self->storename ), keyfile => \( $self->keyfile ), addrnum => \$addrnum, result => \$result, - cardNumber => 'card_number', - cardExpMonth => \$month, - cardExpYear => \$year, + cardnumber => 'card_number', + cardexpmonth => \$month, + cardexpyear => \$year, chargetotal => 'amount', ); my $lperl = new LPPERL; $self->required_fields(qw/ - hostname port storename keyfile amount cardNumber cardExpMonth cardExpYear + host port configfile keyfile amount cardnumber cardexpmonth cardexpyear /); my %post_data = $self->get_fields(qw/ - hostname port configfile keyfile + 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 /); - $post_data{'order_type'} = $content{action}; + $post_data{'ordertype'} = $content{action}; - if ( $self->cvv2 ) { + if ( $content{'cvv2'} ) { $post_data{cvmindicator} = 'provided'; - $post_data{cvmvalue} = $self->cvv2; + $post_data{cvmvalue} = $content{'cvv2'}; } warn "$_ => $post_data{$_}\n" foreach keys %post_data; @@ -169,11 +170,14 @@ sub submit { #} %response = $lperl->curl_process(\%post_data); + 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('');