Global Payment Service Developer Guide

Transcription

Global Payment Service Developer Guide
Title Page
CyberSource Global Payment Service
Developer Guide
For Bank Transfers,
Brazilian Boletos Bancários,
and Direct Debits
Simple Order API
SCMP API
March 2015
CyberSource Corporation HQ | P.O. Box 8999 | San Francisco, CA 94128-8999 | Phone: 800-530-9095
CyberSource Contact Information
For general information about our company, products, and services, go to
http://www.cybersource.com.
For sales questions about any CyberSource Service, email sales@cybersource.com or
call 650-432-7350 or 888-330-2300 (toll free in the United States).
For support information about any CyberSource Service, visit the Support Center at
http://www.cybersource.com/support.
Copyright
© 2015 CyberSource Corporation. All rights reserved. CyberSource Corporation ("CyberSource") furnishes this
document and the software described in this document under the applicable agreement between the reader of
this document ("You") and CyberSource ("Agreement"). You may use this document and/or software only in
accordance with the terms of the Agreement. Except as expressly set forth in the Agreement, the information
contained in this document is subject to change without notice and therefore should not be interpreted in any way
as a guarantee or warranty by CyberSource. CyberSource assumes no responsibility or liability for any errors
that may appear in this document. The copyrighted software that accompanies this document is licensed to You
for use only in strict accordance with the Agreement. You should read the Agreement carefully before using the
software. Except as permitted by the Agreement, You may not reproduce any part of this document, store this
document in a retrieval system, or transmit this document, in any form or by any means, electronic, mechanical,
recording, or otherwise, without the prior written consent of CyberSource.
Restricted Rights Legends
For Government or defense agencies. Use, duplication, or disclosure by the Government or defense agencies
is subject to restrictions as set forth the Rights in Technical Data and Computer Software clause at DFARS
252.227-7013 and in similar clauses in the FAR and NASA FAR Supplement.
For civilian agencies. Use, reproduction, or disclosure is subject to restrictions set forth in subparagraphs (a)
through (d) of the Commercial Computer Software Restricted Rights clause at 52.227-19 and the limitations set
forth in CyberSource Corporation's standard commercial agreement for this software. Unpublished rights
reserved under the copyright laws of the United States.
Trademarks
CyberSource, The Power of Payment, CyberSource Payment Manager, CyberSource Risk Manager,
CyberSource Decision Manager, CyberSource Connect, Authorize.Net, and eCheck.net are trademarks and/or
service marks of CyberSource Corporation. All other brands and product names are trademarks or registered
trademarks of their respective owners.
2
CONTENTS
Contents
Recent Revisions to This Document
About This Guide
8
10
Audience and Purpose
10
Conventions 10
Note and Important Statements 10
Text and Command Conventions 10
Related Documents
Chapter 1
11
Customer Support
11
Getting Started
12
Global Collect
12
Bank Account Requirements
12
API Versions for the XML Schema
12
Order Tracking 13
Reconciliation IDs and Transaction Reference Numbers
Request IDs 14
Payment Reference Numbers 14
Chapter 2
13
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Requesting Bank Transfers
15
15
Requesting Bank Transfer Refunds
Researching a Missing Payment
16
17
API Fields 18
Request Fields 18
Reply Fields 25
Request and Reply Examples 28
Bank Transfer Request 28
Bank Transfer Reply 29
Standalone Bank Transfer Refund Request 30
Standalone Bank Transfer Refund Reply 31
Global Payment Service Developer Guide | March 2015
3
Contents
Follow-On Bank Transfer Refund Request 31
Follow-On Bank Transfer Refund Reply 32
Chapter 3
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Requesting Bank Transfers
33
33
Requesting Bank Transfer Refunds
Researching a Missing Payment
34
35
API Fields 36
Request Fields 36
Offer-Level Fields 41
Reply Fields 42
Reply Flags 45
Request and Reply Examples 46
Bank Transfer Request 46
Bank Transfer Reply 47
Standalone Bank Transfer Refund Request 48
Standalone Bank Transfer Refund Reply 49
Follow-On Bank Transfer Refund Request 49
Follow-On Bank Transfer Refund Reply 50
Chapter 4
Real-Time Bank Transfers Using the Simple Order API
51
Transaction Status 51
Sending the Query 51
Viewing the Response 53
Requesting Real-Time Bank Transfers
54
Requesting Real-Time Bank Transfer Refunds
API Fields 55
Request Fields 55
Bank Codes 60
Reply Fields 61
Additional Request Fields
63
Request and Reply Examples 64
Real-Time Bank Transfer Request 64
Real-Time Bank Transfer Reply 65
Real-Time Bank Transfer Refund 65
Real-Time Bank Transfer Refund Reply
Global Payment Service Developer Guide | March 2015
55
66
4
Contents
Chapter 5
Real-Time Bank Transfers Using the SCMP API
67
Transaction Status 67
Sending the Query 67
Viewing the Response 69
Requesting Real-Time Bank Transfers
70
Requesting Real-Time Bank Transfer Refunds
API Fields 71
Request Fields 71
Offer-Level Fields 75
Bank Codes 76
Reply Fields 78
Reply Flags 79
Additional Request Fields
71
80
Request and Reply Examples 81
Real-Time Bank Transfer Request 81
Real-Time Bank Transfer Reply 81
Real-Time Bank Transfer Refund Request 82
Real-Time Bank Transfer Refund Reply 83
Chapter 6
Boletos Bancários Using the Simple Order API
Requesting a Boleto Bancário
API Fields 84
Data Type Definitions
Request Fields 85
Reply Fields 86
84
84
84
Examples 88
Name-Value Pairs: Request 88
Name-Value Pairs: Reply 88
XML: Request 89
XML: Reply 89
Chapter 7
Boletos Bancários Using the SCMP API
Requesting a Boleto Bancário
90
90
API Fields 90
Request Fields 90
Reply Fields 92
Reply Flags 94
Request and Reply Examples
Request 95
Reply 95
Global Payment Service Developer Guide | March 2015
95
5
Contents
Chapter 8
Reports for Boletos Bancários
96
Boleto Bancário Unfulfilled Report 96
Viewing and Downloading Reports 96
XML Conventions and Data Types 97
Syntax for Report Declarations 97
Syntax for Element Declarations 98
Data Types and Lengths 98
Elements in the Report 99
<Report> 99
<Summary> 101
<Range> 103
<TransactionDetail> 104
<Transaction> 105
DTD 108
Example 109
Single Transaction Report
Chapter 9
112
Direct Debits and Direct Debit Refunds Using the Simple Order API
Requesting Direct Debits
115
115
Requesting Direct Debit Refunds
116
API Fields 118
Request Fields 118
Reply Fields 126
Request and Reply Examples 128
Direct Debit Request 128
Direct Debit Reply 129
Standalone Direct Debit Refund Request
Follow-On Direct Debit Refund 130
Chapter 10
129
Direct Debits and Direct Debit Refunds Using the SCMP API
Requesting Direct Debits
132
132
Requesting Direct Debit Refunds
133
API Fields 135
Request Fields 135
Offer-Level Fields 141
Reply Fields 142
Reply Flags 144
Request and Reply Examples 145
Direct Debit Request 145
Direct Debit Refund—Standalone 147
Direct Debit Refund—Follow-On 148
Global Payment Service Developer Guide | March 2015
6
Contents
Chapter 11
Testing
149
Sending Test Requests
149
Testing Bank Transfers, Direct Debits, and Refunds
149
Testing Real-Time Bank Transfers 151
Testing Your CyberSource Interface 151
Testing Your Network Interface 152
Going Live
153
Appendix A Product Codes
154
Appendix B Reason Codes
155
Reason Codes for the Simple Order API
155
Appendix C Researching a Missing Bank Transfer Payment
Index
158
161
Global Payment Service Developer Guide | March 2015
7
REVISIONS
Recent Revisions to This
Document
Release
Changes
March 2015

Updated Example 15. See page 54.

Updated Example 22. See page 70.
January 2015
Removed the Interac processor from the document.
December 2014
Removed requirement to send request token fields with follow-on bank
transfer and direct debit refunds. See the following sections:

Bank transfers:
 Simple Order API—"Requesting Bank Transfer Refunds," page 16


SCMP API—"Requesting Bank Transfer Refunds," page 34
Direct debits:
 Simple Order API—"Requesting Direct Debit Refunds," page 116

SCMP API—"Requesting Direct Debit Refunds," page 133
Updated customer company API request field length specifications and
added shipping name and phone number API request fields to the following
tables:

Bank transfers:
 Simple Order API—Table 5, page 18


SCMP API—Table 7, page 36
Real-time bank transfers:
 Simple Order API—Table 12, page 55

SCMP API—Table 17, page 71
Updated the response examples for Simple Order API real-time bank
transfer payments. See "Viewing the Response," page 53.
Added the request token API reply field to the following tables:

Real-time bank transfers:
 Simple Order API—Table 14, page 61

SCMP API—Table 20, page 78
Added the bank SWIFT code information to the following sections:

Direct debits:
 Simple Order API—"Requesting Direct Debits," page 115, Table 37,
page 118, and Example 41, page 128

SCMP API—"Requesting Direct Debits," page 132, Table 39,
page 135, Example 47, page 145, and Example 49, page 147
Global Payment Service Developer Guide | March 2015
8
Recent Revisions to This Document
Release
Changes
September 2014
This revision contains only editorial changes and no technical updates.
August 2014
Removed the following request fields for direct debits and direct debit
refunds:
July 2014

directDebitService_mandateID

direct_debit_mandate_id
Added examples to the following sections:

Bank transfers
 Simple Order API— page 28.


Real-time bank transfers
 Simple Order API—page 64.


SCMP API—page 46.
SCMP API—page 81.
Direct debits
 Simple Order API—page 128.

SCMP API—page 145.
Global Payment Service Developer Guide | March 2015
9
ABOUT GUIDE
About This Guide
Audience and Purpose
This guide is written for merchants who want to use the Global Collect processor to offer
the Global Payment services to customers. This guide describes the tasks a merchant
must complete in order to make bank transfers and bank transfer refunds, real-time bank
transfers, boleto bancario payments, and direct debits and direct debit refunds.
Conventions
Note and Important Statements
A Note contains helpful suggestions or references to material not contained in
the document.
Note
An Important statement contains information essential to successfully
completing a task or learning a concept.
Important
Text and Command Conventions
Convention
Usage
bold

Field and service names in text; for example:
Include the ics_applications field.

Items that you are instructed to act upon; for example:
Click Save.
Global Payment Service Developer Guide | March 2015
10
About This Guide
Convention
Usage
monospace

XML elements.

Code examples and samples.

Text that you enter in an API environment; for example:
Set the davService_run field to true.
Related Documents

The Global Payment Service Planning Guide (PDF | HTML) describes the business
and technical implementations a merchant must complete in order to make bank
transfers and bank transfer refunds, real-time bank transfers, boleto bancario
payments, and direct debits and direct debit refunds.

Credit Card Services Using the Simple Order API (PDF | HTML) describes the tasks
you must complete to integrate the credit card services into your existing management
system.

Credit Card Services Using the SCMP API (PDF | HTML) describes the tasks you
must complete to integrate the credit card services into your existing order
management system.

Getting Started with CyberSource Advanced for the Simple Order API (PDF | HTML)
describes how to get started using the Simple Order API.

Getting Started with CyberSource Advanced for the SCMP API (PDF | HTML)
describes how to get started using the SCMP API.

The Reporting Developer Guide (PDF | HTML) describes how to download reports.
Refer to the Support Center for complete CyberSource technical documentation:
http://www.cybersource.com/support_center/support_documentation
Customer Support
For support information about any CyberSource service, visit the Support Center:
http://www.cybersource.com/support
Global Payment Service Developer Guide | March 2015
11
CHAPTER
1
Getting Started
Global Collect
The Global Payment Service supports the Global Collect processor. This processor
supports all the countries mentioned in the Global Payment Service Planning Guide
(PDF | HTML)
Bank Account Requirements
Become familiar with the bank account requirements for the countries in which you will be
processing payments. Contact CyberSource Customer Support for required countryspecific bank account information.
API Versions for the XML Schema
For general information about the API versions, see Getting Started with CyberSource
Advanced for the Simple Order API. The following table shows which Simple Order API
version to use for new payment methods.
Table 1
Choosing a Simple Order API Version
Payment Method
Version
Boletos Bancários
1.42 or later
Real-time bank transfers
1.23 or later
Global Payment Service Developer Guide | March 2015
12
Chapter 1
Getting Started
Order Tracking
For general information about order tracking, see Getting Started with CyberSource
Advanced for the Simple Order API or Getting Started with CyberSource Advanced for the
SCMP API.
Reconciliation IDs and Transaction Reference
Numbers
The following table lists the field names for the reconciliation IDs and transaction
reference numbers for the Global Payment Service payment methods.
Table 2
Reconciliation IDs and Transaction Reference Numbers
Payment Method
Service
Field Names
Bank transfers
Bank transfer

Simple Order API: bankTransferReply_reconciliationID

SCMP API: bank_transfer_trans_ref_no
Bank transfer
refund

Simple Order API: bankTransferRefundReply_reconciliationID

SCMP API: bank_transfer_refund_trans_ref_no
Real-time bank
transfer

Simple Order API: bankTransferRealTimeReply_
reconciliationID

SCMP API: bank_transfer_real_time_trans_ref_no
Boleto Bancário
payment

Simple Order API: boletoPaymentReply_reconciliationID

SCMP API: boleto_payment_trans_ref_no
Direct debit

Simple Order API: directDebitReply_reconciliationID

SCMP API: direct_debit_trans_ref_no

Simple Order API: directDebitRefundReply_reconciliationID

SCMP API: direct_debit_refund_trans_ref_no
Boletos Bancários
Direct debits
Direct debit refund
Global Payment Service Developer Guide | March 2015
13
Chapter 1
Getting Started
Request IDs
For all Global Payment Services, the request ID is returned in the reply message in:

requestID for the Simple Order API

request_id for the SCMP API
The following table lists the field names for the Global Payment Service request IDs in the
request messages.
Table 3
Reconciliation IDs and Transaction Reference Numbers
Payment Method
Service
Field Names
Bank transfers
Bank transfer
refund for a bank
transfer

Simple Order API:
bankTransferRefundService_bankTransferRequestID

SCMP API: bank_transfer_request_id
Bank transfer
refund for a realtime bank transfer

Simple Order API:
bankTransferRefundService_
bankTransferRealTimeRequestID

SCMP API: bank_transfer_real_time_request_id

Simple Order API: directDebitRefundService_
directDebitRequestID

SCMP API: direct_debit_request_id
Direct debits
Direct debit refund
Payment Reference Numbers
The payment reference number is a unique value for each bank transfer. CyberSource
returns this value in the bank transfer reply message, and you must display it prominently
to the customer. The customer must send in the number with the bank transfer so that the
payment can be matched to the order.
The following table lists the field names for the payment reference numbers.
Table 4
Payment Reference Numbers
Service
Field Names
Bank transfer

Simple Order API: bankTransferReply_paymentReference

SCMP API: bank_transfer_payment_reference

Simple Order API: bankTransferRealTimeReply_
paymentReference

SCMP API: bank_transfer_real_time_payment_reference
Real-time bank
transfer
Global Payment Service Developer Guide | March 2015
14
CHAPTER
Bank Transfers and Bank
Transfer Refunds Using the
Simple Order API
2
Requesting Bank Transfers
To request a bank transfer, set the bankTransferService_run field to true. See Table 5,
page 18, for a list of the fields to use when requesting the service.
When requesting a bank transfer, you may not request any other ICS service except Tax
Calculation. For more information about the service, see Tax Calculation Service Using
the Simple Order API.
In the bank transfer reply, you receive fields containing information about the bank and
bank account that the customer should transfer funds to. Display this information to
customers so that they can easily transcribe it or print it and give it to their banks.
The information includes the bank’s name, bank’s country, the account holder’s name, and
so on. The primary field containing the bank account information is bankTransferReply_
accountNumber. This field contains the bank account number information you need to
display, including a bank code or sort code, branch code or check digit, if any of those are
used for the particular country. You can display the contents of the field as you receive it in
the reply from CyberSource.
You might also receive the bankTransferReply_iban field with the International Bank
Account Number (IBAN). The IBAN is an international standard for bank account numbers
that the EU is adopting. In the future, the EU is planning to switch to using only the IBAN
format and not the original format presented in bankTransferReply_accountNumber. If
the IBAN is present in the reply, display it to the customer along with the other bank
information, and identify it as the IBAN.
Depending on the country, you might also receive the bank’s SWIFT code, which is
another bank identifier. When the bankTransferReply_bankSwiftCode field is present,
display the SWIFT code to the customer along with the other bank information, and
identify it as the SWIFT code.
Global Payment Service Developer Guide | March 2015
15
Chapter 2
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Requesting Bank Transfer
Refunds
Important
From August 1, 2016, for euro countries and from October 31, 2016, for noneuro countries, the IBAN must be included in each request. If you provide a
BBAN it will be converted to an IBAN, and this conversion process will continue
only until August 1, 2016.
a
Important
A follow-on refund must occur within 60 days of the request for the bank
transfer. After the time limit expires, only a stand-alone refund can be
requested. To refund a bank transfer, wait 1 to 3 days after the bank transfer
request is processed by CyberSource. When you attempt to request a followon refund before the initial bank transfer is processed into your merchant bank
account, the error ORDER WITHOUT REFUNDABLE PAYMENTS is
displayed. This error could also mean that your account is not configured for
standalone refunds with Global Collect. To configure your account, please
contact CyberSource Customer Support.
There are two types of bank transfer refunds: follow-on refunds and stand-alone refunds.
A follow-on refund uses information from a previous bank transfer. A stand-alone refund
does not depend on a previous transaction.
To request a bank transfer refund:

Set the bankTransferRefundService_run field to true.

Do not request any other ICS services except Tax Calculation, which is optional. For
more information about this service, see Tax Calculation Service Using the Simple
Order API.

Send the fields required for a bank transfer refund request as described in Table 5,
page 18. For a follow-on refund, the fields and values must match the fields and
values you sent in the bank transfer request.

For a stand-alone refund, the bankTransferRefundService_
bankTransferRequestID field is optional. See page 30.

For a follow-on refund, include one of these fields from the original request with the
request ID (see page 31):


bankTransferRefundService_bankTransferRequestID

bankTransferRefundService_bankTransferRealTimeRequestID
The easiest way to implement bank transfer refunds is to always send the request ID
from the original bank transfer with every bank transfer refund request.
Global Payment Service Developer Guide | March 2015
16
Chapter 2

Bank Transfers and Bank Transfer Refunds Using the Simple Order API
CyberSource recommends that when you request a refund, you use the same value
for merchantReferenceCode that you used for the bank transfer. This makes it
easier for you to link the refund to the original bank transfer in your own system as
well as in CyberSource reports and transaction search screens.
CyberSource validates basic checks the format of the bank account number before
performing the bank transfer refund. If the account number does not pass the validation,
CyberSource rejects the request with reasonCode=244 instead of processing the bank
transfer refund. CyberSource recommends that you then confirm that the customer
entered the number correctly, and if it is incorrect, request the refund again with the
correct number.
You may perform multiple partial refunds against a bank transfer. The sum of the refunds
may not exceed the amount of the payment.
You do not receive an error in the reply for either of the following conditions:

The bankTransferRefundService_bankTransferRequestID field is invalid.

The customer’s payment has not yet been received.
Instead, CyberSource does not process the refund, and the transaction appears in the
daily Transaction Exception Detail Report. You should monitor this report daily for
transactions problems. For descriptions of the reason codes that can appear in the report,
see "Reason Codes," page 155. For information about the report and how to use it, see
the Global Payment Service Planning Guide. For details about downloading the report and
its format, see the Reporting Developer Guide.
Researching a Missing Payment
If CyberSource cannot match the customer’s payment information to the information you
submit in the original bank transfer request (typically because the customer made a
mistake), a situation could arise in which a customer makes a bank transfer payment but
does not receive the goods, and CyberSource’s report and your bank account statement
do not show that you received the payment. You can make a payment inquiry in the
Business Center and have CyberSource research the missing payment and try to match
your request with the customer’s payment.
Note
You must wait at least five days after the funds are debited from the customer’s
account before initiating an inquiry because it can take that long for the funds to
appear in your account and in CyberSource’s reports. CyberSource does not
allow you to perform an inquiry within five days of submitting the initial bank
transfer request.
For instructions on using the Business Center to research a lost payment, see
Appendix C, "Researching a Missing Bank Transfer Payment," on page 158.
Global Payment Service Developer Guide | March 2015
17
Chapter 2
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
API Fields
For information about the data types, see Getting Started with CyberSource Advanced for
the Simple Order API.
Request Fields
The following table lists the fields to use in requests for bank transfers and bank transfer
refunds.
Table 5
Request Fields for Bank Transfers and Bank Transfer Refunds
for the Simple Order API
Request Field
Description
Used By and
Required (R) or
Optional (O)
Data Type
& Length
bankInfo_address
Bank’s address.
Refund (O)
String (255)
bankInfo_bankCode
Bank's code. Used for some countries
when you are not using the IBAN. Contact
CyberSource Customer Support for
required country-specific bank account
information.
Refund (See
description)
String (See
description)
Note This is a required field if the
bankInfo_country field is GB, AT, FR, or
DE. For more information see the twocharacter ISO Standard Country Codes.
bankInfo_branchCode
Code that identifies the branch of the
customer's bank when you are not using
the IBAN.
Refund (O)
String (15)
bankInfo_city
City in which the bank is located.
Refund (O)
String (40)
Bank Transfer
(See description)
String (2)
Some banks validate the bank account
information, so consider sending this field
if the bank is not located in the same city
of the billing address.
bankInfo_country
Country in which the bank is located. Use
the two-character ISO Standard Country
Codes.
Refund (R)
Note If bankInfo_country is not set,
CyberSource uses billTo_country to
determine the country in which the bank
transfer is taking place.
1. Required if billTo_country value is US or CA
2. Required if any shipping information is included
3. Required if shipTo_country value is US or CA
Global Payment Service Developer Guide | March 2015
18
Chapter 2
Table 5
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Request Fields for Bank Transfers and Bank Transfer Refunds
for the Simple Order API (Continued)
Request Field
Description
Used By and
Required (R) or
Optional (O)
Data Type
& Length
bankInfo_name
Bank's name.
Refund (See
description)
String (40)
Bank Transfer (O)
String (30)
Note This is a required field if the
bankInfo_country field is AU, FI, FR, IT,
NO, ES, SE, or CH. For more information
see the two-character ISO Standard
Country Codes.
bankInfo_swiftCode
Bank’s SWIFT code. Unique address of
the bank. Also known as the Bank
Identification Code (BIC).
Refund (O)
Note This field is required when the
IBAN is included in the request.
bankTransferRefundService_
bankTransferRequestID
The requestID value returned from a
previous request for the bank transfer
service.
Refund (R)
String (26)
bankTransferRefundService_
reconciliationID
Unique identifier for the order submitted to
Global Collect.
Refund (R for
standalone
refunds)
String (60)
Note If you do not include this field in a
refund request, CyberSource will
generate the value.
bankTransferRefundService_
run
Set to true to include the bank transfer
refund service in your request.
Refund (R)
String (5)
bankTransferService_run
Set to true to include the bank transfer
service in your request.
Bank Transfer (R)
String (5)
billTo_city
City of the billing address.
Bank Transfer (R)
String (50)
Refund (R)
billTo_company
Name of the customer’s company.
Bank Transfer (O)
String (60)
billTo_country
Billing address country. Use the ISO
Standard Country Codes.
Bank Transfer (R)
String (2)
Customer’s email address, including the
full domain name. For example:
jdoe@example.com
Bank Transfer (R)
Customer’s first name.
Bank Transfer (R)
billTo_email
billTo_firstName
Refund (R)
String (255)
Refund (R)
String (60)
Refund (R)
billTo_lastName
Customer’s last name.
Bank Transfer (R)
String (60)
Refund (R)
1. Required if billTo_country value is US or CA
2. Required if any shipping information is included
3. Required if shipTo_country value is US or CA
Global Payment Service Developer Guide | March 2015
19
Chapter 2
Table 5
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Request Fields for Bank Transfers and Bank Transfer Refunds
for the Simple Order API (Continued)
Request Field
Description
Used By and
Required (R) or
Optional (O)
Data Type
& Length
billTo_phoneNumber
Customer’s telephone number.
Bank Transfer (O)
String (15)
Refund (O)
billTo_postalCode
Postal code for the billing address. The
postal code must consist of 5 to 9 digits.
Bank Transfer (R)
String (10)
Refund (R)
If the value of billTo_country is US, the
9-digit postal code must follow this format:
[5 digits][dash][4 digits]
Example: 12345-6789
If the value of billTo_country is CA, the
6-digit postal code must follow this format:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C3
billTo_state
Billing address state.
Bank Transfer
(R)1
String (2)
Refund (R)1
billTo_street1
Billing address street address.
Bank Transfer (R)
String (60)
Refund (R)
billTo_street2
Additional address information.
Bank Transfer (O)
String (60)
Refund (O)
fundTransfer_accountName
Name used on the bank account. If you do
not send this field, it is assumed the last
name on the account is the billTo_
lastName value. Some banks validate the
name on the bank account, so consider
sending this field if the bank account
owner is not the customer. This scenario
might happen, for example, if a husband
places the order, but the wife’s name is on
the bank account.
Refund (O)
String (50)
Contact CyberSource Customer Support
for required country-specific bank account
information.
1. Required if billTo_country value is US or CA
2. Required if any shipping information is included
3. Required if shipTo_country value is US or CA
Global Payment Service Developer Guide | March 2015
20
Chapter 2
Table 5
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Request Fields for Bank Transfers and Bank Transfer Refunds
for the Simple Order API (Continued)
Request Field
Description
Used By and
Required (R) or
Optional (O)
Data Type
& Length
fundTransfer_accountNumber
Bank account number.
Refund (O)
String (See
description)
Note From August 1, 2016, for euro
countries and from October 31, 2016, for
non-euro countries, the IBAN must be
included in each request. If you provide a
BBAN it will be converted to an IBAN, and
this conversion process will continue only
until August 1, 2016.
Note Do not use the IBAN in this field.
include the IBAN in the fundTransfer_
iban field.
fundTransfer_bankCheckDigit
Code used to validate the customer's
account number when you are not using
the IBAN. Contact CyberSource Customer
Support for required country-specific bank
account information.
Refund (O)
String (2)
fundTransfer_iban
International Bank Account Number
(IBAN) for the bank account.
Refund (See
description)
String (30)
Bank Transfer (O)
String (30)
Note Required for specific countries.
Contact CyberSource Customer Support
for required country-specific bank account
information.
item_#_productCode
Type of product, which is also used to
determine the product category:
electronic, handling, physical, service, or
shipping. The default value is default.
See "Product Codes," page 154, for a list
of valid values.
Refund (O)
For bank transfers, if you set this field to a
value other than default, stored_
value, or any of the values related to
shipping and/or handling, the item_#_
quantity, item_#_productName, and
item_#_productSKU fields are required.
item_#_productName
Name of the product. For bank transfers,
required if item_#_productCode is NOT
default, stored_value, or one of
the values related to shipping and/or
handling.
Bank Transfer
(See description)
String (30)
Refund (O)
1. Required if billTo_country value is US or CA
2. Required if any shipping information is included
3. Required if shipTo_country value is US or CA
Global Payment Service Developer Guide | March 2015
21
Chapter 2
Table 5
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Request Fields for Bank Transfers and Bank Transfer Refunds
for the Simple Order API (Continued)
Request Field
Description
Used By and
Required (R) or
Optional (O)
Data Type
& Length
item_#_productSKU
Product identifier code. For bank
transfers, required if item_#_
productCode is NOT default,
stored_value, or one of the values
related to shipping and/or handling.
Bank Transfer
(See description)
String (30)
Quantity of the product being purchased.
For bank transfers, required if item_#_
productCode is NOT default,
stored_value, or one of the values
related to shipping and/or handling.
Bank Transfer
(See description)
Tax amount associated with this item. The
item_#_taxAmount field is additive. For
example, if you send one item with
unitPrice of 10.00 and taxAmount of
0.80, and you send another item with
unitPrice of 20.00 and taxAmount of
1.60, the total amount authorized will be
for 32.40, not 30.00 with 2.40 of tax
included.
Bank Transfer (O)
item_#_quantity
item_#_taxAmount
Refund (O)
Integer (10)
Refund (O)
String (15)
Refund (O)
The item_#_taxAmount and the item_#_
unitPrice must be in the same currency.
If you include item_#_taxAmount, and
you also include taxService in your
request, taxService does not calculate
tax for the item. Instead, it returns the
value in the item_#_taxAmount field.
item_#_unitPrice
Per-item price of the product. You must
include either this field or
purchaseTotals_grandTotalAmount in
your request. This value cannot be
negative. For more information, see
Getting Started with CyberSource
Advanced for the Simple Order API.
Bank Transfer
String (15)
Refund
(See description)
You can include a decimal point (.) in this
field, but you cannot include any other
special characters. The amount will be
truncated at the request level to the
correct number of decimal places.
1. Required if billTo_country value is US or CA
2. Required if any shipping information is included
3. Required if shipTo_country value is US or CA
Global Payment Service Developer Guide | March 2015
22
Chapter 2
Table 5
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Request Fields for Bank Transfers and Bank Transfer Refunds
for the Simple Order API (Continued)
Request Field
Description
Used By and
Required (R) or
Optional (O)
Data Type
& Length
linkToRequest
Value that links the current request to a
previous authorization request for a debit
card or prepaid card. This value is useful
when multiple payment methods are used
to complete an order. For more
information, see Credit Card Services
Using the Simple Order API.
Bank Transfer (O)
String (26)
merchantID
Your CyberSource merchant ID.
Bank Transfer (R)
String (30)
Note When opening your account with
Refund (R)
CyberSource, be sure to inform
CyberSource if you plan to use multiple
CyberSource merchant IDs. For example,
if you have separate business units within
your company, each with a separate
CyberSource merchant ID. You must have
a separate processor merchant ID for
each CyberSource merchant ID. For more
information, contact CyberSource
Customer Support.
Merchant-generated order reference or
tracking number. For more information,
see Getting Started with CyberSource
Advanced for the Simple Order API.
Bank Transfer (R)
Currency used for the order. Use the ISO
Standard Currency Codes.
Bank Transfer (R)
Grand total for the order. You must include
either this field or item_#_unitPrice in
your request. For more information, see
Getting Started with CyberSource
Advanced for the Simple Order API.
Bank Transfer
shipTo_city
City of the shipping address.
Bank Transfer
(O)2
String (50)
shipTo_country
Country of the shipping address. Use the
two-character ISO Standard Country
Codes.
Bank Transfer (O)
String (2)
shipTo_firstName
First name of the person receiving the
product.
Bank Transfer (O)
String (60)
shipTo_lastName
Last name of the person receiving the
product.
Bank Transfer (O)
String (60)
merchantReferenceCode
purchaseTotals_currency
purchaseTotals_
grandTotalAmount
String (50)
Refund (R)
String (5)
Refund (R)
String (15)
Refund
See description
1. Required if billTo_country value is US or CA
2. Required if any shipping information is included
3. Required if shipTo_country value is US or CA
Global Payment Service Developer Guide | March 2015
23
Chapter 2
Table 5
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Request Fields for Bank Transfers and Bank Transfer Refunds
for the Simple Order API (Continued)
Request Field
Description
Used By and
Required (R) or
Optional (O)
Data Type
& Length
shipTo_phoneNumber
Phone number for the shipping address.
Bank Transfer (O)
String (15)
shipTo_postalCode
Postal code for the shipping address. The
postal code must consist of 5 to 9 digits.
Bank Transfer
(O)3
String (10)
If the value of shipTo_country is US, the
9-digit postal code must follow these
rules:
[5 digits][dash][4 digits]
Example: 12345-6789
If the value of shipTo_country is CA, the
6-digit postal code must follow these
rules:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C4
If the postal code for the shipping address
is not included in the request message,
CyberSource uses the postal code from
the billing address. If the postal code for
the billing address is not included in the
request message, the postal code for the
shipping address is required.
shipTo_state
State or province of the shipping address.
Use the State, Province, and Territory
Codes for the United States and Canada.
Bank Transfer
(O)3
String (2)
shipTo_street1
First line of the shipping address.
Bank Transfer
(O)2
String (60)
shipTo_street2
Second line of the shipping address.
Bank Transfer (O)
String (60)
1. Required if billTo_country value is US or CA
2. Required if any shipping information is included
3. Required if shipTo_country value is US or CA
Global Payment Service Developer Guide | March 2015
24
Chapter 2
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Reply Fields
The following table lists the fields returned in a reply from bankTransferService or
bankTransferRefundService service request.
Table 6
Bank Transfer and Bank Transfer Refund Reply Fields
for the Simple Order API
Reply Field
Description
Returned By
Data Type
& Length
bankTransferRefundReply_
amount
Total amount for the bank transfer refund.
Refund
String (15)
bankTransferRefundReply_
iban
International Bank Account Number (IBAN)
for the bank account.
Refund
Alphanumeric
(50)
bankTransferRefundReply_
processorResponse
Response code from the processor.
Refund
String (10)
bankTransferRefundReply_
reasonCode
A numeric value corresponding to the result
of the bank transfer refund request. See
"Reason Codes," page 155, for a list of
possible values.
Refund
Integer (5)
bankTransferRefundReply_
reconciliationID
Unique value generated by CyberSource. For
more information, see Getting Started with
CyberSource Advanced for the Simple Order
API.
Refund
String (60)
bankTransferRefundReply_
requestDateTime
Time the bank transfer refund was requested.
Format: YYYY-MM-DDThh:mm:ssZ.
Example: 2007-08-11T22:47:57Z, which is
August 11, 2007, at 10:47:57 P.M. The T
separates the date and the time. The Z
indicates UTC.
Refund
String (20)
bankTransferReply_
accountHolder
Name of the account holder.
Bank Transfer
String (50)
bankTransferReply_
accountNumber
Bank account number. Use the contents of
this field along with the contents of the
bankTransferReply_bankSpecialID field to
display the country’s traditional
representation of the full bank account
number on the bank transfer confirmation
page.
Bank Transfer
String (30)
Contact CyberSource Customer Support for
required country-specific bank account
information.
bankTransferReply_amount
Total amount for the bank transfer.
Bank Transfer
String (15)
bankTransferReply_bankCity
City in which the bank is located.
Bank Transfer
String (50)
bankTransferReply_
bankCountry
Country in which the bank is located.
Bank Transfer
String (50)
Global Payment Service Developer Guide | March 2015
25
Chapter 2
Table 6
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Bank Transfer and Bank Transfer Refund Reply Fields
for the Simple Order API (Continued)
Reply Field
Description
Returned By
Data Type
& Length
bankTransferReply_
bankName
Name of the bank.
Bank Transfer
String (50)
bankTransferReply_
bankSpecialID
Special ID used for the bank. For example,
the sort code for U.K. banks. This field is only
for the Global Collect processor. Use the
contents of this field along with the contents
of the bankTransferReply_accountNumber
field to display the country’s traditional
representation of the full bank account
number on the bank transfer confirmation
page. Contact CyberSource Customer
Support for required country-specific bank
account information.
Bank Transfer
String (50)
bankTransferReply_
bankSwiftCode
Bank’s SWIFT code. Unique address of the
bank. Also known as the Bank Identification
Code (BIC). If this field is in the reply, display
the value to the customer along with the other
bank information.
Bank Transfer
String (50)
bankTransferReply_iban
International Bank Account Number (IBAN)
for the bank account. If this field is in the
reply, display the value to the customer along
with the other bank information.
Bank Transfer
String (30)
Note Required for specific countries.
Contact CyberSource Customer Support for
required country-specific bank account
information.
bankTransferReply_
paymentReference
Payment reference number that you must
display to the customer. For more
information, see Getting Started with
CyberSource Advanced for the Simple Order
API. In Italy, this is called the Numero di
riferimento.
Bank Transfer
String (16)
bankTransferReply_
processorResponse
Response code from the processor.
Bank Transfer
String (10)
bankTransferReply_
reasonCode
A numeric value corresponding to the result
of the bank transfer request. See "Reason
Codes," page 155, for a list of possible
values.
Bank Transfer
Integer (5)
bankTransferReply_
reconciliationID
Unique value generated by CyberSource. For
more information, see Getting Started with
CyberSource Advanced for the Simple Order
API.
Bank Transfer
String (60)
Global Payment Service Developer Guide | March 2015
26
Chapter 2
Table 6
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Bank Transfer and Bank Transfer Refund Reply Fields
for the Simple Order API (Continued)
Reply Field
Description
Returned By
Data Type
& Length
bankTransferReply_
requestDateTime
Time the bank transfer was requested.
Format: YYYY-MM-DDThh:mm:ssZ.
Example: 2005-08-11T22:47:57Z, which is
August 11, 2005, at 10:47:57 P.M. The T
separates the date and the time. The Z
indicates UTC.
Bank Transfer
String (20)
decision
Summarizes the result of the overall request.
Possible values:
Bank Transfer
and Refund
String (6)

