Wiki Markup |
---|
{float:right\|width=300px\|background=lightgrey\|border=solid blue 2px\|margin=10px\|padding=8px}*Contents* {toc:all=true|depth=4|excerpt=true|indent=14px} {float} * |
Change
...
log:
...
Date: |
---|
...
Author: |
---|
...
Version: |
---|
...
Changes: |
---|
...
03 Oct 2013 | KTH | 0.1 |
...
Doc |
...
created. | |||
|
|
|
|
Reference log:
Document: | Version: | Date: |
---|---|---|
|
|
|
Introduction
This document describes the interfacing between Rator Customer Care and Billing System (Rator) and the Buckaroo BPE 3.0 payment systems. This interface is file based and will be discussed in detail in this document.
Overview
This document describes the interfacing between the Rator Customer Care and Billing System (Rator) and the Buckaroo BPE 3.0 payment systems . There are two engines involved: Buckaroo Request Generator Engine and Buckaroo Payment Capture Engine. The Request Generator is responsible for generating the payment request csv file that will be sent to Buckaroo. The Capture engine is responsible for processing the payment response files received from Buckaroo.
You can find more detailed information about Buckaroo Request Generator engine here: Buckaroo BPE3 Request Generator Engine
You can find more detailed information about Buckaroo Capture engine here:
Document usage
This document is primarily intended for the Rator implementation team and for confirming understanding of the interface with Buckaroo. It will also be used as a basis for acceptance tests.
Note: Please note that we have a separate integration with Buckaroo BPE 2.0 payment interface. This is also file based. For more detailed description of integration towards the Buckaroo BPE 2.0 interface, please look here.
Scope
The scope of this document is the interface between the Buckaroo BPE 3.0 and Rator.
Production Date
XX November 2013.
Interface
The interface with Buckaroo will be file based. Payment instructions can be sent (by file) to Buckaroo, Buckaroo will then collect the money with our customer, and update us on the payment status via response messages (also in a file).
File format
The format of the request and reaponse files is CSV. This format is described in more detail under the section Payment File Format.
File naming
The names of the files are described in Payment File Format.
Transport
The transport for the files is via SFTP. The SFTP server will be located with Buckaroo;
Frequency
Payment instruction files can be delivered to Buckaroo multiple times a day. Response files will be created by Buckaroo once a day.
Exact times TBD
- Payment instruction file: daily at TBD
- Response file: daily at TBD
Connection details
Connection details are still TBD
- IP address/URL:
- Directory:
- Username:
- Password:
- Certificate:
Messages
In this section we will discuss the individual messages and field values to some more detail.
Note that if a field is not mentioned in this chapter this fact does imply that the field should not be used/populated
Payment instruction message
Every scenario that we will discuss in this document will start with a payment instruction. Normally only one payment instruction will be generated per customer per month (i.e. one payment instruction per customer). For the Rator implementation the following fields will be (especially) important:
- Invoicenumber
The value of this field should link back to the the invoice in the Rator system. All payment responses can be linked back to the instruction via this number. - Invoicedate
- Payment due date
- CustomerCode
Internal Rator customer ID (or Billing Group Id?) - Address fields
Address data stored in Rator for this customer.
Needed by Buckaroo for collection purposes - Bank account number
- Mail address
Email address stored in Rator for this customer.
This email address will be used by Buckaroo for collection purposes - Phone Number and Mobile number
If a fixed phone is registered in the Rator database we will take this phone number.
This number will be used by Buckaroo for collection purposes.
Payment response message
Every payment instruction will result in one or more payment response messages. Fields that are especially important in this message type are the following:
- Payment status code and payment type code
These fields explian the reason for receiving this message. It is primarily used to know what type of payment it is for ex: direct debit / reversal / refund / settlement by merchant etc. - Invoicenumber
This number should be used to link the response to the original payment request message. - Debit/Credit amount
Debit/credit is from the customer's perspective . For a regular payment the debit field should contain an value matching the amount in the corresponding payment instruction message.
Note that the payment response file will contain the complete set of activity on the accounts (so also not monthly-fee related). Responses that cannot be linked back (via the invoicenumber field) can be ignored by Rator (for the time being).
Payment File Format
This section describes the Buckaroo file format (both request and response file formats) in detail.
Description of payment request csv file format
This section describes the record format for the csv files sent from Rator to Buckaroo with BPE3.0 payment requests.
Record lay-out:
websitekey;amount;culture;currency;description;service;invoicenumber;service_directdebitrecurring_action;service_directdebitrecurring_customeraccountnumber;service_directdebitrecurring_customeraccountname;
...
additional_service;service_creditmanagement_action;phonenumber;customerlastname;service_creditmanagement_customeraccountnumber;customergender;amountvat;service_creditmanagement_maxreminderlevel;
...
invoicedate;service_creditmanagement_customerbirthdate;service_creditmanagement_paymentmethodsallowed;datedue;customertype;faxnumber;customeremail;customerfirstname;mobilephonenumber;customerinitials;
...
customertitle;customercode;customerlastnameprefix;address_street_1;address_housenumber_1;address_housenumbersuffix_1;address_zipcode_1;address_city_1;address_state_1;address_country_1
...
Field
...
separators
...
:
...
semi-colon
...
(
...
“;
...
” )
...
or
...
ascii-char(28)
...
FieldSeperator
...
Record
...
separators:
...
“\n” (ascii-char(10)
...
linefeed)
...
or
...
“\n\
...
c” ” (ascii-char(10+13)
...
linefeed+carriage-return)
...
or
...
ascii-char(30)
...
RecordSeperator
...
Allowed
...
characters
...
for
...
fields:
...
a-z,
...
A-Z
...
&
...
1-9,
...
-+.@,
...
<space>
...
Limitation
...
is
...
in
...
the
...
format
...
offered
...
to
...
the
...
bank
...
for
...
the
...
authorized
...
payments.
...
Note
...
:
...
When
...
the
...
invoice
...
is
...
sent
...
to
...
Buckaroo
...
the
...
accompanying
...
payment
...
is
...
inserted
...
in
...
the
...
table
...
account_payment
...
with
...
a
...
payment_type_id
...
(TBD
...
new
...
payment_type_id)
...
that
...
identifies
...
the
...
Buckaroo
...
payment
...
and
...
this
...
payment
...
is
...
set
...
to “Do capture”.
Content fields:
Fieldname | Rator table and field | Example | Format |
---|---|---|---|
websitekey | - | FSsfaJKF&6GH | Buckaroo Websitekey. |
amount | invoice.TOTAL_EXCL_VAT |
...
+ |
...
invoice.TOTAL_VAT |
...
– invoice.PAYED_AMOUNT |
...
10.00 | REAL, 2 decimals; amount | ||
culture | - | nl-NL | String, ISO culture code |
currency | - | EUR | Fixed string for currency code |
description | <Description Prefix> + account_payment.REFERENCE | Test Incasso 1 | String; description, max length 100 chars |
service | - | Directdebitrecurring | String; Buckaroo service name |
invoicenumber | invoice.INVOICE_NUMBER | Test01923r4e | String; Invoice number, max length 100 chars |
service_directdebitrecurring_action | - | Pay | String; Pay or Refund (See Buckaroo service description) |
service_directdebitrecurring_customeraccountnumber | Billing_group_bank_account.BANK_ACCOUNT_NUMBER |
...
123456789 | Bank Account; |
...
Must |
...
be |
...
11 |
...
proof. |
...
Empty |
...
or |
...
null |
...
value |
...
not |
...
allowed |
...
service_directdebitrecurring_ |
...
customeraccountname | users.FIRST_NAME |
...
+ |
...
<space> |
...
+ |
...
users.LAST_NAME |
...
T.Test |
...
String; account name | |||
additional_service | - | Creditmanagement | String; see Buckaroo Service description |
service_creditmanagement_action | - | Invoice | Fixed String |
phonenumber | users.PHONE1 | 0201111111 | String; Phone number |
customerlastname | users.LAST_NAME | Tester | String; customer last name, max 200 chars |
service_creditmanagement_customeraccountnumber | Billing_group_bank_account.BANK_ACCOUNT_NUMBER |
...
123456789 | Bank account; |
...
must |
...
be |
...
11-proof. |
...
Empty |
...
or |
...
null |
...
value |
...
not |
...
allowed. |
...
|
...
be |
...
same as service_directdebitrecurring_customeraccountnumber, |
...
but |
...
must |
...
be |
...
repeated | |
customergender | users.GENDER |
...
1 | Integer, |
...
may |
...
not |
...
be |
...
empty |
...
|
...
Unknown |
...
|
...
Male |
...
|
...
Female | |||
amountvat | - | 0.00 | Real, 2 decimals |
service_creditmanagement_maxreminderlevel | - | 1 | INTEGER, may not be empty. Choose from (0,1,2,3,4). |
...
Default |
...
is |
...
4 | |
invoicedate | invoice.CLOSE_DATE |
...
2012-01-10 |
...
YYYY-MM-DD; |
...
Invoice |
...
date |
...
service_creditmanagement_ |
...
customerbirthdate | users.BIRTHDAY |
...
1970-01-13 |
...
YYYY-MM-DD; |
...
Birth |
...
date |
service_creditmanagement_ |
...
paymentmethodsallowed | - | machtiging,ideal |
...
String; |
...
Comma |
...
seaparated |
...
list |
...
of |
...
allowed |
...
methods |
...
of |
...
payment |
...
as |
...
offered |
...
by |
...
Buckaroo. |
...
See |
...
Buckaroo |
...
Service |
...
description |
...
for |
...
possible |
...
values | ||
datedue | invoice.CLOSE_DATE + <due date off set> | 2012-01-27 |
...
YYYY-MM-DD; |
...
due |
...
date | |||
customertype | - | 1 | String; type of customer |
faxnumber | users.FAX | 0309999999 | String; Fax number |
customeremail | users.EMAIL | support@buckaroo.nl | String; customer email address |
customerfirstname | users.FIRST_NAME | Test | String; Customer first name |
mobilephonenumber | service.PHONE_NUMBER | 0601111111 | String; mobile number |
customerinitials | - | T. | String; optional , currently not used |
customertitle | users.TITLE | 2 | String; customer title |
customercode | account.CUSTOMER_NUMBER | 55225522 | String; Customer rator account number |
customerlastnameprefix | - | de | String; optional , currently not used |
address_street_1 | users.STREET | Hoofdstraat | String; street name |
address_housenumber_1 | users.STREET_NUMBER | 1 | Integer; House number |
address_housenumbersuffix_1 | users.FLOOR | b | String; House number suffix |
address_zipcode_1 | users.ZIP | 1000 AA | String, Zipcode, always in DDDD<space>CC format |
address_city_1 | users.CITY | Amsterdam | String; City (in All capital letters) |
address_state_1 | users.PROVINCE | Noord-Holland | String; province |
address_country_1 | - | NL | String; country |
Example filename: Incasso_25-05-2010_001.CSV
...
Date
...
format
...
25-05-2010
...
is
...
DD-MM-YYYY
...
and
...
001
...
is
...
batch
...
number
...
for
...
that
...
day.
...
In
...
this
...
respect
...
multiple
...
batches
...
per
...
day
...
can
...
be
...
offered.
...
Description
...
of
...
payment
...
response
...
csv
...
file
...
This
...
section
...
described
...
the
...
record
...
layout
...
of
...
the
...
payment
...
response
...
file
...
sent
...
by
...
Buckaroo
...
to
...
us.
...
Record
...
lay-out:
...
"Created";"Website";"Payment
...
type";"Account
...
number";"Customer";"Invoice
...
number";"Description";"Amount
...
Debit";"Amount
...
credit";"Currency";"Status";
...
"Status
...
date";"Success";"Reversal
...
reason";"Country";"Transaction
...
key";"IP
...
Address"
...
Field
...
separators:
...
semi-colon
...
(
...
“;
...
” )
Content fields:
Fieldname | Description | Format |
---|---|---|
Created | Transaction date, i.e. |
...
payment |
...
date | Date format: |
...
YYYY-MM-DD |
...
HH:MM:SS |
...
|
...
2013-10-17 |
...
16:40:24 |
...
Website | Fixed string | String |
Payment type | Payment type code and description indicating the | 4 Character payment type code followed by a payment type string . |
Account number | Customer bank account number | String; IBAN bank account number |
Customer | Customer name | String; customer name |
Invoice number | invoice number | Simyo invoice number |
Description | Description of the payment | String |
Amount Debit | Amount debited from customer account | REAL; 2 decimals (amount in EURO) |
Amount credit | Amount credited from customer account | REAL; 2 decimals (amount in EURO) |
Currency | Currency code | Fixed String "EUR" |
Status | Status of the payment transaction | BPE3 status code |
Status date | Date of the last status update | REAL; 2 decimals, amount debited from customer account |
Success | String representation of boolean indicating whether the | String; true/false |
Reversal reason | Reason for the payment reversal | String |
Country | Country | String |
Transaction key | Payment transaction Key | String |
IP Address | IP address | String |
Filename for daily transactions: trx_2010-05-25.csv
...
Date
...
format
...
2010-05-25
...
is
...
YYYY-MM-DD
...
Additional
...
information
...
regarding
...
status
...
codes
...
and
...
payment
...
type
...
codes
...
of
...
transactions:
...
field | Description |
---|---|
status code |
|
payment type code |
|
Business rules payment response codes
The following table describes the business rules for handling the payment response codes from Buckaroo:
The payments found in the buckaroo response file can be divided into four different categories: payments, refunds, creditnotes and write-offs. The reponses within each category should be processed and booked against certain GL codes in Rator for financial reporting.
Note: When processing the payment response codes from the Buckaroo file, the field “succesvol” must be “True”. If not, process the next record.
Payments
The payments category consists of:
- (direct debit) payments,
- payments done to the collection agency
- settlements by merchant (external payments done by the customer to Simyo’s bank account instead of Buckaroo’s)
- reversals.
Resp. status code(s) | Payment type codes | Description | Action CDRator |
---|---|---|---|
190 | C001/C002/C003 | Successful: Payment/Direct debit/ iDEAL | The action required from CDRator for handling (direct debit) payments is Capture Payment by:
|
...
|
...
|
...
|
...
|
...
|
...
|
...
|
...
| |||
190 | C461/C462 | Payments to the Collection Agency | The action required from CDRator for handlingpayments to the collection agency is Capture Payment by:
|
190 | N800 | Settlement by merchant | The action required from CDRator for handling BPE 3.0 settlements by merchant is Capture Payment by:
|
190 | C561/C562/C501 | Reversal | The action required from CDRator for handling reversals is Insert Reversed Payment by:
|
Refunds & Credit notes
This category consists of:
- Single refund transaction
- Refund followed by a Credit Note
- Single Credit Note transaction
A credit note is a special kind of transaction within the credit management process. The amount of the credit note will be subtracted from the open (principal) invoice amount, leaving no or a partial amount to be paid by the customer.When Simyo refunds (a partial) amount to the customer, the invoice amount will be open again. Therefore, a credit note is usually used to close the invoice amount after a refund. A single refund transaction occurs seldom.
Note:
- A refund is usually followed by a credit note. However, a credit note could also be used as a single transaction, without being prior to a refund. Therefore, the refund should always be processed before the corresponding credit note.
Resp. code(s) | Transaction codes | Description | Action CDRator |
---|---|---|---|
190 | C101/C102/C121C500/C565 | Refund | The action required from CDRator for handling BPE 3.0 (single) refunds is Insert Reversed Payment by:* Checking if the status code is 190. Not found -> write error to log, process next record.
|
190 | I255 | Credit Note | The action required from CDRator for handling BPE 3.0 credit notes is Insert positive payment by:
|
Write off
Invoices that are not paid for by customers are sent to the collection agency.After a certain period of time, the unpaid invoices are closed by the collection agency and should be closed on the rator platform as a write off.
Resp. status code(s) | Payment type codes | Description | Action CDRator |
---|---|---|---|
190 | I256 | Write off | The action required from CDRator for handling reversals is Insert Reversed Payment by:
|
Logging
The following table describes the requirements for logging and how the current implementation achieves it:
Requirement | Implementation |
---|---|
For each response file that is processed, | The DB table BUCKAROO_RESPONSE_HEADER contains one row for each response file processed. |
For each processed record, a row must be written | The table BUCKAROO_RESPONSE_RECORD contains one row for each record in the response file. |
In case of an error, a clear description should be written to the log file and the Rator system should start processing the next (response) record. | The table BUCKAROO_RESPONSE_RECORD contains one row for each record in the response file. |