Bank Connector Interface Guide
This guide provides details on implementing the BankConnectorInterface for integration with sponsor banks to support various benefit programs in the G2P Bridge application.
Overview
The BankConnectorInterface
is designed to provide a unified approach for interacting with different sponsor banks. Custom implementations of this interface allow partners to integrate specific banking APIs without modifying the core G2P Bridge application. An example implementation, openg2p-g2p-bridge-example-bank-connector
, connects to a simulated bank for testing purposes.
Interface Code: BankConnectorInterface on GitHub
Example Implementation: Example Bank Connector Repository
Key Components of BankConnectorInterface
The BankConnectorInterface
requires the following methods:
check_funds
Purpose: Verifies whether sufficient funds are available in a specific account.
Arguments:
account_number
(str): The bank account number to check.currency
(str): Currency type of the account.amount
(float): Amount to verify for availability.
Returns: An instance of
CheckFundsResponse
:status
(FundsAvailableWithBankEnum): Indicates if funds are available (FUNDS_AVAILABLE
) or not (FUNDS_NOT_AVAILABLE
).error_code
(str): Error code if the check fails.
block_funds
Purpose: Blocks a specified amount in the account for a disbursement cycle.
Arguments:
account_number
(str): The bank account to block funds in.currency
(str): Currency of the account.amount
(float): Amount to block.
Returns: An instance of
BlockFundsResponse
:status
(FundsBlockedWithBankEnum): Block status, eitherSUCCESS
orFAILURE
.block_reference_no
(str): Reference number of the block if successful.error_code
(str): Error code if blocking fails.
initiate_payment
Purpose: Sends payment instructions to the bank. This API acknowledges the payment instruction, but the bank processes it asynchronously.
Arguments: A list of
DisbursementPaymentPayload
, where each payload includes:disbursement_id
(str): Unique identifier for the disbursement.remitting_account
(str): Sponsor bank account for the disbursement.payment_amount
(float): Amount to be paid.beneficiary_id
(str): Unique ID for the beneficiary.Additional fields include
beneficiary_account
,beneficiary_name
, anddisbursement_narrative
.
Returns: An instance of
PaymentResponse
:status
(PaymentStatus): Payment status, eitherSUCCESS
orERROR
.error_code
(str): Error code if the payment fails.
retrieve_disbursement_id
Purpose: Extracts the disbursement ID from bank transaction records.
Arguments:
bank_reference
(str): Reference from the bank statement.customer_reference
(str): Unique disbursement ID in G2P Bridge.narratives
(str): Transaction narratives from the bank statement.
Returns:
disbursement_id
(str): Extracted disbursement ID.
retrieve_beneficiary_name
Purpose: Extracts the beneficiary’s name from bank statement narratives.
Arguments:
narratives
(str): Narrative fields in the bank statement.
Returns:
beneficiary_name
(str): Name of the beneficiary.
retrieve_reversal_reason
Purpose: Identifies the reason for reversal transactions in bank statements.
Arguments:
narratives
(str): Narrative fields from the bank statement.
Returns:
reversal_reason
(str): Reason for reversal.
Data Models and Enums
To implement this interface, several data models and enums are used, imported from the G2P Bridge libraries.
CheckFundsResponse
: Defines the response structure for fund checks.BlockFundsResponse
: Defines the response structure for fund blocking.DisbursementPaymentPayload
: Represents the payload for payment initiation.Enums:
FundsAvailableWithBankEnum
: Represents fund availability statuses.FundsBlockedWithBankEnum
: Represents fund blocking statuses.PaymentStatus
: Defines payment outcomes, eitherSUCCESS
orERROR
.
Example Implementation Workflow
Define a Custom Connector: Implement the
BankConnectorInterface
with the sponsor bank’s API details. Use methods likecheck_funds
,block_funds
, andinitiate_payment
to communicate with the bank.Configure Bank Connector Factory: Implement
get_bank_connector(sponsor_bank_code: str)
to return an instance of the custom bank connector based onsponsor_bank_code
.Testing: Use the Example Bank Connector and the bank simulator for validating your implementation.
Last updated