The Electrum Regulated Payments API is an asynchronous API that allows partners to participate in various nationally regulated payment schemes.
This document describes the operations exposed by Electrum for partners to consume in order to initiate outbound or respond to inbound payments.
As the Regulated Payments API is asynchronous, partners have a choice of how to integrate with Electrum:
Receiving transactional events via webhooks or API are equivalent, except that it may be more familiar or convenient to implement one style or the other. Partners may request the method of communication Electrum should use when selecting which payment schemes to participate in.
https://example.com/path/payments/api/v1/
An extension of BaseMessage which includes additional information pertinent to an asynchronous response message. In particular, original message identifiers.
Holds a point-to-point unique message identification string as well as a message's creation date time.
The date and time at which the message was created, in senders local timezone or UTC. The date must be formatted as defined by date-time in RFC3339
A list of key-value pairs to support adding any supplementary/additional data to an Electrum Regulated Payments API message.
Holds a point-to-point unique message identification string as well as a message's creation date time.
The date and time at which the message was created, in senders local timezone or UTC. The date must be formatted as defined by date-time in RFC3339
A code allocated to a financial or non-financial institution by the ISO 9362 Registration Authority as described in ISO 9362 Banking - Banking telecommunication messages - Business identifier code (BIC)
An organisation identified by a code allocated to a party as described in ISO 17442 Financial Services - Legal Entity Identifier (LEI).
Name by which an institution is known and which is usually used to identify that institution
A unique identifier assigned to a company or organisation by a duly appointed authority within a country.
A code allocated to a financial or non-financial institution by the ISO 9362 Registration Authority as described in ISO 9362 Banking - Banking telecommunication messages - Business identifier code (BIC)
An organisation identified by a code allocated to a party as described in ISO 17442 Financial Services - Legal Entity Identifier (LEI).
Name by which an institution is known and which is usually used to identify that institution
A unique identifier assigned to a company or organisation by a duly appointed authority within a country.
The date and time at which the message was created, in senders local timezone or UTC. The date must be formatted as defined by date-time in RFC3339
Specifies the details of the underlying transaction being cancelled
Designates which scheme a resolution of investigation is associated with and describes scheme-specific information.
Identifies the scheme used for the payment
ZA_RTC: South African Realtime Clearing scheme.ZA_RPP: South African Realtime Payments Platform scheme.ZA_EFT: South African Electronic Funds Transfer scheme.ZA_AC : South African Authenticated Collections scheme.ZA_RMS: South African Registered Mandate Service scheme.CBPR_PLUS: Cross-Border Payments and Reporting Plus.{ "messageIdentifiers": { "creationDateTime": "2019-08-24T14:15:22Z", "messageIdentification": "string" }, "supplementaryData": { "property1": "string", "property2": "string" }, "originalMessageIdentifiers": { "creationDateTime": "2019-08-24T14:15:22Z", "messageIdentification": "string" }, "assignment": { "assignee": { … }, "assigner": { … }, "creationDateTime": "2019-08-24T14:15:22Z", "identification": "string" }, "cancellationDetails": { "cancellationStatusReasonInfo": { … }, "originalTransaction": { … }, "originalTransactionIdentifiers": { … }, "transactionCancellationStatus": "RJCR" }, "correctionTransaction": { "messageIdentifiers": { … }, "schema": "CORRECTIVE_INTERBANK_TRANSACTION", "settlementAmount": { … }, "settlementDate": "2019-08-24", "transactionIdentification": { … } }, "paymentScheme": { "schema": "ZA_RTC" }, "resolvedCase": { "creator": { … }, "identification": "string", "reopenCaseIndication": true }, "schema": "ResolutionOfInvestigation", "status": { "confirmationCode": "ACDA", "statusType": "CONFIRMATION" } }
AC01: IncorrectAccountNumberAC03: InvalidCreditorAccountNumberAC04: ClosedAccountNumberAC06: BlockedAccountAC13: InvalidDebtorAccountTypeAC14: InvalidAgentAC15: AccountDetailsChangedAC16: AccountInSequestrationAC17: AccountInLiquidationAG01: TransactionForbiddenAG02: InvalidBankOperationCodeAM01: ZeroAmountAM02: NotAllowedAmountAM03: NotAllowedCurrencyAM04: InsufficientFundsAM05: DuplicationAM06: TooLowAmountAM07: BlockedAmountAM09: WrongAmountAM10: InvalidControlSumARDT: AlreadyReturnedTransactionBE01: InconsistenWithEndCustomerBE04: MissingCreditorAddressBE05: UnrecognisedInitiatingPartyBE06: UnknownEndCustomerBE07: MissingDebtorAddressBE08: BankErrorCN01: AuthorisationCancelledCNOR: CreditorBankIsNotRegisteredCNPC: CashNotPickedUpCURR: IncorrectCurrencyCUST: RequestedByCustomerDNOR: DebtorBankIsNotRegisteredDS28: ReturnForTechnicalReasonDT01: InvalidDateDT02: ChequeExpiredED01: CorrespondentBankNotPossibleED03: BalanceInfoRequestED05: SettlementFailedEMVL: EMVLiabilityShiftERIN: ERIOptionNotSupportedFF05: InvalidLocalInstrumentCodeFOCR: FollowingCancellationRequestFR01: FraudFRTR: FinalResponseMandateCancelledMD01: NoMandateMD02: MissingMandatoryInformationInMandateMD06: RefundRequestByEndCustomerMD07: EndCustomerDeceasedMS02: NotSpecifiedReasonCustomerGeneratedMS03: NotSpecifiedReasonAgentGeneratedNARR: NarrativeNOAS: NoAnswerFromCustomerNOCM: NotCompliantNOOR: NoOriginalTransactionReceivedPINL: PINLiabilityShiftRC01: BankIdentifierIncorrectRC07: InvalidCreditorBICIdentifierRF01: NotUniqueTransactionReferenceRR01: MissingDebtorAccountOrIdentificationRR02: MissingDebtorNameOrAddressRR03: MissingCreditorNameOrAddressRR04: RegulatoryReasonRUTA: ReturnUponUnableToApplySL01: SpecificServiceOfferedByDebtorAgentSL02: SpecificServiceOfferedByCreditorAgentSL11: CreditorNotOnWhitelistOfDebtorSL12: CreditorOnBlacklistOfDebtorSL13: MaximumNumberOfDirectDebitTransactionsExceededSL14: MaximumDirectDebitTransactionAmountExceededSP01: PaymentStoppedSP02: PreviouslyStoppedSVNR: ServiceNotRenderedTM01: CutOffTimeTRAC: RemovedFromTrackingUPAY: UnduePaymentAGNT: IncorrectAgentFF06: InvalidCategoryPurposeCodeRC08: InvalidClearingSystemMemberIdentifierBE11: InvalidCreditorCountryBE17: InvalidCreditorIdentificationCodeAC02: InvalidDebtorAccountNumberRR11: InvalidDebtorAgentServiceIdentificationBE10: InvalidDebtorCountryBE16: InvalidDebtorIdentificationCodeRC11: InvalidIntermediaryAgentRR12: InvalidPartyIdentificationFF03: InvalidPaymentTypeInformationFF07: InvalidPurposeFF04: InvalidServiceLevelCodeRR09: InvalidStructuredCreditorReferenceRR05: RegulatoryInformationInvalidRR07: RemittanceInformationInvalidRR08: RemittanceInformationTruncatedRR06: TaxInformationInvalidAG07: UnsuccesfulDirectDebitG004: CreditPendingFundsMD05: CollectionNotDueAC07: ClosedCreditorAccountNumber{ "schema": "string", "value": "AC01" }