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', map { $_ => $self->{_content}->{$_} } @fields;
115 $DB::single = $DEBUG;
116 if($self->test_transaction()) {
117 print "https://".$self->server.$self->path."\n";
118 print "$_\t".$request{$_}."\n" foreach keys(%request);
119 $self->error_message('test mode not supported');
120 $self->is_success(0);
123 my ($reply, $response, %reply_headers) = $self->https_post(\%request);
125 if(not $response =~ /^200/) {
126 croak "HTTPS error: '$response'";
129 # string looks like this:
130 # P1=1234&P2=General Status&P3=Specific Status
131 # P3 is not always there, though.
132 if($reply =~ /^P1=(\d+)&P2=([\w ]*)(&P3=(\S+))?/) {
134 $self->is_success(1);
135 $self->authorization($4);
138 $self->is_success(0);
139 $self->error_message($2.($4 ? "($4)" : ''));
143 croak "Malformed server response: '$reply'";
154 Business::OnlinePayment::Jety - Jety Payments ACH backend for Business::OnlinePayment
158 use Business::OnlinePayment;
161 # Electronic check authorization. We only support
162 # 'Normal Authorization'.
165 my $tx = new Business::OnlinePayment("Jety");
168 login => 'testdrive',
169 password => 'testpass',
170 action => 'Normal Authorization',
171 description => '111-111-1111 www.example.com',
173 invoice_number => '100100',
174 first_name => 'Jason',
175 last_name => 'Kohles',
176 address => '123 Anystreet',
180 account_type => 'personal checking',
181 account_number => '1000468551234',
182 routing_code => '707010024',
183 check_number => '1001', # optional
187 if($tx->is_success()) {
188 print "Check processed successfully: ".$tx->authorization."\n";
190 print "Check was rejected: ".$tx->error_message."\n";
193 =head1 SUPPORTED TRANSACTION TYPES
197 Content required: type, login, password, action, amount, first_name, last_name, account_number, routing_code, description.
199 description should be set in the form "111-111-1111 www.example.com"
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>.