# Mojaloop Invariants
The following invariants have been established during the course of the platform’s development and based upon the technical requirements inferred from the Level One Project Principles (opens new window) and applicable industry best practices. These invariants should guide any product and technical design discussions related to the architecture of the platform.
# General Principles
# 1. The primary function of the platform is to clear credit-push payments in real-time and facilitate regular settlement, by the end of the value day.
# Notes:
- The platform allows participants to clear funds immediately to their customers while keeping the risks and costs associated with this to a minimum.
- The platform supports per-transfer checks on available liquidity where these are required in support of the first objective.
- The hub is optimized for critical path.
- Intra-day Automated Settlement; configured by scheme and implementation using recommended settlement models for financial market infrastructure.
# 2. The hub supports fully automatic straight-through processing.
# Notes:
- "Straight through processing" means that no manual interventions in the execution of payments or settlements should be required, except where acceptance of the terms of a payment is required from an end user in conformity with the Level One Principles
- Straight through processing helps reduce human errors in the transfer process which ultimately reduces costs.
- The automated nature of straight through processing leads to faster value transfers between end customers.
More information here: Straight Through Processing Definition (opens new window)
# 3. The hub requires no manual reconciliation as the protocol for interacting with the hub guarantees deterministic outcomes.
# Notes:
- When a transfer is finalized, there can be no doubt about the status of that transfer (alternatively, it is not finalized and active notice provided to participants. The notice provided to participants is on demand: if they enquire, they are informed that status is indeterminate).
- The hub guarantees deterministic outcomes for transfers and is accepted by all participants as the final authority on the status of transfers.
- Determinism means individual transfers are traceable, auditable (based on limits, constraints), with final result provided within guaranteed time limit.
- For the avoidance of doubt, batch transfers are processed line-by-line with potentially differing deterministic outcomes for each.
# 4. Transaction setup logic, which is use case-specific, is separated from the policy-free transfer of money.
# Notes:
- Transaction details and business rules should be captured and applied between counterparties prior to the agreement of terms phase and is out of scope for Mojaloop.
- The agreement phase establishes a signed use-case specific transaction object which incorporates all transaction-specific details.
- The transfer phase orchestrates the transfer of retail value between institutions for the benefit of the counterparties (i.e only system limit checks are applied) and without reference to transaction details.
- No additional transaction-specific processing during the transfer phase.
# 5. The hub doesn’t parse or act on end-to-end transaction details; transfer messages contain only the values required to complete clearing and settlement.
# Notes:
- Checks & validations during the transfer step are only for conformance to scheme rules, limit checks, signature authentication, and validation of payment condition and fulfillment.
- Transfers that are committed for settlement are final and are guaranteed to settle under the scheme rules.
# 6. Credit-push transfer semantics are reduced to their simplest form and standardized for all transaction types.
# Notes:
- Simplifies implementation and participant integration as many transaction types and use-cases can reuse the same underlying value transfer message flow.
- Abstracts use-case complexity away from the critical path.
# 7. Internet-based API service hub is not a “message switch.”
# Notes:
- The service hub provides real-time API services for participants to support retail credit-push instant transfers.
- API services such as address resolution, transaction agreement between participants, submission of prepared transfers, and submission of fulfillment advice.
- Auxiliary API services for participants are provided to support onboarding, position management, reporting for reconciliation, and other non-realtime functions not associated with transfer processing.
- All messages are validated for conformance to the API specification; non-conforming messages are actively rejected with a standardized machine-interpretable reason code.
# 8. The hub exposes asynchronous interfaces to participants
# Notes:
- To maximize system throughput.
- To isolate leaf-node connectivity issues so they don't impact other end-users.
- To enable the hub system to process requests in its own priority order and without holding an active connection-per-transfer.
- To handle numerous concurrent long-running processes through internal batching and load balancing.
- To have a single mechanism for handling requests (Examples are transactions such as bulk or those needing end user input or that span multiple hops).
- To better support real world networking as issues with connection speed and reliability for one participant should have minimal impact on other participants or system availability more generally.
# 9. The transfer API is idempotent (opens new window)
# Notes:
- This ensures duplicate requests may be made safely by message originators in conditions of degraded network connectivity.
- Duplicate requests are recognized and result in the same outcome (valid duplicates) or are rejected as duplicate (when not allowed by specification) with reference to the original.
# 10. Finalized Transfer records are held for a scheme-configurable period to support scheme processes such as reconciliation, billing, and for forensic purposes
# Notes:
- It is not possible to query the "sub-status" of an in-process Transfer; the API provides a deterministic outcome with active notice provided within the guaranteed service time.
# 11. Transfer records for finalized transfers are held indefinitely in long-term storage to support business analysis by the scheme operator and by participants (through appropriate interfaces)
# Notes:
- Availability of Transfer records may lag online process finality to accommodate separation of record-keeping from real-time processing of Transfer requests.
# 12. The hub should do the minimum parsing, storing and processing of messages required to execute the services that it provides to the scheme as a whole.
# Notes:
- In some messaging flows e.g. party lookup, it may be desirable for participants to have a single point of contact for routing of scheme related messages, even when the messages are not intended for the hub, nor require any inspection or other processing.
# Security and Safety of APIs
# 13. API messages are confidential, tamper-evident, and non-repudiable.
# Notes:
- Confidentiality is required to protect the privacy of the participants and their customers.
- There are legal requirements in many regulatory domains where Mojaloop is expected to operate and as such, the hub must employ best practices to ensure that the privacy of the participants and their customers is protected.
- Tamper-evident integrity mechanisms are required to ensure that messages cannot be altered in transit.
- To ensure the integrity of the overall system, each recipient of a message should be able to independently tell, with a high degree of confidence, that the message was not altered in transit.
- Public key cryptography (digital signing) provides the current best known mechanism for tamper-evident messaging
- The security of the sender's private key is critical.
- Scheme rules must be established to clarify the responsibilities for key management and the potential for financial liability upon compromise of a private key.
- Non-repudiation is required to ensure that the message was sent by the party which purported to send it and that provenance can not be repudiated by the sender.
- This is important for determining the liable party during audit and dispute resolution processes.
# 14. API messages are Authenticated upon receipt prior to acceptance or further processing
# Notes:
- Authentication gives a degree of confidence that the message was sent by the party which purported to send it.
- Authentication gives a degree of confidence that the message was not sent by an unauthorized party.
# 15. Authenticated Messages are not acknowledged as accepted until safely recorded to permanent store.
# Notes:
- The Mojaloop API assigns significant scheme related business meaning to certain HTTP response codes at various points in transaction flows:
- Certain HTTP responses, e.g. "202 Accepted", are intended to provide financial guarantees to participants and as such must only be sent once the receiving entity is confident it has made safe, permanent record(s) in support of:
- Facilitating system wide recovery to a consistent state after failure(s) in one or more distributed components/entities.
- Accurate settlement processes
- Audit and dispute resolution processes
- For example a "200 OK" from the hub to the payee participant upon receipt of a transfer fulfilment message indicates a guarantee of transaction settlement to the payee pending validation checks.
- Certain HTTP responses, e.g. "202 Accepted", are intended to provide financial guarantees to participants and as such must only be sent once the receiving entity is confident it has made safe, permanent record(s) in support of:
- The Mojaloop API is designed to operate safely under imperfect network conditions and as such has built in support for retries and state synchronisation between participants.
# 16. Three levels of communication security to ensure integrity, confidentiality, and non-repudiation of messages between an API server and API client.
# Notes:
- Secure Connections: mTLS required for all communications between the scheme and authorized participants.
- Ensures communications are confidential, between known correspondents, and communications are protected against tampering.
- Secure Messages: JSON message content is cryptographically signed according to the JWS specification.
- Ensures recipients that messages were sent by the party which purported to send them and that provenance can not be repudiated by the sender.
- Secure Terms of Transfer: Interledger Protocol (ILP) between Payer and Payee participants.
- Protects the integrity of the payment condition and its fulfillment.
- Limits the time within which a transfer instruction is valid.
# 17. To ensure system is arithmetically consistent, only fixed point arithmetic is used.
# Notes:
- For the avoidance of doubt, floating point calculations may lose accuracy and must not be used in any financial calculation.
- See Level One Decimal Type (opens new window) representation and forms.
- This specification enables seamless interchange with XML-based financial systems without loss of precision or accuracy
# Operational Characteristics
Mojaloop is designed to function as part of a jurisdictional Instant Payments System. As such, it must demonstrably meet the standards of performance and resilience which are required for such systems.
# 1. Baseline system demonstrated on minimal hardware supports clearing 1,000 transfers per second, sustained for one hour, with not more than 1% (of transfer stage) taking more than 1 second through the hub.
# Notes:
- This measurement includes all necessary hardware and software components with production grade security and data persistence in place.
- This measurement includes all three transfer stages: discovery, agreement, and transfer.
- This measurement does not include any participant introduced latency.
- A one hour period is a reasonable approximation of a demand peak for a national payment system.
- The cost of scaling up capacity should be less per unit of capacity than the cost of initial provisioning.
- 1000 transfers (clearing) per second is a reasonable starting point for a national payment system.
- 1% of transfers (clearing) taking more than 1 second is a reasonable starting point for a national payment system.
- Mojaloop schemes should be able to start at a reasonable cost point, for national financial infrastructure, and scale economically as demand grows.
# 2. The hub is highly available and resilient to failures.
# Notes:
- Definition of "highly available":
- In this instance we define the term "highly available" as meaning "the ability to provide and maintain an acceptable level of service in the face of faults and challenges to normal operation."
- Although schemes may determine their own definition of what constitutes an "acceptable level of service", Mojaloop makes certain contributing tradeoff choices:
- When fault modes permit, service is degraded across the entire participant population rather than individual participants suffering total outages while others remain serviceable.
- The hub has no single point of failure; meaning that it continues to operate with minimum degradation of service in the event of a failure of any single component.
- Multiple active instances of each component are deployed in a distributed manner behind load balancers.
- Each active component instance can handle requests from any client/participant meaning no single participant loses the ability to transact in the event of a failure of any single component.
- Given appropriate infrastructure to operate upon, the Mojaloop software can be deployed in active:active and/or active:passive multiple, geographically distributed data center configurations where both services and data are replicated across multiple physical nodes which are expected to fail independently.
- Note that it is expected that nodes in replication groups (and/or clusters) will be located in diverse physical locations (racks and/or data centres) with independent power supplies and network interconnects.
- Should multiple component failures occur which have not been mitigated either in the Mojaloop software, deployment configuration or infrastructure, the Mojaloop API provides mechanisms for each entity in the scheme to recover to a consistent state, with the hub being the ultimate source of truth upon full restoration of service.
- Also see further points relating to resistance to data loss in the event of failures.
- Given that Mojaloop schemes are intended to form parts of national financial infrastructure they must have as close to zero downtime as possible, given reasonable cost constraints.
- Failures in hardware and software components are to be expected, even in the highest quality components available. Best practice suggests these failures should be anticipated and planned for as much as possible in the design of the hub with a view to minimising loss or degradation of service and/or data.
- For the avoidance of doubt this means the tradeoffs chosen favour overall service availability and state consistency over performance. I.e:
- All participants can continue to transact at a reduced rate rather than some participants being unable to transact at all.
- Inconsistencies in state between scheme entities are resolvable post service restoration via the Mojaloop API, with minimal manual reconciliation necessary; the hub being the ultimate source of truth.
- In situation where sufficient throughput to handle all incoming requests in a timely manner cannot be sustained, the hub will prioritise processing transfers which are in-flight over new incoming requests.
- Transfers which the hub cannot process before specified deadlines expire will be timed out gracefully.
# 3. The hub is resistant to loss of data in the event of failures.
# Notes:
- Given appropriate infrastructure to operate upon, the Mojaloop software can be deployed in configurations which reliably replicate data across multiple, redundant physical storage nodes prior to processing.
- Database engine components which are provided by the Mojaloop deployment mechanisms support the following:
- Primary:secondary asynchronous replication
- Primary:primary synchronous replication.
- Synchronous quorum consensus algorithm based replication.
- The replication mechanisms available are dependant on the particular storage layer and database technologies employed.
- Database engine components which are provided by the Mojaloop deployment mechanisms support the following:
- Should multiple component failures occur which have not been mitigated either in the Mojaloop software, deployment configuration or infrastructure, the Mojaloop API provides mechanisms for each entity in the scheme to recover to a consistent state with minimal financial exposure risk.
- Transfers become financially binding only when the hub has successfully responded to a transfer fulfilment message from the payee participant. This response is only sent when the hub has persisted the fulfilment message and its outcome to its ledger database.
- Expiration timestamps on all financially significant API messages facilitate timely and deterministic failure path outcomes for all participants via automated retry mechanisms.
- Given that Mojaloop schemes are intended to form parts of national financial infrastructure they must do as much as possible, given reasonable cost constraints, to avoid loss of data in the event of a failure.
- Failures in hardware and software components are to be expected, even in the highest quality components available. Best practice suggests these failures should be anticipated and planned for in the design of the hub with a view to avoiding data loss.
- Participants need timely confidence in the status of financial transactions across the scheme in order to minimise exposure risk and deliver excellent customer experiences.
# Design Decisions
NodeJS is the primary execution environment with TypeScript the preferred language for development.
- This platform is free open source
- Is widely used and actively supported by the world's largest web-based institutions
- Has a massive global portfolio of libraries
- Utilizes only the ECMAScript family of architecture-neutral languages and libraries known by millions of skilled web programmers
Use a micro-service distributed architecture.
- Law of Demeter (opens new window) or Principle of Least Knowledge
- Separation of concerns (opens new window) secured by inter-module contracts
- Modular architecture (opens new window) enables distributed development in a community environment and improvement of components with minimal disruption to adjacent components
Apache Kafka (opens new window) distributed Publish–Subscribe (opens new window) for inter-module Command–Query Separation (CQS) (opens new window)
Apache Kafka (opens new window) for persistent handling of participant API messages
Mojaloop uses APIs based on Open API 3.0.
- Exposes resources that are mapped to functionality to support the defined API use-cases.
- Common practice for web API specification
# Annexure A : Level One Principles Overview
The Level One Project (opens new window) proposes a new low-cost payments system that supports inclusive, interoperable digital payments. The Level One Project Guide (opens new window) outlines a vision of how an inclusive digital financial services system can work for the benefit of poor people. The underlying design principles of the Guide include:
- A credit push payment model with immediate funds transfer and same day settlement
- Open-loop interoperability between providers
- Adherence to well-defined and adopted international standards
- Adequate system-wide shared fraud and security protection
- Efficient and proportional identity and know-your-customer (KYC) requirements
- Meeting or exceeding the convenience, cost and utility of cash
By utilizing an open, digital approach to transactions, and partnering with organizations across the public and private sectors, the Level One Project aims to provide access to a robust, low-cost shared digital financial services infrastructure, sparking innovation from new and existing participants, reducing risk, and generating substantial value for providers, individuals and economies in developing markets. Additional resources have been created to help governments, NGOs and financial service providers successfully implement these changes.