# FSP Interoperability API BC

The FSP Interoperability API Bounded Context provides access to the internal operations and resources that the Mojaloop Ecosystem provides to a given Participant. This Bounded Context is responsible for providing a Participant with interfaces whit which the Participant can perform and execute tasks on Mojaloop. It is also responsible for providing communication back to the Participant regarding different notifications and system messages that a participant should expect to receive.

# Functional Overview

The FSP IOP API interacts with many different bounded contexts and thus the simplified view is provided here, for further reading on the events and connections that the FSP IOP API provides and consumes please review the Mojaloop Common Interfaces [1]. The bounded contexts that are integrated with the FSP IOP API are:

  • Account Lookup & Discovery Bounded Context [2]
  • Notifications and Alerts Bounded Context [3]
  • Participant Lifecycle Management Bounded Context [4]
  • Quoting\Agreement Bounded Context [5]
  • Transfers Bounded Context [6]
  • Settlement Bounded Context [7]

Use Case - FSP Interoperability API Functional Overview

FSP Interoperability API Functional Overview

# Terms

Terms with specific and commonly accepted meaning within the Bounded Context in which they are used.

Term Description
(D)FSP (Digital) Financial Service Provider
Participant Financial Service Provider (FSP) that has registered on the Mojaloop ecosystem. Allowing said FSP to be able to transact with other Participants
FSP IOP API Financial Service Provider Interoperability Application Programming Interface, the API that provides access to functions and features of the Mojaloop Ecosystem.
Payer The payer of electronic funds in a payment transaction.
Payer FSP Payer’s Financial Service Provider.
Payee The recipient of electronic funds in a payment transaction.
Payee FSP Payee’s Financial Service Provider.

# Use Cases

Use case definitions stipulated in the Open API for FSP Interoperability Specification [8] have not been altered.Allowing the Reference Architecture to only change the background orchestration of the internal Mojaloop services and Bounded Contexts.

# Notifications BC - Send Notification

Notifications pertain to ALL below use cases as a response to requests received in various forms. While the FSP IOP API is busy processing a request received, it might need to sends a request to the requesting DFSP or any other relevant DFSPs. The FSP IOP API will then query the Participant Lifecycle Management Bounded Context [4:1] for the Callback URIs for the given participant that the notification needs to be sent to. The FSP IOP API will then send the notification request to the Notification and Alerts Bounded Context [3:1].

Use Case - Notifications BC - Send Notification

Notifications BC - Send Notification

# Account Lookup & Discovery BCs

# Party/Participant Associate

Associate transfer/s Participant/s and/or parties based on the POST Participant request [9] (POST /participants/{Type}/{ID}). The FSP IOP API then sends a request to the Account Lookup & Discovery BC [2:1] which will process the request and respond with a success event. The FSP IOP API then sends a notification PUT Participant response [10] (PUT /participants/{Type}/{ID}).

Use Case - Account Lookup & Discovery BC - Party/Participant Associate

Account Lookup & Discovery BC - Party/Participant Associate

# Party/Participant Disassociate

Disassociate Participant/s and/or parties based on the DELETE Participant request [11] (DELETE /participants/{Type}/{ID}). The FSP IOP API sends the request to the Account Lookup & Discovery BC [2:2] to disassociate the party. The success response is then received by the FSP IOP API and then responds to the caller by sending a notification PUT Participant response [10:1] (PUT /participants/{Type}/{ID}).

Use Case - Account Lookup & Discovery BC - Party/Participant Disassociate

Account Lookup & Discovery BC - Party/Participant Disassociate

# Get Participant

Retrieve participant information based on the GET Participant request [12] (GET /participants/{Type}/{ID}) , which supplies the ID and structure. The FSP IOP API sends the request to the Account Lookup & Discovery BC [2:3] to determine whether the desired participant exists. The FSP IOP API then responds to the requestor with a PUT Participant response [10:2] (PUT /participants/{Type}/{ID}).

