X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=LinkPoint.pm;h=bde5543b5aa080f63c85a66dfe930233b0e3adbd;hb=64714b3e4e50fc336eb7cd9221e00be685d8cab6;hp=8a7dfa9694b6ca4a0d132a245a40e73266dc6e11;hpb=d904bbb8d30c306e0c7055004b177b43340ab5cf;p=Business-OnlinePayment-LinkPoint.git diff --git a/LinkPoint.pm b/LinkPoint.pm index 8a7dfa9..bde5543 100644 --- a/LinkPoint.pm +++ b/LinkPoint.pm @@ -1,6 +1,6 @@ package Business::OnlinePayment::LinkPoint; -# $Id: LinkPoint.pm,v 1.10 2003-08-11 05:05:57 ivan Exp $ +# $Id: LinkPoint.pm,v 1.14 2004-06-24 14:55:12 ivan Exp $ use strict; use vars qw($VERSION @ISA @EXPORT @EXPORT_OK); @@ -13,12 +13,12 @@ require Exporter; @ISA = qw(Exporter AutoLoader Business::OnlinePayment); @EXPORT = qw(); @EXPORT_OK = qw(); -$VERSION = '0.03'; +$VERSION = '0.04'; -use lperl; #2.6; #lperl.pm from LinkPoint -$LPERL::VERSION =~ /^(\d+\.\d+)/ - or die "can't parse lperl.pm version: $LPERL::VERSION"; -die "lperl.pm minimum version 2.6 required\n" unless $1 >= 2.6; +use lpperl; #3; #lperl.pm from LinkPoint +$LPPERL::VERSION =~ /^(\d+\.\d+)/ + or die "can't parse lperl.pm version: $LPPERL::VERSION"; +die "lpperl.pm minimum version 3 required\n" unless $1 >= 3; sub set_defaults { my $self = shift; @@ -35,10 +35,11 @@ sub map_fields { my %content = $self->content(); #ACTION MAP - my %actions = ('normal authorization' => 'ApproveSale', - 'authorization only' => 'CapturePayment', - 'credit' => 'ReturnOrder', - 'post authorization' => 'BillOrders', + my %actions = ('normal authorization' => 'SALE', + 'authorization only' => 'PREAUTH', + 'credit' => 'CREDIT', + 'post authorization' => 'POSTAUTH', + 'void' => 'VOID', ); $content{'action'} = $actions{lc($content{'action'})} || $content{'action'}; @@ -96,7 +97,7 @@ sub submit { my %content = $self->content; my($month, $year); - unless ( $content{action} eq 'BillOrders' ) { + unless ( $content{action} eq 'POSTAUTH' ) { if ( $self->transaction_type() =~ /^(cc|visa|mastercard|american express|discover)$/i @@ -120,7 +121,7 @@ sub submit { my $result = $content{'result'}; if ( $self->test_transaction) { $result ||= 'GOOD'; - $self->server('staging.linkpt.net'); + #$self->server('staging.linkpt.net'); } else { $result ||= 'LIVE'; } @@ -128,55 +129,57 @@ sub submit { $self->revmap_fields( hostname => \( $self->server ), port => \( $self->port ), - storename => \( $self->storename ), + #storename => \( $self->storename ), + configfile => \( $self->storename ), keyfile => \( $self->keyfile ), addrnum => \$addrnum, result => \$result, cardNumber => 'card_number', cardExpMonth => \$month, cardExpYear => \$year, + chargetotal => 'amount', ); - my $lperl = new LPERL; - my $action = $content{action}; + my $lperl = new LPPERL; $self->required_fields(qw/ - hostname port storename keyfile amount cardNumber cardExpMonth cardExpYear + hostname port configfile keyfile amount cardNumber cardExpMonth cardExpYear /); my %post_data = $self->get_fields(qw/ - hostname port storename keyfile + hostname port configfile keyfile result - amount cardNumber cardExpMonth cardExpYear + chargetotal cardNumber cardExpMonth cardExpYear name email phone address city state zip country /); + $post_data{'order_type'} = $content{action}; + + if ( $content{'cvv2'} ) { + $post_data{cvmindicator} = 'provided'; + $post_data{cvmvalue} = $content{'cvv2'}; + } + warn "$_ => $post_data{$_}\n" foreach keys %post_data; my %response; - { - local($^W)=0; - %response = $lperl->$action(\%post_data); - } + #{ + # local($^W)=0; + # %response = $lperl->$action(\%post_data); + #} + %response = $lperl->curl_process(\%post_data); - #if ( $response{'statusCode'} == 0 ) { - if ( $response{'statusMessage'} ) { - $self->is_success(0); - $self->result_code(''); - $self->error_message($response{'statusMessage'}); - } elsif ( $response{'statusCode'} ) { + if ( $response{'r_approved'} eq 'APPROVED' ) { $self->is_success(1); - $self->result_code($response{'AVSCode'}); - $self->authorization($response{'trackingID'}); -# $self->order_number($response{'neworderID'}); + $self->result_code($response{'r_code'}); + $self->authorization($response{'r_ref'}); + $self->order_number($response{'r_ordernum'}); } else { - #if ( exists($response{'statusMessage'}) - # && defined($response{'statusMessage'}) ) { # "normal" error - #} else { # "should not happen" error (should this die/croak?) - $self->error_message("No statusMessage returned! Response follows:". - join(' / ', map { "$_=>".$response{$_} } keys %response ) ); - #} + $self->is_success(0); + $self->result_code(''); + $self->error_message($response{'r_error'}); } + } 1; @@ -232,8 +235,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.3 of this module has been updated for the LinkPoint Perl Wrapper -version 2.6. +Version 0.4 of this module has been updated for the LinkPoint Perl Wrapper +version 3.5. =head1 BUGS