and... a parenthesis! woo 0.4
[Business-OnlinePayment-LinkPoint.git] / LinkPoint.pm
index 6943ba6..5c0286e 100644 (file)
@@ -1,6 +1,6 @@
 package Business::OnlinePayment::LinkPoint;
 
-# $Id: LinkPoint.pm,v 1.13 2004-06-24 14:54:31 ivan Exp $
+# $Id: LinkPoint.pm,v 1.22 2004-06-24 15:32:33 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 configfile 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('');