ACCEPT

ERROR

REJECT
invalidField_0...N
Fields in the request that contained invalid
data. These reply fields are included as an
aid to software developers only. No attempt
should be made to use these fields for end
user interaction. For more information, see
Getting Started with CyberSource Advanced
for the Simple Order API.
Bank Transfer
and Refund
String (100)
merchantReferenceCode
Order reference or tracking number that you
provided in the request. If you included multibyte characters in this field in the request, the
returned value might contain corrupted
characters.
Bank Transfer
and Refund
String (50)
missingField_0...N
Required fields that were missing from the
request. These reply fields are included as an
aid to software developers only. No attempt
should be made to use these fields for end
user interaction. For more information, see
Getting Started with CyberSource Advanced
for the Simple Order API.
Bank Transfer
and Refund
String (100)
purchaseTotals_currency
Currency used for the order. Uses the ISO
Standard Currency Codes.
Bank Transfer
and Refund
String (5)
reasonCode
Numeric value corresponding to the result of
the overall request. See "Reason Codes,"
page 155, for a list of possible values.
Bank Transfer
and Refund
Integer (5)
requestID
Identifier for the request.
Bank Transfer
and Refund
String (26)
Global Payment Service Developer Guide | March 2015
27
Chapter 2
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Request and Reply Examples
Bank Transfer Request
Example 1
Bank Transfer Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.23">
<merchantID>infodev</merchantID>
<merchantReferenceCode>482046C3A7E94F5</merchantReferenceCode>
<billTo>
<firstName>John</firstName>
<lastName>Smith</lastName>
<street1>Boschdijk 987</street1>
<city>Eindhoven</city>
<postalCode>5600 PB</postalCode>
<country>NL</country>
<email>jsmith@example.com</email>
</billTo>
<bankInfo>
<bankCountry>NL</bankCountry>
<bankCity>Amsterdam</bankCountry>
<bankName>ABN Amro Bank N.V</bankName>
<swiftCode>ABNA NL 2A</swiftCode>
</bankInfo>
<fundTransfer>
<accountNumber>440339464</accountNumber>
</fundTransfer>
<item id="0">
<unitPrice>49.95</unitPrice>
<quantity>1</quantity>
</item>
<purchaseTotals>
<currency>GBP</currency>
</purchaseTotals>
<bankTransferService run="true"/>
</requestMessage>
Global Payment Service Developer Guide | March 2015
28
Chapter 2
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Bank Transfer Reply
Example 2
Bank Transfer Reply
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.23">
<c:merchantReferenceCode>482046C3A7E94F5</c:merchantReferenceCode>
<c:requestID>0305782650000167905080</c:requestID>
<c:decision>ACCEPT</c:decision>
<c:reasonCode>100</c:reasonCode>
<c:purchaseTotals>
<c:currency>EUR</c:currency>
</c:purchaseTotals>
<c:bankTransferReply>
<c:reasonCode>100</c:reasonCode>
<c:accountHolder>Global Collect BV</c:accountHolder>
<c:accountNumber>440339464</c:accountNumber>
<c:amount>49.95</c:amount>
<c:bankName>ABN Amro Bank N.V</c:bankName>
<c:bankCity>Amsterdam</c:bankCity>
<c:bankCountry>NL</c:bankCountry>
<c:paymentReference>106157214759</c:paymentReference>
<c:bankSwiftCode>ABNA NL 2A</c:bankSwiftCode>
<c:bankSpecialID>20-00-00</c:bankSpecialID>
<c:requestDateTime>2012-01-28T23:44:27Z</c:requestDateTime>
<c:reconciliationID>0308014624</c:reconciliationID>
</c:bankTransferReply>
</c:replyMessage>
Global Payment Service Developer Guide | March 2015
29
Chapter 2
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Standalone Bank Transfer Refund Request
Example 3
Standalone Bank Transfer Refund Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.103">
<merchantID>demo123</merchantID>
<merchantReferenceCode>demoRef</merchantReferenceCode>
<billTo>
<firstName>Orlando</firstName>
<lastName>Bloom</lastName>
<street1>33, rue Dauphine</street1>
<city>Bergheim</city>
<postalCode>75006</postalCode>
<country>DE</country>
<phoneNumber>33 3 69 20 45 63</phoneNumber>
<email>borlando@cybersource.com</email>
</billTo>
<purchaseTotals>
<currency>EUR</currency>
<grandTotalAmount>112</grandTotalAmount>
</purchaseTotals>
<fundTransfer>
<accountNumber>0044497071</accountNumber>
<accountName>BRADFORD NICKLES</accountName>
</fundTransfer>
<bankInfo>
<bankCode>79050000</bankCode>
<name>SloveniaBank_testing</name>
<country>DE</country>
<swiftCode>BSLJSI2X</swiftCode>
</bankInfo>
<bankTransferRefundService run="true">
<reconciliationID>33552111</reconciliationID>
</bankTransferRefundService>
</requestMessage>
Global Payment Service Developer Guide | March 2015
30
Chapter 2
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
Standalone Bank Transfer Refund Reply
Example 4
Standalone Bank Transfer Refund Reply
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.103">
<c:merchantReferenceCode>demoRef</c:merchantReferenceCode>
<c:requestID>4024435525740181551532</c:requestID>
<c:decision>ACCEPT</c:decision>
<c:reasonCode>100</c:reasonCode>
<c:purchaseTotals>
<c:currency>eur</c:currency>
</c:purchaseTotals>
<c:bankTransferRefundReply>
<c:reasonCode>100</c:reasonCode>
<c:amount>112.00</c:amount>
<c:requestDateTime>2014-06-10T23:39:14Z</c:requestDateTime>
<c:reconciliationID>33552111</c:reconciliationID>
<c:iban>DE58790500000044497071</c:iban>
</c:bankTransferRefundReply>
</c:replyMessage>
Follow-On Bank Transfer Refund Request
Example 5
Follow-On Bank Transfer Refund Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.103">
<merchantID>demo123</merchantID>
<merchantReferenceCode>demoRef</merchantReferenceCode>
<billTo>
<firstName>Orlando</firstName>
<lastName>Bloom</lastName>
<street1>33, rue Dauphine</street1>
<city>Bergheim</city>
<postalCode>75006</postalCode>
<country>DE</country>
<phoneNumber>33 3 69 20 45 63</phoneNumber>
<email>borlando@cybersource.com</email>
</billTo>
<purchaseTotals>
<currency>EUR</currency>
<grandTotalAmount>74</grandTotalAmount>
</purchaseTotals>
<fundTransfer>
<accountNumber>0044497071</accountNumber>
<accountName>BRADFORD NICKLES</accountName>
</fundTransfer>
Global Payment Service Developer Guide | March 2015
31
Chapter 2
Bank Transfers and Bank Transfer Refunds Using the Simple Order API
<bankInfo>
<bankCode>79050000</bankCode>
<name>SloveniaBank_testing</name>
<country>DE</country>
<swiftCode>BSLJSI2X</swiftCode>
</bankInfo>
<bankTransferService run="true"/>
</requestMessage>
Follow-On Bank Transfer Refund Reply
Example 6
Follow-On Bank Transfer Refund Reply
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.103">
<c:merchantReferenceCode>demoRef</c:merchantReferenceCode>
<c:requestID>4024436180000181551532</c:requestID>
<c:decision>ACCEPT</c:decision>
<c:reasonCode>100</c:reasonCode>
<c:purchaseTotals>
<c:currency>eur</c:currency>
</c:purchaseTotals>
<c:bankTransferReply>
<c:reasonCode>100</c:reasonCode>
<c:accountHolder>Global Collect B.V.</c:accountHolder>
<c:accountNumber>115241904</c:accountNumber>
<c:amount>74.00</c:amount>
<c:bankName>Postbank AG</c:bankName>
<c:bankCity>Leipzig</c:bankCity>
<c:bankCountry>Germany</c:bankCountry>
<c:paymentReference>256210123719</c:paymentReference>
<c:bankSwiftCode>PBNKDEFF</c:bankSwiftCode>
<c:bankSpecialID>BLZ|86010090</c:bankSpecialID>
<c:requestDateTime>2014-06-10T23:40:19Z</c:requestDateTime>
<c:reconciliationID>2149560850</c:reconciliationID>
<c:iban>DE53860100900115241904</c:iban>
</c:bankTransferReply>
</c:replyMessage>
Global Payment Service Developer Guide | March 2015
32
CHAPTER
Bank Transfers and Bank
Transfer Refunds Using the
SCMP API
3
Requesting Bank Transfers
Use the ics_bank_transfer service to request a bank transfer. See Table 7, page 36, for a
list of the fields to use when requesting the service.
When requesting a bank transfer, you may not request any of the other ICS services
except ics_tax. For more information about the service, see Tax Calculation Service
Using the SCMP API.
In the bank transfer reply, you will receive fields containing information about the bank and
bank account that the customer should transfer funds to. You need to display this
information to customers so that they can easily transcribe it or print it and give it to their
banks.
The information includes the bank’s name, bank’s country, the account holder’s name, and
so on. The primary field containing the bank account information is bank_transfer_
account_number. This field contains the necessary bank account number information
you need to display, including a bank code or sort code, branch code, or check digit, if any
of those are used for the particular country. You can display the contents of the field as you
receive it in the reply from CyberSource.
You might also receive bank_transfer_iban with the International Bank Account Number
(IBAN). The IBAN is a international standard for bank account numbers that the EU is
adopting. In the future, the EU is planning to switch to using only the IBAN format and not
the original format presented in bank_transfer_account_number. If the IBAN is present
in the reply, display it to the customer along with the other bank information, and identify it
as the IBAN.
Depending on the country, you might also receive the bank’s SWIFT code, which is
another bank identifier. If the bank_transfer_swiftcode field is present, display it to the
customer along with the other bank information, and identify it as the SWIFT code.
Global Payment Service Developer Guide | March 2015
33
Chapter 3
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Requesting Bank Transfer
Refunds
Important
Important
From August 1, 2016, for euro countries and from October 31, 2016, for noneuro countries, the IBAN must be included in each request. If you provide a
BBAN it will be converted to an IBAN, and this conversion process will continue
only until August 1, 2016.
A follow-on refund must occur within 60 days of the request for the bank
transfer. After the time limit expires, only a stand-alone refund can be
requested. To refund a bank transfer, wait 1 to 3 days after the bank transfer
request is processed by CyberSource. When you attempt to request a followon refund before the initial bank transfer is processed into your merchant bank
account, the error ORDER WITHOUT REFUNDABLE PAYMENTS is
displayed. This error could also mean that your account is not configured for
standalone refunds with Global Collect. To configure your account, please
contact CyberSource Customer Support.
There are two types of bank transfer refunds: follow-on refunds and stand-alone refunds.
A follow-on refund uses information from a previous bank transfer. A stand-alone refund
does not depend on a previous transaction.
To request a bank transfer refund:

Use the ics_bank_transfer_refund service to request a bank transfer refund.

Do not request any other ICS services except Tax Calculation, which is optional. For
more information about this service, see Tax Calculation Service Using the SCMP
API.

Send the fields required for a bank transfer refund request as described in Table 7,
page 36. For a follow-on refund, the fields and values must match the fields and
values that you sent in the bank transfer request.

For a follow-on refund, include one of these fields from the original request with the
request ID:

bank_transfer_request_id

bank_transfer_real_time_request_id

For a stand-alone refund, the bank_transfer_request_id field is optional.

The easiest way to implement bank transfer refunds is to always send the request ID
from the original bank transfer with every bank transfer refund request.
Global Payment Service Developer Guide | March 2015
34
Chapter 3

Bank Transfers and Bank Transfer Refunds Using the SCMP API
CyberSource recommends that when you request a refund, you use the same value
for merchant_ref_number that you used for the bank transfer. This makes it easier
for you to link the refund to the original bank transfer in your own system as well as in
CyberSource reports and Transaction Search Screens.
CyberSource validates the bank account number before processing the bank transfer
refund. If the account number does not pass the validation check, CyberSource rejects the
request with a rflag=DINVALIDACCOUNT. CyberSource recommends that you then
confirm the customer entered the number correctly, and if it was incorrect, request the
refund again with the correct number.
You may perform multiple partial refunds against a bank transfer. The sum of the refunds
may not exceed the amount of the payment.
You will not receive an error in the reply for any of the following conditions:

The bank_transfer_request_id is invalid.

The customer’s payment has not yet been received.
Instead, CyberSource will not process the refund and the transaction will appear in the
daily Transaction Exception Detail Report. You should monitor this report daily to
determine if any of your transactions have problems. For information about the report and
how to use it, see the Global Payment Service Planning Guide. For details about
downloading the report and its format, see the Reporting Developer Guide.
Researching a Missing Payment
If a customer calls to say that they have made the bank transfer payment but have not
received the goods, and CyberSource’s report or your bank account statement does not
show that you have received the payment, you can make a payment inquiry in the
Business Center and have CyberSource research the lost payment.
Note
You must wait at least five days after the funds are debited from the customer’s
account before initiating an inquiry because it can take that long before the
funds appear in your account and in CyberSource’s reports. CyberSource will
not allow you to perform an inquiry within five days of submitting the initial bank
transfer request.
For instructions on how to research a lost payment in the Business Center, see
Appendix C, "Researching a Missing Bank Transfer Payment," on page 158.
Global Payment Service Developer Guide | March 2015
35
Chapter 3
Bank Transfers and Bank Transfer Refunds Using the SCMP API
API Fields
The following table lists the fields to use in requests for bank transfers and bank transfer
refunds. See the information about data types in Getting Started with CyberSource
Advanced for the SCMP API.
Request Fields
The following table lists the fields to use in a request for ics_bank_transfer or ics_bank_
transfer_refund.
Table 7
Request-Level Fields for Bank Transfers and Bank Transfer Refunds
for the SCMP API
Request-Level
Field
Description
Used by and
Required (R) or
Optional (O)
Data Type
& Length
bank_account_name
Name used on the bank account. If you do not
send this field, it is assumed the last name on the
account is customer_lastname. Some banks
validate the name on the bank account, so
consider sending this field if the bank account
owner is not the customer.This scenario might
happen, for example, if a husband places the
order, but the wife’s name is on the bank account.
Refund (O)
String (50)
Refund (O)
String (See
description)
Refund (O)
String (255)
Contact CyberSource Customer Support for
required country-specific bank account
information.
bank_account_
number
Bank account number. Contact CyberSource
Customer Support for required country-specific
bank account information.
Note From August 1, 2016, for euro countries and
from October 31, 2016, for non-euro countries, the
IBAN must be included in each request. If you
provide a BBAN it will be converted to an IBAN,
and this conversion process will continue only until
August 1, 2016.
Note Do not use the IBAN in this field. Use only
the traditional account number information. For the
IBAN, use the bank_iban field.
bank_address
Bank’s address.
1. Required if bill_country value is US or CA
2. Required if any shipping information is included
3. Required if ship_to_country value is US or CA
Global Payment Service Developer Guide | March 2015
36
Chapter 3
Table 7
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Request-Level Fields for Bank Transfers and Bank Transfer Refunds
for the SCMP API (Continued)
Request-Level
Field
Description
Used by and
Required (R) or
Optional (O)
Data Type
& Length
bank_check_digit
Code used to validate the customer's account
number when you are not using the IBAN. Contact
CyberSource Customer Support for required
country-specific bank account information.
Refund (O)
String (2)
bank_city
City where the bank is located. Some banks
validate the bank account information, so consider
sending this field if the bank is not located in bill_
city.
Refund (O)
String (40)
bank_code
Bank's code. Used for some countries when you
are not using the IBAN. Contact CyberSource
Customer Support for required country-specific
bank account information.
Refund (See
description)
String (See
description)
Country where the bank is located. Use the twocharacter ISO Standard Country Codes.
Bank Transfer (See
description)
String (2)
Note If bank_country is not set, CyberSource
Refund (R)
Note This is a required field if the bank_country
field is GB, AT, FR, or DE. For more information
see the two-character ISO Standard Country
Codes.
bank_country
uses bill_country to determine the country in
which the bank transfer is taking place.
bank_iban
Refund (See
description)
String (30)
Refund (See
description)
String (40)
Bank’s SWIFT code. Unique address of the bank.
Also known as the Bank Identification Code (BIC).
Bank Transfer (See
description)
String (30)
Note This field is required when the IBAN field is
Refund (O)
International Bank Account Number (IBAN) for the
bank account.
Note Required for specific countries. Contact
CyberSource Customer Support for required
country-specific bank account information.
bank_name
Bank's name.
Note This is a required field if the bank_country
field is AU, FI, FR, IT, NO, ES, SE, or CH. For more
information see the two-character ISO Standard
Country Codes.
bank_swiftcode
included in the request.
bank_transfer_
request_id
The request_id value returned from a previous
request for ics_bank_transfer.
Refund (R)
String (26)
1. Required if bill_country value is US or CA
2. Required if any shipping information is included
3. Required if ship_to_country value is US or CA
Global Payment Service Developer Guide | March 2015
37
Chapter 3
Table 7
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Request-Level Fields for Bank Transfers and Bank Transfer Refunds
for the SCMP API (Continued)
Request-Level
Field
Description
Used by and
Required (R) or
Optional (O)
Data Type
& Length
bank_transfer_trans_
ref_no
Unique identifier for the order submitted to Global
Collect.
Refund (R for
standalone refunds)
String (60)
Bank Transfer (R)
String (60)
Note If you do not include this field in a refund
request, CyberSource will generate the value.
bill_address1
Billing street address.
Refund (R)
bill_address2
Additional billing address information.
Bank Transfer (O)
String (60)
Refund (O)
bill_city
Billing address city.
Bank Transfer (R)
String (50)
Refund (R)
bill_country
Billing address country.
Bank Transfer (R)
String (2)
Refund (R)
bill_state
Billing address state.
Bank Transfer (R) 1
Refund (R)
bill_zip
Zip code for the shipping address. The zip code
must consist of 5 to 9 digits.
If the value of bill_country is US, the 9-digit zip
code must follow this format:
[5 digits][dash][4 digits]
Example:12345-6789
String (2)
1
Bank Transfer (R if
bill_country is US
or CA)
String (10)
Refund (R if bill_
country is US or
CA)
If the value of bill_country is CA, the 6-digit zip
code must follow this format:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C3
branch_code
Code that identifies the branch of the customer's
bank when you are not using the IBAN.
Refund (O)
String (15)
Contact CyberSource Customer Support for
required country-specific bank account
information.
company_name
Name of the customer’s company.
Bank Transfer (O)
String (60)
currency
Currency used for the order. Use the ISO Standard
Currency Codes.
Bank Transfer (R)
String (5)
Customer’s email address. For example:
jdoe@example.com
Bank Transfer (R)
customer_email
Refund (R)
String (255)
Refund (R)
1. Required if bill_country value is US or CA
2. Required if any shipping information is included
3. Required if ship_to_country value is US or CA
Global Payment Service Developer Guide | March 2015
38
Chapter 3
Table 7
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Request-Level Fields for Bank Transfers and Bank Transfer Refunds
for the SCMP API (Continued)
Request-Level
Field
Description
Used by and
Required (R) or
Optional (O)
Data Type
& Length
customer_firstname
Customer’s first name.
Bank Transfer (R)
String (60)
Refund (R)
customer_lastname
Customer’s last name.
Bank Transfer (R)
String (60)
Refund (R)
customer_phone
Customer’s telephone number.
Bank Transfer (O)
String (15)
Refund (O)
grand_total_amount
ics_applications
Grand total for the order. You must include either
this field or offer0 and the offer-level field amount.
See the information about offers and grand totals in
Getting Started with CyberSource Advanced for
the SCMP API.
Bank Transfer
ICS services to process for the request.
Bank Transfer (R)
Refund
Decimal
(15)
See description
String (255)
Refund (R)
link_to_request
Value that links the current request to a previous
authorization request for a debit card or prepaid
card. This value is useful when using multiple
payment methods to complete an order. For
details, see the information about partial
authorizations in Credit Card Services Using the
SCMP API.
Bank Transfer (O)
String (26)
merchant_id
Your CyberSource merchant ID.
Bank Transfer (R)
String (30)
Note When opening your account with
Refund (R)
CyberSource, make sure to inform CyberSource if
you plan to use multiple CyberSource merchant
IDs. For example, if you have separate business
units within your company, each with a separate
CyberSource merchant ID. You must have a
separate processor merchant ID for each
CyberSource merchant ID. For more information,
contact CyberSource Customer Support.
merchant_ref_
number
Merchant-generated order reference or tracking
number. See the information about tracking orders
in Getting Started with CyberSource Advanced for
the SCMP API.
Bank Transfer (R)
offer0...N
Offers for the request. An offer is a line item for the
order.
Bank Transfer (O)
String (50)
Refund (R)
String (50)
Refund (O)
1. Required if bill_country value is US or CA
2. Required if any shipping information is included
3. Required if ship_to_country value is US or CA
Global Payment Service Developer Guide | March 2015
39
Chapter 3
Table 7
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Request-Level Fields for Bank Transfers and Bank Transfer Refunds
for the SCMP API (Continued)
Request-Level
Field
Description
Used by and
Required (R) or
Optional (O)
Data Type
& Length
ship_to_address1
First line of the address to which to ship the
product.
Bank Transfer (O) 2
String (60)
ship_to_address2
Second line of the address to which to ship the
product.
Bank Transfer (O)
String (60)
ship_to_city
City to which to ship the product.
Bank Transfer (O) 2
String (50)
ship_to_country
Country to which to ship the product. Use the twocharacter ISO Standard Country Codes.
Bank Transfer (O)
String (2)
ship_to_firstname
First name of person receiving the product.
Bank Transfer (O)
String (60)
ship_to_lastname
Last name of person receiving the product.
Bank Transfer (O)
String (60)
ship_to_phone
Phone number for the shipping address.
Bank Transfer (O)
String (15)
3
ship_to_state
State or province to which to ship the product. Use
the State, Province, and Territory Codes for the
United States and Canada.
Bank Transfer (O)
ship_to_zip
Zip code for the shipping address.
Bank Transfer (O) 3
String (10)
Bank Transfer (O)
Positive
integer (3)
String (2)
If the value of ship_to_country is US, the 9-digit
zip code must follow this format:
[5 digits][dash][4 digits]
Example: 12345-6789
If the value of ship_to_country is CA, the 6-digit
zip code must follow this format:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C3
If the postal code for the shipping address is not
included in the request message, CyberSource will
use the postal code for the billing address. If the
postal code for the billing address is not included in
the request message, the postal code for the
shipping address is required.
timeout
Number of seconds until the transaction times out.
The default is 110 seconds.
Refund (O)
1. Required if bill_country value is US or CA
2. Required if any shipping information is included
3. Required if ship_to_country value is US or CA
Global Payment Service Developer Guide | March 2015
40
Chapter 3
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Offer-Level Fields
The following table lists the offer-level fields to use in a request for ics_bank_transfer or
ics_bank_transfer_refund.
Table 8
Offer-Level Fields for Bank Transfers and Bank Transfer Refunds
for the SCMP API
Offer-Level Field
Description
Used by and
Required (R) or
Optional (O)
Data Type
& Length
amount
Per-item price of the product. You must include
either offer0 and this field, or the request-level field
grand_total_amount in your request. This value
cannot be negative. See the information about
offers and grand totals in Getting Started with
CyberSource Advanced for the SCMP API.
Bank Transfer
(See description)
Decimal (15)
Refund
(See description)
You can include a decimal point (.) in this field, but
you cannot include any other special characters.
The amount will be truncated at the request level to
the correct number of decimal places.
merchant_product_
sku
product_code
Product identifier code. It is required for bank
transfers if product_code is not default,
stored_value, or one of the values related to
shipping and/or handling.
Bank Transfer (See
description)
Type of product that the offer contains, which is
also used to determine the category that the
product falls under: electronic, handling, physical,
service, or shipping. The default value is
default. See "Product Codes," page 154, for a
list of valid values.
Bank Transfer (O)
String (30)
Refund (O)
String (30)
Refund (O)
For bank transfers, if you set this to a value other
than default, stored_value, or any of the
values related to shipping and/or handling, the
quantity, product_name, and merchant_
product_sku fields are required.
product_name
quantity
Name of the product. For bank transfers, required
if product_code is NOT default, stored_
value, or one of the values related to shipping
and/or handling.
Bank Transfer (See
description)
Quantity of the product being purchased. The
default value is 1. For bank transfers, required if
product_code is NOT default, stored_
value or one of the values related to shipping
and/or handling.
Bank Transfer (See
description)
Global Payment Service Developer Guide | March 2015
String (30)
Refund (O)
Refund (O)
Nonnegative
integer (10)
41
Chapter 3
Table 8
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Offer-Level Fields for Bank Transfers and Bank Transfer Refunds
for the SCMP API (Continued)
Offer-Level Field
Description
Used by and
Required (R) or
Optional (O)
Data Type
& Length
tax_amount
Tax amount associated with this item. The tax_
amount field is additive. For example, if you send
these offer lines:
Bank Transfer (O)
Decimal (15)
Refund (O)
offer0=amount:10.00^
quantity:1^tax_amount:0.80
offer1=amount:20.00^
quantity:1^tax_amount:1.60
the total amount authorized will be for 32.40, not
30.00 with 2.40 of tax included.
The tax_amount and the amount must be in the
same currency.
If you include tax_amount, and you request the
ics_tax service, ics_tax will not calculate tax for
the offer. Instead, it will return the value in the tax_
amount field.
Reply Fields
The following table lists the fields returned in a reply from ics_bank_transfer or ics_
bank_transfer_refund.
Table 9
Reply Fields for Bank Transfers and Bank Transfer Refunds
for the SCMP API
Reply Field
Description
Returned
By
Data Type
& Length
bank_transfer_account_
holder
Name of the account holder.
Bank Transfer
String (50)
bank_transfer_account_
number
Bank account number. Use the contents of this field
along with the contents of the bank_transfer_
special_id field to display on the bank transfer
confirmation page the country’s traditional
representation of the full bank account number.
Contact CyberSource Customer Support for
required country-specific bank account information.
Bank Transfer
String (30)
bank_transfer_amount
Total amount for the bank transfer.
Bank Transfer
Decimal (15)
bank_transfer_bank_city
City in which the bank is located.
Bank Transfer
String (50)
bank_transfer_bank_
country
Country in which the bank is located.
Bank Transfer
String (50)
Global Payment Service Developer Guide | March 2015
42
Chapter 3
Table 9
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Reply Fields for Bank Transfers and Bank Transfer Refunds
for the SCMP API (Continued)
Reply Field
Description
Returned
By
Data Type
& Length
bank_transfer_bank_
name
Bank’s name.
Bank Transfer
String (50)
bank_transfer_iban
International Bank Account Number (IBAN) for the
bank account. If this field is in the reply, display the
value to the customer along with the other bank
information.
Bank Transfer
String (30)
Note Contact CyberSource Customer Support for
required country-specific bank account information.
bank_transfer_
payment_reference
Payment reference number that you must display to
the customer. For more information, see Getting
Started with CyberSource Advanced for the SCMP
API. In Italy, this is called the Numero di riferimento.
Bank Transfer
String (16)
bank_transfer_rcode
One-digit code that indicates whether the ics_
bank_transfer request was successful.
Bank Transfer
Integer (1)
bank_transfer_refund_
amount
Amount of the bank transfer refund.
Refund
Decimal (15)
bank_transfer_refund__
iban
International Bank Account Number (IBAN) for the
bank account.
Refund
Alphanumeric
(50)
bank_transfer_refund_
rcode
One-digit code that indicates whether the ics_
bank_transfer_refund request was successful.
Refund
Integer (1)
bank_transfer_refund_
response_code
Response code from the processor.
Refund
String (10)
bank_transfer_refund_
rflag
One-word description of the result of the ics_bank_
transfer_refund request.
Refund
String (50)
bank_transfer_refund_
rmsg
Message that explains the reply flag bank_
transfer_refund_rflag.
Refund
String (255)
bank_transfer_refund_
time
Time of bank transfer refund request in UTC format.
For more information, see Getting Started with
CyberSource Advanced for the SCMP API.
Refund
Date and
time (20)
bank_transfer_refund_
trans_ref_no
Unique value generated by CyberSource. See the
information about tracking orders in Getting Started
with CyberSource Advanced for the SCMP API.
Refund
String (60)
bank_transfer_request_
time
Time of the bank transfer request in UTC format. For
more information, see Getting Started with
CyberSource Advanced for the SCMP API.
Bank Transfer
Date and
time (20)
bank_transfer_
response_code
Response code from the processor.
Bank Transfer
String (10)
bank_transfer_rflag
One-word description of the result of the ics_bank_
transfer request.
Bank Transfer
String (50)
bank_transfer_rmsg
Message that explains the reply flag bank_
transfer_rflag.
Bank Transfer
String (255)
Global Payment Service Developer Guide | March 2015
43
Chapter 3
Table 9
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Reply Fields for Bank Transfers and Bank Transfer Refunds
for the SCMP API (Continued)
Reply Field
Description
Returned
By
Data Type
& Length
bank_transfer_special_
id
Contains any special ID used for the bank. For
example, the sort code for U.K. banks. This field is
only for the Global Collect processor. Use the
contents of this field along with the contents of the
bank_transfer_account_number field to display
on the bank transfer confirmation page the country’s
traditional representation of the full bank account
number. Contact CyberSource Customer Support
for required country-specific bank account
information.
Bank Transfer
String (50)
bank_transfer_swiftcode
Bank’s SWIFT code. Unique address of the bank. If
this field is in the reply, display the value to the
customer along with the other bank information.
Bank Transfer
String (50)
bank_transfer_trans_
ref_no
Unique value generated by CyberSource. For more
information, see Getting Started with CyberSource
Advanced for the SCMP API.
Bank Transfer
String (60)
client_lib_version
Information about the client library used to request
the transaction.
Bank Transfer
and Refund
String (50)
currency
Currency used for the order. Uses the ISO Standard
Currency Codes.
Bank Transfer
and Refund
String (5)
ics_rcode
One-digit code that indicates whether the entire
request was successful. The field will contain one of
the following values:
Bank Transfer
and Refund
Integer (1)

