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';
42 'login' => 'username',
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',
51 'description' => 'programdesc',
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->{'ref'} = time2str('%Y%m%d',time).'-'.int(rand(1000000));
76 $content->{'phone'} ||= '111-111-1111';
78 $content->{'bankname'} ||= 'unknown';
79 $content->{'bankcity'} ||= 'unknown';
80 $content->{'bankstate'} ||= 'XX';
87 $Business::OnlinePayment::HTTPS::DEBUG = $DEBUG;
90 # strip existent but empty fields so that required_fields works right
91 foreach(keys(%{$self->{_content}})) {
92 delete $self->{_content}->{$_}
93 if (!defined($self->{_content}->{$_} ) or
94 $self->{_content}->{$_} eq '');
97 $self->required_fields(qw(
113 tie my %request, 'Tie::IxHash', (
114 map { $_, $self->{_content}->{$_} } @fields
117 $DB::single = $DEBUG;
118 if($self->test_transaction()) {
119 print "https://".$self->server.$self->path."\n";
120 print "$_\t".$request{$_}."\n" foreach keys(%request);
121 $self->error_message('test mode not supported');
122 $self->is_success(0);
125 my ($reply, $response, %reply_headers) = $self->https_post(\%request);
127 if(not $response =~ /^200/) {
128 croak "HTTPS error: '$response'";
131 # string looks like this:
132 # P1=1234&P2=General Status&P3=Specific Status
133 # P3 is not always there, though.
134 if($reply =~ /^P1=(\d+)&P2=([\w ]*)(&P3=(\S+))?/) {
136 $self->is_success(1);
137 $self->authorization($4);
140 $self->is_success(0);
141 $self->error_message($2.($4 ? "($4)" : ''));
145 croak "Malformed server response: '$reply'";
156 Business::OnlinePayment::Jety - Jety Payments ACH backend for Business::OnlinePayment
160 use Business::OnlinePayment;
163 # Electronic check authorization. We only support
164 # 'Normal Authorization'.
167 my $tx = new Business::OnlinePayment("Jety");
170 login => 'testdrive',
171 password => 'testpass',
172 action => 'Normal Authorization',
173 description => 'Business::OnlinePayment test',
175 invoice_number => '100100',
176 first_name => 'Jason',
177 last_name => 'Kohles',
178 address => '123 Anystreet',
182 account_type => 'personal checking',
183 account_number => '1000468551234',
184 routing_code => '707010024',
185 check_number => '1001', # optional
189 if($tx->is_success()) {
190 print "Check processed successfully: ".$tx->authorization."\n";
192 print "Check was rejected: ".$tx->error_message."\n";
195 =head1 SUPPORTED TRANSACTION TYPES
199 Content required: type, login, password, action, amount, first_name, last_name, account_number, routing_code.
203 For detailed information see L<Business::OnlinePayment>.
205 =head1 METHODS AND FUNCTIONS
207 See L<Business::OnlinePayment> for the complete list. The following methods either override the methods in L<Business::OnlinePayment> or provide additional functions.
211 Returns the four-digit result code.
215 Returns a useful error message.
217 =head1 Handling of content(%content) data:
221 The following actions are valid:
227 Mark Wells <mark@freeside.biz>
231 perl(1). L<Business::OnlinePayment>.