Use Case - Account Lookup & Discovery BC - Get Participant

Account Lookup & Discovery BC - Get Participant

# Get Party

Retrieve party information based on the ID passed with the GET Party request [13] (GET /parties/{Type}/{ID}). The FSP IOP API then sends a request to the Account Lookup & Discovery BC [2:4] to determine the target FSP to forward the GET request to. The target FSP then responds with a PUT parties request. The information is then sent to the Account Lookup & Discovery BC to be cached before the PUT Party response [14] (PUT /parties/{Type}/{ID}) is sent to the original sender of the GET request.

Use Case - Account Lookup & Discovery BC - Get Party

Account Lookup & Discovery BC - Get Party

# Agreement (Quoting) BC

# Calculate Quote - Happy Path

When a quote is sent using the POST Quote request [15] (POST /quotes), the FSP IOP API will sends the request to the Quoting/Agreement BC [5:1] to validate the quote. The FSP IOP API will then send the POST Quote to the Payee FSP, which in turn responds with a PUT Quote response [16] (PUT /quotes/{ID}) and updated relevant information. The FSP IOP API sends the accepted quote to the The Quoting/Agreement BC [5:2] to persist the quote information. The FSP IOP API will then forwards the PUT quote request to the Payer FSP and consider the quote successful.

Use Case - Agreement BC - Calculate Quote - Happy Path

Agreement BC - Calculate Quote - Happy Path

# Get Quote - Happy Path

This allows a FSP to get quote information of an existing quote. The GET Quote request [17] (GET /quotes/{ID}) is sent to the FSP IOP API that queries the Quoting/Agreement BC [5:3] for existing quotes. When the quote is retrieved the information is send back to the requesting FSP by sending the PUT Quote response [16:1] (PUT /quotes/{ID}).
Use Case - Agreement BC -  Get Quote - Happy Path

Agreement BC - Get Quote - Happy Path

# Calculate Quote - Invalid Quote Request

When a POST Quote request [15:1] (POST /quotes) is , the FSP IOP API sends the request to the Quoting/Agreement BC [5:4] for processing. The quote then fails validation the Quoting/Agreement BC [5:5] responds with an error response that the FSP IOP API notifies the requesting FSP through the use of the PUT Quote Error response [18] (PUT /quotes/{ID}/error).

Use Case - Agreement BC - Calculate Quote - Invalid Quote Request

Agreement BC - Calculate Quote - Invalid Quote Request

# Calculate Quote - Invalid FSPs

When a POST Quote request [15:2] (POST /quotes) is sent but the FSP IOP API sends the request to the Quoting/Agreement BC [5:6] for processing and it cannot determine that both participants are valid FSPs then an error response is then sent to the FSP IOP API. The FSP IOP API then notifies the requesting FSP through the use of the PUT Quote Error response [18:1] (PUT /quotes/{ID}/error).

Use Case - Agreement BC - Calculate Quote - Invalid FSPs

Agreement BC - Calculate Quote - Invalid FSPs

# Calculate Quote - Invalid Scheme Rules detected in Request

When the Payer FSP sends a POST Quote request [15:3] (POST /quotes) the FSP IOP API sends the request to the Quoting/Agreement BC [5:7] for processing and the quote does not adhere to the scheme rules defined then an error response is then sent to the FSP IOP API. The FSP IOP API then notifies the Payer FSP through the use of the PUT Quote Error response [18:2] (PUT /quotes/{ID}/error)

Use Case - Agreement BC - Calculate Quote - Invalid Scheme Rules detected in Request

Agreement BC - Calculate Quote - Invalid Scheme Rules detected in Request

# Calculate Quote - Invalid Scheme Rules detected in Response

