Central Ledger API Documentation
Base URL: /, Version: 1.0
Summary
Tag: enums
Operation | Description |
---|---|
GET /enums |
Tag: health
Operation | Description |
---|---|
GET /health |
Tag: metrics
Operation | Description |
---|---|
GET /metrics | Prometheus metrics endpoint |
Tag: participants
Operation | Description |
---|---|
GET /participants | |
POST /participants | |
GET /participants/limits | View limits for all participants |
GET /participants/{name} | |
PUT /participants/{name} | |
GET /participants/{name}/endpoints | View participant endpoints |
POST /participants/{name}/endpoints | Add/Update participant endpoints |
GET /participants/{name}/limits | View participant limits |
PUT /participants/{name}/limits | Adjust participant limits |
GET /participants/{name}/positions | View participant positions |
GET /participants/{name}/accounts | View participant accounts and balances |
POST /participants/{name}/accounts | Create hub accounts |
POST /participants/{name}/initialPositionAndLimits | Add initial participant limits and position |
POST /participants/{name}/accounts/{id} | Record Funds In or Out of participant account |
PUT /participants/{name}/accounts/{id} | Update participant accounts |
PUT /participants/{name}/accounts/{id}/transfers/{transferId} | Record Funds In or Out of participant account |
Tag: ledgerAccountTypes
Operation | Description |
---|---|
GET /ledgerAccountTypes | View all ledger account types |
Tag: ledgerAccountType
Operation | Description |
---|---|
POST /ledgerAccountTypes | Create a ledgerAccount type |
Tag: settlementModels
Operation | Description |
---|---|
GET /settlementModels | View all settlement models |
POST /settlementModels | Create a settlement model. This will create any associated ledgerAccountTypes for every participant that matches the settlementModel's currency |
GET /settlementModels/{name} | View settlement model by name |
PUT /settlementModels/{name} | Update a settlement model |
Tag: transaction
Operation | Description |
---|---|
GET /transactions/{id} | Retrieve transaction details by a transferId |
Paths
GET /enums
Tags: enums- default
-
Successful
GET /health
Tags: health- default
-
Successful
- default
-
Successful
- default
-
Successful
GET /participants
Tags: participantsName | Description | Type | Data Type | Annotation |
---|---|---|---|---|
isProxy | Filter by if participant is a proxy |
query | string,boolean,integer,null , x ∈ { false , 0 , false , , true , 1 , true , } |
- default
-
Successful
POST /participants
Tags: participantsName | Description | Type | Data Type | Annotation |
---|---|---|---|---|
currency | Currency code |
query | string , x ∈ { AED , AFA , AFN , ALL , AMD , ANG , AOA , AOR , ARS , AUD , AWG , AZN , BAM , BBD , BDT , BGN , BHD , BIF , BMD , BND , BOB , BRL , BSD , BTN , BWP , BYN , BZD , CAD , CDF , CHF , CLP , CNY , COP , CRC , CUC , CUP , CVE , CZK , DJF , DKK , DOP , DZD , EEK , EGP , ERN , ETB , EUR , FJD , FKP , GBP , GEL , GGP , GHS , GIP , GMD , GNF , GTQ , GYD , HKD , HNL , HRK , HTG , HUF , IDR , ILS , IMP , INR , IQD , IRR , ISK , JEP , JMD , JOD , JPY , KES , KGS , KHR , KMF , KPW , KRW , KWD , KYD , KZT , LAK , LBP , LKR , LRD , LSL , LTL , LVL , LYD , MAD , MDL , MGA , MKD , MMK , MNT , MOP , MRO , MUR , MVR , MWK , MXN , MYR , MZN , NAD , NGN , NIO , NOK , NPR , NZD , OMR , PAB , PEN , PGK , PHP , PKR , PLN , PYG , QAR , RON , RSD , RUB , RWF , SAR , SBD , SCR , SDG , SEK , SGD , SHP , SLL , SOS , SPL , SRD , STD , SVC , SYP , SZL , THB , TJS , TMT , TND , TOP , TRY , TTD , TVD , TWD , TZS , UAH , UGX , USD , UYU , UZS , VEF , VND , VUV , WST , XAF , XAG , XAU , XCD , XDR , XFO , XFU , XOF , XPD , XPF , XPT , YER , ZAR , ZMK , ZMW , ZWD , ZWL , ZWN , ZWR } | |
type | Limit Type |
query | string |
- default
-
Successful
GET /participants/{name}
Tags: participantsName | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Participant name |
path | string |
- default
-
Successful
PUT /participants/{name}
Tags: participantsName | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Participant name |
path | string |
- default
-
Successful
Name | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Name of the participant |
path | string (2 to 30 chars) |
- default
-
Successful
Name | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Participant name |
path | string |
- default
-
Successful
POST /participants/{name}/accounts/{id}
Tags: participantsName | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Name of the participant |
path | string (2 to 30 chars) | |
id | path | integer |
- default
-
Successful
Name | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Name of the participant |
path | string (2 to 30 chars) | |
id | path | integer |
- default
-
Successful
PUT /participants/{name}/accounts/{id}/transfers/{transferId}
Tags: participantsName | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Name of the participant |
path | string (2 to 30 chars) | |
id | path | integer | ||
transferId | path | string |
- default
-
Successful
Name | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Name of the participant |
path | string (2 to 30 chars) |
- default
-
Successful
Name | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Name of the participant |
path | string (2 to 30 chars) |
- default
-
Successful
POST /participants/{name}/initialPositionAndLimits
Tags: participantsName | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Name of the participant |
path | string (2 to 30 chars) |
- default
-
Successful
Name | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Name of the participant |
path | string (2 to 30 chars) | |
currency | Currency code |
query | string , x ∈ { AED , AFA , AFN , ALL , AMD , ANG , AOA , AOR , ARS , AUD , AWG , AZN , BAM , BBD , BDT , BGN , BHD , BIF , BMD , BND , BOB , BRL , BSD , BTN , BWP , BYN , BZD , CAD , CDF , CHF , CLP , CNY , COP , CRC , CUC , CUP , CVE , CZK , DJF , DKK , DOP , DZD , EEK , EGP , ERN , ETB , EUR , FJD , FKP , GBP , GEL , GGP , GHS , GIP , GMD , GNF , GTQ , GYD , HKD , HNL , HRK , HTG , HUF , IDR , ILS , IMP , INR , IQD , IRR , ISK , JEP , JMD , JOD , JPY , KES , KGS , KHR , KMF , KPW , KRW , KWD , KYD , KZT , LAK , LBP , LKR , LRD , LSL , LTL , LVL , LYD , MAD , MDL , MGA , MKD , MMK , MNT , MOP , MRO , MUR , MVR , MWK , MXN , MYR , MZN , NAD , NGN , NIO , NOK , NPR , NZD , OMR , PAB , PEN , PGK , PHP , PKR , PLN , PYG , QAR , RON , RSD , RUB , RWF , SAR , SBD , SCR , SDG , SEK , SGD , SHP , SLL , SOS , SPL , SRD , STD , SVC , SYP , SZL , THB , TJS , TMT , TND , TOP , TRY , TTD , TVD , TWD , TZS , UAH , UGX , USD , UYU , UZS , VEF , VND , VUV , WST , XAF , XAG , XAU , XCD , XDR , XFO , XFU , XOF , XPD , XPF , XPT , YER , ZAR , ZMK , ZMW , ZWD , ZWL , ZWN , ZWR } | |
type | Limit Type |
query | string |
- default
-
Successful
Name | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Name of the participant |
path | string (2 to 30 chars) |
- default
-
Successful
Name | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | Name of the participant |
path | string (2 to 30 chars) | |
currency | Currency code |
query | string , x ∈ { AED , AFA , AFN , ALL , AMD , ANG , AOA , AOR , ARS , AUD , AWG , AZN , BAM , BBD , BDT , BGN , BHD , BIF , BMD , BND , BOB , BRL , BSD , BTN , BWP , BYN , BZD , CAD , CDF , CHF , CLP , CNY , COP , CRC , CUC , CUP , CVE , CZK , DJF , DKK , DOP , DZD , EEK , EGP , ERN , ETB , EUR , FJD , FKP , GBP , GEL , GGP , GHS , GIP , GMD , GNF , GTQ , GYD , HKD , HNL , HRK , HTG , HUF , IDR , ILS , IMP , INR , IQD , IRR , ISK , JEP , JMD , JOD , JPY , KES , KGS , KHR , KMF , KPW , KRW , KWD , KYD , KZT , LAK , LBP , LKR , LRD , LSL , LTL , LVL , LYD , MAD , MDL , MGA , MKD , MMK , MNT , MOP , MRO , MUR , MVR , MWK , MXN , MYR , MZN , NAD , NGN , NIO , NOK , NPR , NZD , OMR , PAB , PEN , PGK , PHP , PKR , PLN , PYG , QAR , RON , RSD , RUB , RWF , SAR , SBD , SCR , SDG , SEK , SGD , SHP , SLL , SOS , SPL , SRD , STD , SVC , SYP , SZL , THB , TJS , TMT , TND , TOP , TRY , TTD , TVD , TWD , TZS , UAH , UGX , USD , UYU , UZS , VEF , VND , VUV , WST , XAF , XAG , XAU , XCD , XDR , XFO , XFU , XOF , XPD , XPF , XPT , YER , ZAR , ZMK , ZMW , ZWD , ZWL , ZWN , ZWR } |
- default
-
Successful
- default
-
Successful
POST /settlementModels
Tags: settlementModelsName | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | SettlementModel name |
path | string |
- default
-
Successful
Name | Description | Type | Data Type | Annotation |
---|---|---|---|---|
name | settlementModel name |
path | string |
- default
-
Successful
Name | Description | Type | Data Type | Annotation |
---|---|---|---|---|
id | Transfer Id |
path | string |
- default
-
Successful
Schema definitions
The API data type Amount is a JSON String in a canonical format that is restricted by a regular expression for interoperability reasons. This pattern does not allow any trailing zeroes at all, but allows an amount without a minor currency unit. It also only allows four digits in the minor currency unit; a negative value is not allowed. Using more than 18 digits in the major currency unit is not allowed.
Currency: string , x ∈ { AED , AFN , ALL , AMD , ANG , AOA , ARS , AUD , AWG , AZN , BAM , BBD , BDT , BGN , BHD , BIF , BMD , BND , BOB , BRL , BSD , BTN , BWP , BYN , BZD , CAD , CDF , CHF , CLP , CNY , COP , CRC , CUC , CUP , CVE , CZK , DJF , DKK , DOP , DZD , EGP , ERN , ETB , EUR , FJD , FKP , GBP , GEL , GGP , GHS , GIP , GMD , GNF , GTQ , GYD , HKD , HNL , HRK , HTG , HUF , IDR , ILS , IMP , INR , IQD , IRR , ISK , JEP , JMD , JOD , JPY , KES , KGS , KHR , KMF , KPW , KRW , KWD , KYD , KZT , LAK , LBP , LKR , LRD , LSL , LYD , MAD , MDL , MGA , MKD , MMK , MNT , MOP , MRO , MUR , MVR , MWK , MXN , MYR , MZN , NAD , NGN , NIO , NOK , NPR , NZD , OMR , PAB , PEN , PGK , PHP , PKR , PLN , PYG , QAR , RON , RSD , RUB , RWF , SAR , SBD , SCR , SDG , SEK , SGD , SHP , SLL , SOS , SPL , SRD , STD , SVC , SYP , SZL , THB , TJS , TMT , TND , TOP , TRY , TTD , TVD , TWD , TZS , UAH , UGX , USD , UYU , UZS , VEF , VND , VUV , WST , XAF , XCD , XDR , XOF , XPF , YER , ZAR , ZMW , ZWD } (3 to 3 chars)
The currency codes defined in ISO 4217 as three-letter alphabetic codes are used as the standard naming representation for currencies.
Data model for the complex type Extension
- key: string
-
Extension key.
- value: string
-
Extension value.
Data model for the complex type ExtensionList
- extension: object[]
-
Number of Extension elements
GET /transaction/{id} response object
- quoteId: QuoteId
-
Common id between the FSPs for the quote object, decided by the Payer FSP. The id should be reused for resends of the same quote for a transaction. A new id should be generated for each new quote for a transaction.
- transactionId: TransactionId
-
Common id (decided by the Payer FSP) between the FSPs for the future transaction object. The actual transaction will be created as part of a successful transfer process. The id should be reused for resends of the same quote for a transaction. A new id should be generated for each new quote for a transaction.
- transactionRequestId: string
-
Identifies an optional previously-sent transaction request.
- payee: Party
-
Information about the Payee in the proposed financial transaction.
- payer: Party
-
Information about the Payer in the proposed financial transaction.
- amount: Money
-
Depending on amountType. If SEND - The amount the Payer would like to send, that is, the amount that should be withdrawn from the Payer account including any fees. The amount is updated by each participating entity in the transaction. If RECEIVE - The amount the Payee should receive, that is, the amount that should be sent to the receiver exclusive any fees. The amount is not updated by any of the participating entities.
- transactionType: TransactionType
-
Type of transaction for which the quote is requested.
- note: string
-
A memo that will be attached to the transaction.
- extensionList: ExtensionList
-
Optional extension, specific to deployment.
- name: string (2 to 30 chars) , must match ^\w+$
-
Name of the ledger account type
- description: string
-
Description of the ledger account type
- isActive: boolean
-
Determines whether the ledger account is active
- isSettleable: boolean
-
Determines whether the ledger account is settleable
- amount: number
-
- currency: Currency
-
Currency code
Participant Limit
- type: string
-
Limit Type
- value: number
-
Limit Value
- alarmPercentage: number
-
limit threshold alarm percentage value
- transferId: string
-
- externalReference: string
-
- action: string , x ∈ { recordFundsIn , recordFundsOutPrepareReserve }
-
- reason: string
-
- amount: NoAmountProvided
-
- extensionList: ExtensionList
-
Data model for the complex type Party.
- partyIdInfo: PartyIdInfo
-
Party Id type, id, sub id or type, and FSP Id.
- merchantClassificationCode: string
-
Used in the context of Payee Information, where the Payee happens to be a merchant accepting merchant payments.
- name: string
-
Display name of the Party, could be a real name or a nick name.
- personalInfo: PartyPersonalInfo
-
Personal information used to verify identity of Party such as first, middle, last name and date of birth.
Data model for the complex type PartyComplexName.
- firstName: string
-
Party’s first name.
- middleName: string
-
Party’s middle name.
- lastName: string
-
Party’s last name.
Data model for the complex type PartyIdInfo.
- partyIdType: PartyIdType
-
Type of the identifier.
- partyIdentifier: PartyIdentifier
-
An identifier for the Party.
- partySubIdOrType: string
-
A sub-identifier or sub-type for the Party.
- fspId: string
-
FSP id (if known)
- extensionList: ExtensionList
-
Optional extension, specific to deployment.
PartyIdType: string , x ∈ { MSISDN , EMAIL , PERSONAL_ID , BUSINESS , DEVICE , ACCOUNT_ID , IBAN , ALIAS }
Below are the allowed values for the enumeration - MSISDN An MSISDN (Mobile Station International Subscriber Directory Number, that is, the phone number) is used as reference to a participant. The MSISDN identifier should be in international format according to the ITU-T E.164 standard. Optionally, the MSISDN may be prefixed by a single plus sign, indicating the international prefix. - EMAIL An email is used as reference to a participant. The format of the email should be according to the informational RFC 3696. - PERSONAL_ID A personal identifier is used as reference to a participant. Examples of personal identification are passport number, birth certificate number, and national registration number. The identifier number is added in the PartyIdentifier element. The personal identifier type is added in the PartySubIdOrType element. - BUSINESS A specific Business (for example, an organization or a company) is used as reference to a participant. The BUSINESS identifier can be in any format. To make a transaction connected to a specific username or bill number in a Business, the PartySubIdOrType element should be used. - DEVICE A specific device (for example, a POS or ATM) id connected to a specific business or organization is used as reference to a Party. For referencing a specific device under a specific business or organization, use the PartySubIdOrType element. - ACCOUNT_ID A bank account number or FSP account id should be used as reference to a participant. The ACCOUNT_ID identifier can be in any format, as formats can greatly differ depending on country and FSP. - IBAN A bank account number or FSP account id is used as reference to a participant. The IBAN identifier can consist of up to 34 alphanumeric characters and should be entered without whitespace. - ALIAS An alias is used as reference to a participant. The alias should be created in the FSP as an alternative reference to an account owner. Another example of an alias is a username in the FSP system. The ALIAS identifier can be in any format. It is also possible to use the PartySubIdOrType element for identifying an account under an Alias defined by the PartyIdentifier.
Data model for the complex type PartyPersonalInfo.
- complexName: PartyComplexName
-
First, middle and last name for the Party.
- dateOfBirth: string
-
Date of birth for the Party.
- currency: Currency
-
- type: string
-
Account type
- type: string
-
Endpoint Type
- value: string
-
Endpoint Value
- name: string (2 to 30 chars)
-
Name of the participant
- currency: Currency
-
Currency code
- isProxy: boolean
-
Is the participant a proxy
- currency: Currency
-
Currency code
- limit: ParticipantLimit
-
QuoteId: string (at least 1 chars) , must match ^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$
Quote Identifier. The API data type UUID (Universally Unique Identifier) is a JSON String in canonical format, conforming to RFC 4122, that is restricted by a regular expression for interoperability reasons. An UUID is always 36 characters long, 32 hexadecimal symbols and 4 dashes (‘-‘). A minLength of 1 has been specified due to the regex not being validated on empty strings, this should be removed once the enjoi module has been fixed.
- action: string , x ∈ { recordFundsOutCommit , recordFundsOutAbort }
-
- reason: string
-
Data model for the complex type Refund.
- originalTransactionId: string
-
Reference to the original transaction id that is requested to be refunded.
- refundReason: string
-
Free text indicating the reason for the refund.
- name: string (2 to 30 chars)
-
Name of the settlement model
- settlementGranularity: string , x ∈ { GROSS , NET }
-
Granularity type for the settlement model GROSS or NET
- settlementInterchange: string , x ∈ { BILATERAL , MULTILATERAL }
-
Interchange type for the settlement model BILATERAL or MULTILATERAL
- settlementDelay: string , x ∈ { DEFERRED , IMMEDIATE }
-
Delay type for the settlement model IMMEDIATE or DEFERRED
- currency: Currency
-
Currency code
- requireLiquidityCheck: boolean
-
Liquidity Check boolean
- ledgerAccountType: string , x ∈ { INTERCHANGE_FEE , POSITION }
-
Account type for the settlement model
- settlementAccountType: string
-
Account type into which the settlement should be settled into : POSITION, SETTLEMENT or INTERCHANGE_FEE_SETTLEMENT
- autoPositionReset: boolean
-
Automatic position reset setting, which determines whether to execute the settlement transfer or not
TransactionId: string (at least 1 chars) , must match ^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$
Transaction Identifier. The API data type UUID (Universally Unique Identifier) is a JSON String in canonical format, conforming to RFC 4122, that is restricted by a regular expression for interoperability reasons. An UUID is always 36 characters long, 32 hexadecimal symbols and 4 dashes (‘-‘). A minLength of 1 has been specified due to the regex not being validated on empty strings, this should be removed once the enjoi module has been fixed.
Data model for the complex type TransactionType.
- scenario: string
-
Deposit, withdrawal, refund, …
- subScenario: string
-
Possible sub-scenario, defined locally within the scheme.
- initiator: string
-
Who is initiating the transaction - Payer or Payee
- initiatorType: string
-
Consumer, agent, business, …
- refundInfo: Refund
-
Extra information specific to a refund scenario. Should only be populated if scenario is REFUND
- balanceOfPayments: string
-
Balance of Payments code.