summaryrefslogtreecommitdiff
path: root/BatchPayment.pm
blob: 8b30c11cbdebd758f7f1962616a778e90d7814e5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
package Business::BatchPayment;

use 5.006;
use strict;
use vars '$DEBUG';
use warnings;

use Class::MOP;
use Business::BatchPayment::Processor;
use Business::BatchPayment::Item;
use Business::BatchPayment::Transport;

$DEBUG = 0;

=head1 NAME

Business::BatchPayment - Batch-oriented payment processing

=cut

our $VERSION = '0.02';

=head1 SYNOPSIS

  use Business::BatchPayment;

  my %options = ( merchant_id => '00451', password => 'opensesame' );
  my $processor = Business::BatchPayment->create(MyGateway => %options);

  my @request;
  push @request, Business::BatchPayment->create(Item =>
    action        => 'payment', # as opposed to 'credit'
    payment_type  => 'CC', #credit card, or 'ECHECK' for check/ACH
    amount        => '49.95',
    tid           => '0001234', # transaction id, like a customer/order number
    card_number   => '1234123412341238',
    expiration    => '0100', # MM/YY
    # these fields are optional
    first_name    => 'John',
    last_name     => 'Doe',
    address       => '123 Main Street',
    address2      => 'Suite H',
    city          => 'Anytown',
    state         => 'CA',
    country       => 'US',
    zip           => '99015',
  ); # returns a Business::OnlinePayment::Item;

  $processor->submit(@request);

  # at some point in the future
  
  my @reply = $processor->receive();
  foreach my $item (@reply) {
    ... process items and record successful/failed payments
  }

  # if your processor uses processor_id...

  $processor->submit(@request);
  foreach (@request) {
    ... record process_id for that request
  }
  # later...
  my @reply = $processor->receive(@process_ids);

=head1 CLASS METHODS

=over 4

=item create MODULE[, OPTIONS ]

Loads Business::BatchPayment::MODULE, then attempts to call 
Business::BatchPayment::MODULE->new(OPTIONS).

=cut

# not a Moose method

sub create {
  my $class = shift;
  my $subclass = shift;
  $subclass = "Business::BatchPayment::$subclass";
  Class::MOP::load_class($subclass);
  $subclass->new(@_);
}

=back

=head1 AUTHOR

Mark Wells, C<< <mark at freeside.biz> >>

=head1 BUGS

=head1 SUPPORT

You can find documentation for this module with the perldoc command.

    perldoc Business::BatchPayment

Commercial support is available from Freeside Internet Services,
L<http://www.freeside.biz>.

=head1 LICENSE AND COPYRIGHT

Copyright 2012 Mark Wells.

This program is free software; you can redistribute it and/or modify it
under the terms of either: the GNU General Public License as published
by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.


=cut

1; # End of Business::BatchPayment