When the Payer FSP sends a POST Quote request [15:4] (POST /quotes) the FSP IOP API sends the request to the Quoting/Agreement BC [5:8] for processing and it succeeds initial processing. The FSP IOP API sends the request POST quote request to the Payee FSP. The Payee FSP should react with a accepted quote by sending PUT Quote request [16:2] (PUT /quotes/{ID}). The response is sent to Quoting/Agreement BC [5:9] for further processing and validation. When the Bounded Context detects that the quote does not adhere to the scheme rules defined then an error response is then sent to the FSP IOP API. The FSP IOP API then notifies both the Payer FSP and the Payee FSP through the use of the PUT Quote Error response [18:3] (PUT /quotes/{ID}/error).

Use Case - Agreement BC - Calculate Quote - Invalid Scheme Rules detected in Response

Agreement BC - Calculate Quote - Invalid Scheme Rules detected in Response

# Transfers BC

# Perform Transfer (Universal Mode)

The Payer FSP sends a POST Transfers request [19] (POST /transfers) to the FSP IOP API. The FSP IOP API then sends an event to the Settlements Bounded Context [7:1]. The FSP IOP API waits for an event from the Transfers Bounded Context [6:1], to indicate that the transfer has been prepared, to send a POST request to the Payee FSP. The Payee FSP then responds with a PUT Transfers request [20] (PUT /transfers/{ID}) (transferState = committed) to the FSP IOP API which in turn commits the transfer fulfillment. The PUT transfer is then send to the Payer FSP.

Use Case - Transfers BC - Perform Transfer (Universal Mode)

Transfers BC - Perform Transfer (Universal Mode)

# Perform Transfer with Payee Confirmation

The Payer FSP sends a POST Transfers request [19:1] (POST /transfers) to the FSP IOP API. The FSP IOP API then sends an event to the Settlements Bounded Context [7:2]. The FSP IOP API waits for an event from the Transfers Bounded Context [6:2], to indicate that the transfer has been prepared, to send a POST request to the Payee FSP. The Payee FSP then responds with a PUT Transfers request [20:1] (PUT /transfers/{ID}) (transferState = reserved) to the FSP IOP API which in turn reservers the transfer fulfillment. The PUT transfer is then send to the Payer FSP. The Payee FSP then receives a PATCH Transfers request [21] (PATCH /transfers/{ID}) to notify the state change of the transfer.

Use Case - Transfers BC - Perform Transfer with Payee Confirmation

Transfers BC - Perform Transfer with Payee Confirmation

# Query Get Transfer

Gets the transfer info based on the transfer ID used in GET Transfer request [22] (GET /transfers/{ID}) and receives a PUT Transfers request [20:2] (PUT /transfers/{ID}) to get the relevant information about the transfer.

Use Case - Transfers BC - Query Get Transfer

Transfers BC - Query Get Transfer

# Perform Transfer - Duplicate Post (Resend)

POST Transfers request [19:2] (POST /transfers) has already been processed and a status report is returned to the Payer FSP by receiving a PUT Transfers request [20:3] (PUT /transfers/{ID}).

Use Case - Transfers BC - Perform Transfer - Duplicate Post (Resend)

Transfers BC - Perform Transfer - Duplicate Post (Resend)

# Perform Transfer - Duplicate Post (Ignore)

POST Transfers request [19:3] (POST /transfers) has already been processed but no response is needed or requested.

Use Case - Transfers BC - Perform Transfer - Duplicate Post (Ignore)

Transfers BC - Perform Transfer - Duplicate Post (Ignore)

# Perform Transfer - Payee DFSP Rejects Transfer

The Payer FSP sends a POST Transfers request [19:4] (POST /transfers) to the FSP IOP API. The Api then prepares the transfer and then sends the POST request through to the Payee FSP. The Payee FSP then declines the transfer by sending a PUT Transfer error request [23] (PUT /transfers/{ID}/error) to the FSP IOP API. The FSP IOP API then notifies the Transfers Bounded Context [6:3] that the transfer has been rejected and sends a PUT Transfer error request [23:1] (PUT /transfers/{ID}/error) to the Payer FSP.

