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

ParameterRequiredAllowed inputDescriptionExample
X-MessageReferenceOptionalStringUnique reference of the HTTP request. If left blank this field will be populated with a GUID6198eb60-d1dd-4aad-9bbd-b01a49214e62
Idempotency-KeyOptionalStringUnique 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 Request2b7b05ad-4411-4a19-8c95-2508b17e0fd8

Content specifications Body

ParameterRequiredAllowed inputDescriptionExample
requestedExecutionDateMandatoryYYYY-MM-DDThe date on which you would like your payment to be processed and debited from your Debtor Account05/12/2021
fxQuoteIdOptionalGUIDThe quote id which includes exchange rate, currency pair and expiry time53c7b2c3-d013-4dd7-82ee-458dbc41b2b5
debtorAccount
accountMandatoryIBAN or accountAccount from which funds will be debitedDK1111111111111111
financialInstitutionMandatory if Debtor Account is not an IBAN. Optional otherwiseBank Identifier Code (BIC) or a National Clearing Code (NCC)Financial Institution where Debtor Account residesSXPYDKKKXXX or SC083002
countryMandatory if Debtor Account is not an IBAN. Optional otherwiseISO Country CodeCountry of sender’s bankDK
debtorVibanOptionalIBANVIBAN belonging to the chosen account. This field should be populated if you wish to use funds from a specific VIBANDK1111111111111111
debtorReferenceOptionalMaximum 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 paymentDebtor reference from your system
debtorNarrativeToSelfOptionalMaximum 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 paymentFree text field
currencyOfTransferMandatoryFormat of Alpha 3 ISO 4217Currency of the amount that will be transferred to the creditor. Only supported currencies allowedEUR
amount
currencyMandatoryFormat of Alpha 3 ISO 4217Currency of the amount. Only supported currencies allowedEUR
amountMandatoryMust 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 CurrencyInstructed amountValid examples (GBP): 100 or 100. or 100.00. Invalid examples (GBP): 1,100 or 1,100.00 or 1100.000
chargeBearerMandatory"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
line1OptionalMaximum 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
line2OptionalMaximum length: 35. Allowed characters*. Illegal characters**Line 2 of the textual information passed from Debtor to Creditor as part of the transferFree text field
line3OptionalMaximum length: 35. Allowed characters*. Illegal characters**Line 3 of the textual information passed from Debtor to Creditor as part of the transferFree text field
CreditorIdMandatory if creditorAccount is left blankGUIDID of the creditor if they are created as a pre-defined beneficiary3d7279c9-bca2-444f-a872-a8dc042f1c63
creditorAccount
accountMandatory, unless CreditorId is populatedIBAN or account numberAccount of the creditor that will receive funds. Can be either an account number or an International Bank Account Number (IBAN).DK5989000000054321
financialInstitutionMandatory 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 numberFinancial Institution where Creditor Account residesWIREDEMM or SC123456
countryMandatory if Creditor Account is not an IBANAnd CreditorId is not populatedOptional otherwiseISO Country CodeCountry of receiver’s bankDE
creditorNameMandatory if payment targets institutions other than BCMaximum length: 35. Allowed characters*. Illegal characters**Legal name of creditorBeneficiary name
creditorAddress
line1Mandatory if payment targets institutions other than BCMaximum length: 35. Allowed characters*. Illegal characters**Line 1 detailing the address of the CreditorAddress line 1
line2OptionalMaximum length: 35. Allowed characters*. Illegal characters**Line 2 detailing the address of the CreditorAddress line 2
line3OptionalMaximum 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 codeAddress line 3
clearingNetworkOptionalOnly allowed values: "SEPAINST", "SEPA" or "T2"Use this parameter to select the payment rail to be used for executing the paymentSEPAINST
purposeCodeConditional“GOD”, “STR”, “CTF” or “OTF”Purpose code is mandatory for CNH payments going to ChinaGOD

*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