-1: An error occurred

0: The request was declined

1: The request was successful
ics_rflag
One-word description of the result of the entire
request.
Bank Transfer
and Refund
String (50)
ics_rmsg
Message that explains the reply flag ics_rflag.
Bank Transfer
and Refund
String (255)
merchant_ref_number
Order reference or tracking number that you
provided in the request. If you included multi-byte
characters in this field in the request, the returned
value might contain corrupted characters.
Bank Transfer
and Refund
String (50)
request_id
Identifier for the request generated by CyberSource.
Bank Transfer
and Refund
String (26)
Global Payment Service Developer Guide | March 2015
44
Chapter 3
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Reply Flags
The following table lists the reply flags for ics_bank_transfer and ics_bank_transfer_
refund.
Table 10
Reply Flags for Bank Transfer and Bank Transfer Refunds for the SCMP API
Reply Flag
Description
Returned by
DINVALIDACCOUNT
The bank account number did not pass the validation check.
Verify with the customer that the account number is correct;
if it was incorrect, request the service again with the
corrected information. Applies to bank transfer refunds with
banks in France, Germany, and the United Kingdom.
Bank Transfer Refund
DINVALIDDATA
Data provided is not consistent with the request.
Bank Transfer and Refund
DMISSINGFIELD
The request is missing a required field.
Bank Transfer and Refund
ESYSTEM
System error. You must design your transaction
management system to correctly handle CyberSource
system errors. Depending on the payment processor
handling the transaction, the error may indicate a valid
CyberSource system error or a processor rejection due to
invalid data. In either case, CyberSource recommends that
you do not design your system to endlessly retry sending a
transaction. For important information on handling system
errors and retries, see the documentation for your
CyberSource client.
Bank Transfer and Refund
ETIMEOUT
The request timed out.
Bank Transfer and Refund
SOK
The transaction was successful.
Bank Transfer and Refund
Global Payment Service Developer Guide | March 2015
45
Chapter 3
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Request and Reply Examples
Bank Transfer Request
Example 7
Bank Transfer Request
bill_address1=Boschdijk 987
bill_city=Eindhoven
bill_country=NL
bill_zip=5600 PB
currency=EUR
customer_email=jsmith@example.com
customer_firstname=John
customer_lastname=Smith
bank_country=NL
bank_city=Amsterdam
bank_name=ABN Amro
bank_swiftCode=ABNA NL 2A
bank_account_number=440339464
ics_applications=ics_bank_transfer
merchant_id=infodev
merchant_ref_number=482046C3A7E94F5BD1FE3C66C
offer0=amount:49.95^quantity:1
Global Payment Service Developer Guide | March 2015
46
Chapter 3
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Bank Transfer Reply
Example 8
Bank Transfer Reply
merchant_ref_number=482046C3A7E94F5BD1FE3C66C
currency=EUR
ics_rcode=1
ics_rflag=SOK
ics_rmsg=Request was processed successfully.
request_id=0305782650000167905080
bank_transfer_trans_ref_no=0308014624
bank_transfer_amount=49.95
bank_transfer_bank_country=NL
bank_transfer_account_holder=Global Collect BV
bank_transfer_bank_name=ABNA NL 2A
bank_transfer_bank_city=Amsterdam
bank_transfer_swiftcode=ABNA NL 2A
bank_transfer_time=2003-08-22T170910Z
bank_transfer_payment_reference=106157214759
bank_transfer_response_code=800
bank_transfer_special_id=20-00-00
bank_transfer_account_number=440339464
bank_transfer_rcode=1
bank_transfer_rflag=SOK
bank_transfer_rmsg=Request was processed successfully.
client_lib_version=Perl3.2/MSWin324.0/NT4.0/WIN32/C/3.4.5
Global Payment Service Developer Guide | March 2015
47
Chapter 3
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Standalone Bank Transfer Refund Request
Example 9
Standalone Bank Transfer Refund Request
ics_applications=ics_bank_transfer_refund
bank_account_name=nette
bank_account_number=30004 00819 00010023116 61
bank_check_digit=12
bank_city=Paris
bank_code=0440339464
bank_country=France
bank_name=BNP Paribas
bill_address1=1ere Avenue
bill_address2=14eme Rue BP 148
bill_city=Carros Cedex
bill_country=FR
bill_zip=06513
branch_code=1234567890ABCDE
currency=EUR
customer_email=antoinette@cybersource.com
customer_firstname=antoi
customer_lastname=nette
customer_phone=33-04-9208-2846
merchant_id=mercid123
merchant_ref_number=merRef123
offer0=product_code:electronic_software^merchant_product_
sku:testdl^quantity:1^amount:1.56^tax_amount:0.25^product_
name:PName1^offer_id:0
request_id=4024360078230179087451
ship_to_address1=37 se main street
ship_to_address2=suite 2-5A
ship_to_city=bloomington
ship_to_country=US
ship_to_state=indiana
ship_to_zip=47404
Global Payment Service Developer Guide | March 2015
48
Chapter 3
Bank Transfers and Bank Transfer Refunds Using the SCMP API
Standalone Bank Transfer Refund Reply
Example 10
Standalone Bank Transfer Refund Reply
bank_transfer_refund_amount=1.81
bank_transfer_refund_iban=IE64BOFI30004 00819 00010023116 61
bank_transfer_refund_rcode=1
bank_transfer_refund_rflag=SOK
bank_transfer_refund_rmsg=Request was processed successfully.
bank_transfer_refund_time=2014-06-10T213327Z
bank_transfer_refund_trans_ref_no=2147997003
currency=eur
ics_rcode=1
ics_rflag=SOK
ics_rmsg=Request was processed successfully.
merchant_ref_number=merRef123
request_id=4024360078230179087451
Follow-On Bank Transfer Refund Request
Example 11
Follow-On Bank Transfer Refund Request
ics_applications=ics_bank_transfer_refund
bank_account_name=nette
bank_account_number=30004 00819 00010023116 61
bank_check_digit=12
bank_city=Paris
bank_code=0440339464
bank_country=France
bank_name=BNP Paribas
bank_swiftcode=BNPA FR PP PLZ
bank_transfer_request_id=4024360037900179087451
bill_address1=1ere Avenue
bill_address2=14eme Rue BP 148
bill_city=Carros Cedex
bill_country=FR
bill_zip=06513
branch_code=1234567890ABCDE
currency=EUR
customer_email=antoinette@cybersource.com
customer_firstname=antoi
customer_lastname=nette
customer_phone=33-04-9208-2846
merchant_id=mercid123
merchant_ref_number=merRef123
offer0=product_code:electronic_software^merchant_product_
sku:testdl^quantity:1^amount:1.56^tax_amount:0.25^product_
name:PName1^offer_id:0
request_id=4024360039900179087451
sender_id=gc_btr_sepa_1
Global Payment Service Developer Guide | March 2015
49
Chapter 3
Bank Transfers and Bank Transfer Refunds Using the SCMP API
ship_to_address1=37 se main street
ship_to_address2=suite 2-5A
ship_to_city=bloomington
ship_to_country=US
ship_to_state=indiana
ship_to_zip=47404
Follow-On Bank Transfer Refund Reply
Example 12
Follow-On Bank Transfer Refund Reply
bank_transfer_account_holder=Global Collect BV
bank_transfer_account_number=30004 00819 00010023116 61
bank_transfer_amount=1.81
bank_transfer_bank_city=Paris
bank_transfer_bank_country=France
bank_transfer_bank_name=BNP Paribas
bank_transfer_iban=FR7630004008190001002311661
bank_transfer_payment_reference=140243600385
bank_transfer_rcode=1
bank_transfer_rflag=SOK
bank_transfer_rmsg=Request was processed successfully.
bank_transfer_swiftcode=BNPA FR PP PLZ
bank_transfer_time=2014-06-10T213323Z
Global Payment Service Developer Guide | March 2015
50
CHAPTER
Real-Time Bank Transfers
Using the Simple Order API
4
Transaction Status
You can perform an on-demand query to get the status of a transaction. CyberSource
recommends that you wait at least 5 minutes after the customer has completed a
transaction before sending an on-demand query. If you need to request the status more
than once, you must wait at least 10 minutes between queries for the same transaction.
For China, real-time bank transfer settlements are not posted until the next
business day.
Note
Sending the Query
To send the query, send the fields described in the following table in an HTTP POST
request to the following URL:
https://ebc.cybersource.com/ebc/Query
After you send the query, CyberSource prompts you for your username and password to
verify that you have access to the merchant ID.
Table 11
Required Data for an On-Demand Transaction Status Query
Field
Description
Required (R)
or Optional (O)
Data Type
& Length
merchantID
Your CyberSource merchant ID.
R
String (30)
Type of query. The only possible value is
R
String (30)
type
transaction.
subtype
Query subtype. The only possible value is
transactionStatus.
R
String (30)
requestID
Request ID returned in the real-time bank
transfer reply.
R
String (26)
Global Payment Service Developer Guide | March 2015
51
Chapter 4
Table 11
Real-Time Bank Transfers Using the Simple Order API
Required Data for an On-Demand Transaction Status Query (Continued)
Field
Description
Required (R)
or Optional (O)
Data Type
& Length
transRefNo
Transaction reference number (SCMP
API) or reconciliation ID (Simple Order
API) returned in the real-time bank
transfer reply.
R
String (60)
requestToken
Request token data generated by
CyberSource for each transaction reply.
R
String (256)
This example shows an on-demand query for a transaction status.
Example 13
On-Demand Transaction Status Query
<html>
<body>
<form action="https://ebc.cybersource.com/ebc/Query" method="POST">
<input type="hidden" name="type" value="transaction">
<input type="hidden" name="subtype" value="transactionStatus">
<table>
<tr>
<td>merchant ID <font color=red>*</font>:</td>
<td><input type="text" name="merchantID" value="dm_ptech"></td>
</tr>
<tr>
<td>Request ID: </td>
<td><input type="text" name="requestID" value=""></td>
</tr>
<tr>
<td>Transaction Reference Number:</td>
<td><input type="text" name="transRefNo" value=""></td>
</tr>
<tr>
<td>Request Token:</td>
<td><input type="text" name="requestToken" value=""></td>
</tr>
<tr><td colspan=2>&nbsp;</td></tr>
<tr><td colspan=2><input type="submit" value="submit"></td></tr>
</table>
</form>
</body>
</html>
Global Payment Service Developer Guide | March 2015
52
Chapter 4
Real-Time Bank Transfers Using the Simple Order API
Viewing the Response
You receive a response immediately. There are two possible outcomes:

If the query is successful, the results appear as a document of mime type application/
xml. To use this document, you must write a program to save or process the XML data
of the document.

