receipt_number sales_number uuid guid
date
card_type cardholder
- total_amount taxes
+ total_amount tax_amounts
avs_response cvv2_response
));
- # Just in case someone tries to call taxes() *before* submit()
- $self->taxes( {} );
+ # Just in case someone tries to call tax_amounts() *before* submit()
+ $self->tax_amounts( {} );
}
# OnlinePayment's get_fields now filters out undefs in 3.x. :(
my @flags = ($currency);
- foreach (split ' ' => uc($data{taxes} || '')) {
- croak "Unknown tax code $_" unless /^(GST|PST|HST)$/;
- push @flags, $_;
+ my @taxes;
+ if (ref $data{taxes}) {
+ @taxes = @{ $data{taxes} };
+ } elsif ($data{taxes}) {
+ @taxes = split ' ' => $data{taxes};
+ }
+
+ foreach (@taxes) {
+ croak "Unknown tax code $_" unless /^(GST|PST|HST)$/i;
+ push @flags, uc $_;
}
if ($self->test_transaction) {
croak "Unknown currency code ", $content{currency}
unless $content{currency} =~ /^(CAD|USD)$/;
- $content{taxes} = uc($content{taxes} || '');
-
my %data = $self->get_remap_fields(qw(
xxxCard_Number card_number
}
}
-sub extract_taxes {
+sub extract_tax_amounts {
my ($self, $response) = @_;
- my %taxes;
+ my %tax_amounts;
my $products = $response->{Products};
return unless $products;
grep($_ eq '{TAX}', @$flags) &&
grep($_ eq '{CALCULATED}', @$flags))
{
- $taxes{ $node->{code} } = $node->{subtotal};
+ $tax_amounts{ $node->{code} } = $node->{subtotal};
}
}
- return %taxes;
+ return %tax_amounts;
}
# Parse the server's response and set various fields
$self->card_type(CARD_TYPES->{$self->card_type});
- $self->taxes( { $self->extract_taxes($response) } );
+ $self->tax_amounts( { $self->extract_tax_amounts($response) } );
return $self;
}
=item taxes
-Taxes to be added automatically to B<amount> by InternetSecure.
+Taxes to be added automatically to B<amount> by InternetSecure. Available
+taxes are C<GST>, C<PST> and C<HST>.
-Available taxes are C<GST>, C<PST> and C<HST>. Multiple taxes can specified
-by concatenating them with spaces, such as C<GST HST>.
+This argument can either be a single string of taxes concatenated with spaces
+(such as C<GST PST>), or a reference to an array of taxes (such as C<[ "GST",
+"PST" ]>).
=item name / company / address / city / state / zip / country / phone / email
Total amount billed for this order, including taxes.
-=item taxes()
+=item tax_amounts()
-Returns a I<reference> to a hash that maps tax names (such as C<GST>) to the
-amount that was billed for each.
+Returns a I<reference> to a hash that maps taxes, which were listed under the
+B<taxes> argument to B<submit>(), to the amount that was calculated by
+InternetSecure.
=item cardholder()