ParameterRequiredAllowed inputDescriptionExample
X-Content-typeOptionaltext/csvv0Specifying content type. Currently supported type is "text/csvv0"text/csvv0
X-MessageReferenceOptionalStringUnique reference of the HTTP request. If left blank this field will be populated with a GUID6198eb60-d1dd-4aad-9bbd-b01a49214e62
X-ChannelOptionalchannel/apiChannel reference of the paymentchannel/api
ProceedWithErrorsOptionaltrue or falseAllow Bulk payment to be partially accepted. Read more about partial bulk processing here.
Default: false
false
Idempotency-KeyOptionalStringUnique 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 Request2b7b05ad-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.

FieldParameterRequiredAllowed inputDescriptionExample
1Debtor Customer IDMandatory (for technical reasons)9-digit NumericCustomer ID for the debtor account. Field is not utilised, but needs to be populated with a value to ensure that file is read properly999999999
2Debtor AccountMandatoryIBANAccount from which you want funds debitedDK4789000000012345
3Debtor Account Branch CodeOptional10The bank branch for the debtor account is always 01010
4Debtor Account CurrencyOptionalAlphabeticThe currency for the debtor account populated in field 2EUR
5AmountMandatoryMust be larger than zero. Separators can not be includedInstructed amountValid examples (GBP): 100 or 100. or 100.00. Invalid examples (GBP): 1,100 or 1,100.00 or 1100.000
6Currency of TransferMandatoryAlphabetic. Format of Alpha 3 ISO 4217Currency of the amount that will be transferred to the creditorEUR
7Requested Execution DateMandatoryDDMMYYYYThe 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 date25012022
8Payment TypeOptionalA'A' (for ad-hoc/general payment type)A
9Creditor NameMandatory if payment targets institutions other than BCMaximum length: 35 . Allowed characters*. Illegal characters**Name of the creditor that will receive fundsCompany A
10Creditor AccountMandatoryIBAN 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
11Transfer ModeOptionalS'S' for SWIFTS
12Creditor Account Financial InstitutionConditional: Mandatory if Creditor Account is not an IBAN. Optional otherwiseSupported 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 CodeExample BIC: SXPYDKKKXXX. National clearing codes: SC123456FW123456789
13Beneficiary e-mailOptionalE-mailEmail of the beneficiary. The field does not carry additional functionality[email protected]
14Remittance Information Line 1OptionalMaximum 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
15Remittance Information Line 2Optional***Maximum length: 35 . Allowed characters*. Illegal characters**Line 2 of the textual information passed from Debtor to Creditor as part of the transferFree text field
16Remittance Information Line 3Optional***Maximum length: 35 . Allowed characters*. Illegal characters**Line 3 of the textual information passed from Debtor to Creditor as part of the transferFree text field
17Remittance Information Line 4Optional***Maximum length: 35 . Allowed characters*. Illegal characters**Line 4 of the textual information passed from Debtor to Creditor as part of the transferFree text field
18Charge BearerMandatory"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
19Debtor Narrative to SelfOptionalMaximum length: 35. Allowed characters*Dual purpose: Internal reference for client OR Virtual International Bank Account Number (VIBAN): the IBAN of one of your VIBANsFree text field
20Narrative for CreditorOptionalMaximum length: 35. Allowed characters*Additional narrative. The field has no functional impact and not included in reporting.Free text field
21Amount CurrencyMandatoryAlphabeticCurrency 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
22Debtor ReferenceOptionalMaximum length: 35. Allowed characters*Debtor own reference. Own reference which can be used for own reconciliation.Debtor reference from your system
23Creditor Address Line 1Conditional***
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 BCFree text field
24Creditor Address Line 2Optional***Maximum length: 35. Allowed characters*. Illegal characters**Line 2 detailing the address of the CreditorFree text field
25Creditor Address Line 3Optional***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
26IntracompanyOptionalN'N' can be usedN
27Clearing networkOptionalOnly allowed values: "SEPAINST", "SEPA" or "T2"Use this parameter to select the payment rail to be used for executing the paymentSEPAINST
28Purpose codeOptionalOnly allowed values: “GOD”, “STR”, “CTF” or “OTF”Purpose code is mandatory for CNH payments going to ChinaGOD

*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"  
}

What’s Next

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.