X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=LinkPoint.pm;h=6943ba673013f9ef9d3f9416bb4087a35de00f48;hb=d3717f864dfd884cdc8d4bea75c61d73a4d6064c;hp=9a77236a3b24e228c01591e02cae4615322abfc3;hpb=563e5cf00aa4a7eb8697ce831e3e62cbb117d8b9;p=Business-OnlinePayment-LinkPoint.git diff --git a/LinkPoint.pm b/LinkPoint.pm index 9a77236..6943ba6 100644 --- a/LinkPoint.pm +++ b/LinkPoint.pm @@ -1,6 +1,6 @@ package Business::OnlinePayment::LinkPoint; -# $Id: LinkPoint.pm,v 1.1 2002-02-15 01:19:27 ivan Exp $ +# $Id: LinkPoint.pm,v 1.13 2004-06-24 14:54:31 ivan Exp $ use strict; use vars qw($VERSION @ISA @EXPORT @EXPORT_OK); @@ -8,21 +8,24 @@ use Carp qw(croak); use AutoLoader; use Business::OnlinePayment; -use lperl; #lperl.pm from Linkpoint. - require Exporter; @ISA = qw(Exporter AutoLoader Business::OnlinePayment); @EXPORT = qw(); @EXPORT_OK = qw(); -$VERSION = '0.01'; +$VERSION = '0.04'; + +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; #$self->server('staging.linkpt.net'); $self->server('secure.linkpt.net'); - $self->port('1139'); + $self->port('1129'); } @@ -32,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'}; @@ -43,6 +47,15 @@ sub map_fields { $self->content(%content); } +sub build_subs { + my $self = shift; + foreach(@_) { + #no warnings; #not 5.005 + local($^W)=0; + eval "sub $_ { my \$self = shift; if(\@_) { \$self->{$_} = shift; } return \$self->{$_}; }"; + } +} + sub remap_fields { my($self,%map) = @_; @@ -79,13 +92,12 @@ sub get_fields { sub submit { my($self) = @_; - $self->map_fields(); 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 @@ -106,53 +118,66 @@ sub submit { $content{'address'} =~ /^(\S+)\s/; my $addrnum = $1; - $self->server('staging.linkpt.net') if $self->test_transaction; + my $result = $content{'result'}; + if ( $self->test_transaction) { + $result ||= 'GOOD'; + #$self->server('staging.linkpt.net'); + } else { + $result ||= 'LIVE'; + } $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 - $self->lbin, - 'FILE', - $self->can('tmp') - ? $self->tmp - : '/tmp'; - 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 /); - print "$_ => $post_data{$_}\n" foreach keys %post_data; - #die; + $post_data{'order_type'} = $content{action}; + + if ( $self->cvv2 ) { + $post_data{cvmindicator} = 'provided'; + $post_data{cvmvalue} = $self->cvv2; + } - my %response = $lperl->$action(\%post_data); + warn "$_ => $post_data{$_}\n" foreach keys %post_data; - if ( $response{'statusCode'} == 0 ) { + my %response; + #{ + # local($^W)=0; + # %response = $lperl->$action(\%post_data); + #} + %response = $lperl->curl_process(\%post_data); + + 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'}); + } else { $self->is_success(0); $self->result_code(''); - $self->error_message($response{'statusMessage'}); - } else { - $self->is_success(1); - $self->result_code($response{'AVCCode'}); - $self->authorization($response{'trackingID'}); -# $self->order_number($response{'neworderID'}); + $self->error_message($response{'r_error'}); } } @@ -162,7 +187,7 @@ __END__ =head1 NAME -Business::OnlinePayment::LinkPoint - LinkPoint backend for Business::OnlinePayment +Business::OnlinePayment::LinkPoint - LinkPoint (Cardservice) backend for Business::OnlinePayment =head1 SYNOPSIS @@ -171,8 +196,6 @@ Business::OnlinePayment::LinkPoint - LinkPoint backend for Business::OnlinePayme my $tx = new Business::OnlinePayment( 'LinkPoint', 'storename' => 'your_store_number', 'keyfile' => '/path/to/keyfile.pem', - 'lbin' => '/path/to/binary/lbin', - 'tmp' => '/secure/tmp', # a secure tmp directory ); $tx->content( @@ -210,7 +233,10 @@ For detailed information see L. =head1 COMPATIBILITY This module implements an interface to the LinkPoint Perl Wrapper -http://www.linkpoint.com/product_solutions/internet/inet_index.html +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. =head1 BUGS @@ -222,7 +248,7 @@ Based on Busienss::OnlinePayment::AuthorizeNet written by Jason Kohles. =head1 SEE ALSO -perl(1). L. +perl(1), L. =cut