Use Case - Transfers BC - Perform Transfer - Payee DFSP Rejects Transfer

Transfers BC - Perform Transfer - Payee DFSP Rejects Transfer

# Perform Transfer - Timeout (Prepare)

POST Transfers request [19:5] (POST /transfers) gets rejected because the transfer timed out [24] while funds are being prepared. The FSP IOP API sends a PUT Transfer error request [23:2] (PUT /transfers/{ID}/error) request to the Payer FSP to notify of the error.

Use Case - Transfers BC - Perform Transfer - Timeout (Prepare)

Transfers BC - Perform Transfer - Timeout (Prepare)

# Perform Transfer - Timeout (Pre-Committed)

The Payer FSP sends a POST Transfers request [19:6] (POST /transfers) to the FSP IOP API. The FSP IOP API then sends an event to the Settlements Bounded Context [7:3]. The FSP IOP API waits for an event from the Transfers Bounded Context [6:4], to indicate that the transfer has been prepared, to send a POST request to the Payee FSP. The Payee FSP then responds with a PUT Transfers request [20:4] (PUT /transfers/{ID}) (transferState = committed) to the FSP IOP API which in turn commits the transfer fulfillment. The transfer times out [24:1] while/before the funds are committed and causes the transfer to be rejected. The FSP IOP API then notifies both the Payer and Payee FSPs with a PUT Transfer error request [23:3] (PUT /transfers/{ID}/error).

Use Case - Transfers BC - Perform Transfer - Timeout (Pre-Committed)

Transfers BC - Perform Transfer - Timeout (Pre-Committed)

# Perform Transfer - Timeout (Post-Committed)

The Payer FSP sends a POST Transfers request [19:7] (POST /transfers) to the FSP IOP API. The FSP IOP API then sends an event to the Settlements Bounded Context [7:4]. The FSP IOP API waits for an event from the Transfers Bounded Context [6:5], to indicate that the transfer has been prepared, to send a POST request to the Payee FSP. The Payee FSP then responds with a PUT Transfers request [20:5] (PUT /transfers/{ID}) (transferState = committed) to the FSP IOP API which in turn commits the transfer fulfillment. The transfer times out [24:2] after the funds are committed and causes the transfer to be rejected.

Use Case - Transfers BC - Perform Transfer - Timeout (Post-Committed)

Transfers BC - Perform Transfer - Timeout (Post-Committed)

# Perform Transfer - Duplicate Post (None Matching)

POST Transfers request [19:8] (POST /transfers) has already been processed and a status report is returned to the Payer FSP by receiving a PUT Transfer error request [23:4] (PUT /transfers/{ID}/error).

Use Case - Example REPLACE ME

Transfers BC - Perform Transfer - Duplicate Post (None Matching)

# Perform Transfer - Payer FSP Insufficient Liquidity

The Payer FSP sends a POST Transfers request [19:9] (POST /transfers) to the FSP IOP API. The FSP IOP API then sends an event to the Settlements Bounded Context [7:5]. The FSP IOP API waits for an event from the Transfers Bounded Context [6:6], to indicate that the transfer has been prepared, but receives a Liquidity check failure for the Payer FSP. The FSP OIP API then sends a PUT [23:5] transfers error request to the Payer FSP to notify of the error.

Use Case - Transfers BC - Perform Transfer - Payer FSP Insufficient Liquidity

Transfers BC - Perform Transfer - Payer FSP Insufficient Liquidity

# Perform Transfer - Transfer Prepare Rejected

The Payer FSP sends a POST Transfers request [19:10] (POST /transfers) to the FSP IOP API. The Api then prepares the transfer and then sends the POST request through to the Payee FSP. The Payee FSP then declines the transfer by sending a PUT Transfer error request [23:6] (PUT /transfers/{ID}/error) to the FSP IOP API. The FSP IOP API then notifies the Transfers Bounded Context [6:7] that the transfer has been rejected and sends a PUT Transfer error request [23:7] (PUT /transfers/{ID}/error) to the Payer FSP.

