1 package Business::OnlinePayment::Jety;
5 use Business::OnlinePayment 3;
6 use Business::OnlinePayment::HTTPS;
7 use vars qw($VERSION @ISA $me $DEBUG);
12 @ISA = qw(Business::OnlinePayment::HTTPS);
14 $me = 'Business::OnlinePayment::Jety';
43 first_name => 'firstname',
44 last_name => 'lastname',
45 address => 'address1',
46 bank_name => 'bankname',
47 bank_city => 'bankcity',
48 bank_state => 'bankstate',
49 account_number => 'accountdda',
50 routing_code => 'accountaba',
56 $self->server('api.cardservicesportal.com');
58 $self->path('/servlet/drafts.echeck');
64 my $content = $self->{_content};
66 $self->remap_fields(%map);
68 die "Jety API only supports ECHECK payments.\n"
69 if(lc($content->{type}) ne 'echeck');
70 die "Jety interface only supports Normal Authorization.\n"
71 if(lc($content->{action}) ne 'normal authorization');
73 $content->{'function'} = 'echeck';
74 $content->{'programdesc'} = "415-462-1624 Business::OnlinePayment::Jety v$VERSION";
75 $content->{'ref'} = time2str('%Y%m%d',time).'-'.int(rand(1000000));
77 $content->{'phone'} ||= '111-111-1111';
79 $content->{'bankname'} ||= 'unknown';
80 $content->{'bankcity'} ||= 'unknown';
81 $content->{'bankstate'} ||= 'XX';
88 $Business::OnlinePayment::HTTPS::DEBUG = $DEBUG;
91 # strip existent but empty fields so that required_fields works right
92 foreach(keys(%{$self->{_content}})) {
93 delete $self->{_content}->{$_}
94 if (!defined($self->{_content}->{$_} ) or
95 $self->{_content}->{$_} eq '');
98 $self->required_fields(qw(
114 tie my %request, 'Tie::IxHash', (
115 map { $_, $self->{_content}->{$_} } @fields
118 $DB::single = $DEBUG;
119 if($self->test_transaction()) {
120 print "https://".$self->server.$self->path."\n";
121 print "$_\t".$request{$_}."\n" foreach keys(%request);
122 $self->error_message('test mode not supported');
123 $self->is_success(0);
126 my ($reply, $response, %reply_headers) = $self->https_post(\%request);
128 if(not $response =~ /^200/) {
129 croak "HTTPS error: '$response'";
132 # string looks like this:
133 # P1=1234&P2=General Status&P3=Specific Status
134 # P3 is not always there, though.
135 if($reply =~ /^P1=(\d+)&P2=([\w ]*)(&P3=(\S+))?/) {
137 $self->is_success(1);
138 $self->authorization($4);
141 $self->is_success(0);
142 $self->error_message($2.($4 ? "($4)" : ''));
146 croak "Malformed server response: '$reply'";
157 Business::OnlinePayment::Jety - Jety Payments ACH backend for Business::OnlinePayment
161 use Business::OnlinePayment;
164 # Electronic check authorization. We only support
165 # 'Normal Authorization'.
168 my $tx = new Business::OnlinePayment("Jety");
171 login => 'testdrive',
172 password => 'testpass',
173 action => 'Normal Authorization',
174 description => 'Business::OnlinePayment test',
176 invoice_number => '100100',
177 first_name => 'Jason',
178 last_name => 'Kohles',
179 address => '123 Anystreet',
183 account_type => 'personal checking',
184 account_number => '1000468551234',
185 routing_code => '707010024',
186 check_number => '1001', # optional
190 if($tx->is_success()) {
191 print "Check processed successfully: ".$tx->authorization."\n";
193 print "Check was rejected: ".$tx->error_message."\n";
196 =head1 SUPPORTED TRANSACTION TYPES
200 Content required: type, login, password, action, amount, first_name, last_name, account_number, routing_code.
204 For detailed information see L<Business::OnlinePayment>.
206 =head1 METHODS AND FUNCTIONS
208 See L<Business::OnlinePayment> for the complete list. The following methods either override the methods in L<Business::OnlinePayment> or provide additional functions.
212 Returns the four-digit result code.
216 Returns a useful error message.
218 =head1 Handling of content(%content) data:
222 The following actions are valid:
228 Mark Wells <mark@freeside.biz>
232 perl(1). L<Business::OnlinePayment>.