If your POST data contains an error, you receive a system error. If the system error
persists, contact CyberSource Customer Support.
The DTD for a successful query result:
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
xml (Request, Response)>
Request (MerchantID, RequestID, RequestDate)>
MerchantID (#PCDATA)>
RequestID (#PCDATA)>
RequestDate (#PCDATA)>
Response (PaymentStatus?)>
PaymentStatus (Status, ProcessorMessage?)>
Status (#PCDATA)>
ProcessorMessage (#PCDATA)>
This example shows on-demand query results for a successful real-time bank transfer
payment.
Example 14
Successful Payment
<xml>
<Request>
<MerchantID>okgo123</MerchantID>
<RequestID>4146924260000171399092</RequestID>
<RequestDate>Oct 30, 2014</RequestDate>
<Response>
<PaymentStatus>
<Status>Payment</Status>
<ProcessorMessage>The payment instruction has been accepted.
</ProcessorMessage>
</PaymentStatus>
</Response>
</Request>
</xml>
Global Payment Service Developer Guide | March 2015
53
Chapter 4
Real-Time Bank Transfers Using the Simple Order API
This example shows on-demand query results for a failed real-time bank transfer
payment.
Example 15
Failed Payment
<xml>
<Request>
<MerchantID>OKGo1234</MerchantID>
<RequestID>1545412404130167905103</RequestID>
<Response>
<PaymentStatus>
<Status>Failed</Status>
<ProcessorMessage>Payment instruction has been rejected</ProcessorMessage>
</PaymentStatus>
</Response>
</Request>
</xml>
Requesting Real-Time Bank
Transfers
To request a real-time bank transfer, set the bankTransferRealTimeService_run field to
true. See Table 12, page 55, for a list of the fields to use when requesting the service.
Table 14, page 61, describes the fields that the service returns to you.
When requesting a real-time bank transfer, you may not request any other ICS service
except Tax Calculation, which is optional. For more information about the service, see Tax
Calculation Service Using the Simple Order API.
Global Payment Service Developer Guide | March 2015
54
Chapter 4
Real-Time Bank Transfers Using the Simple Order API
Requesting Real-Time Bank
Transfer Refunds
Important
From August 1, 2016, for euro countries and from October 31, 2016, for noneuro countries, the IBAN must be included in each request. If you provide a
BBAN it will be converted to an IBAN, and this conversion process will continue
only until August 1, 2016.
Except for a few additional fields, refunds for real-time bank transfers are the same as
refunds for other bank transfers. See "Requesting Bank Transfer Refunds," page 16. The
additional fields are identifiers that have been re-named for real-time bank transfers. See
Table 15, page 63.
API Fields
For information about the data types, see Getting Started with CyberSource Advanced for
the Simple Order API.
Request Fields
The following table lists the fields to use in a request for real-time bank transfers.
Table 12
Request Fields for Real-Time Bank Transfers Using the Simple Order API
Request Field
Description
Required (R) or
Optional (O)
Data Type
& Length
bankInfo_bankCode
Code for the customer’s bank.
Real-Time Bank
Transfer (O)
String (8)
bankInfo_country
Country in which the bank is located. Use the
two-character ISO Standard Country Codes.
Real-Time Bank
Transfer (R)
String (2)
bankTransferRealTime
Service_bankTransfer
RealTimeType
Code that indicates which payment method or
bank to use for this transaction. See Table 13,
page 60.
Real-Time Bank
Transfer (R)
String (2)
bankTransferRealTime
Service_run
Set to true to include the real-time bank
transfer service in your request.
Real-Time Bank
Transfer (R)
String (5)
billTo_city
Billing address city.
Real-Time Bank
Transfer (R)
String (50)
billTo_company
Name of the customer’s company.
Real-Time Bank
Transfer (O)
String (60)
Global Payment Service Developer Guide | March 2015
55
Chapter 4
Table 12
Real-Time Bank Transfers Using the Simple Order API
Request Fields for Real-Time Bank Transfers Using the Simple Order API (Continued)
Request Field
Description
Required (R) or
Optional (O)
Data Type
& Length
billTo_country
Billing address country.
Real-Time Bank
Transfer (R)
String (2)
billTo_email
Customer’s email address, including the full
domain name. For example:
johnnysmith@example.com
Real-Time Bank
Transfer (R)
String (255)
billTo_firstName
Customer’s first name.
Real-Time Bank
Transfer (R)
String (60)
billTo_language
Language used for the order. Use the ISO
standard language codes.
Real-Time Bank
Transfer (O)
String (2)
billTo_lastName
Customer’s last name.
Real-Time Bank
Transfer (R)
String (60)
billTo_phoneNumber
Customer’s telephone number.
Real-Time Bank
Transfer (O)
String (15)
billTo_postalCode
Postal code for the billing address. The postal
code must consist of 5 to 9 digits.
Real-Time Bank
Transfer (R if
billing country is
US or CA)
String (10)
If the value of billTo_country is US, the 9-digit
postal code must follow this format:
[5 digits][dash][4 digits]
Example: 12345-6789
If the value of billTo_country is CA, the 6-digit
postal code must follow this format:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C3
billTo_state
Billing address state. This field is required if the
billTo_country value is US or CA.
Real-Time Bank
Transfer (See
description)
String (2)
billTo_street1
Billing address street address.
Real-Time Bank
Transfer (R)
String (60)
billTo_street2
Additional address information.
Real-Time Bank
Transfer (O)
String (60)
fundTransfer_
accountNumber
Customer’s bank account number.
Real-Time Bank
Transfer (O)
String (10)
fundTransfer_iban
International Bank Account Number (IBAN) for
the bank account.
Real-Time Bank
Transfer (See
description)
String (30)
Note Required for specific countries. Contact
CyberSource Customer Support for required
country-specific.
Global Payment Service Developer Guide | March 2015
56
Chapter 4
Table 12
Real-Time Bank Transfers Using the Simple Order API
Request Fields for Real-Time Bank Transfers Using the Simple Order API (Continued)
Request Field
Description
Required (R) or
Optional (O)
Data Type
& Length
invoiceHeader_
merchantDescriptor
Merchant descriptor that is displayed on the
customer’s statement for each real-time bank
transfer.
Real-Time Bank
Transfer (O)
String (50)
Real-Time Bank
Transfer (O)
String (30)
For iDEAL:
String (32)
To enable this field and to optionally set a
default descriptor for all real-time bank
transfers, contact CyberSource Customer
Support.
item_#_productCode
Type of product. This value is used to determine
the product category: electronic, handling,
physical, service, or shipping. The default value
is default. See "Product Codes," page 154,
for a list of valid values.
If you set it to a value other than default,
stored_value, or any of the values related
to shipping and/or handling, the item_#_
quantity, item_#_product_name, and item_#_
productSKU fields are required.
item_#_productName
Name of the product. This field is required if
item_#_productCode is not default,
stored_value, or one of the values related
to shipping and/or handling.
Real-Time Bank
Transfer (See
description)
String (30)
item_#_productSKU
Product identifier code. It is required if item_#_
productCode is not default, stored_
value, or one of the values related to shipping
and/or handling.
Real-Time Bank
Transfer (See
description)
String (30)
item_#_quantity
Quantity of the product being purchased. The
default value is 1. This field is required if item_
#_productCode is not default, stored_
value, or one of the values related to shipping
and/or handling.
Real-Time Bank
Transfer (See
description)
Integer (10)
Global Payment Service Developer Guide | March 2015
57
Chapter 4
Table 12
Real-Time Bank Transfers Using the Simple Order API
Request Fields for Real-Time Bank Transfers Using the Simple Order API (Continued)
Request Field
Description
Required (R) or
Optional (O)
Data Type
& Length
item_#_taxAmount
Tax amount associated with this item. This field
is additive. For example, if you send these offer
lines:
Real-Time Bank
Transfer (O)
String (15)
Real-Time Bank
Transfer (See
description)
String (15)
offer0=amount:10.00^
quantity:1^tax_amount:0.80
offer1=amount:20.00^
quantity:1^tax_amount:1.60
the total amount authorized will be for 32.40, not
30.00 with 2.40 of tax included.
The item_#_taxAmount and the item_#_
unitPrice values must be in the same currency.
If you include item_#_taxAmount and you
include taxService in your request, taxService
does not calculate the tax for the offer. Instead,
it returns the value in the item_#_taxAmount
field.
item_#_unitPrice
Per-item price of the product. You must include
either this field or the purchaseTotals_
grandTotalAmount field in your request. This
value cannot be negative. See the information
about items and grand totals in Getting Started
with CyberSource Advanced for the Simple
Order API.
You can include a decimal point (.) in this field,
but you cannot include any other special
characters. The amount will be truncated at the
request level to the correct number of decimal
places.
linkToRequest
Value that links the current request to a previous
authorization request for a debit card or prepaid
card. This value is useful when using multiple
payment methods to complete an order. For
more information about partial authorizations,
see Credit Card Services Using the Simple
Order API.
Real-Time Bank
Transfer (O)
String (26)
merchantID
Your CyberSource merchant ID.
Real-Time Bank
Transfer (R)
String (30)
merchantReferenceCode
Merchant-generated order reference or tracking
number. If this field includes multi-byte
characters, it might be corrupted when it is
returned to you in the reply. For more
information about tracking orders, see Getting
Started with CyberSource Advanced for the
Simple Order API.
Real-Time Bank
Transfer (R)
String (50)
Global Payment Service Developer Guide | March 2015
58
Chapter 4
Table 12
Real-Time Bank Transfers Using the Simple Order API
Request Fields for Real-Time Bank Transfers Using the Simple Order API (Continued)
Request Field
Description
Required (R) or
Optional (O)
Data Type
& Length
purchaseTotals_currency
Currency used for the order. Use the ISO
Standard Currency Codes.
Real-Time Bank
Transfer (R)
String (5)
purchaseTotals_
grandTotalAmount
Grand total for the order. You must include
either this field or item_#_unitPrice in your
request. For more information about items and
grand totals, see Getting Started with
CyberSource Advanced for the Simple Order
API.
Real-Time Bank
Transfer (See
description)
String (15)
returnURL
URL that returns the customer to your Web site
after the transaction. You are required to
provide this value using one of the following
methods:
Real-Time Bank
Transfer (See
description)
String (512)

Send this field with every request.

Provide the URL when you register for the
service, and CyberSource will store it in a
database.
shipTo_city
City of shipping address. This field is required if
any shipping information is included in the
request.
Real-Time Bank
Transfer (See
description)
String (50)
shipTo_country
Country of shipping address. Use the twocharacter ISO Standard Country Codes.
Real-Time Bank
Transfer (O)
String (2)
shipTo_firstName
First name of the person receiving the product.
Real-Time Bank
Transfer (O)
String (60)
shipTo_lastName
Last name of the person receiving the product.
Real-Time Bank
Transfer (O)
String (60)
shipTo_phoneNumber
Phone number for the shipping address.
Real-Time Bank
Transfer (O)
String (15)
shipTo_postalCode
Postal code for the shipping address. The postal
code must consist of 5 to 9 digits.
Real-Time Bank
Transfer (R if
shipTo_country is
US or CA)
String (10)
If the value of shipTo_country is US, the 9-digit
postal code must follow these rules:
[5 digits][dash][4 digits]
Example: 12345-6789
If the value of shipTo_country is CA, the 6-digit
postal code must follow these rules:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C4
If the postal code for the shipping address is not
included in the request message, CyberSource
uses the postal code from the billing address. If
the postal code for the billing address is not
included in the request message, the postal
code for the shipping address is required.
Global Payment Service Developer Guide | March 2015
59
Chapter 4
Table 12
Real-Time Bank Transfers Using the Simple Order API
Request Fields for Real-Time Bank Transfers Using the Simple Order API (Continued)
Request Field
Description
Required (R) or
Optional (O)
Data Type
& Length
shipTo_state
State or province of shipping address. Use the
State, Province, and Territory Codes for the
United States and Canada. This field is required
if the shipTo_country value is US or CA.
Real-Time Bank
Transfer (See
description)
String (2)
shipTo_street1
First line of shipping address. This field is
required if any shipping information is included
in the request.
Real-Time Bank
Transfer (See
description)
String (60)
shipTo_street2
Second line of shipping address.
Real-Time Bank
Transfer (O)
String (60)
Bank Codes
The following table describes the bank codes that indicate the payment method or bank to
use for a real-time bank transfer.
Table 13
Bank Transfer Real Time Type
Bank
Code
Bank or
Payment Type
Country
Bank or Network
1
ING Home Pay
Belgium
Single bank
2
Nordea e-maksu
Finland
Single bank
3
Nordea e-betaling
Denmark
Single bank
5
Nordea e-betalning
Sweden
Single bank
7
iDEAL
Netherlands
Banking network. The customer selects the
specific bank on your payment page.
9
GiroPay
Germany
Banking network. The customer selects the
specific bank on a web page that you do not
control.
11
eCard
Poland
Banking network. The customer selects the
specific bank on a web page that you do not
control.
12
eNets
Singapore
Banking network. The customer selects the
specific bank on a web page that you do not
control.
17
Akita
Finland
Banking network. The customer selects the
specific bank on a web page that you do not
control.
18
Sofortuberweisung
Germany
Banking network. The customer selects the
specific bank on a web page that you do not
control.
Global Payment Service Developer Guide | March 2015
60
Chapter 4
Table 13
Real-Time Bank Transfers Using the Simple Order API
Bank Transfer Real Time Type (Continued)
Bank
Code
Bank or
Payment Type
Country
Bank or Network
20
Poli
Australia
Banking network. The customer selects the
specific bank on a web page that you do not
control.
Reply Fields
The following table lists the fields returned in a reply from the
bankTransferRealTimeService service request.
Table 14
Reply Fields for Real-Time Bank Transfers Using the Simple Order API
Reply Field
Description
Data Type &
Length
bankTransferRealTimeReply_
amount
Total amount for the real-time bank transfer.
String (15)
bankTransferRealTimeReply_
formAction
URL that will be used to re-direct the customer’s browser
window back to your web site.
String (4000)
bankTransferRealTimeReply_
formMethod
Method that redirects the customer’s browser window to
your web site. The possible values are:
String (4)

GET

POST
bankTransferRealTimeReply_
paymentReference
Payment reference number that you must display to the
customer. For more information about tracking orders, see
Getting Started with CyberSource Advanced for the Simple
Order API. In Italy, this number is called the Numero di
riferimento.
String (16)
bankTransferRealTimeReply_
reasonCode
A numeric value corresponding to the result of the real-time
bank transfer request. See "Reason Codes," page 155, for a
list of possible values.
Integer (5)
bankTransferRealTimeReply_
reconciliationID
Unique value generated by CyberSource. See the
information about tracking orders in Getting Started with
CyberSource Advanced for the Simple Order API.
String (60)
bankTransferRealTimeReply_
requestDateTime
Time the real-time bank transfer was requested.
Format: YYYY-MM-DDThh:mm:ssZ.
Example: 2007-08-11T22:47:57Z, which is August 11, 2007,
at 10:47:57 P.M.
The T separates the date and the time. The Z indicates UTC.
String (20)
bankTransferRefundReply_iban
International Bank Account Number (IBAN) for the bank
account.
Alphanumeric
(50)
Global Payment Service Developer Guide | March 2015
61
Chapter 4
Table 14
Real-Time Bank Transfers Using the Simple Order API
Reply Fields for Real-Time Bank Transfers Using the Simple Order API (Continued)
Reply Field
Description
Data Type &
Length
decision
Summarizes the result of the overall request. The possible
values are:
String (6)
invalidField_0...N

ACCEPT

ERROR

REJECT
Fields in the request that contained invalid data. These reply
fields are included as an aid to software developers only.
String (100)
Note Do not attempt to use these fields for interacting with
end users.
For more information about missing and invalid fields, see
Getting Started with CyberSource Advanced for the Simple
Order API.
merchantReferenceCode
Order reference or tracking number that you provided in the
request. If you included multi-byte characters in this field in
the request, the returned value might contain corrupted
characters.
String (50)
missingField_0...N
Required fields that were missing from the request. These
reply fields are included as an aid to software developers
only.
String (100)
Note Do not attempt to use these fields for interacting with
end users.
For more information about missing and invalid fields, see
Getting Started with CyberSource Advanced for the Simple
Order API.
purchaseTotals_currency
Currency used for the order. Use the ISO Standard Currency
Codes.
String (5)
reasonCode
Numeric value corresponding to the result of the overall
request. See "Reason Codes," page 155, for a list of
possible values.
Integer (5)
requestID
Identifier for the request generated by CyberSource.
String (26)
requestToken
Request token data created by CyberSource for each reply.
The field is an encoded string that contains no confidential
information such as an account number. The string can
contain a maximum of 256 characters.
String (256)
Global Payment Service Developer Guide | March 2015
62
Chapter 4
Real-Time Bank Transfers Using the Simple Order API
Additional Request Fields
The following table lists the additional fields to use in a request for the
bankTransferRefundService service. In addition to these fields, you must use the fields
specified for refunds in "Request Fields," page 18.
Table 15
Additional Request Fields for Bank Transfer Refunds
for the Simple Order API
Request Field
Description
Required (R) or
Optional (O)
Data
Type &
Length
bankTransferRefund
Service_bankTransfer
RealTimeReconciliationID
Unique identifier for the order submitted to
Global Collect.
Bank Transfer
Refund (R for
standalone
refunds)
String (60)
Bank Transfer
Refund (R)
String (26)
bankTransferRefund
Service_bankTransfer
RealTimeRequestID
Note If you do not include this field in a
refund request, CyberSource will generate
the value.
The requestID field returned from a
previous request for the
bankTransferRealTimeService service.
Send this field instead of the
bankTransferRefundService_
bankTransferRequestID field.
Global Payment Service Developer Guide | March 2015
63
Chapter 4
Real-Time Bank Transfers Using the Simple Order API
Request and Reply Examples
Real-Time Bank Transfer Request
Example 16
Real-Time Bank Transfer Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.23">
<bankTransferRealTimeService run="true"/>
<merchantID>demo</merchantID>
<merchantReferenceCode>482046</merchantReferenceCode>
<billTo>
<firstName>John</firstName>
<lastName>Smith</lastName>
<street1>Boschdijk 987</street1>
<city>Eindhoven</city>
<country>NL</country>
<language>nl</language>
<postalCode>5600 PB</postalCode>
<email>jsmith@example.com</email>
<phoneNumber>040-5551212</phoneNumber>
</billTo>
<purchaseTotals>
<currency>EUR</currency>
</purchaseTotals>
<item id="0">
<unitPrice>49.95</unitPrice>
<quantity>1</quantity>
</item>
<bankTransferRealTimeService>
<bankTransferRealTimeType>7</bankTransferRealTimeType>
</bankTransferRealTimeService>
<bankInfo>
<country>NL</country>
</bankInfo>
</requestMessage>
Global Payment Service Developer Guide | March 2015
64
Chapter 4
Real-Time Bank Transfers Using the Simple Order API
Real-Time Bank Transfer Reply
Example 17
Real-Time Bank Transfer Reply
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.23">
<c:requestID>0305782650000167905080</c:requestID>
<c:merchantReferenceCode>482046</c:merchantReferenceCode>
<c:purchaseTotals>
<c:currency>EUR</c:currency>
</c:purchaseTotals>
<c:decision>ACCEPT</c:decision>
<c:reasonCode>100</c:reasonCode>
<c:bankTransferRealTimeReply>
<c:reconciliationID>0308014624</c:reconciliationID>
<c:amount>49.95</c:amount>
<c:requestDateTime>2012-01-28T23:44:27Z</c:requestDateTime>
<c:paymentReference>106157214759</c:paymentReference>
<c:reasonCode>100</c:reasonCode>
<c:formMethod>GET</c:formMethod>
<c:formAction>http://www.cybs.com?REF=124&MAC=346o+123</c:formAction>
</c:bankTransferRealTimeReply>
</c:replyMessage>
Real-Time Bank Transfer Refund
Example 18
Real-Time Bank Transfer Refund Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.103">
<merchantID>demo123</merchantID>
<merchantReferenceCode>demoRef</merchantReferenceCode>
<billTo>
<firstName>Orlando</firstName>
<lastName>Bloom</lastName>
<street1>33, rue Dauphine</street1>
<city>Bergheim</city>
<postalCode>75006</postalCode>
<country>DE</country>
<phoneNumber>33 3 69 20 45 63</phoneNumber>
<email>borlando@cybersource.com</email>
</billTo>
<purchaseTotals>
<currency>EUR</currency>
<grandTotalAmount>74</grandTotalAmount>
</purchaseTotals>
<fundTransfer>
<accountNumber>0044497071</accountNumber>
<accountName>BRADFORD NICKLES</accountName>
</fundTransfer>
Global Payment Service Developer Guide | March 2015
65
Chapter 4
Real-Time Bank Transfers Using the Simple Order API
<bankInfo>
<bankCode>79050000</bankCode>
<name>SloveniaBank_testing</name>
<country>DE</country>
<swiftCode>BSLJSI2X</swiftCode>
</bankInfo>
<bankTransferRefundService run="true">
<reconciliationID>21223345</reconciliationID>
</bankTransferRefundService>
</requestMessage>
Real-Time Bank Transfer Refund Reply
Example 19
Real-Time Bank Transfer Refund Reply
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.103">
<c:merchantReferenceCode>demoRef</c:merchantReferenceCode>
<c:requestID>4024431863670181551532</c:requestID>
<c:decision>ACCEPT</c:decision>
<c:reasonCode>100</c:reasonCode>
<c:purchaseTotals>
<c:currency>eur</c:currency>
</c:purchaseTotals>
<c:bankTransferRefundReply>
<c:reasonCode>100</c:reasonCode>
<c:amount>74.00</c:amount>
<c:requestDateTime>2014-06-10T23:33:08Z</c:requestDateTime>
<c:reconciliationID>21223345</c:reconciliationID>
<c:iban>DE58790500000044497071</c:iban>
</c:bankTransferRefundReply>
</c:replyMessage>
Global Payment Service Developer Guide | March 2015
66
CHAPTER
Real-Time Bank Transfers
Using the SCMP API
5
Transaction Status
You can perform an on-demand query to get the status of a transaction. CyberSource
recommends that you wait at least 5 minutes after the customer has completed a
transaction before sending an on-demand query. If you need to request the status more
than once, you must wait at least 10 minutes between queries for the same transaction.
For China, real-time bank transfer settlements are not posted until the next
business day.
Note
Sending the Query
To send the query, send the fields described in the following table in an HTTP POST
request to the following URL:
https://ebc.cybersource.com/ebc/Query
After you send the query, CyberSource will prompt you for your username and password
to verify that you have access to the merchant ID.
Table 16
Required Data for the On-Demand Transaction Status Query
Field
Description
Required (R)
or Optional (O)
Data Type
& Length
merchantID
Your CyberSource merchant ID.
R
String (30)
Type of query. The only possible value is
R
String (30)
type
transaction.
subtype
Query subtype. The only possible value is
transactionStatus.
R
String (30)
requestID
Request ID returned in the real-time bank
transfer reply.
R
String (26)
transRefNo
Transaction reference number (SCMP API)
or reconciliation ID (Simple Order API)
returned in the real-time bank transfer reply.
R
String (60)
Global Payment Service Developer Guide | March 2015
67
Chapter 5
Table 16
Real-Time Bank Transfers Using the SCMP API
Required Data for the On-Demand Transaction Status Query (Continued)
Field
Description
Required (R)
or Optional (O)
Data Type
& Length
requestToken
Request token data generated by
CyberSource for each transaction reply.
R
String (256)
This example shows an on-demand query for a transaction’s status:
Example 20
On-Demand Transaction Status Query
<html>
<body>
<form action="https://ebc.cybersource.com/ebc/Query" method="POST">
<input type="hidden" name="type" value="transaction">
<input type="hidden" name="subtype" value="transactionStatus">
<table>
<tr>
<td>merchant ID <font color=red>*</font>: </td>
<td><input type="text" name="merchantID" value="dm_ptech"></td>
</tr>
<tr>
<td>Request ID: </td>
<td><input type="text" name="requestID" value=""></td>
</tr>
<tr>
<td>Transaction Reference Number: </td>
<td><input type="text" name="transRefNo" value=""></td>
</tr>
<tr>
<td>Request Token: </td>
<td><input type="text" name="requestToken" value=""></td>
</tr>
<tr><td colspan=2>&nbsp;</td></tr>
<tr><td colspan=2><input type="submit" value="submit"></td></tr>
</table>
</form>
</body>
</html>
Global Payment Service Developer Guide | March 2015
68
Chapter 5
Real-Time Bank Transfers Using the SCMP API
Viewing the Response
You receive a response immediately. There are two possible outcomes:

If the query is successful, the results appear as a document of mime type application/
xml. To use this document, you need to write a program to save or process the XML
data of the document.

If your POST data contains an error, you receive a system error. If the system error
persists, contact CyberSource Customer Support.
The DTD for a successful query result:
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
<!ELEMENT
xml (Request, Response)>
Request (MerchantID, RequestID)>
MerchantID (#PCDATA)>
RequestID (#PCDATA)>
Response (PaymentStatus?)>
PaymentStatus (Status, ProcessorMessage?)>
Status (#PCDATA)>
ProcessorMessage (#PCDATA)>
This example shows on-demand query results for a successful real-time bank transfer
payment:
Example 21
Successful Payment
<xml>
<Request>
<MerchantID>OKGo1234</MerchantID>
<RequestID>1688722776730008402433</RequestID>
<Response>
<PaymentStatus>
<Status>Payment</Status>
</PaymentStatus>
</Response>
</Request>
</xml>
Global Payment Service Developer Guide | March 2015
69
Chapter 5
Real-Time Bank Transfers Using the SCMP API
This example shows on-demand query results for a failed real-time bank transfer
payment:
Example 22
Failed Payment
<xml>
<Request>
<MerchantID>OKGo1234</MerchantID>
<RequestID>1545412404130167905103</RequestID>
<Response>
<PaymentStatus>
<Status>Failed</Status>
<ProcessorMessage>Payment instruction has been rejected</ProcessorMessage>
</PaymentStatus>
</Response>
</Request>
</xml>
Requesting Real-Time Bank
Transfers
Use the ics_bank_transfer_real_time service to request a real-time bank transfer. See
Table 17, page 71, and Table 18, page 75, for fields to use when requesting the service.
Table 20, page 78, describes the fields that the service returns to you.
When requesting a real-time bank transfer, you may not request any of the other ICS
services except ics_tax, which is optional. For more information about the service, see
Tax Calculation Service Using the SCMP API.
Global Payment Service Developer Guide | March 2015
70
Chapter 5
Real-Time Bank Transfers Using the SCMP API
Requesting Real-Time Bank
Transfer Refunds
Important
From August 1, 2016, for euro countries and from October 31, 2016, for noneuro countries, the IBAN must be included in each request. If you provide a
BBAN it will be converted to an IBAN, and this conversion process will continue
only until August 1, 2016.
Except for a few additional fields, refunds for real-time bank transfers are the same as
refunds for traditional bank transfers. See "Requesting Bank Transfer Refunds," page 34.
The additional fields are identifiers that have been re-named for real-time bank transfers.
See Table 22, page 80.
API Fields
For information about the data types, see Getting Started with CyberSource Advanced for
the SCMP API.
Request Fields
The following table lists the fields to use in a request for the ics_bank_transfer_real_
time field.
Table 17
Request-Level Fields for Real-Time Bank Transfers Using the SCMP API
Request-Level Field
Description
Required (R) or
Optional (O)
Data
Type &
Length
bank_account_number
Customer’s bank account number.
Real-Time Bank
Transfer (O)
String (10)
bank_code
Code for the customer’s bank.
Real-Time Bank
Transfer (O)
String (8)
bank_country
Country where the bank is located. Use the
two-character ISO Standard Country Codes.
Real-Time Bank
Transfer (R)
String (2)
bank_iban
International Bank Account Number (IBAN) for
the bank account.
Real-Time Bank
Transfer (See
description)
String (30)
Note Required for specific countries. Contact
CyberSource Customer Support for required
country-specific requirements.
Global Payment Service Developer Guide | March 2015
71
Chapter 5
Table 17
Real-Time Bank Transfers Using the SCMP API
Request-Level Fields for Real-Time Bank Transfers Using the SCMP API (Continued)
Request-Level Field
Description
Required (R) or
Optional (O)
Data
Type &
Length
bank_transfer_real_time_
type
Code that indicates the payment method or
bank to use for this transaction. See Table 19,
page 76.
Real-Time Bank
Transfer (R)
String (2)
bill_address1
Billing street address.
Real-Time Bank
Transfer (R)
String (60)
bill_address2
Additional billing address information.
Real-Time Bank
Transfer (O)
String (60)
bill_city
Billing address city.
Real-Time Bank
Transfer (R)
String (50)
bill_country
Billing address country.
Real-Time Bank
Transfer (R)
String (2)
bill_state
Billing address state. This field is required if the
value of bill_country is US or CA.
Real-Time Bank
Transfer (See
description)
String (2)
bill_zip
Zip code for the shipping address. The zip
code must consist of 5 to 9 digits.
Real-Time Bank
Transfer (R if bill_
country is US or
CA)
String (10)
If the value of bill_country is US, the 9-digit
zip code must follow this format:
[5 digits][dash][4 digits]
Example:12345-6789
If the value of bill_country is CA, the 6-digit
zip code must follow this format:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C3
company_name
Name of the customer’s company.
Real-Time Bank
Transfer (O)
String (60)
currency
Currency used for the order. Use the ISO
Standard Currency Codes.
Real-Time Bank
Transfer (R)
String (5)
customer_email
Customer’s email address. For example:
johnnysmith@example.com
Real-Time Bank
Transfer (R)
String
(255)
customer_firstname
Customer’s first name.
Real-Time Bank
Transfer (R)
String (60)
customer_language
Language used for the order. Use the ISO
standard language codes.
Real-Time Bank
Transfer (O)
String (2)
customer_lastname
Customer’s last name.
Real-Time Bank
Transfer (R)
String (60)
customer_phone
Customer’s telephone number.
Real-Time Bank
Transfer (O)
String (15)
Global Payment Service Developer Guide | March 2015
72
Chapter 5
Table 17
Real-Time Bank Transfers Using the SCMP API
Request-Level Fields for Real-Time Bank Transfers Using the SCMP API (Continued)
Request-Level Field
Description
Required (R) or
Optional (O)
Data
Type &
Length
grand_total_amount
Grand total for the order. You must include
either this field or offer0 and the offer-level
field amount. See the information about offers
and grand totals in Getting Started with
CyberSource Advanced for the SCMP API.
Real-Time Bank
Transfer (See
description)
Decimal
(15)
ics_applications
ICS services to process for the request.
Real-Time Bank
Transfer (R)
String
(255)
link_to_request
Value that links the current request to a
previous authorization request for a debit card
or prepaid card. This value is useful when
using multiple payment methods to complete
an order. For details, see the information about
partial authorizations in Credit Card Services
Using the SCMP API.
Real-Time Bank
Transfer (O)
String (26)
merchant_descriptor
Merchant descriptor that is displayed on the
customer’s statement for each real-time bank
transfer.
Real-Time Bank
Transfer (O)
String (50)
For iDEAL:
String (32)
To enable this field and to optionally set a
default descriptor for all real-time bank
transfers, contact CyberSource Customer
Support.
merchant_id
Your CyberSource merchant ID.
Real-Time Bank
Transfer (R)
String (30)
merchant_ref_number
Merchant-generated order reference or
tracking number. If this field includes multi-byte
characters, it might be corrupted when it is
returned to you in the reply. See the
information about tracking orders in Getting
Started with CyberSource Advanced for the
SCMP API.
Real-Time Bank
Transfer (R)
String (50)
offer0...N
Offers for the request. An offer is a line item for
the order.
Real-Time Bank
Transfer (O)
String (50)
return_url
URL that will be used to return the customer to
your web site after the transaction. You are
required to provide this value using one of the
following methods:
Real-Time Bank
Transfer (See
description)
String
(512)
Real-Time Bank
Transfer (See
description)
String (60)
ship_to_address1

Send this field with every request.

Provide the URL when you sign up for the
service, and CyberSource will store it in a
database.
First line of the address to which the product
will be shipped. This field is required if any
shipping information is included in the request.
Global Payment Service Developer Guide | March 2015
73
Chapter 5
Table 17
Real-Time Bank Transfers Using the SCMP API
Request-Level Fields for Real-Time Bank Transfers Using the SCMP API (Continued)
Request-Level Field
Description
Required (R) or
Optional (O)
Data
Type &
Length
ship_to_address2
Second line of the address to which the
product will be shipped.
Real-Time Bank
Transfer (O)
String (60)
ship_to_city
City to which the product will be shipped. This
field is required if any shipping information is
included in the request.
Real-Time Bank
Transfer (See
description)
String (50)
ship_to_country
Country to which the product will be shipped.
Use the two-character ISO Standard Country
Codes.
Real-Time Bank
Transfer (O)
String (2)
ship_to_firstname
First name of person receiving the product.
Real-Time Bank
Transfer (O)
String (60)
ship_to_lastname
Last name of person receiving the product.
Real-Time Bank
Transfer (O)
String (60)
ship_to_phone
Phone number for the shipping address.
Real-Time Bank
Transfer (O)
String (15)
ship_to_state
State or province to which the product will be
shipped. Use the State, Province, and Territory
Codes for the United States and Canada. This
field is required if the value ship_to_country is
US or CA.
Real-Time Bank
Transfer (See
description)
String (2)
ship_to_zip
Zip code for the shipping address.
Real-Time Bank
Transfer (R is if
ship_to_country
is US or CA)
String (10)
Real-Time Bank
Transfer (O)
Positive
integer (3)
If the value of ship_to_country is US, the 9digit zip code must follow this format:
[5 digits][dash][4 digits]
Example: 12345-6789
If the value of ship_to_country is CA, the 6digit zip code must follow this format:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C3
If the postal code for the shipping address is
not included in the request message,
CyberSource will use the postal code for the
billing address. If the postal code for the billing
address is not included in the request
message, the postal code for the shipping
address is required.
timeout
Number of seconds until the transaction times
out. The default is 110 seconds.
Global Payment Service Developer Guide | March 2015
74
Chapter 5
Real-Time Bank Transfers Using the SCMP API
Offer-Level Fields
The following table lists the offer-level fields for the ics_bank_transfer_real_time field.
Table 18
Offer-Level Fields for Real-Time Bank Transfers for the SCMP API
Offer-Level Field
Description
Required (R) or
Optional (O)
Data
Type &
Length
amount
Per-item price of the product. You must
include either offer0 and this field, or the
request-level field grand_total_amount in
your request. This value cannot be negative.
See the information about offers and grand
totals in Getting Started with CyberSource
Advanced for the SCMP API.
Real-Time Bank
Transfer (See
description)
Decimal
(15)
You can include a decimal point (.) in this
field, but you cannot include any other
special characters. The amount will be
truncated at the request level to the correct
number of decimal places.
merchant_product_sku
Product identifier code. It is required if
product_code is not default, stored_
value, or one of the values related to
shipping and/or handling.
Real-Time Bank
Transfer (See
description)
String (30)
product_code
Type of product the offer contains. This
value is used to determine the category that
the product falls under: electronic, handling,
physical, service, or shipping. The default
value is default. See "Product Codes,"
page 154, for a list of valid values.
Real-Time Bank
Transfer (O)
String (30)
If you set this to a value other than
default, stored_value, or any of the
values related to shipping and/or handling,
the quantity, product_name and
merchant_product_sku fields are required.
product_name
Name of the product. This field is required if
product_code is not default, stored_
value or one of the values related to
shipping and/or handling.
Real-Time Bank
Transfer (See
description)
String (30)
quantity
Quantity of the product being purchased.
The default value is 1. This field is required if
product_code is not default, stored_
value or one of the values related to
shipping and/or handling.
Real-Time Bank
Transfer (See
description)
Nonnegative
integer (10)
Global Payment Service Developer Guide | March 2015
75
Chapter 5
Table 18
Real-Time Bank Transfers Using the SCMP API
Offer-Level Fields for Real-Time Bank Transfers for the SCMP API (Continued)
Offer-Level Field
Description
Required (R) or
Optional (O)
Data
Type &
Length
tax_amount
Tax amount associated with this item. This
field is additive. For example, if you send
these offer lines:
Real-Time Bank
Transfer (O)
Decimal
(15)
offer0=amount:10.00^
quantity:1^tax_amount:0.80
offer1=amount:20.00^
quantity:1^tax_amount:1.60
the total amount authorized will be for 32.40,
not 30.00 with 2.40 of tax included.
The tax_amount and the amount values
must be in the same currency.
If you include tax_amount and you request
the ics_tax service, ics_tax will not
calculate tax for the offer. Instead, it will
return the value in the tax_amount field.
Bank Codes
The following table describes the values for the bank transfer real-time type.
Table 19
Bank Transfer Real-Time Type
Bank
Code
Bank or
Payment Type
Country
Bank or Network
1
ING Home Pay
Belgium
Single bank
2
Nordea e-maksu
Finland
Single bank
3
Nordea e-betaling
Denmark
Single bank
5
Nordea e-betalning
Sweden
Single bank
7
iDEAL
Netherlands
Banking network. The customer selects the
specific bank on your payment page.
9
GiroPay
Germany
Banking network. The customer selects the
specific bank on a web page that you do not
control.
11
eCard
Poland
Banking network. The customer selects the
specific bank on a web page that you do not
control.
12
eNets
Singapore
Banking network. The customer selects the
specific bank on a web page that you do not
control.
Global Payment Service Developer Guide | March 2015
76
Chapter 5
Table 19
Real-Time Bank Transfers Using the SCMP API
Bank Transfer Real-Time Type (Continued)
Bank
Code
Bank or
Payment Type
Country
Bank or Network
17
Akita
Finland
Banking network. The customer selects the
specific bank on a web page that you do not
control.
18
Sofortuberweisung
Germany
Banking network. The customer selects the
specific bank on a web page that you do not
control.
20
Poli
Australia
Banking network. The customer selects the
specific bank on a web page that you do not
control.
Bank
Code
Bank or
Payment Type
Country
Bank or Network
1
ING Home Pay
Belgium
Single bank
2
Nordea e-maksu
Finland
Single bank
3
Nordea e-betaling
Denmark
Single bank
5
Nordea e-betalning
Sweden
Single bank
7
iDEAL
Netherlands
Banking network. The customer selects the
specific bank on your payment page.
Global Payment Service Developer Guide | March 2015
77
Chapter 5
Real-Time Bank Transfers Using the SCMP API
Reply Fields
The following table lists the fields returned in a reply from the ics_bank_transfer_real_
time request.
Table 20
Reply Fields for Real-Time Bank Transfers Using the SCMP API
Reply Field
Description
Data Type &
Length
bank_transfer_refund_iban
International Bank Account Number (IBAN) for the bank
account.
Alphanumeric
(50)
bank_transfer_real_time_amount
Total amount for the real-time bank transfer.
Decimal (15)
bank_transfer_real_time_form_
action
URL that will be used to re-direct the customer’s browser
window back to your web site.
String (4000)
bank_transfer_real_time_form_
method
Method that will be used to re-direct the customer’s browser
window back to your web site. The possible values are:
String (4)

GET

POST
bank_transfer_real_time_
payment_reference
Payment reference number that you must display to the
customer. See the information about tracking orders in
Getting Started with CyberSource Advanced for the SCMP
API. In Italy, this is called the Numero di riferimento.
String (16)
bank_transfer_real_time_rcode
One-digit code that indicates whether the ics_bank_
transfer_real_time request was successful.
Integer (1)
bank_transfer_real_time_rflag
One-word description of the result of the ics_bank_
transfer_real_time request.
String (50)
bank_transfer_real_time_rmsg
Message that explains the reply flag bank_transfer_real_
time_rflag.
String (255)
bank_transfer_real_time_time
Time of the real-time bank transfer request in UTC. For the
format, see the information about data types in Getting
Started with CyberSource Advanced for the SCMP API.
Date and time
(20)
bank_transfer_real_time_trans_
ref_no
Unique value generated by CyberSource. See the
information about tracking orders in Getting Started with
CyberSource Advanced for the SCMP API.
String (60)
client_lib_version
Information about the client library used to request the
transaction.
String (50)
currency
Currency used for the order. Use the ISO Standard
Currency Codes.
String (5)
ics_rcode
One-digit code that indicates whether the entire request was
successful. The possible values are:
Integer (1)
ics_rflag

-1: An error occurred

0: The request was declined

1: The request was successful
One-word description of the result of the entire request.
Global Payment Service Developer Guide | March 2015
String (50)
78
Chapter 5
Table 20
Real-Time Bank Transfers Using the SCMP API
Reply Fields for Real-Time Bank Transfers Using the SCMP API (Continued)
Reply Field
Description
Data Type &
Length
ics_rmsg
Message that explains the reply flag ics_rflag.
String (255)
merchant_ref_number
Order reference or tracking number that you provided in the
request. If you included multi-byte characters in this field in
the request, the returned value might contain corrupted
characters.
String (50)
request_id
Identifier for the request generated by CyberSource.
String (26)
request_token
Request token data created by CyberSource for each reply.
The field is an encoded string that contains no confidential
information such as an account number. The string can
contain a maximum of 256 characters.
String (256)
Reply Flags
The following table lists the reply flags for the ics_bank_transfer_real_time request.
Table 21
Reply Flags for Real-Time Bank Transfers for the SCMP API
Reply Flag
Description
DINVALIDDATA
Data provided is not consistent with the request.
DMISSINGFIELD
The request is missing a required field.
ESYSTEM
System error. You must design your transaction management system to
correctly handle CyberSource system errors. Depending on the payment
processor handling the transaction, the error may indicate a valid
CyberSource system error or a processor rejection due to invalid data. In
either case, CyberSource recommends that you do not design your
system to endlessly retry sending a transaction. For important
information on handling system errors and retries, see the documentation
for your CyberSource client.
ETIMEOUT
The request timed out.
SOK
The transaction was successful.
Global Payment Service Developer Guide | March 2015
79
Chapter 5
Real-Time Bank Transfers Using the SCMP API
Additional Request Fields
The following table lists the additional fields to use in a request for the ics_bank_
transfer_refund service. In addition to these fields, you must use the fields specified for
refunds in "Request Fields," page 36.
Table 22
Additional Request Fields for Bank Transfer Refunds Using the SCMP API
Request Field
Description
Required (R) or
Optional (O)
Data Type
& Length
bank_transfer_real_time_
request_id
The request_id value returned from a
previous request for the ics_bank_
transfer_real_time service. Send this field
instead of the bank_transfer_request_id
field.
Bank Transfer
Refund (R)
String (26)
bank_transfer_real_time_
trans_ref_no
Unique identifier for the order submitted to
Global Collect.
Bank Transfer
Refund (R for
standalone
refunds)
String (60)
Note If you do not include this field in a
refund request, CyberSource will generate
the value.
Global Payment Service Developer Guide | March 2015
80
Chapter 5
Real-Time Bank Transfers Using the SCMP API
Request and Reply Examples
Real-Time Bank Transfer Request
Example 23
Real-Time Bank Transfer Request
ics_applications=ics_bank_transfer_real_time
bank_country=NL
bank_transfer_real_time_type=12
bill_address1=1276VicenteDRAptH
bill_city=Eindhoven
bill_country=NL
bill_zip=5600 PB
currency=EUR
customer_email=jsmith@example.com
customer_firstname =john
customer_lastname=smith
customer_language=nl
grand_total_amount=10.00
merchant_id=demo
merchant_ref_number=C299792458C
Real-Time Bank Transfer Reply
Example 24
Real-Time Bank Transfer Reply
request_id=0305782650000167905080
merchant_ref_number=C299792458C
currency=EUR
ics_rcode=1
ics_rflag=SOK
ics_rmsg=Request was processed successfully.
bank_transfer_real_time_trans_ref_no=0308014624
bank_transfer_real_time_amount=10.00
bank_transfer_real_time_time=2012-01-22T170910Z
bank_transfer_real_time_payment_reference=106157214759
bank_transfer_real_time_rcode=1
bank_transfer_real_time_rflag=SOK
bank_transfer_real_time_rmsg=Request was processed successfully.
bank_transfer_real_time_form_method=GET
Global Payment Service Developer Guide | March 2015
81
Chapter 5
Real-Time Bank Transfers Using the SCMP API
Real-Time Bank Transfer Refund Request
Example 25
Real-Time Bank Transfer Refund Request
bank_account_name=nette
bank_account_number=30004 00819 00010023116 61
bank_check_digit=12
bank_city=Paris
bank_code=0440339464
bank_country=France
bank_name=BNP Paribas
bank_swiftcode=BNPA FR PP PLZ
bank_transfer_real_time_request_id=4024360119000179087451
bill_address1=1ere Avenue
bill_address2=14eme Rue BP 148
bill_city=Carros Cedex
bill_country=FR
bill_zip=06513
branch_code=1234567890ABCDE
currency=EUR
customer_email=antoinette@example.com
customer_firstname=antoi
customer_lastname=nette
customer_phone=33-04-9208-2846
ics_applications=ics_bank_transfer_refund
merchant_id=demo
merchant_ref_number=C299792458C
offer0=product_code:electronic_software^merchant_product_
sku:testdl^quantity:1^amount:1.56^tax_amount:0.25^product_
name:PName1^offer_id:0
ship_to_address1=37 se main street
ship_to_address2=suite 2-5A
ship_to_city=bloomington
ship_to_country=US
ship_to_state=indiana
ship_to_zip=47404
Global Payment Service Developer Guide | March 2015
82
Chapter 5
Real-Time Bank Transfers Using the SCMP API
Real-Time Bank Transfer Refund Reply
Example 26
Real-Time Bank Transfer Refund Reply
bank_transfer_refund_amount=1.81
bank_transfer_refund_iban=IE64BOFI30004 00819 00010023116 61
bank_transfer_refund_rcode=1
bank_transfer_refund_rflag=SOK
bank_transfer_refund_rmsg=Request was processed successfully.
bank_transfer_refund_time=2014-06-10T213332Z
bank_transfer_refund_trans_ref_no=2149563030
currency=eur
ics_rcode=1
ics_rflag=SOK
ics_rmsg=Request was processed successfully.
merchant_ref_number=C299792458C
request_id=4024360120420179087451
Global Payment Service Developer Guide | March 2015
83
CHAPTER
Boletos Bancários Using the
Simple Order API
6
Requesting a Boleto Bancário
Use the boletoPaymentService service to request the Boleto Bancário payment service.
See Table 23, page 85, for a list of the fields to use.
In the Boleto Bancário reply, you receive a URL for a form that contains information about
the Boleto Bancário. Display the information in this form to your customer exactly as you
received it so that the customer can easily transcribe it or print it and give it to their bank.
Note
You are responsible for storing the Boleto Bancário form URL. You might want
to present the URL or its contents to the customer if you have to remind them
that their payment is unexpectedly late and that the Boleto Bancário will time
out soon. CyberSource does not store the URL.
API Fields
This section provides detailed information about the Simple Order API fields for the Boleto
Bancário payment service. For information about the data types, see Getting Started with
CyberSource Advanced for the Simple Order API.
Data Type Definitions
For more information about these data types, see the World Wide Web Consortium (W3C)
XML Schema Part 2: DataTypes specification.

Integer—Whole number {..., -3, -2, -1, 0, 1, 2, 3, ...}.

String—Sequence of letters, numbers, spaces, and special characters, such as @
and #.
Global Payment Service Developer Guide | March 2015
84
Chapter 6
Boletos Bancários Using the Simple Order API
Request Fields
The following table describes the fields to use in a request for the boletoPaymentService
service.
Table 23
Request Fields for Boletos Bancários for the Simple Order API
Request Field
Description
Required or
Optional
Data Type
& Length
billTo_firstName
Customer’s first name.
Required
String (60)
billTo_lastName
Customer’s last name.
Required
String (60)
billTo_personalID
Personal identifier. For CyberSource Latin
American Processing, you can use this field
for the Cadastro de Pessoas Fisicas (CPF).
Optional
String (18)
boletoPaymentService_
expirationDate
Expiration date of the Boleto Bancário in
GMT in ISO format: YYYY-MM-DD.
Optional
String (10)
boletoPaymentService_
instruction
Text instructions for the Boleto Bancário.
This field allows you to specify the text that
will be printed in the customer message
field on the Boleto form. The customer
message field is often used to remind the
customer to submit the Boleto promptly.
Optional
String (512)
boletoPaymentService_run
Whether to include boletoPaymentService
in your request. Possible values:
Required
String (50)
Optional
Decimal
(15)
Optional
String (26)
item_#_unitPrice

true: Include the service in your request.

false (default): Do not include the service
in your request.
Per-item price of the product. You must
include either this field or purchaseTotals_
grandTotalAmount in your request. For
more information about items and grand
totals, see Getting Started with
CyberSource Advanced for the Simple
Order API.
This value cannot be negative. You can
include a decimal point (.) in this field, but
you cannot include any other special
characters. The amount will be truncated at
the request level to the correct number of
decimal places.
linkToRequest
Value that links the current request to a
previous authorization request for a debit
card or prepaid card. This value is useful
when using multiple payment methods to
complete an order. For more information
about partial authorizations, see Credit
Card Services Using the Simple Order API.
Global Payment Service Developer Guide | March 2015
85
Chapter 6
Table 23
Boletos Bancários Using the Simple Order API
Request Fields for Boletos Bancários for the Simple Order API (Continued)
Request Field
Description
Required or
Optional
Data Type
& Length
merchantID
Your CyberSource merchant ID.
Required
String (30)
Note When opening your account with
CyberSource, be sure to inform
CyberSource if you plan to use multiple
CyberSource merchant IDs. For example, if
you have separate business units within
your company, each with a separate
CyberSource merchant ID, you must have a
separate processor merchant ID for each
CyberSource merchant ID. For more
information, contact Customer Support.
merchantReferenceCode
Merchant-generated order reference or
tracking number. For more information, see
Getting Started with CyberSource
Advanced for the Simple Order API.
Required
String (50)
purchaseTotals_
grandTotalAmount
Grand total for the order. You must include
either this field or item_#_unitPrice in your
request. For more information, see Getting
Started with CyberSource Advanced for the
Simple Order API.
Required
Decimal
(15)
Reply Fields
The following table describes the fields returned in a reply from boletoPaymentService.
Table 24
Reply Fields for Boletos Bancários for the Simple Order API
Reply Field
Description
Data Type
& Length
boletoPaymentReply_
amount
Total amount of the Boleto Bancário payment.
Decimal
(15)
boletoPaymentReply_
boletoNumber
Boleto Bancário payment number.
String (6)
boletoPaymentReply_
expirationDate
Expiration date of the Boleto Bancário in GMT. On the face of the
Boleto Bancário, the date is in the European format: DD-MM-YYYY.
For this expiration date field, the date is mapped to an ISO format:
YYYY-MM-DD hh:mm:ss.
String (20)
Note There is a space between the date and the time.
boletoPaymentReply_
reasonCode
Numeric value corresponding to the result of the Boleto Bancário
request. See Appendix B, "Reason Codes," on page 155.
Integer (5)
boletoPaymentReply_
reconciliationID
Unique value generated by CyberSource. For more information
about tracking orders, see Getting Started with CyberSource
Advanced for the Simple Order API.
String (60)
Global Payment Service Developer Guide | March 2015
86
Chapter 6
Table 24
Boletos Bancários Using the Simple Order API
Reply Fields for Boletos Bancários for the Simple Order API (Continued)
Reply Field
Description
Data Type
& Length
boletoPaymentReply_
requestDateTime
Time of the Boleto Bancário request in UTC.
Format: YYYY-MM-DDThh:mm:ssZ.
Example: 2007-08-11T22:47:57Z which is August 11, 2007 at
10:47:57 P.M.
The T separates the date and the time. The Z indicates UTC.
Date and
time (20)
boletoPaymentReply_url
URL of the Boleto Bancário form.
String (255)
decision
Summarizes the result of the overall request. Possible values:
String (6)

ACCEPT

ERROR

REJECT
For more information about decision values, see Getting Started
with CyberSource Advanced for the Simple Order API.
invalidField_0…N
Fields in the request that contained invalid data. These reply fields
are included as an aid to software developers only. Do not attempt
to use these fields for end user interaction. For more information
about missing and invalid fields, see Getting Started with
CyberSource Advanced for the Simple Order API.
String (100)
merchantReferenceCode
Order reference or tracking number that you provided in the
request. If you included multi-byte characters in this field in the
request, the returned value might contain corrupted characters. For
more information about tracking orders, see Getting Started with
CyberSource Advanced for the Simple Order API.
String (50)
missingField_0...N
Required fields that were missing from the request. These reply
fields are included as an aid to software developers only. Do not
attempt to use these fields for end user interaction. For more
information about missing and invalid fields, see Getting Started
with CyberSource Advanced for the Simple Order API.
String (100)
purchaseTotals_currency
Currency used for the order. The only possible value is BRL.
String (5)
reasonCode
Numeric value corresponding to the result of the overall request.
See Appendix B, "Reason Codes," on page 155.
Integer (5)
requestID
Identifier for the request. For more information about request
tokens, see Getting Started with CyberSource Advanced for the
Simple Order API.
String (26)
Global Payment Service Developer Guide | March 2015
87
Chapter 6
Boletos Bancários Using the Simple Order API
Examples
Name-Value Pairs: Request
Example 27
Boleto Bancário Request
billTo_firstName=Jane
billTo_lastName=Smith
billTo_personalID=1111
merchantID=okgo
merchantReferenceCode=1234567
item_0_unitPrice=10.00
boletoPaymentService_run=true
boletoPaymentService_instruction=this is a test
boletoPaymentService_expirationDate=2008-11-22
Name-Value Pairs: Reply
Example 28
Boleto Bancário Reply
decision=ACCEPT
reasonCode=100
requestID=12345678901234567890
merchantReferenceCode=1234567
purchaseTotals_currency=BRL
boletoPaymentReply_reasonCode=100
boletoPaymentReply_reconciliationID=12345678
boletoPaymentReply_amount=10.00
boletoPaymentReply_boletoNumber=123456
boletoPaymentReply_expirationDate=2008-11-22 23:59:59
boletoPaymentReply_url=https://www.pagador.com.br/pagador/
reenvia.asp?Id_Transacao=93b5668a-6129-48d5-ad95-76308d997479
Global Payment Service Developer Guide | March 2015
88
Chapter 6
Boletos Bancários Using the Simple Order API
XML: Request
Example 29
Boleto Bancário Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.42">
<billTo>
<firstName>Jane</firstName>
<lastName>Smith</lastName>
<personalID>1111</personalID>
</billTo>
<merchantID>okgo</merchantID>
<merchantReferenceCode>1234567</merchantReferenceCode>
<item id="0"><unitPrice>10.00</unitPrice></item>
<boletoPaymentService run="true">
<instruction>this is a test</instruction>
<expirationDate>2008-11-22</expirationDate>
</boletoPaymentService>
</requestMessage>
XML: Reply
Example 30
Boleto Bancário Reply
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.42">
<c:decision>ACCEPT</c:decision>
<c:reasonCode>100</c:reasonCode>
<c:requestID>12345678901234567890</c:requestID>
<c:merchantReferenceCode>1234567</c:merchantReferenceCode>
<c:purchaseTotals><c:currency>BRL</c:currency></c:purchaseTotals>
<c:boletoPaymentReply>
<c:reasonCode>100</c:reasonCode>
<c:reconciliationID>12345678</c:reconciliationID>
<c:amount>10.00</c:amount>
<c:boletoNumber>123456</c:boletoNumber>
<c:expirationDate>2008-11-22 23:59:59</c:expirationDate>
<c:url>https://www.pagador.com.br/pagador/reenvia.asp?
Id_Transacao=93b5668a-6129-48d5-ad95-76308d997479</c:url>
</c:boletoPaymentReply>
</c:replyMessage>
Global Payment Service Developer Guide | March 2015
89
CHAPTER
7
Boletos Bancários Using the
SCMP API
Requesting a Boleto Bancário
Use the ics_boleto_payment field to request the Boleto Bancário payment service. See
Table 25, page 90, for a list of the fields.
In the Boleto Bancário reply, you receive a URL for a form that contains information about
the Boleto Bancário. Display the information in this form to your customer exactly as you
received it so that the customer can easily transcribe it or print it and give it to their bank.
Note
You are responsible for storing the Boleto Bancário form URL. You might want
to present the URL or its contents to the customer if you have to remind them
that their payment is unexpectedly late and that the Boleto Bancário will time
out soon. CyberSource does not store the URL.
API Fields
This section provides detailed information about the SCMP API fields for the Boleto
Bancário payment service. For information about the data types, see Getting Started with
CyberSource Advanced for the SCMP API.
Request Fields
The following table describes the fields to use in a request for the ics_boleto_payment
service.
Table 25
Request-Level Fields for Boletos Bancários for the SCMP API
Request-Level
Field
Description
Required or
Optional
Data Type
& Length
boleto_payment_
expiration_date
Expiration date of the Boleto Bancário in GMT in
ISO format: YYYY-MM-DD.
Optional
String (10)
Global Payment Service Developer Guide | March 2015
90
Chapter 7
Table 25
Boletos Bancários Using the SCMP API
Request-Level Fields for Boletos Bancários for the SCMP API (Continued)
Request-Level
Field
Description
Required or
Optional
Data Type
& Length
boleto_payment_
instruction
Text instructions for the Boleto Bancário. This field
allows you to specify the text that will be printed in
the customer message field on the Boleto
Bancários form. The customer message field is
often used to remind the customer to submit the
Boleto Bancários promptly.
Optional
String (512)
customer_firstname
Customer’s first name.
Required
String (60)
customer_lastname
Customer’s last name.
Required
String (60)
grand_total_amount
Grand total for the order. You must include either
this field or offer0 and the offer-level field amount.
For more information about offers and grand totals,
see Getting Started with CyberSource Advanced
for the SCMP API.
Required
Decimal
(15)
ics_applications
Service to process for the request. For a Boleto
Bancário request, this value must be ics_boleto_
payment.
Required
String (255)
link_to_request
Value that links the current request to a previous
authorization request for a debit card or prepaid
card. This value is useful when using multiple
payment methods to complete an order. For more
information about partial authorizations, see Credit
Card Services Using the SCMP API.
Optional
String (26)
merchant_id
Your CyberSource merchant ID.
Required
String (30)
Required
String (50)
Note When opening your account with
CyberSource, make sure that you inform
CyberSource if you plan to use multiple
CyberSource merchant IDs. For example, when
you have separate business units within your
company, each with a separate CyberSource
merchant ID, you must have a separate processor
merchant ID for each CyberSource merchant ID.
For more information, contact Customer Support.
merchant_ref_
number
Merchant-generated order reference or tracking
number. For more information about tracking
orders, see Getting Started with CyberSource
Advanced for the SCMP API.
Global Payment Service Developer Guide | March 2015
91
Chapter 7
Table 25
Boletos Bancários Using the SCMP API
Request-Level Fields for Boletos Bancários for the SCMP API (Continued)
Request-Level
Field
Description
Required or
Optional
Data Type
& Length
offerN: amount
Per-item price of the product. You must include this
field, the offer0 field, or the request-level field
grand_total_amount in your request. This value
cannot be negative. For more information about
offers and grand totals, see Getting Started with
CyberSource Advanced for the SCMP API.
Optional
Decimal
(15)
Optional
String (18)
You can include a decimal point (.) in this field, but
you cannot include any other special characters.
The amount will be truncated at the request level to
the correct number of decimal places.
personal_id
Personal identifier. For CyberSource Latin
American Processing, you can use this field for the
Cadastro de Pessoas Fisicas (CPF).
Reply Fields
The following table describes the fields returned in a reply from the ics_boleto_payment
service request.
Table 26
Reply Fields for Boletos Bancários for the SCMP API
Reply Field
Description
Data Type
& Length
boleto_payment_amount
Total amount of the Boleto Bancário payment.
Decimal
(15)
boleto_payment_boleto_
number
Boleto Bancário payment number.
String (6)
boleto_payment_expiration_
date
Expiration date of the Boleto Bancário in GMT. On the face of the
Boleto Bancário, the date is in the European format: DD-MM-YYYY.
For this expiration date field, the date is mapped to an ISO format:
YYYY-MM-DD hh:mm:ss.
String (20)
Note There is a space between the date and the time.
boleto_payment_rcode
One-digit code that indicates whether the ics_boleto_payment
request was successful:

-1: An error occurred

0: The request was declined

1: The request was successful
Integer (1)
For more information about handling replies, see Getting Started
with CyberSource Advanced for the SCMP API.
boleto_payment_request_
time
Time of the Boleto Bancário request in UTC. For more information
about the format, see the data type information in Getting Started
with CyberSource Advanced for the SCMP API.
Global Payment Service Developer Guide | March 2015
Date and
time (20)
92
Chapter 7
Table 26
Boletos Bancários Using the SCMP API
Reply Fields for Boletos Bancários for the SCMP API (Continued)
Reply Field
Description
Data Type
& Length
boleto_payment_rflag
One-word description of the result of the ics_boleto_payment
request. See "Reply Flags," page 94, and for more information, see
Getting Started with CyberSource Advanced for the SCMP API.
String (50)
boleto_payment_rmsg
Message that explains the reply flag boleto_payment_rflag. Do
not display this message to the customer and do not use this field
to write an error handler. For more information, see Getting Started
with CyberSource Advanced for the SCMP API.
String (255)
boleto_payment_trans_ref_
no
Unique value generated by CyberSource. For more information,
see Getting Started with CyberSource Advanced for the SCMP API.
String (60)
boleto_payment_url
URL of the Boleto Bancário form.
String (255)
currency
Currency used for the order. The only possible value is BRL.
String (5)
ics_rcode
One-digit code that indicates whether the entire request was
successful:
Integer (1)

-1: An error occurred

0: The request was declined

1: The request was successful
For more information, see Getting Started with CyberSource
Advanced for the SCMP API.
ics_rflag
One-word description of the result of the entire request. See "Reply
Flags," page 94, and for more information, see Getting Started with
CyberSource Advanced for the SCMP API.
String (50)
ics_rmsg
Message that explains the reply flag ics_rflag. Do not display this
message to the customer, and do not use this field to write an error
handler. For more information, see Getting Started with
CyberSource Advanced for the SCMP API.
String (255)
merchant_ref_number
Order reference or tracking number that you provided in the
request. If you included multi-byte characters in this field in the
request, the returned value might contain corrupted characters. For
more information about tracking orders, see Getting Started with
CyberSource Advanced for the SCMP API.
String (50)
request_id
Unique identifier generated by CyberSource for the transaction. For
more information about request IDs, see Getting Started with
CyberSource Advanced for the SCMP API.
String (26)
Global Payment Service Developer Guide | March 2015
93
Chapter 7
Boletos Bancários Using the SCMP API
Reply Flags
The following table describes the reply flags for the ics_boleto_payment service request.
Table 27
Reply Flags for Boletos Bancários for the SCMP API
Reply Flag
Description
DBOLETODECLINED
When CyberSource sent a Boleto Bancário request to CyberSource
Latin American Processing, the processor returned an error to
CyberSource.
DINVALIDDATA
Data provided is not consistent with the request.
DMISSINGFIELD
The request is missing a required field.
ESYSTEM
System error. You must design your transaction management system
to correctly handle CyberSource system errors. Depending on the
payment processor handling the transaction, the error may indicate a
valid CyberSource system error or a processor rejection caused by
invalid data. In either case, CyberSource recommends that you do not
design your system to endlessly retry sending a transaction. For
important information on handling system errors and retries, see the
SDK for your CyberSource client.
ETIMEOUT
The request timed out.
SOK
The transaction was successful.
Global Payment Service Developer Guide | March 2015
94
Chapter 7
Boletos Bancários Using the SCMP API
Request and Reply Examples
Request
Example 31
Boleto Bancário Request
bill_city=Louisville
bill_country=BRA
currency=BRL
customer_firstname=Joe
customer_lastname=Doe
ics_applications=ics_boleto_payment
merchant_id=philpot2
merchant_ref_number=1234567
offer0=product_code:electronic_software^merchant_product_
sku:testdl^quantity:1^amount:1.18^tax_amount:0.00^product_name:Clorox
Wipes^offer_id:0
boleto_payment_instruction=my test
boleto_payment_expiration_date=2008-11-22
personal_id=1111
Reply
Example 32
Boleto Bancário Reply
boleto_payment_url=https://www.pagador.com.br/pagador/reenvia.asp?Id_
Transacao=93b5668a-6129-48d5-ad95-76308d997479
ics_rcode=1
ics_rmsg=Request was processed successfully.
request_id=2259925521130170394179
boleto_payment_rcode=1
boleto_payment_boleto_number=100000
boleto_payment_rmsg=Request was processed successfully.
boleto_payment_trans_ref_no=10992551
ics_rflag=SOK
boleto_payment_rflag=SOK
merchant_ref_number=1654291
boleto_payment_expiration_date=2008-11-22 23:59:59
Global Payment Service Developer Guide | March 2015
95
CHAPTER
Reports for Boletos
Bancários
8
Boleto Bancário Unfulfilled Report
The Boleto Bancário Unfulfilled Report provides information about Boleto Bancário
transactions that have been issued but not fulfilled. The reasons for an unfulfilled Boleto
Bancário are:

The customer has not submitted the Boleto Bancário.

The Boleto Bancário is still in the Brazilian clearing system.
A transaction continues to be included in the Boleto Bancário Unfulfilled Report every day
until:

CyberSource Latin American Processing confirms that the transaction has been
funded.

The Boleto Bancário expires.
To view the Boleto Bancário Unfulfilled Report, you must subscribe to it on the Business
Center.
Viewing and Downloading Reports
There are two ways to view and download Boleto Bancário Unfulfilled reports:

Through an API
See the first chapter in the Reporting Developer Guide, which is available at the
Support Center, for information about requesting a report with a client application.

On the CyberSource Business Center
For information about downloading the Boleto Bancário Unfulfilled Report from the
Business Center, see the Business Center help topic “Downloading Detail Reports”.
Global Payment Service Developer Guide | March 2015
96
Chapter 8
Reports for Boletos Bancários
To view and download reports:
Step 1
Navigate to the Boleto Bancário Unfulfilled Report.
Step 2
Click I need help with this page.
A help topic for the Boleto Bancário Unfulfilled Report opens.
Step 3
In the help topic, click Downloading Reports.
The “Downloading Detail Reports” topic opens. The Boleto Bancário Unfulfilled Report is a
detail report, and you can download it the same way that you download other reports.
For additional information, see the first chapter in the Reporting Developer Guide, which is
available at the Support Center.
XML Conventions and Data Types
Syntax for Report Declarations
A report declaration has this syntax:
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE Report SYSTEM URIreference>
<Report Name=CDATA
Version=NMTOKEN
xmlns=CDATA
MerchantID=CDATA
ReportDate=CDATA>
The value of the URIreference tag is the same as the value of the xmlns tag. Whether
you are operating in test or live mode, the namespace always refers to ebctest instead
of ebc.
Global Payment Service Developer Guide | March 2015
97
Chapter 8
Reports for Boletos Bancários
Syntax for Element Declarations
An element declaration has this syntax:
<Sample Attribute=CDATA>
(Element)
(ChoiceOne) | (ChoiceTwo)
(ComplexElement)
(RequiredRecurringElement)+
(OptionalElement)?
(OptionalRecurringElement)*
</Sample>
The DTDs for the reports can use syntax with the ?, +, or * character inside the
parentheses.
Table 28
Conventions for Element Declarations
Convention
Description
<Sample>
Parent of the subsequent elements.
Attribute=CDATA
Name of the attribute followed by the XML data format for
the attribute.
(Element)
Required element. Must appear only once.
(ChoiceOne) | (ChoiceTwo)
Element <ChoiceOne> or <ChoiceTwo> but not both.
(ComplexElement)
Element with one or more children.
(RequiredRecurringElement)+
Required element. Can appear one or more times.
(OptionalElement)?
Optional element. Can appear once or be omitted.
(OptionalRecurringElement)*
Optional element. Can appear zero or more times.
Data Types and Lengths
In each description, the data length indicates the maximum length for that data type.
Table 29
Data Types for XML Reports
Data Type
Description
Alphanumeric
String containing letters, numbers, and special characters such as @, #, and %.
All text uses UTF-8 character encoding.
Boolean
Single character: T for true or F for false.
Amount
Can include a decimal point.
Date
YYYY-MM-DD where:

YYYY is the four-digit year

MM is the two-digit month

DD is the two-digit day
The hyphens are included in a Date value.
Global Payment Service Developer Guide | March 2015
98
Chapter 8
Table 29
Reports for Boletos Bancários
Data Types for XML Reports (Continued)
Data Type
Description
DateTime
YYYY-MM-DDTHH:MM:SS[+ | -]HH:MM where:

YYYY is the four-digit year

MM is the two-digit month

DD is the two-digit day

T separates the date information from the time information

HH is the two-digit hours

MM is the two-digit minutes

SS is the two-digit seconds

[+ | -]HH:MM is the time zone’s offset from GMT (Greenwich Mean Time)
The hyphens are included in a DateTime value.
Numeric
String containing numbers.
Elements in the Report
<Report>
The <Report> element is the root of the report.
Syntax
<?xml version="1.0" encoding="utf-8" ?>
<Report Name=CDATA
Version=CDATA
xmlns=CDATA
MerchantID=CDATA
ReportDate=CDATA>
(Summary)
(TransactionDetail)?
</Report>
Global Payment Service Developer Guide | March 2015
99
Chapter 8
Reports for Boletos Bancários
Attributes
Table 30
Attributes of <Report> in the Boleto Bancário Unfulfilled Report
Attribute Name
Description
Data Type &
Length
Name
Name of the report. This value is always Boleto
Bancário Unfulfilled Report.
Alphanumeric (100)
Version
Version number of the report.
Numeric (10)
xmlns
XML namespace for the report. This value is
always https://ebc.cybersource.com/
ebc/reports/dtd/bbur.dtd.
Alphanumeric (100)
MerchantID
CyberSource merchant ID.
Alphanumeric (30)
ReportDate
Date the report was generated.
DateTime (25)
Child Elements
Table 31
Child Elements of <Report> in the Boleto Bancário Unfulfilled Report
Element Name
Description
<Summary>
Summary of the transaction information for each range. See
"<Summary>," page 101.
<TransactionDetail>
Information about all of the unfunded transactions that have occurred
during the previous 3 to 180 days. See "<TransactionDetail>,"
page 104.
Example
Example 33
<Report> Element
<?xml version="1.0" encoding="utf-8" ?>
<Report Name="BoletoBancarioUnfulfilledReport"
Version="1.0"
xmlns=https://ebc.cybersource.com/ebc/reports/dtd/bbur.dtd
MerchantID="exampleMerchant"
ReportDate="2008-01-24T08:00:00-08:00">
<Summary>
...
</Summary>
<TransactionDetail>
...
</TransactionDetail>
</Report>
Global Payment Service Developer Guide | March 2015
100
Chapter 8
Reports for Boletos Bancários
<Summary>
The <Summary> element contains a summary of the transaction information for each
range:

3 days outstanding

4 days outstanding

5 to 7 days outstanding

8 to 14 days outstanding

15 to 30 days outstanding

31 to 60 days outstanding

61 to 90 days outstanding

91 to 180 days outstanding

3 to 180 days outstanding
Syntax
<Summary>
(Range)*
</Summary>
Child Element
Table 32
Child Element of <Summary> in the Boleto Bancário Unfulfilled Report
Element Name
Description
<Range>
Summary of the transaction information for one range. See
"<Range>," page 103.
Example
Example 34
<Summary> Element
<Summary>
<Range DaysOutstandingStart="3"
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="3"
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="4"
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="4"
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
DaysOutstandingEnd="3" CurrencyCode="BRL">
DaysOutstandingEnd="3" CurrencyCode="USD">
DaysOutstandingEnd="4" CurrencyCode="BRL">
DaysOutstandingEnd="4" CurrencyCode="USD">
Global Payment Service Developer Guide | March 2015
101
Chapter 8
Example 34
Reports for Boletos Bancários
<Summary> Element (Continued)
<Range DaysOutstandingStart="5" DaysOutstandingEnd=" 7" CurrencyCode="BRL">
<Count>2</Count>
<NetAmount>121.38</NetAmount>
</Range>
<Range DaysOutstandingStart="5" DaysOutstandingEnd=" 7" CurrencyCode="USD">
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="8" DaysOutstandingEnd="14" CurrencyCode="BRL">
<Count>8</Count>
<NetAmount>823.40</NetAmount>
</Range>
<Range DaysOutstandingStart="8" DaysOutstandingEnd="14" CurrencyCode="USD">
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="15" DaysOutstandingEnd="30" CurrencyCode="BRL">
<Count>21</Count>
<NetAmount>2030.11</NetAmount>
</Range>
<Range DaysOutstandingStart="15" DaysOutstandingEnd="30" CurrencyCode="USD">
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="31" DaysOutstandingEnd="60" CurrencyCode="BRL">
<Count>7</Count>
<NetAmount>777.17</NetAmount>
</Range>
<Range DaysOutstandingStart="31" DaysOutstandingEnd="60" CurrencyCode="USD">
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="61" DaysOutstandingEnd="90" CurrencyCode="BRL">
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="61" DaysOutstandingEnd="90" CurrencyCode="USD">
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="91 DaysOutstandingEnd="180" CurrencyCode="BRL">
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="91 DaysOutstandingEnd="180" CurrencyCode="USD">
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
Global Payment Service Developer Guide | March 2015
102
Chapter 8
Example 34
Reports for Boletos Bancários
<Summary> Element (Continued)
<Range DaysOutstandingStart="3" DaysOutstandingEnd="180" CurrencyCode="BRL">
<Count>38</Count>
<NetAmount>3752.06</NetAmount>
</Range>
<Range DaysOutstandingStart="3" DaysOutstandingEnd="180" CurrencyCode="USD">
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
</Summary>
<Range>
The <Range> element contains a summary of the transaction information for one currency
in one range.
Syntax
<Range DaysOutstandingStart=CDATA
DaysOutstandingEnd=CDATA
CurrencyCode=CDATA>
(Count)
(NetAmount)
</Range>
Table 33
Attributes of <Range> in the Boleto Bancário Unfulfilled Report
Attribute Name
Description
Data Type &
Length
DaysOutstandingStart
Start of the range of the number of days
outstanding. For example, for the range of 5
to 7 days outstanding, the start of the range is
5.
Alphanumeric (4)
DaysOutstandingEnd
End of the range of the number of days
outstanding. For example, for the range of 5
to 7 days outstanding, the end of the range is
7.
Alphanumeric (4)
CurrencyCode
Currency code. Possible value:
Alphanumeric (5)

BRL
Global Payment Service Developer Guide | March 2015
103
Chapter 8
Reports for Boletos Bancários
Child Elements
Table 34
Child Elements of <Range> in the Boleto Bancário Unfulfilled Report
Element Name
Description
Count
Number of transactions that await funding in the currency specified
by CurrencyCode and in the range specified by
DaysOutstandingStart and DaysOutstandingEnd.
NetAmount
Sum of transactions that await funding in the currency specified by
CurrencyCode and in the range specified by
DaysOutstandingStart and DaysOutstandingEnd.
Example
Example 35
<Range> Element
<Range DaysOutstandingStart="3" DaysOutstandingEnd="3" CurrencyCode="CNY">
<Count>2</Count>
<NetAmount>121.38</NetAmount>
</Range>
<TransactionDetail>
The <TransactionDetail> element contains information about all of the unfunded
transactions that have occurred during the previous 3 to 180 days.
Syntax
<TransactionDetail>
(Transaction)*
</TransactionDetail>
Child Elements
Table 35
Child Element of <TransactionDetail> in the Boleto Bancário
Unfulfilled Report
Element Name
Description
<Transaction>
Information about an unfunded transaction. See "<Transaction>,"
page 105.
Global Payment Service Developer Guide | March 2015
104
Chapter 8
Reports for Boletos Bancários
Example
Example 36
<TransactionDetail> Element
<TransactionDetail>
<Transaction>
...
</Transaction>
</TransactionDetail>
<Transaction>
The <Transaction> element contains information about an unfunded transaction.
Syntax
<Transaction Processor=CDATA
DaysOutstanding=CDATA
MerchantID=CDATA
OriginalTransactionDate=CDATA
RequestID=CDATA
TransactionReferenceNumber=CDATA
MerchantReferenceNumber=CDATA
Amount=CDATA
CurrencyCode=CDATA
EventType=CDATA
BoletoNumber=CDATA
</Transaction>
Table 36
Attributes of <Transaction> in the Boleto Bancário
Unfulfilled Report
Attribute Name
Description
Data Type &
Length
Processor
Payment processor used for the
transaction. This value is always
Alphanumeric (40)
brazilboleto: braspag.
DaysOutstanding
Number of days since the transaction was
initiated.
Alphanumeric (4)
MerchantID
CyberSource merchant ID.
Alphanumeric (30)
OriginalTransactionDate
Date that the original payment transaction
was initiated.
DateTime (25)
RequestID
Unique identifier generated by
CyberSource for the transaction. For more
information about request IDs, see Getting
Started with CyberSource Advanced for the
Simple Order API or Getting Started with
CyberSource Advanced for the SCMP API.
Numeric (26)
Global Payment Service Developer Guide | March 2015
105
Chapter 8
Table 36
Reports for Boletos Bancários
Attributes of <Transaction> in the Boleto Bancário
Unfulfilled Report (Continued)
Attribute Name
Description
Data Type &
Length
TransactionReference
Number
CyberSource-generated reference or
tracking number for the transaction. You
can use this value to reconcile your
CyberSource reports with your processor
reports. This value corresponds to:
Alphanumeric (60)

<service>_reconciliationID for the
Simple Order API.

<service>_trans_ref_no for the SCMP
API.
For more information about tracking orders,
see Getting Started with CyberSource
Advanced for the Simple Order API or
Getting Started with CyberSource
Advanced for the SCMP API.
MerchantReference
Number
Merchant-generated reference or tracking
number for the transaction. You can use
this value to perform searches in the
CyberSource Business Center. This value
corresponds to:

merchantReferenceCode for the
Simple Order API.

merchant_ref_number for the SCMP
API.
Alphanumeric (50)
See the information about tracking orders,
see Getting Started with CyberSource
Advanced for the Simple Order API or
Getting Started with CyberSource
Advanced for the SCMP API.
Amount
Amount of the transaction. For refunds, the
amount is negative.
Amount (19)
CurrencyCode
Currency code used for the transaction.
Possible value:
Alphanumeric (5)

Global Payment Service Developer Guide | March 2015
BRL
106
Chapter 8
Table 36
Reports for Boletos Bancários
Attributes of <Transaction> in the Boleto Bancário
Unfulfilled Report (Continued)
Attribute Name
Description
Data Type &
Length
EventType
Type of event that occurred for the
transaction. Possible values:
Alphanumeric (20)
BoletoNumber

Expired: The Boleto Bancário has
expired and will not be accepted for
payment by Brazilian financial
institutions.

Fulfilled: The bank issuing the Boleto
Bancário has received funds and
deposited them into your account.

Pending Fulfillment: The Boleto Bancário
was issued, but the customer has not
submitted it yet, or it is still in the
Brazilian clearing system.
The number identifying the Boleto Bancário
payment involved in the transaction.
Alphanumeric (15)
Example
Example 37
<Transaction> Element
<Transaction Processor="brazilboleto"
DaysOutstanding="3"
MerchantID="123456789"
OriginalTransactionDate="2009-01-11T10:45:00-08:00"
RequestID="912342343468"
TransactionReferenceNumber="123456"
MerchantReferenceNumber="2884554"
Amount="75,00"
CurrencyCode="BRL"
EventType="Fulfilled"
BoletoNumber="987654">
</Transaction>
Global Payment Service Developer Guide | March 2015
107
Chapter 8
Reports for Boletos Bancários
DTD
<!ELEMENT Report (Summary, TransactionDetail)>
<!ATTLIST Report Name CDATA #REQUIRED
Version NMTOKEN #REQUIRED
xmlns CDATA #REQUIRED
MerchantID CDATA #REQUIRED
ReportDate CDATA #REQUIRED>
<!ELEMENT Summary (Range*)>
<!ELEMENT Range (Count, NetAmount)>
<!ATTLIST Range DaysOutStandingStart CDATA #REQUIRED
DaysOutStandingEnd CDATA #REQUIRED
CurrencyCode CDATA #REQUIRED>
<!ELEMENT Count (#PCDATA)>
<!ELEMENT NetAmount (#PCDATA)>
<!ELEMENT TransactionDetail (Transaction*)>
<!ELEMENT Transaction EMPTY>
<!ATTLIST Transaction Processor CDATA #REQUIRED
DaysOutstanding CDATA #REQUIRED
MerchantID CDATA #REQUIRED
OriginalTransactionDate CDATA #REQUIRED
RequestID CDATA #REQUIRED
TransactionReferenceNumber CDATA #REQUIRED
MerchantReferenceNumber CDATA #REQUIRED
Amount CDATA #REQUIRED
CurrencyCode CDATA #REQUIRED
EventType CDATA #REQUIRED
BoletoNumber CDATA #REQUIRED>
Global Payment Service Developer Guide | March 2015
108
Chapter 8
Reports for Boletos Bancários
Example
This report example consists of the following unfulfilled transactions:

One payment totalling 1.20 BRL, 3 days outstanding

Five payments totalling 6.00 BRL, 5-7 days outstanding

Six payments totalling 7.20 BRL, 3-180 days outstanding
These transactions are included in the following ranges in the <Summary> section:

3 days outstanding

5 to 7 days outstanding

3 to 14 days outstanding
Example 38
Unfulfilled Transactions
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE Report SYSTEM "https://ebctest.cybersource.com/ebctest/reports/
dtd/bbur.dtd">
<Report Name="BoletoBancarioUnfulfilledReport"
Version="1.0"
xmlns="https://ebctest.cybersource.com/ebctest/reports/dtd/bbur.dtd"
MerchantID="examplemerchant"
ReportDate="2008-01-24T08:00:00-08:00">
<Summary>
<Range DaysOutstandingStart="3"
DaysOutstandingEnd="3"
CurrencyCode="BRL">
<Count>1</Count>
<NetAmount>1.20</NetAmount>
</Range>
<Range DaysOutstandingStart="4"
DaysOutstandingEnd="4"
CurrencyCode="BRL">
<Count>0</Count>
<NetAmount>0.00</NetAmount>
</Range>
<Range DaysOutstandingStart="5"
DaysOutstandingEnd="7"
CurrencyCode="BRL">
<Count>5</Count>
<NetAmount>6.00</NetAmount>
</Range>
<Range DaysOutstandingStart="8"
DaysOutstandingEnd="14"
CurrencyCode="BRL">
<Count>6</Count>
<NetAmount>7.20</NetAmount>
Global Payment Service Developer Guide | March 2015
109
Chapter 8
Reports for Boletos Bancários
</Range>
</Summary>
<TransactionDetail>
<Transaction Processor="brazilboleto"
DaysOutstanding="3"
MerchantID="examplemerchant"
OriginalTransactionDate="2008-01-22T00:14:40-08:00"
RequestID="2009608779023232235878"
TransactionReferenceNumber="20080122_1684_608779023232235878"
MerchantReferenceNumber="1234567890"
Amount="1.20"
CurrencyCode="BRL"
EventType="Pending Fulfillment"
BoletoNumber="321654851"/>
<Transaction Processor="brazilboleto"
DaysOutstanding="5"
MerchantID="examplemerchant"
OriginalTransactionDate="2008-01-20T02:38:24-08:00"
RequestID="2007967037043232235878"
TransactionReferenceNumber="20080120_1684_967037043232235878"
MerchantReferenceNumber="1234567891"
Amount="1.20"
CurrencyCode="BRL"
EventType="Pending Fulfillment"
BoletoNumber="321564133"/>
<Transaction Processor="brazilboleto"
DaysOutstanding="5"
MerchantID="examplemerchant"
OriginalTransactionDate="2008-01-20T02:38:24-08:00"
RequestID="2007967037043232235878"
TransactionReferenceNumber="20080120_1684_967037043232235878"
MerchantReferenceNumber="1234567892"
Amount="1.20"
CurrencyCode="BRL"
EventType="Pending Fulfillment"
BoletoNumber="854523221"/>
<Transaction Processor="brazilboleto"
DaysOutstanding="6"
MerchantID="examplemerchant"
OriginalTransactionDate="2008-01-20T02:38:24-08:00"
RequestID="2007967037043232235878"
TransactionReferenceNumber="20080120_1684_967037043232235878"
MerchantReferenceNumber="1234567893"
Amount="1.20"
CurrencyCode="BRL"
EventType="Pending Fulfillment"
BoletoNumber="255587512"/>
<Transaction Processor="brazilboleto"
DaysOutstanding="7"
MerchantID="examplemerchant"
OriginalTransactionDate="2008-01-20T02:38:24-08:00"
RequestID="2007967037043232235878"
TransactionReferenceNumber="20080120_1684_967037043232235878"
Global Payment Service Developer Guide | March 2015
110
Chapter 8
Reports for Boletos Bancários
MerchantReferenceNumber="1234567894"
Amount="1.20"
CurrencyCode="BRL"
EventType="Pending Fulfillment"
BoletoNumber="265845654"/>
<Transaction Processor="brazilboleto"
DaysOutstanding="7"
MerchantID="examplemerchant"
OriginalTransactionDate="2008-01-20T02:38:24-08:00"
RequestID="2007967037043232235878"
TransactionReferenceNumber="20080120_1684_967037043232235878"
MerchantReferenceNumber="1234567895"
Amount="1.20"
CurrencyCode="BRL"
EventType="Pending Fulfillment"
BoletoNumber="652325456"/>
</TransactionDetail>
</Report>
Global Payment Service Developer Guide | March 2015
111
Chapter 8
Reports for Boletos Bancários
Single Transaction Report
Version 1.4 of the Single Transaction Report is supported for Boletos Bancários. It is
described in the Reporting Developer Guide. The On-Demand Single Transaction Report
provides you with the status of the transaction while the transaction is occurring.
Example 39
Query for a Single Transaction
<form action="https://ebc.cybersource.com/ebc/Query" method="POST">
<table>
<tr>
<td>merchantID</td>
<td><input type="text" name="merchantID" value="nwtest1"></td>
</tr>
<tr>
<td>type</td>
<td><input type="text" name="type" value="transaction"></td>
</tr>
<tr>
<td>subtype</td>
<td><input type="text" name="subtype" value="transactionDetail"></td>
</tr>
<tr>
<td>requestID</td>
<td><input type="text" name="requestID" value="1999370597170167905049"></td>
</tr>
<tr>
<td>versionNumber</td>
<td><input type="text" name="versionNumber" value="1.4"></td>
</tr>
<tr>
<td></td>
<td><input type="reset">
<input type="submit" value="Submit"></input></td>
</tr>
</table>
</form>
Global Payment Service Developer Guide | March 2015
112
Chapter 8
Example 40
Reports for Boletos Bancários
Single Transaction Report
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE Report (View Source for full doctype...)>
<Report xmlns="https://ebctest.cybersource.com/ebctest/reports/dtd/tdr_1_4.dtd"
Name="Transaction Detail"
Version="1.4"
MerchantID="nwtest1"
ReportStartDate="2008-01-09T19:50:59-08:00"
ReportEndDate="2008-01-09T19:50:59-08:00">
<Requests>
<Request MerchantReferenceNumber="1234567890"
RequestDate="2008-09-10T14:00:08-08:00"
RequestID="1999370597170167905049"
SubscriptionID=""
Source="SCMP API"
TransactionReferenceNumber="0001094522"
PredecessorRequestID=”7904567221330010160804”>
<BillTo>
<FirstName>Jane</FirstName>
<LastName>Smith</LastName>
<Address1>1295 Charleston Road</Address1>
<Address2>Suite 2</Address2>
<City>Mountain View</City>
<State>CA</State>
<Zip>94043</Zip>
<Email />
<Country>US</Country>
</BillTo>
<ShipTo>
<LastName>Smith</LastName>
<Address1>1295 Charleston Road</Address1>
<Address2>Suite 2</Address2>
<City>Mountain View</City>
<State>CA</State>
<Zip>94043</Zip>
<Country>US</Country>
</ShipTo>
<PaymentMethod>
<Card>
<AccountSuffix />
<ExpirationMonth />
<ExpirationYear />
<CardType>Brazil Bank Transfer</CardType>
<BoletoNumber>12345</BoletoNumber>
</Card>
</PaymentMethod>
Global Payment Service Developer Guide | March 2015
113
Chapter 8
Example 40
Reports for Boletos Bancários
Single Transaction Report (Continued)
<LineItems>
<LineItem Number="0">
<FulfillmentType />
<Quantity>1</Quantity>
<UnitPrice>1.56</UnitPrice>
<TaxAmount>0.25</TaxAmount>
<MerchantProductSKU>testdl</MerchantProductSKU>
<ProductName>PName1</ProductName>
<ProductCode>electronic_software</ProductCode>
</LineItem>
</LineItems>
<ApplicationReplies>
<ApplicationReply Name="ics_boleto_payment">
<RCode>1</RCode>
<RFlag>SOK</RFlag>
<RMsg>Request was processed successfully.</RMsg>
</ApplicationReply>
</ApplicationReplies>
<PaymentData>
<PaymentProcessor>payeasecn</PaymentProcessor>
<Amount>1.81</Amount>
<CurrencyCode>BRL</CurrencyCode>
<TotalTaxAmount>0.25</TotalTaxAmount>
<EventType>Fulfilled</EventType>
<NumberOfInstallments>5</NumberOfInstallments>
</PaymentData>
</Request>
</Requests>
</Report>
Global Payment Service Developer Guide | March 2015
114
CHAPTER
Direct Debits and Direct
Debit Refunds Using the
Simple Order API
Important
9
Our processing partner requires us to pre-populate their fields to show that the
mandate has been signed and dated. The MANDATEDATE field is populated
with the system date, the MANDATEPLACE field is populated with the
customer city, and the MANDATESIGNED indicator is set to 1. These fields are
for future use and will support e-mandates.
Requesting Direct Debits
Important
Note
From August 1, 2016, for euro countries and from October 31, 2016, for noneuro countries, the IBAN must be included in each request. If you provide a
BBAN it will be converted to an IBAN; this conversion process will continue only
until August 1, 2016.
The bank SWIFT code, a unique address of the bank, does not have to be
included in each request; however, CyberSource strongly recommends
including this code in the request when the IBAN is included in the request.
To request a direct debit, set the directDebitService_run field to true. See Table 37,
page 118, for the fields to use when requesting the service. For an example Direct Debit
request, see page 128.
When requesting a direct debit, you may not request any of the other ICS services except
Tax Calculation. For more information about the service, see Tax Calculation Service
Using the Simple Order API.
When you take an order that uses a direct debit, you must gather the customer’s billing
and bank account information. For most countries, CyberSource accepts either the
traditional bank account information or the account’s IBAN. The traditional bank account
information and the corresponding API fields you need to provide vary by country. Contact
CyberSource Customer Support for required country-specific bank account information.
Global Payment Service Developer Guide | March 2015
115
Chapter 9
Direct Debits and Direct Debit Refunds Using the Simple Order API
CyberSource validates the format of the bank account number before processing the
direct debit. If the account number does not pass the validation check, CyberSource
rejects the request with a reasonCode=244. CyberSource recommends that you then
confirm the customer entered the number correctly, and if it was incorrect, request the
refund again with the correct number.
Requesting Direct Debit Refunds
Important
From August 1, 2016, for euro countries and from October 31, 2016, for noneuro countries, the IBAN must be included in each request. If you provide a
BBAN it will be converted to an IBAN; this conversion process will continue only
until August 1, 2016.
There are two types of direct debit refunds: follow-on refunds and stand-alone refunds. A
follow-on refund uses information from a previous direct debit. A stand-alone refund does
not depend on a previous transaction.
A follow-on refund must occur within 60 of the request for the direct debit. When the time
limit for a follow-on refund expires, the only kind of refund you can perform is a standalone refund.
To request a direct debit refund:

Set the directDebitRefundService_run field to true.

Do not request any other ICS services except Tax Calculation, which is optional. For
more information about this service, see Tax Calculation Service Using the Simple
Order API.

Send the fields required for a direct debit refund request as described in Table 37,
page 118. For a follow-on refund, the fields and values must match the fields and
values you sent in the original direct debit request.

For a stand-alone refund, the directDebitRefundService_directDebitRequestID
field is optional. See page 129.

For a follow-on refund, include the directDebitRefundService_
directDebitRequestID field with the request ID from the direct debit reply is required.
See page 130.

The easiest way to implement direct debit refunds is to always send the request ID
from the original direct debit with every direct debit refund request.

CyberSource recommends that when you request a refund, you use the same value
for merchantReferenceCode that you used for the direct debit. This makes it easier
Global Payment Service Developer Guide | March 2015
116
Chapter 9
Direct Debits and Direct Debit Refunds Using the Simple Order API
for you to link the refund to the original direct debit in your own system as well as in
CyberSource reports and Transaction Search Screens.
CyberSource performs basic checks on the format of the bank account number before
processing the direct debit refund. If the account number does not pass the validation
check, CyberSource rejects the request with a reasonCode=244. CyberSource
recommends that you then confirm the customer entered the number correctly, and if it
was incorrect, request the refund again with the correct number.
You may perform multiple partial refunds against a direct debit. The sum of the refunds
may not exceed the amount of the payment.
You will not receive an error in the reply for any of the following conditions:

The directDebitRefundService_requestID field is invalid.

The customer’s payment has not yet been received.
Instead, CyberSource will not process the refund and the transaction will appear in the
daily Transaction Exception Detail Report. You should monitor this report daily to
determine if any of your transactions have problems. For descriptions of the reason codes
that can appear in the report, see "Reason Codes," page 155. For more information about
the report, see the Global Payment Service Planning Guide. For details about
downloading the report and its format, see the Reporting Developer Guide.
Global Payment Service Developer Guide | March 2015
117
Chapter 9
Direct Debits and Direct Debit Refunds Using the Simple Order API
API Fields
For information about the data types, see Getting Started with CyberSource Advanced for
the Simple Order API.
Request Fields
The following table lists the fields to use in a request for the directDebitService service or
the directDebitRefundService service.
Table 37
Request Fields for Direct Debits and Direct Debit Refunds
for the Simple Order API
Request Field
Description
Required (R)
or Optional
(O)
Data Type &
Length
bankInfo_address
Bank’s address.
Direct Debit (O)
String (255)
Refund (O)
bankInfo_bankCode
bankInfo_branchCode
bankInfo_city
bankInfo_country
bankInfo_name
Bank's code. Used for some countries
when you are not using the IBAN. Contact
CyberSource Customer Support for
required country-specific bank account
information.
Direct Debit (See
description)
Code that identifies the branch of the
customer's bank when you are not using
the IBAN. Contact CyberSource Customer
Support for required country-specific bank
account information.
Direct Debit (See
description)
City in which the bank is located. If you do
not send this field, Global Collect assumes
that the billTo_city field contains the bank
name. Some banks validate the bank
account information, so consider sending
this field if the bank is not located in billTo_
city.
Direct Debit (See
description)
Country in which the bank is located.
Possible values are the two-character ISO
Standard Country Codes.
Direct Debit (R)
Bank's name. Required when using the
Global Collect processor to make one of
the following types of direct debit
transactions:
Direct Debit (See
description)

Direct debit

Stand-alone direct debit refund
String (See
description)
Refund (See
description)
String (15)
Refund (See
description)
String (35)
Refund (See
description)
String (2)
Refund (R)
String (40)
Refund (See
description)
Otherwise it is optional.
Global Payment Service Developer Guide | March 2015
118
Chapter 9
Table 37
Direct Debits and Direct Debit Refunds Using the Simple Order API
Request Fields for Direct Debits and Direct Debit Refunds
for the Simple Order API (Continued)
Request Field
Description
Required (R)
or Optional
(O)
Data Type &
Length
bankInfo_swiftCode
Bank’s SWIFT code. Unique address of the
bank. Also known as the Bank
Identification Code (BIC).
Direct Debit (O)
String (30)
Refund (O)
Note This field is optional; however,
CyberSource strongly recommends
including this code in each request when
the IBAN is included in the request.
billTo_city
City for the billing address.
Direct Debit (R)
String (50)
Refund (R)
billTo_country
billTo_email
billTo_firstName
Country for the billing address. Possible
values are the two-character ISO Standard
Country Codes.
Direct Debit (R)
Customer’s email address, including the
full domain name. For example,
jdoe@example.com.
Direct Debit (R)
Customer’s first name.
Direct Debit (R)
String (2)
Refund (R)
String (255)
Refund (R)
String (60)
Refund (R)
billTo_lastName
Customer’s last name.
Direct Debit (R)
String (60)
Refund (R)
billTo_phoneNumber
Customer’s telephone number.
Direct Debit (O)
String (15)
Refund (O)
billTo_postalCode
Postal code for the billing address. The
postal code must consist of 5 to 9 digits.
If the value of billTo_country is US, the 9digit postal code must follow this format:
[5 digits][dash][4 digits]
Example: 12345-6789
Direct Debit (R if
billTo_country
is US or CA)
String (10)
Refund (R if
billTo_country
is US or CA)
If the value of billTo_country is CA, the 6digit postal code must follow this format:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C3
billTo_state
billTo_street1
State for the billing address. Required if
billTo_country is US or CA. Otherwise
optional. Possible values are the State,
Province, and Territory Codes for the
United States and Canada.
Direct Debit (See
description)
Street address for the billing address.
Direct Debit (R)
String (2)
Refund (See
description)
String (60)
Refund (R)
Global Payment Service Developer Guide | March 2015
119
Chapter 9
Table 37
Direct Debits and Direct Debit Refunds Using the Simple Order API
Request Fields for Direct Debits and Direct Debit Refunds
for the Simple Order API (Continued)
Request Field
Description
Required (R)
or Optional
(O)
Data Type &
Length
billTo_street2
Additional street address information for
the billing address.
Direct Debit (O)
String (60)
directDebitRefundService_
directDebitRequestID
The requestID value returned from a
previous request for directDebitService.
Refund (R for
follow-on
refunds. Not
used for standalone refunds.)
String (26)
directDebitRefundService_
reconciliationID
To use this field, contact CyberSource
Customer Support.
Refund (R)
String (60)
directDebitRefundService_run
Flag indicating whether or not to include
the directDebitRefundService service in
your request. Possible values:
Refund (R)
String (5)

true: Include the service in your request

false (default): Do not include the
service in your request
Refund (O)
directDebitService_
dateCollect
Date on which the direct debit should be
debited. This field is only for the Global
Collect processor. Format: YYYYMMDD
Direct Debit (O)
Numeric (8)
directDebitService_
directDebitText
Text describing the reason for the direct
debit. This field is required only for the
Global Collect processor. Appears on the
customer’s bank statement.
Direct Debit (See
description)
String (See
description)
Direct Debit (See
description)
String (3)
Direct Debit (O)
Numeric (8)
Austria: Max 28 characters
Germany: Max 50 characters
Netherlands: Max 32 characters
Spain: Max 40 characters
directDebitService_
directDebitType
directDebitService_mandate
AuthenticationDate
Type of direct debit. This field is required
only for the Global Collect processor. The
possible values are:

001: Austria

003: Netherlands

004: Spain

005: German ELV direct debit
The date the direct debit mandate was
authenticated. Format: YYYYMMDD
Global Payment Service Developer Guide | March 2015
120
Chapter 9
Table 37
Direct Debits and Direct Debit Refunds Using the Simple Order API
Request Fields for Direct Debits and Direct Debit Refunds
for the Simple Order API (Continued)
Request Field
Description
Required (R)
or Optional
(O)
Data Type &
Length
directDebitService_
recurringType
Whether the direct debit is the first or last
direct debit associated with the mandate,
or one in between. This field is only for the
United Kingdom. The possible values are:
Direct Debit (See
description)
String (3)
Direct Debit (R)
String (5)
Direct Debit (See
description)
String (2)
Direct Debit (R)
String (30)
directDebitService_run
directDebitService_
transactionType

001: First direct debit associated with
this mandate. Use this value for a onetime direct debit.

002: Subsequent direct debits
associated with this mandate.

003: Last direct debit associated with
this mandate.
Flag indicating whether or not to include
the directDebitService service in your
request. Possible values:

true: Include the service in your request

false (default): Do not include the
service in your request
Type of direct debit transaction. This field is
required only for the Netherlands when
using the Global Collect processor. The
possible values are:

01: First collection using this account

02: Other
Note For first collections on a Post giro
account called onzuivere posten, the
account number is verified against the
account name and city by the Post bank.
This verification requires one additional
processing day.
fundTransfer_accountName
Name used on the bank account.
Refund (R)
Global Payment Service Developer Guide | March 2015
121
Chapter 9
Table 37
Direct Debits and Direct Debit Refunds Using the Simple Order API
Request Fields for Direct Debits and Direct Debit Refunds
for the Simple Order API (Continued)
Request Field
Description
Required (R)
or Optional
(O)
Data Type &
Length
fundTransfer_accountNumber
Bank account number.
Direct Debit (See
description)
String (See
description)
Note From August 1, 2016, for euro
countries and from October 31, 2016, for
non-euro countries, the IBAN must be
included in each request. If you provide a
BBAN it will be converted to an IBAN, and
this conversion process will continue only
until August 1, 2016.
Refund (See
description)
Note Do not use the IBAN in this field.
include the IBAN in the fundTransfer_
iban field.
fundTransfer_bankCheckDigit
Code used to validate the customer's
account number when you are not using
the IBAN. Contact CyberSource Customer
Support for required country-specific bank
account information.
Direct Debit (See
description)
String (2)
fundTransfer_iban
International Bank Account Number (IBAN)
for the bank account.
Direct Debit (See
description)
Alphanumeric
(50)
Direct Debit (O)
String (30)
Note From August 1, 2016, for euro
countries and from October 31, 2016, for
non-euro countries, the IBAN must be
included in each request. If you provide a
BBAN it will be converted to an IBAN, and
this conversion process will continue only
until August 1, 2016.
item_#_productCode
Type of product. This value is also used to
determine the category that the product
falls under: electronic, handling, physical,
service, or shipping. The default value is
default. See "Product Codes,"
page 154, for a list of valid values.
Refund (O)
For direct debits, if you set this field to a
value other than default, stored_
value, or any of the values related to
shipping or handling, the item_#_quantity,
item_#_productName field and the item_
#_productSKU fields are required.
item_#_productName
Product’s name. For direct debits, required
if item_#_productCode is not default,
stored_value, or one of the values
related to shipping and/or handling.
Global Payment Service Developer Guide | March 2015
Direct Debit (See
description)
String (30)
Refund (O)
122
Chapter 9
Table 37
Direct Debits and Direct Debit Refunds Using the Simple Order API
Request Fields for Direct Debits and Direct Debit Refunds
for the Simple Order API (Continued)
Request Field
Description
Required (R)
or Optional
(O)
Data Type &
Length
item_#_productSKU
Product identifier code. For direct debits,
required if item_#_productCode is not
default, stored_value, or one of
the values related to shipping or handling.
Direct Debit (See
description)
String (30)
Quantity of the product being purchased.
The default is 1. For direct debits, required
if item_#_productCode is not default,
stored_value, or one of the values
related to shipping or handling.
Direct Debit (See
description)
Tax amount associated with this item. The
field is additive. For example, if you send
one item with unitPrice of 10.00 and
taxAmount of 0.80, and you send another
item with unitPrice of 20.00 and
taxAmount of 1.60, the total amount
authorized will be for 32.40, not 30.00 with
2.40 of tax included.
Direct Debit (O)
item_#_quantity
item_#_taxAmount
Refund (O)
Integer (10)
Refund (O)
String (15)
Refund (O)
The item_#_taxAmount and the item_#_
unitPrice fields must use the same
currency.
If you include item_#_taxAmount field,
and you also include taxService service in
your request, the taxService service does
not calculate tax for the item. Instead, it
returns the value in the item_#_
taxAmount field.
item_#_unitPrice
Per-item price of the product. You must
include either this field or
purchaseTotals_grandTotalAmount in
your request. This value cannot be
negative. For more information about items
and grand totals, see Getting Started with
CyberSource Advanced for the Simple
Order API.
Direct Debit (See
description)
String (15)
Refund (See
description)
You can include a decimal point (.) in this
field, but you cannot include any other
special characters. The amount will be
truncated at the request level to the correct
number of decimal places.
Global Payment Service Developer Guide | March 2015
123
Chapter 9
Table 37
Direct Debits and Direct Debit Refunds Using the Simple Order API
Request Fields for Direct Debits and Direct Debit Refunds
for the Simple Order API (Continued)
Request Field
Description
Required (R)
or Optional
(O)
Data Type &
Length
linkToRequest
Value that links the current request to a
previous authorization request for a debit
card or prepaid card. This value is useful
when multiple payment methods are being
used to complete an order. For more
information, see Credit Card Services
Using the Simple Order API.
Direct Debit (O)
String (26)
merchantID
Your CyberSource merchant ID.
Direct Debit (R)
String (30)
Note When opening your account with
CyberSource, make sure that you inform
CyberSource whether you plan to use
multiple CyberSource merchant IDs. For
example, if you have separate business
units within your company, each with a
separate CyberSource merchant ID. You
must have a separate processor merchant
ID for each CyberSource merchant ID. For
more information, contact CyberSource
Customer Support.
Refund (R)
Merchant-generated order reference or
tracking number. For more information, see
Getting Started with CyberSource
Advanced for the Simple Order API.
Direct Debit (R)
Currency used for the order. Possible
values are the ISO Standard Currency
Codes.
Direct Debit (R)
Grand total for the order. You must include
either this field or the item_#_unitPrice
field in your request. For more information,
see, Getting Started with CyberSource
Advanced for the Simple Order API.
Direct Debit (See
description)
shipTo_city
City of the shipping address.
Direct Debit
(Required if any
shipping
information is
included)
String (50)
shipTo_country
Country of the shipping address. Possible
values are the two-character ISO Standard
Country Codes.
Direct Debit (O)
String (2)
shipTo_firstName
First name of the person receiving the
product.
Direct Debit (O)
String (60)
shipTo_lastName
Last name of the person receiving the
product.
Direct Debit (O)
String (60)
merchantReferenceCode
purchaseTotals_currency
purchaseTotals_
grandTotalAmount
Global Payment Service Developer Guide | March 2015
String (50)
Refund (R)
String (5)
Refund (R)
String (15)
Refund (See
description)
124
Chapter 9
Table 37
Direct Debits and Direct Debit Refunds Using the Simple Order API
Request Fields for Direct Debits and Direct Debit Refunds
for the Simple Order API (Continued)
Request Field
Description
Required (R)
or Optional
(O)
Data Type &
Length
shipTo_phoneNumber
Phone number for the shipping address.
Direct Debit (O)
String (15)
shipTo_postalCode
Postal code for the shipping address. The
postal code must consist of 5 to 9 digits.
Direct Debit (R if
shipTo_
country=US or
CA)
String (10)
If the value of shipTo_country is US, the
9-digit postal code must follow these rules:
[5 digits][dash][4 digits]
Example: 12345-6789
If the value of shipTo_country is CA, the
6-digit postal code must follow these rules:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C4
If the postal code for the shipping address
is not included in the request message,
CyberSource uses the postal code from
the billing address. If the postal code for
the billing address is not included in the
request message, the postal code for the
shipping address is required.
shipTo_state
State or province of the shipping address.
Required if shipTo_country=US or
CA.Possible values are the State,
Province, and Territory Codes for the
United States and Canada.
Direct Debit (See
description)
String (2)
shipTo_street1
First line of the shipping address.
Direct Debit
(Required if any
shipping
information is
included)
String (60)
shipTo_street2
Second line of the shipping address.
Direct Debit (O)
String (60)
Global Payment Service Developer Guide | March 2015
125
Chapter 9
Direct Debits and Direct Debit Refunds Using the Simple Order API
Reply Fields
The following table lists the fields returned in a reply from the directDebitService service
or the directDebitRefundService service.
Table 38
Direct Debit and Direct Debit Refund Reply Fields for the Simple Order API
Reply Field
Description
Returned By
Data Type &
Length
decision
Summary of the result for the overall
request. Possible values:
Direct Debit
and Refund
String (6)

ACCEPT

ERROR

REJECT
directDebitRefundReply_
amount
Total amount for the direct debit refund.
Refund
String (15)
directDebitRefundReply_iban
International Bank Account Number (IBAN)
for the bank account.
Refund
Alphanumeric
(50)
directDebitRefundReply_
processorResponse
Response code from the processor.
Refund
String (10)
directDebitRefundReply_
reasonCode
Numeric value that indicates the result of
the direct debit refund request. See
"Reason Codes," page 155, for a list of
possible values.
Refund
Integer (5)
directDebitRefundReply_
reconciliationID
Unique value generated by CyberSource.
For more information, see Getting Started
with CyberSource Advanced for the Simple
Order API.
Refund
String (60)
directDebitRefundReply_
requestDateTime
Time of the direct debit refund request in
UTC.
Format: YYYY-MM-DDThh:mm:ssZ.
Example: 2007-08-11T22:47:57Z,
which is August 11, 2007, at 10:47:57 P.M.
The T separates the date and the time. The
Z indicates UTC.
Refund
String (20)
directDebitReply_amount
Total amount for the direct debit.
Direct Debit
String (15)
directDebitReply_iban
International Bank Account Number (IBAN)
for the bank account.
Direct Debit
Alphanumeric
(50)
directDebitReply_mandateID
The identification reference for the direct
debit mandate.
Direct Debit
Alphanumeric
(16)
directDebitReply_
processorResponse
Response code from the processor.
Direct Debit
String (10)
directDebitReply_reasonCode
Numeric value that indicates the result of
the direct debit request. See "Reason
Codes," page 155, for a list of possible
values.
Direct Debit
Integer (5)
Global Payment Service Developer Guide | March 2015
126
Chapter 9
Table 38
Direct Debits and Direct Debit Refunds Using the Simple Order API
Direct Debit and Direct Debit Refund Reply Fields for the Simple Order API (Continued)
Reply Field
Description
Returned By
Data Type &
Length
directDebitReply_
reconciliationID
Unique value generated by CyberSource.
For more information, see Getting Started
with CyberSource Advanced for the Simple
Order API.
Direct Debit
String (60)
directDebitReply_
requestDateTime
Time of the direct debit request in UTC.
Format: YYYY-MM-DDThh:mm:ssZ.
Example: 2007-08-11T22:47:57Z,
which is August 11, 2007 at 10:47:57 P.M.
The T separates the date and the time.
The Z indicates UTC.
Direct Debit
String (20)
invalidField_0...N
Fields in the request that contained invalid
data. These reply fields are included as an
aid to software developers only. No attempt
should be made to use these fields for end
user interaction. For more information, see
Getting Started with CyberSource
Advanced for the Simple Order API.
Direct Debit
and Refund
String (100)
merchantReferenceCode
Order reference or tracking number that you
provided in the request. If you included
multi-byte characters in this field in the
request, the returned value might contain
corrupted characters.
Direct Debit
and Refund
String (50)
missingField_0...N
Required fields that were missing from the
request. These reply fields are included as
an aid to software developers only. No
attempt should be made to use these fields
for end user interaction. For more
information, see Getting Started with
CyberSource Advanced for the Simple
Order API.
Direct Debit
and Refund
String (100)
purchaseTotals_currency
Currency used for the order. Possible
values are the ISO Standard Currency
Codes.
Direct Debit
and Refund
String (5)
reasonCode
Numeric value that indicates the result of
the overall request. See "Reason Codes,"
page 155, for a list of possible values.
Direct Debit
and Refund
Integer (5)
requestID
Identifier for the request.
Direct Debit
and Refund
String (26)
Global Payment Service Developer Guide | March 2015
127
Chapter 9
Direct Debits and Direct Debit Refunds Using the Simple Order API
Request and Reply Examples
In the direct debit example below the customer includes the BBAN in the
request. The BBAN is converted to an IBAN in the direct debit reply.
Note
Direct Debit Request
Example 41
Direct Debit Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.103">
<merchantID>demo123</merchantID>
<merchantReferenceCode>demoRef</merchantReferenceCode>
<billTo>
<firstName>Orlando</firstName>
<lastName>Bloom</lastName>
<street1>Kaerntner Strasse 22</street1>
<city>Vienna</city>
<postalCode>1010</postalCode>
<country>ES</country>
<phoneNumber>431427721010</phoneNumber>
<email>borlando@cybersource.com</email>
</billTo>
<purchaseTotals>
<currency>EUR</currency>
<grandTotalAmount>41</grandTotalAmount>
</purchaseTotals>
<fundTransfer>
<accountNumber>0001155325</accountNumber>
<bankCheckDigit>90</bankCheckDigit>
</fundTransfer>
<bankInfo>
<bankCode>0081</bankCode>
<name>SloveniaBank_testing</name>
<country>ES</country>
<branchCode>5394</branchCode>
<swiftCode>ABNA NL 2A</swiftCode>
</bankInfo>
<directDebitService run="true">
<directDebitText>abcd</directDebitText>
<directDebitType>004</directDebitType>
<mandateAuthenticationDate>20140610</mandateAuthenticationDate>
</directDebitService>
</requestMessage>
Global Payment Service Developer Guide | March 2015
128
Chapter 9
Direct Debits and Direct Debit Refunds Using the Simple Order API
Direct Debit Reply
Example 42
Direct Debit Reply
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.103">
<c:merchantReferenceCode>demoRef</c:merchantReferenceCode>
<c:requestID>4024443213630181552683</c:requestID>
<c:decision>ACCEPT</c:decision>
<c:reasonCode>100</c:reasonCode>
<c:purchaseTotals>
<c:currency>eur</c:currency>
</c:purchaseTotals>
<c:directDebitReply>
<c:reasonCode>100</c:reasonCode>
<c:amount>41.00</c:amount>
<c:requestDateTime>2014-06-10T23:52:01Z</c:requestDateTime>
<c:reconciliationID>2149564611</c:reconciliationID>
<c:mandateID>159799546111146963</c:mandateID>
<c:iban>IE64BOFI0001155325</c:iban>
</c:directDebitReply>
</c:replyMessage>
Standalone Direct Debit Refund Request
In the direct debit refund example below the customer includes the BBAN in the
request. The BBAN is converted to an IBAN in the direct debit refund reply.
Note
Example 43
Standalone Direct Debit Refund Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.103">
<merchantID>demo123</merchantID>
<merchantReferenceCode>demoRef</merchantReferenceCode>
<billTo>
<firstName>Orlando</firstName>
<lastName>Bloom</lastName>
<street1>33, rue Dauphine</street1>
<city>Bergheim</city>
<postalCode>75006</postalCode>
<country>DE</country>
<phoneNumber>33 3 69 20 45 63</phoneNumber>
<email>borlando@cybersource.com</email>
</billTo>
<purchaseTotals>
<currency>EUR</currency>
<grandTotalAmount>12</grandTotalAmount>
</purchaseTotals>
Global Payment Service Developer Guide | March 2015
129
Chapter 9
Direct Debits and Direct Debit Refunds Using the Simple Order API
<fundTransfer>
<accountNumber>0044497071</accountNumber>
<accountName>BRADFORD NICKLES</accountName>
</fundTransfer>
<bankInfo>
<bankCode>79050000</bankCode>
<name>SloveniaBank_testing</name>
<country>DE</country>
<swiftCode>BSLJSI2X</swiftCode>
</bankInfo>
<directDebitService run="">
<reconciliationID>335556323</reconciliationID>
</directDebitService>
<directDebitRefundService run="true"/>
</requestMessage>
Example 44
Standalone Direct Debit Refund Reply
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.103">
<c:merchantReferenceCode>demoRef</c:merchantReferenceCode>
<c:requestID>4024444278270181551532</c:requestID>
<c:decision>ACCEPT</c:decision>
<c:reasonCode>100</c:reasonCode>
<c:purchaseTotals>
<c:currency>eur</c:currency>
</c:purchaseTotals>
<c:directDebitRefundReply>
<c:reasonCode>100</c:reasonCode>
<c:amount>12.00</c:amount>
<c:requestDateTime>2014-06-10T23:53:50Z</c:requestDateTime>
<c:reconciliationID>335556323</c:reconciliationID>
<c:processorResponse>800</c:processorResponse>
<c:iban>DE58790500000044497071</c:iban>
</c:directDebitRefundReply>
</c:replyMessage>
Follow-On Direct Debit Refund
Example 45
Follow-On Direct Debit Refund Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.103">
<merchantID>demo123</merchantID>
<merchantReferenceCode>demoRef</merchantReferenceCode>
<purchaseTotals>
<grandTotalAmount>41</grandTotalAmount>
</purchaseTotals>
<directDebitRefundService run="true">
<directDebitRequestID>4024443213630181552683</directDebitRequestID>
</directDebitRefundService>
</requestMessage>
Global Payment Service Developer Guide | March 2015
130
Chapter 9
Example 46
Direct Debits and Direct Debit Refunds Using the Simple Order API
Follow-On Direct Debit Refund Reply
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.103">
<c:merchantReferenceCode>demoRef</c:merchantReferenceCode>
<c:requestID>4024443591910181552683</c:requestID>
<c:decision>ACCEPT</c:decision>
<c:reasonCode>100</c:reasonCode>
<c:purchaseTotals>
<c:currency>eur</c:currency>
</c:purchaseTotals>
<c:directDebitRefundReply>
<c:reasonCode>100</c:reasonCode>
<c:amount>41.00</c:amount>
<c:requestDateTime>2014-06-10T23:52:39Z</c:requestDateTime>
<c:reconciliationID>2149564611</c:reconciliationID>
<c:iban>IE64BOFI0001155325</c:iban>
</c:directDebitRefundReply>
</c:replyMessage>
Global Payment Service Developer Guide | March 2015
131
CHAPTER
Direct Debits and Direct
Debit Refunds Using the
SCMP API
Important
10
Our processing partner requires us to pre-populate their fields to show that the
mandate has been signed and dated. The MANDATEDATE field is populated
with the system date, the MANDATEPLACE field is populated with the
customer city, and the MANDATESIGNED indicator is set to 1. These fields are
for future use and will support e-mandates.
Requesting Direct Debits
Important
Note
From August 1, 2016, for euro countries and from October 31, 2016, for noneuro countries, the IBAN must be included in each request. If you provide a
BBAN it will be converted to an IBAN; this conversion process will continue only
until August 1, 2016.
The bank SWIFT code, a unique address of the bank, does not have to be
included in each request; however, CyberSource strongly recommends
including this code in the request when the IBAN is included in the request.
To request a direct debit, set the ics_applications field to ics_direct_debit. See
Table 39, page 135, for a list of the fields to use.
When requesting a direct debit, you may not request any of the other ICS services except
ics_tax. For more information about the service, see Tax Calculation Service Using the
SCMP API.
When you take an order that uses a direct debit, you must gather the customer’s billing
and bank account information. For most countries, CyberSource accepts either the
traditional bank account information or the account’s IBAN. The traditional bank account
information and the corresponding API fields you need to provide vary by country. Contact
CyberSource Customer Support for required country-specific bank account information.
CyberSource validates the format of the bank account number before performing the
direct debit. If the account number does not pass the validation check, CyberSource
Global Payment Service Developer Guide | March 2015
132
Chapter 10
Direct Debits and Direct Debit Refunds Using the SCMP API
rejects the request with a rflag=DINVALIDACCOUNT. CyberSource recommends that you
confirm the customer entered the number correctly, and if it was incorrect, request the
direct debit again with the correct number.
Requesting Direct Debit Refunds
Important
From August 1, 2016, for euro countries and from October 31, 2016, for noneuro countries, the IBAN must be included in each request. If you provide a
BBAN it will be converted to an IBAN; this conversion process will continue only
until August 1, 2016.
There are two types of direct debit refunds: follow-on refunds and stand-alone refunds. A
follow-on refund uses information from a previous direct debit. A stand-alone refund does
not depend on a previous transaction.
A follow-on refund must occur within 60 of the request for the direct debit. When the time
limit for a follow-on refund expires, the only kind of refund you can perform is a standalone refund.
To request a direct debit refund:

Set the ics_applications field to ics_direct_debit_refund.

Do not request any other ICS services except Tax Calculation, which is optional. For
more information about this service, see Tax Calculation Service Using the SCMP
API.

Send the fields required for a direct debit refund request as described in Table 39,
page 135. For a follow-on refund, the fields and values must match the fields and
values you sent in the original direct debit request.

For a stand-alone refund, the direct_debit_request_id field is optional. See
page 147.

For a follow-on refund, include the direct_debit_request_id field with the request ID
from the direct debit reply. See page 148.

The easiest way to implement direct debit refunds is to always send the request ID
from the original direct debit with every direct debit refund request.

CyberSource recommends that when you request a refund, you use the same value
for the merchant_ref_number field that you used for the direct debit. This makes it
easier for you to link the refund to the original direct debit in your own system as well
as in CyberSource reports and Transaction Search Screens.
Global Payment Service Developer Guide | March 2015
133
Chapter 10
Direct Debits and Direct Debit Refunds Using the SCMP API
CyberSource validates the format of the bank account number before processing the
direct debit refund. If the account number does not pass the validation check,
CyberSource rejects the request with a rflag=DINVALIDACCOUNT. CyberSource
recommends that you then confirm the customer entered the number correctly, and if it
was incorrect, request the refund again with the correct number.
You can perform multiple partial refunds against a direct debit. The sum of the refunds
must not exceed the amount of the payment.
You will not receive an error in the reply for either of the following conditions:

The direct_debit_request_id field is invalid.

The customer’s payment has not yet been received.
Instead, CyberSource does not process the refund, and the transaction appears in the
daily Transaction Exception Detail Report. You should monitor this report daily to
determine whether any of your transactions have problems. For descriptions of the reason
codes that can appear in the report, see Appendix B, "Reason Codes," on page 155. For
information about the report and how to use it, see the Global Payment Service Planning
Guide. For details about downloading the report and its format, see the Reporting
Developer Guide.
Global Payment Service Developer Guide | March 2015
134
Chapter 10
Direct Debits and Direct Debit Refunds Using the SCMP API
API Fields
In the “Used By” column, the services are referred to by shortened names: Direct Debit
and Refund. For information about the data types, see Getting Started with CyberSource
Advanced for the SCMP API.
Request Fields
The following table lists the fields to use in a request for the ics_direct_debit service or
the ics_direct_debit_refund service.
Table 39
Request-Level Fields for Direct Debits and Direct Debit Refunds
for the SCMP API
Request-Level
Field
Description
Required (R)
or Optional
(O)
Data Type
& Length
bank_account_
name
Name used on the bank account.
Direct Debit (O)
String (30)
bank_account_
number
Bank account number.
Refund (O)
Important From August 1, 2016, for euro countries
and from October 31, 2016, for non-euro countries, the
IBAN must be included in each request. If you provide a
BBAN it will be converted to an IBAN, and this
conversion process will continue only until August 1,
2016.
Direct Debit
(See
description)
String (See
description)
Refund (See
description)
Note Do not use the IBAN in this field. include the
IBAN in the fundTransfer_iban field.
bank_address
Bank’s address.
Direct Debit (O)
String (255)
Refund (O)
bank_check_digit
Code used to validate the customer's account number
when you are not using the IBAN. Contact CyberSource
Customer Support for required country-specific bank
account information.
Direct Debit
(See
description)
String (2)
bank_city
City in which the bank is located. If you do not send this
field, Global Collect assumes the bank is located in the
bill_city field. Some banks validate the bank account
information, so include this field if the bank is not
included in the bill_city field.
Direct Debit (O)
String (35)
Bank's code. Used for some countries when you are not
using the IBAN. Contact CyberSource Customer
Support for required country-specific bank account
information.
Direct Debit
(See
description)
bank_code
Global Payment Service Developer Guide | March 2015
Refund (O)
String (See
description)
Refund (See
description)
135
Chapter 10
Table 39
Direct Debits and Direct Debit Refunds Using the SCMP API
Request-Level Fields for Direct Debits and Direct Debit Refunds
for the SCMP API (Continued)
Request-Level
Field
Description
Required (R)
or Optional
(O)
Data Type
& Length
bank_country
Country in which the bank is located. Possible values
are the two-character ISO Standard Country Codes.
Direct Debit (R)
String (2)
International Bank Account Number (IBAN) for the bank
account.
Direct Debit
(See
description)
Alphanumeric
(50)
Direct Debit
(See
description)
String (40)
bank_iban
Important From August 1, 2016, for euro countries
Refund (R)
and from October 31, 2016, for non-euro countries, the
IBAN must be included in each request. If you provide a
BBAN it will be converted to an IBAN, and this
conversion process will continue only until August 1,
2016.
bank_name
Bank's name. Required when using the Global Collect
processor to make one of the following types of direct
debit transactions:

Direct debit

Stand-alone direct debit refund
Refund (See
description)
Otherwise optional.
bank_swiftcode
Bank’s SWIFT code. Unique address of the bank. Also
known as the Bank Identification Code (BIC).
Direct Debit (O)
String (30)
Refund (O)
Note This field is optional; however, CyberSource
strongly recommends including this code in each
request when the IBAN is included in the request.
bill_address1
Billing street address.
Direct Debit (R)
String (60)
Refund (R)
bill_address2
Additional billing address information.
Direct Debit (O)
String (60)
Refund (O)
bill_city
Billing address city.
Direct Debit (R)
String (50)
Refund (R)
bill_country
bill_state
Billing address country. Possible values are the twocharacter ISO Standard Country Codes.
Direct Debit (R)
Billing address state. Required if bill_country=US or
CA. Possible values are the State, Province, and
Territory Codes for the United States and Canada.
Direct Debit
(See
Description)
String (2)
Refund (R)
String (2)
Refund (See
Description)
Global Payment Service Developer Guide | March 2015
136
Chapter 10
Table 39
Direct Debits and Direct Debit Refunds Using the SCMP API
Request-Level Fields for Direct Debits and Direct Debit Refunds
for the SCMP API (Continued)
Request-Level
Field
Description
Required (R)
or Optional
(O)
Data Type
& Length
bill_zip
Zip code for the shipping address. The zip code must
consist of 5 to 9 digits.
Direct Debit (R if
bill_
country=US or
CA)
String (10)
If the value of bill_country is US, the 9-digit zip code
must follow this format:
[5 digits][dash][4 digits]
Example:12345-6789
If the value of bill_country is CA, the 6-digit zip code
must follow this format:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C3
Refund (R if
bill_
country=US or
CA)
Code that identifies the branch of the customer's bank
when you are not using the IBAN. Contact CyberSource
Customer Support for required country-specific bank
account information.
Direct Debit
(See
description)
Currency used for the order. Possible values are the
ISO Standard Currency Codes.
Direct Debit (R)
Customer’s email address, including the full domain
name. For example, jdoe@example.com.
Direct Debit (R)
customer_
firstname
Customer’s first name.
Direct Debit (R)
customer_
lastname
Customer’s last name.
customer_phone
Customer’s telephone number.
branch_code
currency
customer_email
String (15)
Refund (See
description)
String (5)
Refund (R)
String (255)
Refund (R)
String (60)
Refund (R)
Direct Debit (R)
String (60)
Refund (R)
Direct Debit (O)
String (15)
Refund (O)
date_collect
Date the direct debit should be debited.
Format: YYYYMMDD
Direct Debit (O)
String (8)
direct_debit_
mandate_
authentication_
date
The date the direct debit mandate was authenticated.
Format: YYYYMMDD
Direct Debit (O)
Numeric (8)
Global Payment Service Developer Guide | March 2015
137
Chapter 10
Table 39
Direct Debits and Direct Debit Refunds Using the SCMP API
Request-Level Fields for Direct Debits and Direct Debit Refunds
for the SCMP API (Continued)
Request-Level
Field
Description
Required (R)
or Optional
(O)
Data Type
& Length
direct_debit_
recurring_type
Whether the direct debit is the first or last direct debit
associated with the mandate, or one in between.
Required only for the United Kingdom. Possible values:
Direct Debit
(See
description)
String (3)

001: First direct debit associated with this mandate.
Use this value if a one-time direct debit).

002: Subsequent direct debits associated with this
mandate.

003: Last direct debit associated with this mandate.
direct_debit_
request_id
The request_id value returned from a previous request
for ics_direct_debit.
Refund (R)
String (26)
direct_debit_text
Text describing reason for the direct debit. Required
only for the Global Collect processor. Appears on the
customer’s bank statement.
Direct Debit (R)
String (See
description)
Austria: Max 28 characters
Germany: Max 50 characters
Netherlands: Max 32 characters
Spain: Max 40 characters
direct_debit_
trans_ref_no
To use this field, contact CyberSource Customer
Support.
Refund (R)
String (60)
direct_debit_type
Type of direct debit. Required only for the Global Collect
processor. Possible values:
Direct Debit
(See
description)
String (3)
Grand total for the order. You must include either this
field or the offer0 field and the offer-level field amount.
For more information about offers and grand totals, see
Getting Started with CyberSource Advanced for the
SCMP API.
Direct Debit
(See
description)
Decimal (15)
ICS services to process for the request.
Direct Debit (R)
grand_total_
amount
ics_applications

001: Austria

003: Netherlands

004: Spain

005: German ELV direct debit
Refund (See
description)
String (255)
Refund (R)
link_to_request
Value that links the current request to a previous
authorization request for a debit card or prepaid card.
This value is useful when using multiple payment
methods to complete an order. For more information,
see Credit Card Services Using the SCMP API.
Global Payment Service Developer Guide | March 2015
Direct Debit (O)
String (26)
138
Chapter 10
Table 39
Direct Debits and Direct Debit Refunds Using the SCMP API
Request-Level Fields for Direct Debits and Direct Debit Refunds
for the SCMP API (Continued)
Request-Level
Field
Description
Required (R)
or Optional
(O)
Data Type
& Length
mandate_id
The mandate ID. Required only for the United Kingdom.
Direct Debit
(See
description)
String (16)
merchant_id
Your CyberSource merchant ID.
Direct Debit (R)
String (30)
Note When opening your account with CyberSource,
tell CyberSource whether you plan to use multiple
CyberSource merchant IDs. For example, if you have
separate business units within your company, each with
a separate CyberSource merchant ID. You must have a
separate processor merchant ID for each CyberSource
merchant ID. For more information, contact
CyberSource Customer Support.
Refund (R)
merchant_ref_
number
Merchant-generated order reference or tracking
number. For more information, see Getting Started with
CyberSource Advanced for the SCMP API.
Direct Debit (R)
offer0...N
Offers for the request. An offer is a line item for the
order.
Direct Debit (O)
ship_to_address1
First line of the shipping address. Required if any
shipping information is included.
Direct Debit
(See
description)
String (60)
ship_to_address2
Second line of the shipping address.
Direct Debit (O)
String (60)
ship_to_city
City of the shipping address. Required if any shipping
information is included.
Direct Debit
(See
description)
String (50)
ship_to_country
Country of the shipping address. Possible values are
the two-character ISO Standard Country Codes.
Direct Debit (O)
String (2)
ship_to_firstname
First name of person receiving the product.
Direct Debit (O)
String (60)
ship_to_lastname
Last name of person receiving the product.
Direct Debit (O)
String (60)
ship_to_phone
Phone number for the shipping address.
Direct Debit (O)
String (15)
ship_to_state
State or province of the shipping address. Required if
ship_to_country=US or CA. Possible values are the
State, Province, and Territory Codes for the United
States and Canada.
Direct Debit
(See
description)
String (2)
Global Payment Service Developer Guide | March 2015
String (50)
Refund (R)
String (50)
Refund (O)
139
Chapter 10
Table 39
Direct Debits and Direct Debit Refunds Using the SCMP API
Request-Level Fields for Direct Debits and Direct Debit Refunds
for the SCMP API (Continued)
Request-Level
Field
Description
Required (R)
or Optional
(O)
Data Type
& Length
ship_to_zip
Zip code for the shipping address.
Direct Debit (R if
ship_to_
country=US or
CA)
String (10)
Number of seconds until the transaction times out. The
default is 110 seconds.
Direct Debit (O)
Positive
integer (3)
Type of direct debit transaction. Required only for the
Netherlands when using the Global Collect processor.
Possible values:
Direct Debit
(See
description)
If the value of ship_to_country is US, the 9-digit zip
code must follow this format:
[5 digits][dash][4 digits]
Example: 12345-6789
If the value of ship_to_country is CA, the 6-digit zip
code must follow this format:
[alpha][numeric][alpha]
[numeric][alpha][numeric]
Example: A1B 2C3
If the postal code for the shipping address is not
included in the request message, CyberSource uses
the postal code from the billing address. If the postal
code for the billing address is not included in the
request message, the postal code for the shipping
address is required.
timeout
transaction_type

01: First collection using this account

02: Other
Refund (O)
String (2)
Note For first collections on a Post giro account called
onzuivere posten, the account number is verified
against the account name and city by the Post bank.
This verification requires one additional processing day.
Global Payment Service Developer Guide | March 2015
140
Chapter 10
Direct Debits and Direct Debit Refunds Using the SCMP API
Offer-Level Fields
The following table lists the fields to use in a request for the ics_direct_debit service or
the ics_direct_debit_refund service.
Table 40
Offer-Level Fields for Direct Debits and Direct Debit Refunds
for the SCMP API
Offer-Level Field
Description
Required (R)
or Optional (O)
Data
Type &
Length
amount
Per-item price of the product. You must include
either this field and the offer0 field, or the
request-level field grand_total_amount in your
request. This value cannot be negative. For more
information about offers and grand totals, see
Getting Started with CyberSource Advanced for
the SCMP API.
Direct Debit (See
description)
Decimal
(15)
Refund (See
description)
You can include a decimal point (.) in this field,
but you cannot include any other special
characters. The amount will be truncated at the
request level to the correct number of decimal
places.
merchant_product_sku
product_code
Product identifier code. For direct debits,
required if product_code is not default,
stored_value, or one of the values related to
shipping or handling.
Direct Debit (See
description)
Type of product. This value is also used to
determine the product category: electronic,
handling, physical, service, or shipping.The
default value is default. See "Product
Codes," page 154, for a list of valid values.
Direct Debit (O)
String (30)
Refund (O)
String (30)
Refund (O)
For direct debits, if you set this to a value other
than default, stored_value, or any of the
values related to shipping or handling, the
quantity, product_name, and merchant_
product_sku fields are required.
product_name
quantity
Product’s name. For direct debits, required if
product_code is not default, stored_
value, or one of the values related to shipping
or handling.
Direct Debit (See
description)
Quantity of the product being purchased.The
default is 1. For direct debits, required if
product_code is not default, stored_
value, or one of the values related to shipping
or handling.
Direct Debit (See
description)
Global Payment Service Developer Guide | March 2015
String (30)
Refund (O)
Refund (O)
Nonnegative
integer
(10)
141
Chapter 10
Table 40
Direct Debits and Direct Debit Refunds Using the SCMP API
Offer-Level Fields for Direct Debits and Direct Debit Refunds
for the SCMP API (Continued)
Offer-Level Field
Description
Required (R)
or Optional (O)
Data
Type &
Length
tax_amount
Tax amount associated with this item.The field is
additive. For example, if you send the following
offer lines:
Direct Debit (O)
Decimal
(15)
Refund (O)
offer0=amount:10.00^
quantity:1^tax_amount:0.80
offer1=amount:20.00^
quantity:1^tax_amount:1.60
the total amount authorized will be for 32.40, not
30.00 with 2.40 of tax included.
The tax_amount and amount values must be in
the same currency.
If you include tax_amount, and you request the
ics_tax service, ics_tax will not calculate tax for
the offer. Instead, it will return the value in the
tax_amount field.
Reply Fields
The following table lists the fields returned in a reply from ics_direct_debit service
request or the ics_direct_debit_refund service request.
Table 41
Reply Fields for Direct Debits and Direct Debit Refunds for the SCMP API
Reply Field
Description
Returned
By
Data Type &
Length
client_lib_version
Information about the client library used to request
the transaction.
Direct Debit
String (50)
Currency used for the order. Possible values are
the ISO Standard Currency Codes.
Direct Debit
direct_debit_amount
Amount of the direct debit.
Direct Debit
Decimal (15)
direct_debit_iban
International Bank Account Number (IBAN) for the
bank account.
Direct Debit
Alphanumeric
(50)
direct_debit_mandate_id
The identification reference for the direct debit
mandate.
Direct Debit
Alphanumeric
(16)
direct_debit_rcode
One-digit code that indicates if the ics_direct_
debit request was successful.
Direct Debit
Integer (1)
direct_debit_refund_
amount
Amount of the direct debit refund.
Refund
Decimal (15)
currency
Global Payment Service Developer Guide | March 2015
Refund
String (5)
Refund
142
Chapter 10
Table 41
Direct Debits and Direct Debit Refunds Using the SCMP API
Reply Fields for Direct Debits and Direct Debit Refunds for the SCMP API (Continued)
Reply Field
Description
Returned
By
Data Type &
Length
direct_debit_refund_
iban
International Bank Account Number (IBAN) for the
bank account.
Refund
Alphanumeric
(50)
direct_debit_refund_
rcode
One-digit code that indicates if the ics_direct_
debit_refund request was successful.
Refund
Integer (1)
direct_debit_refund_
request_time
Time of direct debit refund request in UTC. For
more information, see Getting Started with
CyberSource Advanced for the SCMP API.
Refund
Date and time
(20)
direct_debit_refund_
response_code
Response code from the processor.
Refund
String (10)
direct_debit_refund_
rflag
One-word description of the result of the ics_
direct_debit_refund request.
Refund
String (50)
direct_debit_refund_
rmsg
Message that explains the reply flag direct_debit_
refund_rflag.
Refund
String (255)
direct_debit_refund_
trans_ref_no
Reference number for the transaction. For more
information, see Getting Started with CyberSource
Advanced for the SCMP API.
Refund
String (60)
direct_debit_request_
time
Time of direct debit request in UTC. For more
information, see Getting Started with CyberSource
Advanced for the SCMP API.
Refund
Date and time
(20)
direct_debit_response_
code
Response code from the processor.
Direct Debit
String (10)
direct_debit_rflag
One-word description of the result for the ics_
direct_debit request.
Direct Debit
String (50)
direct_debit_rmsg
Message that explains the reply flag direct_debit_
rflag.
Direct Debit
String (255)
direct_debit_trans_ref_
no
Reference number for the transaction. For more
information, see Getting Started with CyberSource
Advanced for the SCMP API.
Refund
String (60)
ics_rcode
One-digit code that indicates whether the entire
request was successful.
Direct Debit
and Refund
Integer (1)
ics_rflag
One-word description of the result for the entire
request.
Direct Debit
and Refund
String (50)
ics_rmsg
Message that explains the reply flag ics_rflag.
Direct Debit
and Refund
String (255)
merchant_ref_number
Order reference or tracking number that you
provided in the request. If you included multi-byte
characters in this field in the request, the returned
value might contain corrupted characters.
Direct Debit
and Refund
String (50)
request_id
Identifier for the request generated by the client.
Direct Debit
and Refund
String (26)
Global Payment Service Developer Guide | March 2015
143
Chapter 10
Direct Debits and Direct Debit Refunds Using the SCMP API
Reply Flags
The following table lists the reply flags for the ics_direct_debit service request and the
ics_direct_debit_refund service request.
Table 42
Reply Flags for Direct Debits and Direct Debit Refunds for the SCMP API
Reply Flag
Description
Returned By
DINVALIDACCOUNT
The bank account number did not pass the validation. Verify with the
customer that the account number is correct; if it was incorrect, request
the service again with the correct information.
Direct Debit
and Refund
DINVALIDDATA
Data provided is not consistent with the request.
Direct Debit
and Refund
DMISSINGFIELD
The request is missing a required field.
Direct Debit
and Refund
ESYSTEM
System error. Wait a few minutes before re-sending your request. You
must design your transaction management system to correctly handle
CyberSource system errors. Depending on the payment processor
handling the transaction, the error may indicate a valid CyberSource
system error or a processor rejection caused by invalid data. In either
case, CyberSource recommends that you do not design your system to
endlessly retry sending a transaction. See the documentation for your
CyberSource client for information on handling system errors and
retries.
Direct Debit
and Refund
ETIMEOUT
The request timed out.
Direct Debit
and Refund
SOK
The transaction was successful.
Direct Debit
and Refund
Global Payment Service Developer Guide | March 2015
144
Chapter 10
Direct Debits and Direct Debit Refunds Using the SCMP API
Request and Reply Examples
In the direct debit example below the customer includes the BBAN in the
request. The BBAN is converted to an IBAN in the direct debit reply.
Note
Direct Debit Request
Example 47
Direct Debit Request
ics_applications=ics_direct_debit
bank_account_name=Direct_Debit Testing
bank_account_number=55500643635
bank_address=Vienna Central Branch
bank_city=Hinterbruhl
bank_code=31000
bank_country=AT
bank_swiftcode=ABNA NL 2A
bill_address1=Parkstrasse 4
bill_city=Hinterbruhl
bill_country=AT
bill_zip=2371
currency=eur
customer_email=null@cybersource.com
customer_firstname=John
customer_lastname=Smith
customer_phone=999-999-9999
direct_debit_mandate_authentication_date=20140610
direct_debit_text=Direct Debit Text
direct_debit_type=001
grand_total_amount=21.11
merchant_id=mercid123
merchant_ref_number=merRef123
Global Payment Service Developer Guide | March 2015
145
Chapter 10
Example 48
Direct Debits and Direct Debit Refunds Using the SCMP API
Direct Debit Reply
currency=eur
direct_debit_amount=21.11
direct_debit_iban=IE64BOFI55500643635
direct_debit_mandate_id=697458823683278238
direct_debit_rcode=1
direct_debit_rflag=SOK
direct_debit_rmsg=Request was processed successfully.
direct_debit_time=2014-06-10T211943Z
direct_debit_trans_ref_no=2149562887
ics_decision_reason_code=100
ics_rcode=1
ics_rflag=SOK
ics_rmsg=Request was processed successfully.
merchant_ref_number=merRef123
request_id=4024351829300172492137
Global Payment Service Developer Guide | March 2015
146
Chapter 10
Direct Debits and Direct Debit Refunds Using the SCMP API
Direct Debit Refund—Standalone
In the direct debit refund example below the customer includes the BBAN in the
request. The BBAN is converted to an IBAN in the direct debit refund reply.
Note
Example 49
Standalone Direct Debit Refund Request
ics_applications=ics_direct_debit_refund
bank_account_name=Direct_Debit Testing
bank_account_number=55500643635
bank_address=Vienna Central Branch
bank_check_digit=77
bank_code=31000
bank_country=AT
bank_name=Raiffeisen Zentral
bank_swiftcode=BNPA FR PP PLZ
bill_address1=PARK
bill_city=HINTERBRUHL
bill_country=AT
branch_code=99999
currency=EUR
customer_email=null@cybersource.com
customer_firstname=John
customer_lastname=Smith
customer_phone=999-999-9999
date_collect=20120821
direct_debit_text=Direct Debit Text
direct_debit_type=001
grand_total_amount=100.00
mandate_id=1
merchant_id=mercid123
merchant_ref_number=merRef123
Example 50
Standalone Direct Debit Refund Reply
currency=eur
direct_debit_refund_amount=100.00
direct_debit_refund_iban=IE64BOFI55500643635
direct_debit_refund_rcode=1
direct_debit_refund_rflag=SOK
direct_debit_refund_rmsg=Request was processed successfully.
direct_debit_refund_time=2014-06-10T211934Z
direct_debit_refund_trans_ref_no=Reference No
ics_rcode=1
ics_rflag=SOK
ics_rmsg=Request was processed successfully.
merchant_ref_number=merRef123
request_id=4024351740870172492137
Global Payment Service Developer Guide | March 2015
147
Chapter 10
Direct Debits and Direct Debit Refunds Using the SCMP API
Direct Debit Refund—Follow-On
Example 51
Follow-On Direct Debit Refund Request
ics_applications=ics_direct_debit_refund
direct_debit_request_id=4024351829300172492137
grand_total_amount=21.11
merchant_id=mercid123
merchant_ref_number=merRef123
Example 52
Follow-On Direct Debit Refund Reply
currency=eur
direct_debit_refund_amount=21.11
direct_debit_refund_iban=IE64BOFI55500643635
direct_debit_refund_rcode=1
direct_debit_refund_rflag=SOK
direct_debit_refund_rmsg=Request was processed successfully.
direct_debit_refund_time=2014-06-10T211943Z
direct_debit_refund_trans_ref_no=2149562887
ics_rcode=1
ics_rflag=SOK
ics_rmsg=Request was processed successfully.
merchant_ref_number=merRef123
request_id=4024351832340172492137
Global Payment Service Developer Guide | March 2015
148
CHAPTER
Testing
11
Sending Test Requests
You can send test requests for bank transfers, real-time bank transfers, direct debits,
refunds, and mandates to the CyberSource test server. CyberSource performs the same
basic validations that are performed for production transactions. For bank transfer replies,
you receive fake bank account information. Test transactions are not forwarded to the
payment processor.
The requirements for test transactions are:

Use your regular CyberSource merchant ID.

Match the country and currency information. For example, if testing a bank transfer in
Germany, make sure that you specify Germany as the bank country and the country of
the customer’s address, and specify EUR as the currency.

When testing the Simple Order API, use the test URL:
https://ics2wstest.ic3.com/commerce/1.x/transactionProcessor

When testing the SCMP API, use the CyberSource test server:
https://ics2test.ic3.com
Testing Bank Transfers, Direct
Debits, and Refunds
You use specific amounts in your test transactions to trigger specific responses. This
process enables you to easily generate the various responses that your system needs to
handle.
The following table shows the amounts and decline or error responses that are returned
by the simulator. The tables include responses for both the Simple Order API (reason
code) and the SCMP API (rflag and rmsg description).
Global Payment Service Developer Guide | March 2015
149
Chapter 11
Testing
See Appendix B, "Reason Codes," on page 155 for descriptions of the Simple Order API
reason codes.
The rmsg you actually receive contains all capital letters with underscores between the
words.
Table 43
Test Data for Global Payment Service
Amount
Simple
Order API
Reason
Code
SCMP API
rflag
SCMP API rmsg Description
Used with
These Payment
Types
2013
233
DINVALIDDATA
No bank found for this country
Bank Transfer
2014
233
DINVALIDDATA
Invalid bank account number
Bank Transfer
Direct Debit
2015
233
DINVALIDDATA
Invalid Post giro account number
Bank Transfer
Direct Debit
2020
233
DINVALIDDATA
Authorization ID is required for country.
Direct Debit
2024
233
DINVALIDDATA
Bank code is required for country
Direct Debit
2025
233
DINVALIDDATA
Account name is required for country
Direct Debit
2026
233
DINVALIDDATA
Account number is required for country
Direct Debit
2027
233
DINVALIDDATA
Direct debit text is required for country
Direct Debit
2028
233
DINVALIDDATA
Date collect is required for country
Direct Debit
2029
233
DINVALIDDATA
Bank check digit is required for country
Direct Debit
2030
233
DINVALIDDATA
Branch code is required for country
Direct Debit
2031
233
DINVALIDDATA
Bank name is required for country
Direct Debit
2032
233
DINVALIDDATA
Date collected.
Direct Debit
2033
233
DINVALIDDATA
Account number has invalid length
Direct Debit
2034
233
DINVALIDDATA
Invalid bank code for payment type and
country combination
Direct Debit
2035
233
DINVALIDDATA
Bank code does not match bank name
Direct Debit
2036
233
DINVALIDDATA
Invalid bank account number
Bank Transfer
Direct Debit
2037
233
DINVALIDDATA
Invalid Post giro account number
Bank Transfer
Direct Debit
2038
2039
233
233
DINVALIDDATA
DINVALIDDATA
Amount not between minimum and
maximum amounts
Bank Transfer
Payment type invalid for country code
Bank Transfer
Direct Debit
Direct Debit
Global Payment Service Developer Guide | March 2015
150
Chapter 11
Table 43
Testing
Test Data for Global Payment Service (Continued)
Amount
Simple
Order API
Reason
Code
SCMP API
rflag
SCMP API rmsg Description
Used with
These Payment
Types
2042
237
DINVALIDDATA
Already refunded; no multiple refunds
allowed
Bank Transfer
Refund
Direct Debit
Refund
2044
239
DINVALIDDATA
Refund amount too large
Bank Transfer
Refund
Direct Debit
Refund
2045
150
ESYSTEM
The request refers to an unknown order.
Bank Transfer
Refund
Direct Debit
Refund
9999.98
250
ETIMEOUT
Time-out connecting to processor
All
9999.99
150
ESYSTEM
Unexpected error
All
Testing Real-Time Bank Transfers
Testing Your CyberSource Interface
This stage of testing is available for all real-time bank transfer networks.
Note
Use the CyberSource simulator to test your interface with the CyberSource services. Send
a real-time bank transfer request to CyberSource and make sure that you receive a realtime bank transfer reply from CyberSource.
Do not use the URL that CyberSource returns to you in the reply message
during this stage of testing. It is not a valid URL.
Important
Global Payment Service Developer Guide | March 2015
151
Chapter 11
Testing
Testing Your Network Interface
This stage of testing is available only for the real-time bank transfer networks in
the following table.
Note
The purpose of network testing is to verify that you can redirect your customer’s browser
to the network.
Table 44
Network Testing for Real-Time Bank Transfers
Network
Description
eNets
It is not necessary to use special test account details for testing.
The test payment pages are identical to the production version.
Only DBS provides a valid test link; the other test links are
down most of the time.
GiroPay (Germany)
The test page is available only in German. Special test cases
are available. The test payment page is not identical to the
production version. The test payment page provides a way to
test the different flows.
iDEAL (Netherlands)
Special test cases are available. The test payment pages are
not identical to the production version. Only a subset of the
different flows can be tested.
Nordea e-betaling (Denmark)
Payment pages are available only in Danish. The test payment
pages are not identical to the production version. Only a subset
of the various flows can be tested.
Nordea e-betalning (Sweden)
Payment pages are available only in Swedish. The test
payment pages are not identical to the production version. Only
a subset of the various flows can be tested.
Nordea e-maksu (Finland)
Payment pages are available only in Finnish. The test payment
pages are not identical to the production version. Only a subset
of the various flows can be tested.
To test your network interface:
Step 1
Contact Customer Support to have your connection switched to the network’s simulator.
Step 2
Set up a test customer that consists of a browser that interfaces with your shopping cart.
Step 3
Simulate the customer experience by having your test customer initiate a real-time bank
transfer payment.
Step 4
When you receive this customer message, send a real-time bank transfer request to
CyberSource.
Step 5
When you receive the real-time bank transfer reply from CyberSource, redirect the test
customer to the network by using the URL in the reply message.
Global Payment Service Developer Guide | March 2015
152
Chapter 11
Step 6
Testing
Using the test customer browser, verify that you have received a page from the network.
Going Live
After successfully testing your account, you must go live with CyberSource before you
begin accepting payments. When you go live, your CyberSource account is updated so
that you can send transactions to the CyberSource production server. If you have not
already done so, you will need to provide your payment processor and banking
information to CyberSource so that your processor can deposit funds to your merchant
bank account. For more information, see Getting Started with CyberSource Advanced for
the Simple Order API or Getting Started with CyberSource Advanced for the SCMP API.
Your production transactions will be available for you to view in the production version of
the Business Center:
https://ebc.cybersource.com
Global Payment Service Developer Guide | March 2015
153
APPENDIX
Product Codes
A
The following table lists the values that you can use for the product code. For the Simple
Order API, use the item_#_productCode request field to specify the product code. For
the SCMP API, use the product_code offer-level field.
Table 45
Product Code Values
Product Code
Definition
adult_content
Adult content.
coupon
Coupon applied to the entire order.
default
Default value for the product code. CyberSource uses default when a request
provides no value for the product code.
electronic_good
Electronic product other than software.
electronic_software
Software distributed electronically rather than on tapes, disks, or other media.
gift_certificate
Gift certificate not issued with CyberSource Stored Value Services.
handling_only
Separate charge that is generally a fee imposed by the seller on the customer.
The fee pays the seller’s administrative selling costs.
service
Service that you perform for the customer.
shipping_and_handling
Shipping is a separate charge for shipping the product to the purchaser. Handling
is generally a fee imposed by the seller to pay administrative selling costs.
shipping_only
Charge for transporting tangible personal property from the seller to the
purchaser. Documentation must be maintained that clearly establishes where title
to the tangible personal property passed from the seller to the purchaser.
subscription
Subscription to a web site or other content.
Global Payment Service Developer Guide | March 2015
154
APPENDIX
Reason Codes
B
Reason Codes for the Simple
Order API
These reason codes apply only if you use the Simple Order API. The reason code
appears in the reply that you receive immediately after you request the service. See
Getting Started with CyberSource Advanced for the Simple Order API for a discussion of
replies, decisions, and reason codes.
Note
Table 46
CyberSource reserves the right to add new reason codes at any time. If your
error handler receives a reason code that it does not recognize, it should use
the decision field to obtain the result.
Reason Codes for the Simple Order API
Reason
Code
Description
100
Successful transaction.
101
The request is missing one or more required fields.
See the reply fields missingField_0...N. Resend the request with the complete
information. For more information about missing and invalid fields, see Getting
Started with CyberSource Advanced for the Simple Order API.
102
One or more fields in the request contain invalid data.
See the reply fields invalidField_0...N. Resend the request with the correct
information. For more information about missing and invalid fields, see Getting
Started with CyberSource Advanced for the Simple Order API.
150
General system failure.
See the documentation for your CyberSource client for information on handling
retries in the case of system errors.
Global Payment Service Developer Guide | March 2015
155
Appendix B
Table 46
Reason Codes
Reason Codes for the Simple Order API (Continued)
Reason
Code
Description
151
The request was received but a server time-out occurred. This error does not
include time-outs between the client and the server.
To avoid duplicating the transaction, do not resend the request until you have
reviewed the transaction status in the Business Center. See the documentation for
your CyberSource client for information on handling retries in the case of system
errors.
152
The request was received, but a service timed out.
To avoid duplicating the transaction, do not resend the request until you have
reviewed the transaction status in the Business Center. See the documentation for
your CyberSource client for information on handling retries in the case of system
errors.
231
Invalid account number.
Request a different form of payment.
233
General decline by the processor.
Request a different form of payment.
234
A problem exists with your CyberSource merchant configuration.
Do not resend the request. Contact Customer Support to correct the configuration
problem.
236
Processor failure.
Wait a few minutes and resend the request.
239
The requested transaction amount must match the previous transaction amount.
Correct the amount and resend the request.
241
The request ID is invalid.
Verify the request ID is correct.
244
The bank account number failed the validation check.
Verify with the customer that the account number is correct; if it was incorrect,
request the service again with the corrected information.
248
When CyberSource sent a Boleto Bancário request to CyberSource Latin American
Processing, the processor returned an error to CyberSource.
250
The request was received, but a time-out occurred with the payment processor.
To avoid duplicating the transaction, do not resend the request until you have
reviewed the transaction status in the Business Center.
254
Your CyberSource account is prohibited from processing stand-alone refunds.
In the refund request, provide the requestID of the payment to create a follow-on
refund. If you want to process stand-alone refunds, contact your CyberSource
account representative.
Global Payment Service Developer Guide | March 2015
156
Appendix B
Table 46
Reason Codes
Reason Codes for the Simple Order API (Continued)
Reason
Code
Description
255
Your CyberSource account is not configured to process the service in the country
you specified.
If this is a bank transfer or bank transfer refund, check the billTo_country value and
bankInfo_country value to make sure they are set to the correct country (if it is a
direct debit, check bankInfo_country). If you want to process the service in a
country for which you are not configured, contact your CyberSource account
representative.
Global Payment Service Developer Guide | March 2015
157
APPENDIX
Researching a Missing Bank
Transfer Payment
C
This appendix explains how to submit an inquiry in the Business Center to research a
missing bank transfer payment. For additional information, see:

Simple Order API—"Researching a Missing Payment," page 17

SCMP API—"Researching a Missing Payment," page 35
Note
Wait at least five days after funds are debited from a customer’s account before
initiating an inquiry because it can take that long for funds to appear in your
account and in CyberSource’s reports. CyberSource does not allow you to
perform an inquiry within five days of submitting the initial bank transfer
request.
If your user permissions in the Business Center are limited to only read
access for the Support Screens, you cannot research a missing payment. You
must have additional access permissions. Contact your Business Center
administrator to change your access level.
Before making the inquiry, you must obtain the following items:

Information about the bank account that the customer used to make the payment,
including the name of the bank, the name on the customer’s account, and the account
number.

The date that the funds were debited from the customer’s account.

A digital copy of a document that shows that the customer initiated the bank transfer
(for example, a scanned bank statement or a screen shot of an online banking
statement showing the payment).
Global Payment Service Developer Guide | March 2015
158
Appendix C
Researching a Missing Bank Transfer Payment
To research a missing payment:
Step 1
Log in to the Business Center and search for the bank transfer transaction.
Step 2
View the transaction’s details.
If at least three days have passed since you sent the bank transfer request, Research
Lost Payment appears as an available action.
Step 3
Click Research Lost Payment.
The Research Lost Payment page opens. Part of the form is already filled out with the
original transaction information that CyberSource has.
Global Payment Service Developer Guide | March 2015
159
Appendix C
Researching a Missing Bank Transfer Payment
Step 4
In the Merchant Information section, enter your contact information. CyberSource uses
this information to contact you if more information is needed.
Step 5
In the Customer’s Bank Information section, enter the customer’s bank’s information and
the payment date (the date that the funds were debited from the customer’s account). The
required fields are in bold.
Step 6
In the Attachment field, attach the scanned copy of the customer’s bank statement or
whatever proof the customer has to show that they made the payment.
Step 7
In the Other Information field, include any other information that might help CyberSource
research the missing payment.
Step 8
Click Submit to submit the information to CyberSource.
A confirmation page opens, and the transaction details are updated to show that you have
made a payment inquiry.
Customer Support receives the inquiry information and contacts the processor to
determine whether the processor received the payment. One of two things happens within
several business days:

The processor uses the inquiry information to match the payment to the original bank
transfer request. Confirmation of the bank transfer payment then automatically
appears in the Payment Events Report. The transaction details screen in the Business
Center is also updated to show that the bank transfer has been paid. CyberSource
does not contact you by email or phone to give you the results, so you should monitor
the Payment Events Report or the transaction’s details in the Business Center.

If the processor is unable to find or match the funds to the original bank transfer
request, CyberSource contacts you by email or phone.
Global Payment Service Developer Guide | March 2015
160
INDEX
Index
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
B
bank account validation
bank transfer refunds
SCMP API 35
Simple Order API 17
direct debit refunds
SCMP API 134
Simple Order API 117
direct debits
SCMP API 132
Simple Order API 116
bank transfer refunds
SCMP API 34
Simple Order API 16
bank transfers
and bank transfer refunds
SCMP API 33
Simple Order API 15
examples
SCMP API 46
Simple Order API 28
requesting
SCMP API 33
Simple Order API 15
unpaid 158
SCMP API 90
Simple Order API 84
reports
Boleto Bancário Unfulfilled Report 96
Single Transaction Report 112
requesting
SCMP API 90
Simple Order API 84
C
check reference numbers 13
coupons 154
D
date and time format
Simple Order API 27
direct debit refunds
SCMP API 133
Simple Order API 116
bankTransferRefundService 16
direct debits
and direct debit refunds
SCMP API 132
Simple Order API 115
examples
SCMP API 95
Simple Order API 88, 128, 145
requesting
SCMP API 132
Simple Order API 115
bankTransferService 15
directDebitRefundService 116
boletoPaymentService 84
directDebitService 115
bank transfers, real-time. See real-time bank
transfers
bankTransferRealTimeService 54
Boletos Bancários
description of
Global Payment Service Developer Guide | March 2015
161
Index
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
E
examples
bank transfers
SCMP API 46
Simple Order API 28
direct debits
SCMP API 95
Simple Order API 88, 128, 145
on-demand queries for failed payments
SCMP API 70
Simple Order API 54
on-demand queries for successful payments
SCMP API 69
Simple Order API 53
on-demand queries for transaction status
SCMP API 68
Simple Order API 52
real-time bank transfers
SCMP API 81
Simple Order API 64
F
follow-on refunds
for bank transfers
SCMP API 34
Simple Order API 16
for direct debits
SCMP API 133
Simple Order API 116
G
GMT format
Simple Order API 27
I
ics_bank_transfer 33
ics_bank_transfer_real_time 70
ics_bank_transfer_refund 34
ics_boleto_payment 90
ics_direct_debit 132
Global Payment Service Developer Guide | March 2015
ics_direct_debit_refund 133
M
missing payments, researching 17
O
on-demand queries
real-time bank transfers
SCMP API 67
Simple Order API 51
order tracking 13
P
POST requests
transaction statuses for
SCMP API 67
Simple Order API 51
processor transaction identifiers 13
product codes
listed 154
R
real-time bank transfers
examples
SCMP API 81
Simple Order API 64
examples of on-demand queries for failed
payments
SCMP API 70
Simple Order API 54
examples of on-demand queries for
successful payments
SCMP API 69
Simple Order API 53
examples of on-demand queries for
transaction status
SCMP API 68
Simple Order API 52
refunds
SCMP API 71
Simple Order API 55
162
Index
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
requesting
SCMP API 70
Simple Order API 54
transaction statuses
SCMP API 67
Simple Order API 51
reason codes
listed 155
SCMP API 134
Simple Order API 117
transaction reference numbers 13
U
UTC format
Simple Order API 27
reconciliation IDs 13
refunds
bank transfers
SCMP API 34
Simple Order API 16
direct debits
SCMP API 133
Simple Order API 116
real-time bank transfers
SCMP API 71
Simple Order API 55
reports
Transaction Exception Detail Report
for bank transfers, SCMP API 35
for bank transfers, Simple Order API 17
for direct debits, SCMP API 134
for direct debits, Simple Order API 117
request IDs 13
S
statuses of real-time bank transfers
SCMP API 67
Simple Order API 51
T
test server 149
time format
Simple Order API 27
Transaction Exception Detail Report
for bank transfers
SCMP API 35
Simple Order API 17
for direct debits
Global Payment Service Developer Guide | March 2015
163