Initiate payments
We provide various methods to initiate payments.
The primary method is through our Payments API, which supports both single and bulk payments, in JSON format. The details of these options are explained further in this section.
We also offer the option to submit payments in the pain.001 format, which adheres to the ISO20022 standard in XML. For more information on this method, read how to Initiate payment with pain.001 & pain.002.
About the Payments API
The Payments API enables you to initiate payments either as single payments or bulk payments, depending on the volume and nature of your systems.
Single Payments
The Single Payments endpoint processes individual payments one at a time. It is suitable for use cases where payments are handled individually, such as companies with low payment volumes or systems that process payments individually in near-real time (interactive processing). If your company deals with small amounts of payments at low frequencies, the Single Payments endpoint is the appropriate choice.
Bulk Payments
The Bulk Payments endpoint processes multiple payments simultaneously. It is designed for companies with high payment volumes or systems that handle payments in batches or queues, processed at intervals. The response time for processing 1000 payments in bulk is faster than processing 1000 payments via the Single Payments endpoint.
Find the right account
If you are initiating a payment for the first time and lack an overview of your available accounts click here for a guide on finding the correct account and account information for the debtorAccount.
Initiate a Single payment
To initiate a single payment, a POST request should be sent to the api/v1/payments/singles
endpoint, described in details here: Single payments.
Content specifications Header
Parameter | Required | Allowed input | Description | Example |
---|---|---|---|---|
X-MessageReference | Optional | String | Unique reference of the HTTP request. If left blank this field will be populated with a GUID | 6198eb60-d1dd-4aad-9bbd-b01a49214e62 |
Idempotency-Key | Optional | String | Unique value generated by the user which the API uses to recognize subsequent retries of the same request. This field is limited to a maximum of 100 characters, if not upheld the API will return with an error 400 - Bad Request | 2b7b05ad-4411-4a19-8c95-2508b17e0fd8 |
Content specifications Body
Parameter | Required | Allowed input | Description | Example |
---|---|---|---|---|
requestedExecutionDate | Mandatory | YYYY-MM-DD | The date on which you would like your payment to be processed and debited from your Debtor Account | 05/12/2021 |
fxQuoteId | Optional | GUID | The quote id which includes exchange rate, currency pair and expiry time | 53c7b2c3-d013-4dd7-82ee-458dbc41b2b5 |
debtorAccount | ||||
account | Mandatory | IBAN or account | Account from which funds will be debited | DK1111111111111111 |
financialInstitution | Mandatory if Debtor Account is not an IBAN. Optional otherwise | Bank Identifier Code (BIC) or a National Clearing Code (NCC) | Financial Institution where Debtor Account resides | SXPYDKKKXXX or SC083002 |
country | Mandatory if Debtor Account is not an IBAN. Optional otherwise | ISO Country Code | Country of sender’s bank | DK |
debtorViban | Optional | IBAN | VIBAN belonging to the chosen account. This field should be populated if you wish to use funds from a specific VIBAN | DK1111111111111111 |
debtorReference | Optional | Maximum length: 35. Allowed characters* | Own reference which can be used for your own reconciliation. This value can be found on the reconciliation and rejection reports under User Reference. This field is purely for own reference, i.e. it is not part of the resulting payment | Debtor reference from your system |
debtorNarrativeToSelf | Optional | Maximum length: 35. Allowed characters* | Dual purpose. Narrative to self: This field is purely for your own reference, i.e. it is not part of the resulting payment | Free text field |
currencyOfTransfer | Mandatory | Format of Alpha 3 ISO 4217 | Currency of the amount that will be transferred to the creditor. Only supported currencies allowed | EUR |
amount | ||||
currency | Mandatory | Format of Alpha 3 ISO 4217 | Currency of the amount. Only supported currencies allowed | EUR |
amount | Mandatory | Must be larger than zero and formatted without the one thousand separator using a full stop ‘.’ as the decimal separator. Must conform with allowed number of decimals for selected Amount Currency | Instructed amount | Valid examples (GBP): 100 or 100. or 100.00. Invalid examples (GBP): 1,100 or 1,100.00 or 1100.000 |
chargeBearer | Mandatory | "SHA", "OUR" or "BEN" | Determines which of the parties will be charged the payment fee. BC Connect will either carry the instructed charge bearer value forward, or overwrite the value, before executing the payment. This depends on the client’s “charge bearer setup”, and the payment rail used to execute the payment. | SHA |
remittanceInformation | ||||
line1 | Optional | Maximum length: 35. Allowed characters*. Illegal characters** | Line 1 of the textual information passed from Debtor to Creditor as part of the transfer. Purpose code required for AED and SAR payments in this field. | Free text field |
line2 | Optional | Maximum length: 35. Allowed characters*. Illegal characters** | Line 2 of the textual information passed from Debtor to Creditor as part of the transfer | Free text field |
line3 | Optional | Maximum length: 35. Allowed characters*. Illegal characters** | Line 3 of the textual information passed from Debtor to Creditor as part of the transfer | Free text field |
CreditorId | Mandatory if creditorAccount is left blank | GUID | ID of the creditor if they are created as a pre-defined beneficiary | 3d7279c9-bca2-444f-a872-a8dc042f1c63 |
creditorAccount | ||||
account | Mandatory, unless CreditorId is populated | IBAN or account number | Account of the creditor that will receive funds. Can be either an account number or an International Bank Account Number (IBAN). | DK5989000000054321 |
financialInstitution | Mandatory if CreditorAccount is not an IBAN, and CreditorId is not populated. | Can be either a Bank Identifier Code (BIC) or a National Clearing Code. Supported National Clearing Codes: UK – Sort Code requires prefix with ‘SC’ followed by the 6-digit sort code. US – Fedwire Code requires prefix with ‘FW’ followed by 9-digit Fedwire/ABA. DK - Registration number requires prefix with 'DK' followed by 4-digit Registration number. 'AU' followed by a 6 digit BSB number | Financial Institution where Creditor Account resides | WIREDEMM or SC123456 |
country | Mandatory if Creditor Account is not an IBANAnd CreditorId is not populatedOptional otherwise | ISO Country Code | Country of receiver’s bank | DE |
creditorName | Mandatory if payment targets institutions other than BC | Maximum length: 35. Allowed characters*. Illegal characters** | Legal name of creditor | Beneficiary name |
creditorAddress | ||||
line1 | Mandatory if payment targets institutions other than BC | Maximum length: 35. Allowed characters*. Illegal characters** | Line 1 detailing the address of the Creditor | Address line 1 |
line2 | Optional | Maximum length: 35. Allowed characters*. Illegal characters** | Line 2 detailing the address of the Creditor | Address line 2 |
line3 | Optional | Maximum length: 35. Allowed characters*. Illegal characters** | Line 3 detailing the address of the Creditor. 3rd address line also referred to as city field. Fill with Country as Alpha 2 ISO 3166-1 and city name with postal code | Address line 3 |
clearingNetwork | Optional | Only allowed values: "SEPAINST", "SEPA" or "T2" | Use this parameter to select the payment rail to be used for executing the payment | SEPAINST |
purposeCode | Conditional | “GOD”, “STR”, “CTF” or “OTF” | Purpose code is mandatory for CNH payments going to China | GOD |
*Characters allowed
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
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
0 1 2 3 4 5 6 7 8 9
/ - ? : ( ) . , ' + _
Space
**Illegal characters:
- Field only composed of blank characters (space)
- First character is colon (:) or hyphen (-)
Duplicate check
All single payments submitted via the Single Payments API undergo a duplicate check to ensure that the same payment is not processed twice. If two single payments with the same amount/currency, beneficiary name and address, debtor reference and execution date are submitted, the second payment will be rejected. The second payment will initially be placed in a PendingProcessing
state before being rejected.
Occasionally, two single payments may run simultaneously and bypass the duplicate check due to parallel processing.
Idempotency key
We have enhanced our duplicate checks by extending all payment initiation endpoints to accept an idempotency key header. The key can prevent the same payment from getting initiated more than once, for example in case of connectivity issues. The idempotency key, provided by you, needs to be unique and maximum 100 characters. The key will be valid for 10 days.
If the idempotency key is more than 100 characters, the endpoint will return a "400 Bad Request".
If the idempotency key is not unique (if the key has been used for the initiation of a previous payment within the past 10 days), the endpoint will return a "409 Conflict" and return the paymentId
of the payment, for which the idempotency key was previously used.
This key will not be exposed in any report or endpoint.
Initiate a Bulk payments
To initiate a bulk payment, a POST request should be sent to the api/v1/payments/bulks
endpoint. The content type for bulk payments is multipart/form-data
. Here is a link to the relevant API reference Bulk payments.
Content specifications header
Parameter | Required | Allowed input | Description | Example |
---|---|---|---|---|
X-Content-type | Optional | text/csvv0 | Specifying content type. Currently supported type is "text/csvv0" | text/csvv0 |
X-MessageReference | Optional | String | Unique reference of the HTTP request. If left blank this field will be populated with a GUID | 6198eb60-d1dd-4aad-9bbd-b01a49214e62 |
X-Channel | Optional | channel/api | Channel reference of the payment | channel/api |
ProceedWithErrors | Optional | true or false | Allow Bulk payment to be partially accepted. Read more about partial bulk processing here. Default: false | false |
Idempotency-Key | Optional | String | Unique value generated by the user which the API uses to recognize subsequent retries of the same request. This field is limited to a maximum of 100 characters, if not upheld the API will return with an error 400 - Bad Request | 2b7b05ad-4411-4a19-8c95-2508b17e0fd8 |
Content specifications body
For the bulk payments only CSV files are accepted as body content. Optional fields may be left empty, but not skipped. Insert the comma as when you separate populated fields. Each payment should be on its own line. The content and format of the file is specified in the below table.
Field | Parameter | Required | Allowed input | Description | Example |
---|---|---|---|---|---|
1 | Debtor Customer ID | Mandatory (for technical reasons) | 9-digit Numeric | Customer ID for the debtor account. Field is not utilised, but needs to be populated with a value to ensure that file is read properly | 999999999 |
2 | Debtor Account | Mandatory | IBAN | Account from which you want funds debited | DK4789000000012345 |
3 | Debtor Account Branch Code | Optional | 10 | The bank branch for the debtor account is always 010 | 10 |
4 | Debtor Account Currency | Optional | Alphabetic | The currency for the debtor account populated in field 2 | EUR |
5 | Amount | Mandatory | Must be larger than zero. Separators can not be included | Instructed amount | Valid examples (GBP): 100 or 100. or 100.00. Invalid examples (GBP): 1,100 or 1,100.00 or 1100.000 |
6 | Currency of Transfer | Mandatory | Alphabetic. Format of Alpha 3 ISO 4217 | Currency of the amount that will be transferred to the creditor | EUR |
7 | Requested Execution Date | Mandatory | DDMMYYYY | The date on which you would like your payment to be processed and debited on your Debtor Account. The date must be current date within currency cut off or future Value date | 25012022 |
8 | Payment Type | Optional | A | 'A' (for ad-hoc/general payment type) | A |
9 | Creditor Name | Mandatory if payment targets institutions other than BC | Maximum length: 35 . Allowed characters*. Illegal characters** | Name of the creditor that will receive funds | Company A |
10 | Creditor Account | Mandatory | IBAN or Account no. | Account of the creditor that will receive funds. Can be either an account number or an International Bank Account Number (IBAN) | Examples: IBAN: DK5989000000054321 Account number: 0000054321 |
11 | Transfer Mode | Optional | S | 'S' for SWIFT | S |
12 | Creditor Account Financial Institution | Conditional: Mandatory if Creditor Account is not an IBAN. Optional otherwise | Supported National Clearing Codes: UK - Sort code requires prefix with 'SC' followed by the 6-digit sort code.US - Fedwire Code requires prefix with 'FW' followed by 9-digit Fedwire/ABA code. | Financial Institution where Creditor Account reside. Can be either a Bank Identifier Code (BIC) or a National Clearing Code | Example BIC: SXPYDKKKXXX. National clearing codes: SC123456FW123456789 |
13 | Beneficiary e-mail | Optional | Email of the beneficiary. The field does not carry additional functionality | [email protected] | |
14 | Remittance Information Line 1 | Optional | Maximum length: 35 . Allowed characters*. Illegal characters** | Line 1 of the textual information passed from Debtor to Creditor as part of the transfer. Purpose code required for AED and SAR in this field. | Free text field |
15 | Remittance Information Line 2 | Optional*** | Maximum length: 35 . Allowed characters*. Illegal characters** | Line 2 of the textual information passed from Debtor to Creditor as part of the transfer | Free text field |
16 | Remittance Information Line 3 | Optional*** | Maximum length: 35 . Allowed characters*. Illegal characters** | Line 3 of the textual information passed from Debtor to Creditor as part of the transfer | Free text field |
17 | Remittance Information Line 4 | Optional*** | Maximum length: 35 . Allowed characters*. Illegal characters** | Line 4 of the textual information passed from Debtor to Creditor as part of the transfer | Free text field |
18 | Charge Bearer | Mandatory | "SHA", "BEN" or "OUR" | Determines which of the parties will be charged the payment fee. BC Connect will either carry the instructed charge bearer value forward, or overwrite the value, before executing the payment. This depends on the client’s “charge bearer setup”, and the payment rail used to execute the payment. | SHA |
19 | Debtor Narrative to Self | Optional | Maximum length: 35. Allowed characters* | Dual purpose: Internal reference for client OR Virtual International Bank Account Number (VIBAN): the IBAN of one of your VIBANs | Free text field |
20 | Narrative for Creditor | Optional | Maximum length: 35. Allowed characters* | Additional narrative. The field has no functional impact and not included in reporting. | Free text field |
21 | Amount Currency | Mandatory | Alphabetic | Currency of the Amount Amount Currency must match one of Debtor Account Currency. Example: I would like 100 EUR from my EUR account sent to Creditor Account in GBP (currency of transfer). Currency of transfer. Example: I want to withdraw from my EUR account what is required to pay my invoice of exactly 100 GBP (Currency of transfer) to Creditor Account | GBP |
22 | Debtor Reference | Optional | Maximum length: 35. Allowed characters* | Debtor own reference. Own reference which can be used for own reconciliation. | Debtor reference from your system |
23 | Creditor Address Line 1 | Conditional*** Mandatory if payment targets other institutions than BC | Maximum length: 35. Allowed characters*. Illegal characters** | Line 1 detailing the address of the Creditor. Mandatory: Only for payment targeting other institutions than BC | Free text field |
24 | Creditor Address Line 2 | Optional*** | Maximum length: 35. Allowed characters*. Illegal characters** | Line 2 detailing the address of the Creditor | Free text field |
25 | Creditor Address Line 3 | Optional*** | Maximum length: 35. Allowed characters*. Illegal characters** | Line 3 detailing the address of the Creditor3rd address line also referred to as city field. Fill with country/city name with postal code. | Examples: DK - 2900 Hellerup or GB - London EC2M 4AY |
26 | Intracompany | Optional | N | 'N' can be used | N |
27 | Clearing network | Optional | Only allowed values: "SEPAINST", "SEPA" or "T2" | Use this parameter to select the payment rail to be used for executing the payment | SEPAINST |
28 | Purpose code | Optional | Only allowed values: “GOD”, “STR”, “CTF” or “OTF” | Purpose code is mandatory for CNH payments going to China | GOD |
*Allowed characters:
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
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
0 1 2 3 4 5 6 7 8 9
/ - ? : ( ) . , ' + _
Space
**Illegal characters:
- Field only composed of blank characters (space)
- First character is colon (:) or hyphen (–)
Example of CSV file content
123456789,DK1111000000010011,015,DKK,20,DKK,10012022,A,Financial Inst.Ltd.,DK1111000000010100,S,SXPYDKKKXXX,,MESSAGE,,,,SHA,,,DKK,hello1234567,45
BOD,SOMETHING,FR - GRENOBLE 38100,N
123456789,DK1111000000010100,010,DKK,20,DKK,10012022,A,Financial
Inst.
Ltd.,DK1111000000010011,S,SXPYDKKKXXX,,MESSAGE,,,,SHA,,,DKK,hello1234568,45
BOD,SOMETHING,FR - GRENOBLE 38100,N
Partial bulk processing
When sending bulk files to the api/v1/payments/bulks
endpoint, if some payments contain errors, they will be caught by our validations. In such cases, you will receive a rejection response with a list of errors, like the example below:
{
"type": "Csv",
"errors": [
{
"fieldIndex": 7,
"elementIndex": 1,
"errorCode": "RequestedExecutionDateDaysInPastThresholdViolation",
"errorDescription": "Requested Execution Date exceeds allowed number of days in the past."
}
],
"canProceedWithErrors": true
}
Properties explained
canProceedWithErrors
:
Boolean property that informs you if BC Connect can continue processing the valid payment instructions from your bulk file. When this property is false, you can't proceed, and the file is rejected completely. When it's true, you can choose to continue.
ProceedWithErrors
:
Boolean optional header parameter that allows you to continue with your bulk file in case of errors, given that canProceedWithErrors
property is true. If you want to continue with the same file, you can resend it to /api/v1/payments/bulks
by adding the ProceedWithErrors
header parameter as true to signal that we may proceed with uploading the file. This action will initiate the valid payments in the file and disregard the invalid ones.
Click here to check the response schema for 400 Bad Request and the header parameters for the bulk payments endpoint.
The invalid payments can be retrieved from GET /api/v1/payments/singles
and filter per
bulkId
and from the GET /api/v1/reports/rejection-report
. You can correct and then reinitiate the payments as singles, or another file can be uploaded only including the corrected payments.
Duplicate check
If two identical bulk files are submitted, one of them will be rejected. Changing a single character within the file will pass the duplicate check, and the payments will be sent for processing. However, if only the name of the file is changed, it will not pass the duplicate check and will be rejected. We keep a hash of submitted bulk payment files for 100 days to prevent duplicate processing.
Duplicate bulk payments will result in the error message: "DuplicateFileUpload".
Idempotency key
We have enhanced our duplicate checks by extending all payment initiation endpoints to accept an idempotency key header. The key can prevent the same payment from getting initiated more than once, for example in case of connectivity issues. The idempotency key, provided by you, needs to be unique and maximum 100 characters. The key will be valid for 10 days.
If the idempotency key is more than 100 characters, the endpoint will return a "400 Bad Request".
If the idempotency key is not unique (if the key has been used for the initiation of a previous payment within the past 10 days), the endpoint will return a "409 Conflict" and return the paymentId
of the payment, for which the idempotency key was previously used.
This key will not be exposed in any report or endpoint.
Cancel a payment
The API utilises Straight-Through-Processing, allowing valid payments to be directly sent to our core system for processing. Once a payment has been initiated, it can only be cancelled if it has a future execution date that has not yet passed.
After initiating a payment
Upon successfully sending a payment, you will receive a response containing the payment's ID and initial status. An example response is provided below:
{
"paymentBulkId": "3fa85f64-5717-4562-b3fc-2c963f66afa6",
"status": "PendingProcessing"
}
Updated 4 months ago
Next you can keep an eye on the status of your payment and get to know what the potential errors and rejection reasons can be.