Use Case - Transfers BC - Perform Transfer - Transfer Prepare Rejected

Transfers BC - Perform Transfer - Transfer Prepare Rejected

# Perform Transfer - Transfer Prepare Validation Failure (Invalid Payer Participant)

The Payer FSP sends a POST Transfers request [19:11] (POST /transfers) to the FSP IOP API. The Transfers Bounded Context [6:8] notifies the FSP IOP API that the Payer FSP is invalid. Depending on the reason for the Payer FSP being invalid the FSP IOP API will send a PUT Transfer error request [23:8] (PUT /transfers/{ID}/error) to the Payer FSP.

Use Case - Transfers BC - Perform Transfer - Transfer Prepare Validation Failure (Invalid Payer Participant)

Transfers BC - Perform Transfer - Transfer Prepare Validation Failure (Invalid Payer Participant)

# Perform Transfer - Transfer Prepare Validation Failure (Invalid Payee Participant)

The Payer FSP sends a POST Transfers request [19:12] (POST /transfers) to the FSP IOP API. The Transfers Bounded Context [6:9] notifies the FSP IOP API that the Payee FSP is invalid. The FSP IOP API will send a PUT Transfer error request [23:9] (PUT /transfers/{ID}/error) to the Payer FSP to notify about the failure.

Use Case - Transfers BC - Perform Transfer - Transfer Prepare Validation Failure (Invalid Payer Participant)

Transfers BC - Perform Transfer - Transfer Prepare Validation Failure (Invalid Payer Participant)

# Notes

# Structure validation on internal events

Many use cases stipulate that the request structure and semantics should be validated when receiving a event from an internal Bounded Context. This does not happen on a per request basis but rather is a requirement to be met when the building phase of the Reference Architecture is underway. What we are trying to say by showing that is that internally all events and available resources should be standardized and verified.


  1. Mojaloop Common Interface List ↩︎

  2. Account Lookup and Discovery Bounded Context ↩︎ ↩︎ ↩︎ ↩︎ ↩︎

  3. Notification and Alerts Bounded Context ↩︎ ↩︎

  4. Participant Lifecycle Management Bounded Context ↩︎ ↩︎

  5. Quoting\Agreement Bounded Context ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎

  6. Transfers Bounded Context ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎

  7. Settlements Bounded Context ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎

  8. Open API for FSP Interoperability Specification Documentation (opens new window) ↩︎

  9. Post Participant - Definition (opens new window) ↩︎

  10. Put Participant - Definition (opens new window) ↩︎ ↩︎ ↩︎

  11. Delete Participant - Definition (opens new window) ↩︎

  12. Get Participant - Definition (opens new window) ↩︎

  13. Get Parties - Definition (opens new window) ↩︎

  14. Put Party- Definition (opens new window) ↩︎

  15. Post Quote - Definition (opens new window) ↩︎ ↩︎ ↩︎ ↩︎ ↩︎

  16. Put Quote - Definition (opens new window) ↩︎ ↩︎ ↩︎

  17. Get Quote - Definition (opens new window) ↩︎

  18. Put Quote Error - Definition (opens new window) ↩︎ ↩︎ ↩︎ ↩︎

  19. Post Transfers - Definition (opens new window) ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎

  20. Put Transfers - Definition (opens new window) ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎

  21. Patch Transfers - Definition (opens new window) ↩︎

  22. Get Transfers - Definition (opens new window) ↩︎

  23. Put Transfers Error - Definition (opens new window) ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎ ↩︎

  24. Transfers Timeout and Expiry - Definition (opens new window) ↩︎ ↩︎ ↩︎

Last Updated: 9/29/2021, 1:44:15 PM