Netbank Digital API (0.0.1)

Download OpenAPI specification:Download

GENERAL GUIDELINES

INTRODUCTION

Welcome to the Netbank Virtual API Technical Documentation.

This documentation/reference includes all the details regarding the API endpoints and webhooks that will allow you to integrate Netbank’s financial services into your own applications, systems, and platforms.

We strongly suggest that you read through the General Guidelines section to familiarize yourself with the overall structure and behavior of the Netbank Virtual APIs.

The API endpoints are grouped according to the product and are ordered based on the usual call sequence for easier reference. Each product, endpoint, and parameter will have a description to define the purpose of each element.

Disclaimer: We will continually update and enhance this page and its contents whenever necessary.

To know more about how to get started and the end-to-end onboarding process, you may refer to https://virtual.netbank.ph/get-started

For any questions/inquiries, you may refer to our FAQs (https://virtual.netbank.ph/faq) or reach out to the Netbank Virtual Team via the Contact Us Form found in various pages of https://virtual.netbank.ph/ and select “Request for integration support for Sandbox and UAT development” in the the “How can we help you?” dropdown.

DEVELOPMENT ENVIRONMENTS

There are 3 environments where you could use our APIs for specific purposes.

  • SANDBOX (https://api-sandbox.netbank.ph)

    • Description: This environment is where you can “try” or test the request and response of our APIs to have an idea on the format and behaviour that your system needs to integrate with.

    • Purpose of Use: To simulate and test the request and response payload of the APIs so you could finalize how your system interacts with our APIs.

    • Connection to our Core: These APIs are connected to a limited are of our Core Banking System but it mimics how our APIs would accept requests and return a response.

    • Access Credentials: You can quickly and simply generate Sandbox Credentials using the Credentials Management section of your Partner Dashboard.

      • Sign-In and access the Netbank Virtual Partner Dashboard

      • Navigate to the Credentials Management section

      • Click “Generate Client ID & Secret”

      • Select “Sandbox Environment”

      • Take note of your Client ID and Client Secret

    • Requirements to get access:

      • Netbank Virtual Account (Sign Up to Netbank Virtual)

      • Sandbox Access Credentials, (Generated via the Credentials Management section of the Partner Dashboard)

  • UAT (https://api-uat.netbank.ph)

    • Description: This environment is where you can perform a deeper level of testing and review to ensure that your integration with us is ready for Production-use.

    • Purpose of Use: To perform various quality assurance testing (e.g. unit, stress, performance, acceptance testing) to ensure that the integration can handle all types of Production-use scenarios.

    • Connection to our Core: These APIs are connected to the test environment of our Core Banking System that reflects the same level of capacity and behaviour as the Production environment.

    • Access Credentials: You can simply generate UAT Credentials using the Credentials Management section of your Partner Dashboard but we suggest using this environment solely for quality assurance testing-- which is done after you’ve finalized the integration setup to our APIs.

      • Sign-In and access the Netbank Virtual Partner Dashboard

      • Navigate to the Credentials Management section

      • Click “Generate Client ID & Secret”

      • Select “UAT Environment”

      • Fill out the Request for UAT Credentials form

      • Take note of your Client ID and Client Secret

    • Requirements to get access:

      • Netbank Virtual Account (Sign Up to Netbank Virtual)

      • UAT Access Credentials (Generated via the Credentials Management section of the Partner Dashboard)

      • Information on the product/service that you are building

  • PROD (https://api.netbank.ph)

    • Description: This environment is where you can create live accounts and initiate live transactions.

    • Purpose of Use: To use the Netbank products and services in actual business transactions and use cases.

    • Connection to our Core: These APIs are connected to the production environment of our Core Banking System.

    • Access Credentials: You can request for Production Credentials using the Credentials Management section of your Partner Dashboard along with the Pre-Production requirements.

      • Sign-In and access the Netbank Virtual Partner Dashboard

      • Navigate to the Credentials Management section

      • Click “Generate Client ID & Secret”

      • Select “PROD Environment”

      • Fill out the Request for PROD Credentials form

      • Wait for Netbank to Approve your Prod Credentials Request

      • Take note of your Client ID and Client Secret

    • Requirements to get access:

      • Netbank Virtual Account (Sign Up to Netbank Virtual)

      • Prod Access Credentials (Generated via the Credentials Management section of the Partner Dashboard)

      • Information on the product/service that you are building

      • Banking-As-A-Service License Agreement (Signed)

      • Any other relevant agreements (Signed)

      • UAT Sign-Off (to indicate that you’ve fully tested the integration in all possible scenarios and that it’s ready for Production-Use)

AUTHENTICATION

The Netbank Virtual APIs utilizes OAuth 2.0–a popular and widely used protocol–to authenticate the API requests. Please use this documentation as guide on how to implement the authentication flow: https://oauth.net/2/

  • Access Token

    • the Netbank APIs require an Access Token to process any type of API request (GET, POST, PUT).

    • An Access Token can be generated after successfully requesting for authorization and getting an Authorization Grant.

    • The Netbank Virtual Access Token has a default validity of 30 Days. (Netbank can grant long-lived tokens depending on the risk assessment during onboarding)

  • Authorization Grant

    Netbank Virtual supports 2 ways (or “Grant Types”) to get an Authorization Grant depending on the transaction scenario and the type of authorization needed

    • If the API User is trying to access/use a Netbank Bank Account that he/she owns,

      • the API User needs to request for authorization directly from Netbank’s Authorization Server

      • the type of Authorization Grant to be used would be the “Client Credentials” (Client ID and Client Secret). Please use this documentation as guide on how to implement the authentication flow: https://oauth.net/2/

      • The Client ID and Secret for this type of Authorization Grant can be generated by accessing the Partner Dashboard and navigating to the “Credentials Management” > “Environment Access Credentials” > “Generate Client ID & Secret”

    • If the API User is trying to access/use a Netbank Bank Account of another entity/individual,

      • the API User needs to gather consent and request authorization directly from the Netbank account holder by directing the account holder to Netbank’s Authorization Server

      • the type of Authorization Grant to be used would be the “Authorization Code” (Client ID and Client Secret). Please use this documentation as guide on how to implement the authentication flow: https://oauth.net/2/

      • The Client ID and Secret for this type of Authorization Grant can be generated by accessing the Partner Dashboard and navigating to the “Credentials Management” > “Authentication Code” > “Generate Client ID & Secret”. The form needs to be filled out:

        • Name: Name/Label for your credentials

        • Environment: The development environment that you would use these credentials for. (“Sandbox”, “UAT”, “PROD”)

        • CORS URL: Describe which URL are permitted to read authorization information from a web browser

        • Redirect URL: The url where the user will be redirected after a successful authorization and where the Access Token will be posted

      • An end user's first-time multi-factor authentication (MFA) flow will consist of a three-step Security question, One Time Password (OTP) through SMS and Consent confirmation. A session cookie will stored in the user’s browser and will be valid for 365 days.

      • When users have to do re-authentication they will directly go to the OTP page if the session cookie is still valid. If no cookie is present we default to first-time MFA flow.

  • Authorization URLs

ERROR HANDLING

During negative scenarios, our APIs would provide 3 identifiers to indicate what the issue is. We suggest to pattern your error handling based on these levels of reference:

  • HTTP Response Status Code: This indicates the standard response of an HTTP request.

  • Error Code: these are the well defined status codes that gRPC uses.

  • Error Message: this will indicate the error description coming from our core system.

REASON FOR REJECTION

  • Settlement Rails Error Code

ISO 20022 is a global standard for exchanging electronic messages between financial institutions. There are a lot of different messaging formats in the financial section so it is essential to make use of a common standard to get everyone on the same page.

CODE LABEL DEFINITION
AC01 IncorrectAccountNumber Format of the account number specified is not correct
AC02 InvalidDebtorAccountNumber Debtor account number invalid or missing
AC03 InvalidCreditorAccountNumber Wrong IBAN in SCT
AC04 ClosedAccountNumber Account number specified has been closed on the bank of account's books
AC05 ClosedDebtorAccountNumber Debtor account number closed
AC06 BlockedAccount Account specified is blocked, prohibiting posting of transactions against it.
AC07 ClosedCreditorAccountNumber Creditor account number closed
AC08 InvalidBranchCode Branch code is invalid or missing
AC09 InvalidAccountCurrency Account currency is invalid or missing
AC10 InvalidDebtorAccountCurrency Debtor account currency is invalid or missing
AC11 InvalidCreditorAccountCurrency Creditor account currency is invalid or missing
AC12 InvalidAccountType Account type missing or invalid Generic usage if cannot specify between group and payment information levels
AC13 InvalidDebtorAccountType Debtor account type is missing or invalid
AC14 InvalidAgent An agent in the payment chain is invalid.
AG01 TransactionForbidden Transaction forbidden on this type of account (formerly NoAgreement)
AG02 InvalidBankOperationCode Bank Operation code specified in the message is not valid for receiver
AG03 TransactionNotSupported Transaction type not supported/authorized on this account
AG04 InvalidAgentCountry Agent country code is missing or invalid Generic usage if cannot specify between group and payment information levels
AG05 InvalidDebtorAgentCountry Debtor agent country code is missing or invalid
AG06 InvalidCreditorAgentCountry Creditor agent country code is missing or invalid
AG07 UnsuccesfulDirectDebit Debtor accounts cannot be debited for a generic reason. Code value may be used in general purposes and as a replacement for AM04 if debtor bank does not reveal its customer's insufficient funds for privacy reasons
AG08 InvalidAccessRights Transaction failed due to invalid or missing user or access right
AGNT IncorrectAgent Agent in the payment workflow is incorrect
AM01 ZeroAmount Specified message amount is equal to zero
AM02 NotAllowedAmount Specific transaction/message amount is greater than allowed maximum
AM03 NotAllowedCurrency Specified message amount is a non processable currency outside of existing agreement
AM04 InsufficientFunds Amount of funds available to cover the specified message amount is insufficient.
AM05 Duplication Duplication
AM06 TooLowAmount Specified transaction amount is less than agreed minimum
AM07 BlockedAmount Amount of funds available to cover the specified message amount is insufficient.
AM09 WrongAmount Amount received is not the amount agreed or expected
AM10 InvalidControlSum Sum of instructed amounts does not equal the control sum.
AM11 InvalidTransactionCurrency Transaction currency is invalid or missing
AM12 InvalidAmount Amount is invalid or missing
AM13 AmountExceedsClearingSystemLimit Transaction amount exceeds limits set by clearing system
AM14 AmountExceedsAgreedLimit Transaction amount exceeds limits agreed between bank and client
AM15 AmountBelowClearingSystemMinimum Transaction amount below minimum set by clearing system
AM16 InvalidGroupControlSum Control Sum at the Group level is invalid
AM17 InvalidPaymentInfoControlSum Control Sum at the Payment Information level is invalid
AM18 InvalidNumberOfTransactions Number of transactions is invalid or missing Generic usage if cannot specify between group and payment information levels
AM19 InvalidGroupNumberOfTransactions Number of transactions at the Group level is invalid or missing
AM20 InvalidPaymentInfoNumberOfTransactions Number of transactions at the Payment Information level is invalid
AM21 LimitExceeded Transaction amount exceeds limits agreed between bank and client.
ARDT AlreadyReturnedTransaction Already returned original SCT
ARPL AwaitingReply Reported when the cancellation request cannot be processed because no reply has been received yet from the receiver of the request message.
BE01 InconsistenWithEndCustomer Identification of the end customer is not consistent with associated account number (formerly CreditorConsistency).
BE04 MissingCreditorAddress Specification of creditor's address, which is required for payment, is missing/not correct (formerly IncorrectCreditorAddress).
BE05 UnrecognisedInitiatingParty Party who initiated the message is not recognised bythe end customer
BE06 UnknownEndCustomer End customer specified is not known at associated Sort/National Bank Code or does no longer exist in the books
BE07 MissingDebtorAddress Specification of debtor's address, which is required for payment, is missing/not correct.
BE08 BankError Party who initiated the message is not recognised by the end customer Returned as a result of a bank error.
BE09 InvalidCountry Country code is missing or Invalid Generic usage if cannot specifically identify debtor or creditor
BE10 InvalidDebtorCountry Debtor country code is missing or Invalid
BE11 InvalidCreditorCountry Creditor country code is missing or Invalid
BE12 InvalidCountryOfResidence Country code of residence is missing or Invalid Generic usage if cannot specifically identify debtor or creditor
BE13 InvalidDebtorCountryOfResidence Country code of debtor's residence is missing or Invalid
BE14 InvalidCreditorCountryOfResidence Country code of creditor's residence is missing or Invalid
BE15 InvalidIdentificationCode Identification code missing or invalid Generic usage if cannot specifically identify debtor or creditor
BE16 InvalidDebtorIdentificationCode Debtor or Ultimate Debtor identification code missing or invalid
BE17 InvalidCreditorIdentificationCode Creditor or Ultimate Creditor identification code missing or invalid
BE18 InvalidContactDetails Contact details missing or invalid
BE19 InvalidChargeBearerCode Charge bearer code for transaction type is invalid
BE20 InvalidNameLength Name length exceeds local rules for payment type.
BE21 MissingName Name missing or invalid Generic usage if cannot specifically identify debtor or creditor
BE22 MissingCreditorName Creditor name is missing
CH03 RequestedExecutionDateOrRequestedCollectionDateTooFarInFuture Value in Requested Execution Date or Requested Collection Date is too far in the future
CH04 RequestedExecutionDateOrRequestedCollectionDateTooFarInPast Value in Requested Execution Date or Requested Collection Date is too far in the past
CH07 ElementIsNotToBeUsedAtB-andC-Level Element is not to be used at B- and C-Level
CH09 MandateChangesNotAllowed Mandate changes are not allowed
CH10 InformationOnMandateChangesMissing Information on mandate changes are missing
CH11 CreditorIdentifierIncorrect Value in Creditor Identifier is incorrect
CH12 CreditorIdentifierNotUnambiguouslyAtTransaction-Level Creditor Identifier is ambiguous at Transaction Level
CH13 OriginalDebtorAccountIsNotToBeUsed Original Debtor Account is not to be used
CH14 OriginalDebtorAgentIsOnlyToBeUsedWithSequenceTypeFRST Original Debtor Agent is only to be used with SequenceType=FRST
CH15 ElementContentIncludesMoreThan140Characters Content Remittance Information/Structured includes more than 140 characters
CH16 ElementContentFormallyIncorrect Content is incorrect
CH17 ElementNotAdmitted Element is not allowed
CH19 ValuesWillBeSetToNextTARGETday Values in Interbank Settlement Date or Requested Collection Date will be set to the next TARGET day
CH20 DecimalPointsNotCompatibleWithCurrency Number of decimal points not compatible with the currency
CH21 RequiredCompulsoryElementMissing Mandatory element is missing
CH22 COREandB2BwithinOnemessage SDD CORE and B2B not permitted within one message
CN01 AuthorisationCancelled Authorisation is canceled.
CNOR Creditor bank is not registered Creditor bank is not registered under this BIC in the CSM
CURR IncorrectCurrency Currency of the payment is incorrect
CUST RequestedByCustomer Cancellation requested by the Debtor
DNOR Debtor bank is not registered Debtor bank is not registered under this BIC in the CSM
DS01 ElectronicSignaturesCorrect The electronic signature(s) is/are correct
DS02 OrderCancelled An authorized user has canceled the order
DS03 OrderNotCancelled The user’s attempt to cancel the order was not successful
DS04 OrderRejected The order was rejected by the bank side (for reasons concerning content)
DS05 OrderForwardedForPostprocessing The order was correct and could be forwarded for post processing
DS06 TransferOrder The order was transferred to VEU
DS07 ProcessingOK All actions concerning the order could be done by the EBICS bank server
DS08 DecompressionError The decompression of the file was not successful
DS09 DecryptionError The decryption of the file was not successful
DS0A DataSignRequested Data signature is required.
DS0B UnknownDataSignFormat Data signature for the format is not available or invalid.
DS0C SignerCertificateRevoked The signer certificate is revoked.
DS0D SignerCertificateNotValid The signer certificate is not valid (revoked or not active).
DS0E IncorrectSignerCertificate The signer certificate is not present.
DS0F SignerCertificationAuthoritySignerNotValid The authority of the signer certification sending the certificate is unknown.
DS0G NotAllowedPayment Signers are not allowed to sign this operation type.
DS0H NotAllowedAccount Signers are not allowed to sign for this account.
DS0K NotAllowedNumberOfTransaction The number of transactions is over the number allowed for this signer.
DS10 Signer1CertificateRevoked The certificate is revoked for the first signer.
DS11 Signer1CertificateNotValid The certificate is not valid (revoked or not active) for the first signer.
DS12 IncorrectSigner1Certificate The certificate is not present for the first signer.
DS13 SignerCertificationAuthoritySigner1NotValid The authority of signer certification sending the certificate is unknown for the first signer.
DS14 UserDoesNotExist The user is unknown on the server
DS15 IdenticalSignatureFound The same signature has already been sent to the bank
DS16 PublicKeyVersionIncorrect The public key version is not correct. This code is returned when a customer sends signature files to the financial institution after conversion from an older program version (old ES format) to a new program version (new ES format) without having carried out re-initialisation with regard to a public key change.
DS17 DifferentOrderDataInSignatures Order data and signatures don’t match
DS18 RepeatOrder File cannot be tested, the complete order has to be repeated. This code is returned in the event of a malfunction during the signature check, e.g. not enough storage space.
DS20 Signer2CertificateRevoked The certificate is revoked for the second signer.
DS21 Signer2CertificateNotValid The certificate is not valid (revoked or not active) for the second signer.
DS22 IncorrectSigner2Certificate The certificate is not present for the second signer.
DS23 SignerCertificationAuthoritySigner2NotValid The authority of signer certification sending the certificate is unknown for the second signer.
DS24 WaitingTimeExpired Waiting time expired due to incomplete order
DS25 OrderFileDeleted The order file was deleted by the bank server(for multiple reasons)
DS26 UserSignedMultipleTimes The same user has signed multiple times
DS27 UserNotYetActivated The user is not yet activated (technically)
DS28 ReturnForTechnicalReason Return following technical problems resulting in erroneous transactions.
DT01 InvalidDate Invalid date (eg, wrong or missing settlement date)
DT02 InvalidCreationDate Invalid creation date and time in Group Header (eg, historic date)
DT03 InvalidNonProcessingDate Invalid non bank processing date (eg, weekend or local public holiday)
DT04 FutureDateNotSupported Future date not supported
DT05 InvalidCutOffDate Associated message, payment information block or transaction was received after an agreed processing cut-off date, i.e., date in the past.
DT06 ExecutionDateChanged Execution Date has been modified in order for transaction to be processed
DU01 DuplicateMessageID Message Identification is not unique.
DU02 DuplicatePaymentInformationID The Payment Information Block is not unique.
DU03 DuplicateTransaction Transactions are not unique.
DU04 DuplicateEndToEndID End To End ID is not unique.
DU05 DuplicateInstructionID Instruction ID is not unique.
DUPL DuplicatePayment Payment is a duplicate of another payment
ED01 CorrespondentBankNotPossible Corresponding bank is not not possible.
ED03 BalanceInfoRequest Balance of payments complementary info is requested
ED05 SettlementFailed Settlement of the transaction has failed.
EMVL EMV Liability Shift The card payment is fraudulent and was not processed with EMV technology for an EMV card.
ERIN ERIOptionNotSupported The Extended Remittance Information (ERI) option is not supported.
FF01 Invalid File Format File Format incomplete or invalid
FF02 SyntaxError Syntax error reason is provided as narrative information in the additional reason information.
FF03 InvalidPaymentTypeInformation Payment Type Information is missing or invalid Generica usage if cannot specify Service Level or Local Instrument code
FF04 InvalidServiceLevelCode Service Level code is missing or invalid
FF05 InvalidLocalInstrumentCode Local Instrument code is missing or invalid
FF06 InvalidCategoryPurposeCode Category Purpose code is missing or invalid
FF07 InvalidPurpose Purpose is missing or invalid
FF08 InvalidEndToEndId End to End Id missing or invalid
FF09 InvalidChequeNumber Cheque number missing or invalid
FF10 BankSystemProcessingError File or transaction cannot be processed due to technical issues at the bank side
FOCR FollowingCancellationRequest Return following a cancellation request
FR01 Fraud Returned as a result of fraud.
FRTRF FinalResponseMandate Canceled Final response/tracking is recalled as the mandate is canceled.
ID01 CorrespondingOriginalFileStillNotSent Signature file was sent to the bank but the corresponding original file has not been sent yet.
LEGL LegalDecision Reported when the cancellation cannot be accepted because of regulatory rules.
MD01 NoMandate No Mandate
MD02 MissingMandatoryInformationIn Mandate Mandate related information data required by the scheme is missing.
MD05 CollectionNotDue Creditor or creditor's agent should not have collected the direct debit
MD06 RefundRequestByEndCustomer Return of funds requested by end customer
MD07 EndCustomerDeceased End customer is deceased.
MS02 NotSpecifiedReasonCustomerGenerated Reason has not been specified by end customer
MS03 NotSpecifiedReasonAgentGenerated Reason has not been specified by agent.
NARR Narrative Reason is provided as narrative information in the additional reason information.
NOAS NoAnswerFromCustomer No response from Beneficiary
NOCM NotCompliant Customer accounts are not compliant with regulatory requirements, for example FICA (in South Africa) or any other regulatory requirements which render an account inactive for certain processing.
NOOR NoOriginalTransactionReceived Original SCT never received
PINL PIN Liability Shift The card payment is fraudulent (lost and stolen fraud) and was processed as an EMV transaction without PIN verification.
PTNA PassedtoTheNextAgent Reported when the cancellation request cannot be accepted because the payment instruction has been passed to the next agent.
RC01 BankIdentifierIncorrect The Bank Identifier code specified in the message has an incorrect format (formerly IncorrectFormatForRoutingCode).
RC02 InvalidBankIdentifier Bank identifier is invalid or missing Generic usage if cannot specify between debit or credit account
RC03 InvalidDebtorBankIdentifier Debtor bank identifier is invalid or missing
RC04 InvalidCreditorBankIdentifier Creditor bank identifier is invalid or missing
RC05 InvalidBICIdentifier BIC identifier is invalid or missing Generic usage if cannot specify between debit or credit account
RC06 InvalidDebtorBICIdentifier Debtor BIC identifier is invalid or missing
RC07 InvalidCreditorBICIdentifier Creditor BIC identifier is invalid or missing
RC08 InvalidClearingSystemMemberIdentifier ClearingSystemMemberidentifier is invalid or missing Generic usage if cannot specify between debit or credit account
RC09 InvalidDebtorClearingSystemMemberIdentifier Debtor ClearingSystemMember identifier is invalid or missing
RC10 InvalidCreditorClearingSystemMemberIdentifier Creditor ClearingSystemMember identifier is invalid or missing
RC11 InvalidIntermediaryAgent Intermediary Agent is invalid or missing
RC12 MissingCreditorSchemeId Creditor Scheme Id is invalid or missing
RF01 NotUniqueTransactionReference Transaction reference is not unique within the message.
RR01 Missing Debtor Account or Identification Specification of the debtor’s account or unique identification needed for reasons of regulatory requirements is insufficient or missing
RR02 Missing Debtor Name or Address Specification of the debtor’s name and/or address needed for regulatory requirements is insufficient or missing.
RR03 Missing Creditor Name or Address Specification of the creditor’s name and/or address needed for regulatory requirements is insufficient or missing.
RR04 Regulatory Reason Regulatory Reason
RR05 RegulatoryInformationInvalid Regulatory or Central Bank Reporting information missing, incomplete or invalid.
RR06 TaxInformationInvalid Tax information missing, incomplete or invalid.
RR07 RemittanceInformationInvalid Remittance information structure does not comply with rules for payment type.
RR08 RemittanceInformationTruncated Remittance information truncated to comply with rules for payment type.
RR09 InvalidStructuredCreditorReference Structured creditor reference invalid or missing.
RR10 InvalidCharacterSet Character set supplied not valid for the country and payment type.
RR11 InvalidDebtorAgentServiceID Invalid or missing identification of a bank proprietary service.
RR12 InvalidPartyID Invalid or missing identification required within a particular country or payment type.
RUTA ReturnUponUnableToApply Return following investigation request and no remediation possible.
SL01 Specific Service offered by Debtor Agent Due to specific service offered by the Debtor Agent
SL02 Specific Service offered by Creditor Agent Due to specific service offered by the Creditor Agent
SL11 Creditor not on Whitelist of Debtor Whitelisting service offered by the Debtor Agent; Debtor has not included the Creditor on its “Whitelist” (yet). In the Whitelist the Debtor may list all allowed Creditors to debit Debtor bank accounts.
SL12 Creditor on Blacklist of Debtor Blacklisting service offered by the Debtor Agent; Debtor included the Creditor on his “Blacklist”. In the Blacklist the Debtor may list all Creditors not allowed to debit Debtor bank accounts.
SL13 Maximum number of Direct Debit Transactions exceeded Due to Maximum allowed Direct Debit Transactions per period service offered by the Debtor Agent.
SL14 Maximum Direct Debit Transaction Amount exceeded Due to Maximum allowed Direct Debit Transaction amount service offered by the Debtor Agent.
SP01 PaymentStopped Payment is stopped by the account holder.
SP02 PreviouslyStopped Previously stopped by means of a stop payment advice.
SVNR ServiceNotRendered The card payment is returned since a cash amount rendered was not correct or goods or a service was not rendered to the customer, e.g. in an ecommerce situation.
SYAD RequestToSettlementSystemAdministrator Cancellation requested by System Member to Settlement System Administrator to indicate that the cancellation request must not be forwarded further in the chain.
TA01 TransmissonAborted The transmission of the file was not successful – it had to be aborted (for technical reasons)
TD01 NoDataAvailable There is no data available (for download)
TD02 FileNonReadable The file cannot be read (e.g. unknown format)
TD03 IncorrectFileStructure The file format is incomplete or invalid
TECH TechnicalProblem Cancellation requested following technical problems resulting in an erroneous transaction.
TM01 InvalidCutOffTime Formerly: CutOffTime Associated message, payment information block or transaction was received after agreed processing cut-off time.
TRAC RemovedFromTracking Return following direct debit being removed from tracking process.
TS01 TransmissionSuccessful The (technical) transmission of the file was successful.
TS04 TransferToSignByHand The order was transferred to pass by accompanying note signed by hand
UPAY UnduePayment Payment is not justified.
9910 Receiving Bank- Logged Off Receiver signed-off
9912 Receiving Participant not available Sending Participant sends a message where the recipient cannot be connected, receives a rejection

HTTP RESPONSE CODES

Code Label Description
200 OK Processing is successful
400 BAD REQUEST The request payload has a missing parameter and/or invalid format
403 FORBIDDEN The call does not have the proper authentication
404 NOT FOUND The resource that is being retrieved is not existing
500 INTERNAL SERVER ERROR There is an issue in processing the request

ERROR CODES

Netbank Virtual APIs use the gRPC status codes to further classify the success or failure of an API request. **Those highlighted in blue are the codes that are mostly used by our APIs.

Code Label Description
0 OK Not an error; returned on success.
1 CANCELLED The operation was cancelled, typically by the caller.
2 UNKNOWN Unknown error. For example, this error may be returned when a Status value received from another address space belongs to an error space that is not known in this address space. Also errors raised by APIs that do not return enough error information may be converted to this error.
3 INVALID_ARGUMENT The client specified an invalid argument. Note that this differs from FAILED_PRECONDITION. INVALID_ARGUMENT indicates arguments that are problematic regardless of the state of the system (e.g., a malformed file name)
4 DEADLINE_EXCEEDED The deadline expired before the operation could complete. For operations that change the state of the system, this error may be returned even if the operation has completed successfully. For example, a successful response from a server could have been delayed long
5 NOT_FOUND Some requested entity (e.g., file or directory) was not found. Note to server developers: if a request is denied for an entire class of users, such as gradual feature rollout or undocumented allowlist, NOT_FOUND may be used. If a request is denied for some users within a class of users, such as user-based access control, PERMISSION_DENIED must be used.
6 ALREADY_EXISTS The entity that a client attempted to create (e.g., file or directory) already exists.
7 PERMISSION_DENIED The caller does not have permission to execute the specified operation. PERMISSION_DENIED must not be used for rejections caused by exhausting some resource (use RESOURCE_EXHAUSTED instead for those errors). PERMISSION_DENIED must not be used if the caller can not be identified (use UNAUTHENTICATED instead for those errors). This error code does not imply the request is valid or the requested entity exists or satisfies other pre-conditions.
8 RESOURCE_EXHAUSTED Some resource has been exhausted, perhaps a per-user quota, or perhaps the entire file system is out of space.
9 FAILED_PRECONDITION The operation was rejected because the system is not in a state required for the operation's execution. For example, the directory to be deleted is non-empty, an rmdir operation is applied to a non-directory, etc. Service implementors can use the following guidelines to decide between FAILED_PRECONDITION, ABORTED, and UNAVAILABLE: (a) Use UNAVAILABLE if the client can retry just the failing call. (b) Use ABORTED if the client should retry at a higher level (e.g., when a client-specified test-and-set fails, indicating the client should restart a read-modify-write sequence). (c) Use FAILED_PRECONDITION if the client should not retry until the system state has been explicitly fixed. E.g., if an "rmdir" fails because the directory is non-empty, FAILED_PRECONDITION should be returned since the client should not retry unless the files are deleted from the directory.
10 ABORTED The operation was aborted, typically due to a concurrency issue such as a sequencer check failure or transaction abort. See the guidelines above for deciding between FAILED_PRECONDITION, ABORTED, and UNAVAILABLE.
11 OUT_OF_RANGE The operation was attempted past the valid range. E.g., seeking or reading past end-of-file. Unlike INVALID_ARGUMENT, this error indicates a problem that may be fixed if the system state changes. For example, a 32-bit file system will generate INVALID_ARGUMENT if asked to read at an offset that is not in the range [0,2^32-1], but it will generate OUT_OF_RANGE if asked to read from an offset past the current file size. There is a fair bit of overlap between FAILED_PRECONDITION and OUT_OF_RANGE. We recommend using OUT_OF_RANGE (the more specific error) when it applies so that callers who are iterating through a space can easily look for an OUT_OF_RANGE error to detect when they are done.
12 UNIMPLEMENTED The operation is not implemented or is not supported/enabled in this service.
13 INTERNAL Internal errors. This means that some invariants expected by the underlying system have been broken. This error code is reserved for serious errors.
14 UNAVAILABLE The service is currently unavailable. This is most likely a transient condition, which can be corrected by retrying with a backoff. Note that it is not always safe to retry non-idempotent operations.
15 DATA_LOSS Unrecoverable data loss or corruption.
16 UNAUTHENTICATED The request does not have valid authentication credentials for the operation.

API TIMEOUT HANDLING AND IDEMPOTENCY

Idempotency simply refers to the API design principle that ensures that multiple identical API requests should return the same and original response of the initial request instead of reprocessing the operation. The Netbank Virtual APIs are designed to be idempotent in order to:

  • Avoid unintentional duplicate API requests

    This protects our API users from the risk of unintentional reprocessing of transactions due to the mistake of re-sending the same API request twice or more.

  • Retrieve the API Response in the event of an API Request Timeout

    This also serves as a mechanism to retrieve the original response of a request in the event that the API call has timed out due to network interruptions or other causes.

How does it work:

  • Our GET APIs are idempotent by nature given that these APIs retrieve information or data from our database. As such, sending multiple identical requests will return the same response.

  • Our POST and PUT APIs can be made idempotent by passing a unique id in the idempotency-key header parameter as part of the API request. Sending a request payload and a idempotency-key that is identical to a previous request and key would simply return the response of the original request without processing the second identical request.

  • In case of an API request timeout, simply resend the same request with the same idempotency-key.

    • If the original request successfully pushed through and was processed in our system, the API would simply return the response of the original request.

    • If the original request did not reach our system, we would process the second request and return a response just like a regular API call.

OTHER API GUIDELINES

  • When you start to use our APIs either in UAT or PROD, we will create a dedicated “Branch” for you in our core banking system where all your customers, accounts, and transactions would be associated/recorded. This allows us to create a silo for your activities with us to keep it private, secure, and exclusive to your application.

Virtual Collection Accounts (VCA)

Overview

Virtual Collection Accounts (VCA) is one of Netbank’s Banking-as-a-Service solutions that enables you, our Partners, to accept fully- traceable bank transfer payments from clients.

Through this solution, you are able to freely generate and assign reference numbers that act as virtual accounts that you can provide to your payors. These virtual accounts act as beneficiary account numbers for payors to transfer funds to.

The funds credited to virtual accounts are settled in your Netbank Corporate Account, enabling easier reconciliation.

To illustrate, let’s suppose you have a Netbank Corporate Bank Account Number which is 123-111-99999-1.

Instead of providing that account number to your payors, you can assign a Virtual Collection Account to a payor as a destination account when they make payments via fund transfer. For the purposes of this illustration, let’s say that the VCA assigned to customer A is “999971234567”.

When the payment to VCA “999971234567” is made, funds are credited to your Netbank Corporate Bank Account Number 123-111- 99999-1. Since both the assignment and generation of the VCA was done on your end, you should now be able to reconcile what the payment is for or who the payment was from.

There are generally no (or very minimal) APIs needed to integrate VCAs, making it a very flexible plug-and-play solution for Partners looking to implement a collection solution.

You also can receive notifications directly from our system to yours via webhooks as soon as we receive the inbound transaction.

Generating Virtual Collection Accounts

Generating Virtual Collection Accounts do not require any API integration. Instead, it is a standard format of generating the accounts that simply need to be followed. VCA numbers are generally 12-digit numbers that are comprised of:

5-digit Partner Alias + 7-digit Reference Number

Netbank will assign the 5-digit Partner Alias while the rest of the VCA number can freely be assigned by you or your system.

To enable Netbank to assign your Partner Alias, you will need to provide Netbank your nominated Netbank Corporate Account that will receive the payments credited to VCAs.

Using Virtual Collection Accounts

Virtual Collection Accounts are highly-flexible.

You can use VCAs by assigning them on a per-invoice basis where your payors will remit to different VCAs per transaction.

On the flipside, you can use VCAs by assigning them similar to a dedicated bank account where your users will remit to the same VCA for all of their transactions.

However you decide, Netbank does not need to be notified on your preferred use-case.

Features and Benefits of VCA’s

The VCA being a collection solution, allows for easier payment reconciliation. As you have visibility of the VCA that your payors are crediting, once funds are received, tagging payables as paid is much easier. This also eliminates the extra step for payors to send a proof of payment.

For fintechs and businesses looking to roll out a collection solution that is readily available to as many payors as possible, VCAs are recognized by the rails of Instapay and Pesonet. This means that payors, using their own banking or e-wallet apps, can immediately transfer funds to VCAs. There is no need to integrate separately with popular platforms like GCash, Maya, Unionbank or BPI which can be tedious, costly and time-consuming.

As VCAs are essentially a masking of your Netbank Corporate account, whenever a fund transfer occurs, they are settled directly with Netbank. The settlement schedule follows solely that of Instapay and Pesonet, eliminating clearing delays that are commonly experienced with other payment aggregators where there is normally further batching and crediting.

Making Payments to VCA’s

The user journey of paying a VCA is simple and straightforward: users log on to their favorite banking or e-wallet apps (GCash, Maya, Unionbank, BDO, BPI, etc)

  1. Select the option where can perform a fund transfer (normally labelled “Transfer” or “Send Money to Other Banks”),

  2. Look for “Netbank” in the list of banks,

  3. Enter the amount, the account name of your Netbank Corporate Account and the VCA as the destination account number.

Payment Confirmation

There are several ways to confirm if a payment into a VCA has been received, allowing for great flexibility for system and operational integration for your apps/platforms or workflow.

  1. Via the Channel Transactions page of the Netbank Virtual Partner Dashboard, you can view funds you have received in the UAT and PRODUCTION environment under the Collect Tab. Transaction details are displayed in an easy-to-understand and straightforward tabular format that includes the destination VCA that the funds were paid to.

  2. We can register an endpoint that you will expose in order to receive credit notification webhooks. You may refer to the documentation on webhooks here for further information.

  3. Via our Retrieve Bank Account Transaction History API endpoint, you can use a VCA number in the path parameter to obtain a list of transactions. Kindly refer to our API documentation for further details.

QRPH Integration

Generating QRPH images for Virtual Collection Accounts is also possible. Kindly refer to our API documentation here.

You can use a specific Virtual Collection Account as the “destination_account” in the Generate QRPH Image endpoint. This way, payors would not have to manually type in their target VCA when performing a fund transfer but instead, upload or scan a QR image. This minimizes or even eliminates the possibility of payors transferring to erroneous account details.

Testing and Integration

There is little to no API integration that would need to be done to implement Virtual Collection Accounts to your system.

In order to commence testing, you may contact your Client Success Manager via support@netbank.ph or an alternative communication point that they have established for you to receive assistance during integration. Your client Success Managers would ask you for

  1. The UAT bank account account (that you have opened via the Netbank Virtual Partner Dashboard) where your assigned 5-digit Partner Alias would be associated and

  2. A URL endpoint that you have exposed where we can push credit notification webhooks.

To simulate incoming transfers in the UAT environment, kindly utilize Netbank’s Process Account-To-Account Fund Transfer API. You can open and nominate another UAT bank account and designate it as your source account.

Feel free to reach out to your Client Success Managers for assistance on testing and other questions.

Account-As-A-Service

PRODUCT OVERVIEW

Product Name Account-As-A-Service
Product Description A service that will allow you to open white-labeled bank accounts under the name of your Company or of your end-users via APIs, via the File Upload Platform, or via a White-Labeled App.
Use Case To be able to open digital and white-labeled savings and/or loan accounts for each of your end-users OR open bank accounts under your name for cash management processes or as a receiving account to collect specific payments from your end-users and/or your merchants.
Sandbox Base URL http://api-sandbox.netbank.ph
UAT Base URL http://api-uat.netbank.ph/
PROD Base URL -

Retrieve Bank Account Interest Details

Allows you to retrieve the interest details of a specific bank account that you’ve created.

query Parameters
account_number
required
string

The actual account number of the bank account created for the individual or business/company customer record with dash (e.g. 005-0010-00032-2).
The account_number is returned by the successful response of the Create Account API.
Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created.

date_from
required
string

This is the starting point of the date range which allows you to retrieve the interest details on a custom timeframe (YYYY-MM-DD).

date_to
required
string

This is the ending point of the date range which allows you to retrieve the interest details on a custom timeframe (YYYY-MM-DD).

Responses

Response samples

Content type
application/json
{
  • "account_name": "string",
  • "adb": "string",
  • "branch": "string",
  • "effective_name": "string",
  • "gross_interest": "string",
  • "net_interest": "string",
  • "pdic_type": "string",
  • "product_name": "string",
  • "product_number": "string",
  • "product_status": "string",
  • "wtax": "string"
}

List Account Types

Retrieve list of valid account types and their IDs

Responses

Response samples

Content type
application/json
{
  • "types": [
    ]
}

Retrieve Bank Accounts of a Customer

Allows you to retrieve the full list of all bank accounts that you’ve created and associated with an Individual/ Corporate customer profile (CIF).

query Parameters
customer_id
required
string

The id that is associated by our core banking platform to the individual or corporate/ business customer record.
The customer_id is returned by the successful response of either the Create Customer API or Create Corporate Customer API.
Must be a valid customer_id that you have created within your Branch.

Responses

Response samples

Content type
application/json
{
  • "result": [
    ]
}

Create Bank Account

Allows you to create a bank account for an Individual/Corporate customer profile (CIF)

Request Body schema: application/json
customer_id
required
string

The id that is associated by our core banking platform to the individual or corporate/ business customer record.
The customer_id is returned by the successful response of either the Create Customer API or Create Corporate Customer API.
Must be a valid customer_id that you have created within your Branch

account_type_id
required
string

The id that refers to the type of bank account to be opened (e.g. Regular Savings Account, Limited Account, Loan Account, etc.).
Must only input the account type id that is approved for your Branch

description
required
string

Descriptive information regarding the account.

Responses

Request samples

Content type
application/json
{
  • "customer_id": "1480",
  • "account_type_id": "8",
  • "description": "Corporate Savings Account"
}

Response samples

Content type
application/json
{
  • "account_number": "005-0010-00032-2"
}

Update Bank Account

Allows you to update details of a bank account.

Request Body schema: application/json
bank_account_number
required
string

Netbank Bank Account Number

account_type_id
string

The id that refers to the type of bank account (e.g. Regular Savings Account, Limited Account, Loan Account, etc.).
Must only input the account type id that is approved for your Branch

extra_number
string

Reference Number of the bank account.

interest_rate
string

The interest that will be applied to the bank account

Responses

Request samples

Content type
application/json
{
  • "bank_account_number": "string",
  • "account_type_id": "string",
  • "extra_number": "string",
  • "interest_rate": "string"
}

Response samples

Content type
application/json
{
  • "processed": "2022-02-02T02:10:52.880Z"
}

Retrieve Bank Account Details

Allows you to retrieve the details of a specific bank account that you’ve created.

path Parameters
account_number
required
string

The actual account number of the bank account created for the individual or business/company customer record.
The account_number is returned by the successful response of the Create Account API.
Must be a valid Netbank account number with the proper format and dash (e.g. 005-0010-00032-2) that you have created

Responses

Response samples

Content type
application/json
{
  • "account_number": "005-0010-00032-2",
  • "account_type": {
    },
  • "accrued_interest": {
    },
  • "available_balance": {
    },
  • "balance": {
    },
  • "branch": "6",
  • "customer_id": "1566",
  • "customer_name": "Juan Dela Cruz",
  • "status": "ACTIVE"
}

Verify Bank Account Existence

Allows you to quickly verify the existence of a bank account.

path Parameters
account_number
required
string

The actual account number of the bank account created for the individual or business/company customer record with dash (e.g. 005-0010-00032-2).
The account_number is returned by the successful response of the Create Account API.
Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created

Responses

Response samples

Content type
application/json
{
  • "account_number": "string",
  • "active": true,
  • "exists": true
}

Retrieve Bank Account Transaction History

Allows you to retrieve the list of transactions of a bank account that you’ve created.

path Parameters
account_number
required
string

The actual account number of the bank account created for the individual or business/company customer record.
The account_number is returned by the successful response of the Create Account API.
Must be a valid Netbank account number with the proper format and dash (e.g. 005-0010-00032-2) that you have created.

query Parameters
start_date
string

Return transactions on or after this date (YYYY-MM-DD).

end_date
string

Return transactions before this date (YYYY-MM-DD).

limit
integer <int32>

Maximum number of transactions to return (up to 100).

offset
integer <int32>

Offset for the start of the returned transaction list.

reference_id
string

Filter By Reference ID.

Responses

Response samples

Content type
application/json
{
  • "last_running_balance": {
    },
  • "result": [
    ]
}

Create Customer Record

Allows you to pass the KYC information to create the INDIVIDUAL customer profile (CIF) from which the bank account will be associated.

Request Body schema: application/json
first_name
required
string

FirstName is the first name name of customer
Limited to 1-128 characters

middle_name
string

MiddleName is the middle name of customer
Limited to 0-128 characters

last_name
required
string

LastName is the last name of customer
Limited to 1-128 characters

title
string

Title of the customer
Must be UPPERCASE character

gender
required
string

Gender of the customer
Must be UPPERCASE character

civil_status
string

Civil status of the customer
Must be UPPERCASE character

email
string

Email address of the customer.
Must be in email format (with @domain)

required
object

Complete address of the customer

required
object

Contact number of the customer

required
object

Date of birth of the customer
age limit between 16 to 120

birth_place
required
string

BirthPlace of the customer used as a security question on the consent flow
Limited to 1-128 characters

birth_place_country
required
string

Country of Birth of the customer.
Use the ISO Alpha-2 Country Code

allow_credit_line
boolean

Determines if customer is allowed to open credit line.

object (Estimated income of the customer)

Amount defines a transaction amount.

income_type
string

Type of the customer’s income.
Must be UPPERCASE character

work_description
string

Nature of work/business of the customer

tin
string

Tax Identification Number of the customer

sss
string

Social Security Number of the customer
Limited to 1-10 characters

customer_risk_level
string

Risk level of the customer according to the KYC
Must be UPPERCASE character

phone_numbers
array

List of additional phone of customer
Limited to 0-4 phone numbers

Responses

Request samples

Content type
application/json
{
  • "first_name": "Netbank",
  • "middle_name": "Test",
  • "last_name": "AccountD",
  • "title": "MR",
  • "gender": "Male",
  • "civil_status": "Single",
  • "email": "test@netbank.ph",
  • "address": {
    },
  • "primary_phone": {
    },
  • "birthdate": {
    },
  • "birth_place": "Manila",
  • "birth_place_country": "PH",
  • "allow_credit_line": true,
  • "income": {
    },
  • "income_type": "SALARY",
  • "work_description": "work desc",
  • "tin": "317001098",
  • "sss": "34-1234567-1",
  • "customer_risk_level": "Normal",
  • "phone_numbers": [ ]
}

Response samples

Content type
application/json
{
  • "cif_number": "12847",
  • "customer_id": "1234"
}

Retrieve Customer Record

Allows you to retrieve the details of an Individual/Corporate customer profile (CIF) that you’ve created.

path Parameters
customer_id
required
string

The id that is associated by our core banking platform to the individual or corporate/ business customer record.

Responses

Response samples

Content type
application/json
{
  • "additional_addresses": {
    },
  • "address": {
    },
  • "birthdate": {
    },
  • "birthplace": "birth place",
  • "branch_id": "1",
  • "channel": "string",
  • "channel_id": "string",
  • "cif_number": "string",
  • "civil_status": "string",
  • "corporate_info": {
    },
  • "created_date": "2023-11-22T10:48:08.161Z",
  • "customer_id": "1",
  • "customer_risk_level": "customer risk level",
  • "customer_type": "INDIVIDUAL",
  • "email": "test@netbank.ph",
  • "first_name": "first name",
  • "gender": "MALE",
  • "last_name": "Last name",
  • "middle_name": "middle name",
  • "phone_numbers": {
    },
  • "primary_phone": {
    },
  • "title": "title",
  • "updated_date": "2023-11-22T10:48:08.161Z"
}

Perform KYC Document Upload.

Allows you to upload the necessary KYC Documentation for a specific Individual or Corporate Customer.

path Parameters
customer_id
required
string

The id that is associated by our core banking platform to the individual or corporate/ business customer record.
The customer_id is returned by the successful response of either the Create Customer API or Create Corporate Customer API.
Must be a valid customer_id that you have created within your Branch

Request Body schema: application/json
document_name
required
string

Name of the id/document being uploaded
Limited to 4-64 chars

document_type
required
string

The code of the ”document_type” from the Retrieve KYC Document Types API that matches the type of the id/document being uploaded.
Must be a valid document_type code from the Retrieve KYC Document Types API.

id_type
string

Only required if "document_type" = "legal_id"
The code of the ”id_type” from the Retrieve KYC Document Types API that matches the type of the id/document being uploaded.
Must be a valid id_type code from the Retrieve KYC Document Types API
Limited to 3-64 chars

id_number
string

Only required if "document_type" = "legal_id"
The valid number of the id/document being uploaded.
Limited to 4-64 chars

id_status
string

Only required if "document_type" = "legal_id"
Status of the id/document being uploaded.
Limited to 4-64 chars

issuer
required
string

The issuing authority of the id/document being uploaded
Limited to 2-64 chars

country
required
string

The issuing country of the id/document being uploaded.
Use the ISO Alpha-2 Country Code

primary_id
required
boolean

Identifies if the id/document being uploaded is a primary id or not

file
required
string

The Base64 encoded value of the id/document being uploaded

object

Expiration date of the id/document being uploaded

required
object

The date when id/document being uploaded was received

comments
required
string

Additional comments or remarks regarding the id/document being uploaded

Responses

Request samples

Content type
application/json
{
  • "document_name": "JuanDelaCruz_Philhealth_Card",
  • "document_type": "legal_id",
  • "id_type": "ID26",
  • "id_number": "12345678",
  • "id_status": "VALID",
  • "issuer": "PhilHealth NCR",
  • "country": "PH",
  • "primary_id": true,
  • "file": "iVBORw0KGgoAAAANSUhEUgAABAAAAAKfCAMAAADHI0odAAAC91BMVEUAAAFhmQlFgQpHggpSkQpfoAtrsAu8vLy8vLq8vLy8vLyjt3mn0AiszBKh5AuM2Q2CzQx3vwy84AfQ4QRrrwttsgxwtgxzuQx1vAx3vwx6wgx8xQx+yAyBzAyEzwyH0wyK1g2N2g2Q3g2T4Q2W5A2Y5A2a5Ayd5Ayg5Auj5Aqm5Aup5Aqs5Aqt5Aqv5Aqx5Amz5Am15Am35Ai65Ai85Ai/5AfD5AfG5AbK5AbO5AXR5AXU5QXX4gXY5ATV3wTS3ATP2QTN1wPL1API0gPGzwPDzAPByQO+xgO7wwO4wAO1vQOyugKxuAKvtQKttAKrsgKpsAKnrQKlqwKjqQKiqAKgpgKfpAKcoQKZngGXnAGVmgGTmAGSlgGRlQGPkgGMkAGJjQGGiQGDhgGBgwB",
  • "expiration": {
    },
  • "received": {
    },
  • "comments": "Philhealth Card"
}

Response samples

Content type
application/json
{
  • "processed": "2022-02-02T02:10:52.880Z"
}

Create Corporate Record

Allows you to pass the KYC information to create the CORPORATE customer profile (CIF) from which the bank account will be associated.

Request Body schema: application/json
business_name
required
string

Name of the business/company

trade_name
required
string

Trade name of the business/company

required
object

Complete address of the business/company

business_type
string

Type of the business/company.
List available value : 'ASSOCIATION', 'COOPERATIVE', 'CORPORATION', 'GOVERNMENT', 'NON_PROFIT_ORGANIZATION', 'PARTNERSHIP', 'SEC_REGISTERED', 'SOLE_PROPRIETORSHIP'.

required
object (Estimated size of the business/company)

Amount defines a transaction amount.

required
object (Estimated income of the business/company)

Amount defines a transaction amount.

fund_source
required
string

Source of funding of the business/company

required
object

Primary contact within the business/company

required
object

Contact number of the business/company

required
object

Date that the business/company was founded
founded date limit between 1500-01-01 to today

incorporation_country
required
string

Place of incorporation of the business/company
Use the ISO Alpha-2 Country Code

authorized_signatory
array

The list of customer_id/s of the business/company’s authorized signatories
Limited to 0-128 signatories

related_document
array

Related Document

allow_credit_line
boolean

Determines if customer is allowed to open credit line.

Responses

Request samples

Content type
application/json
{
  • "business_name": "Netbank Corp SandboxDev2",
  • "trade_name": "NetbankSandboxDev1",
  • "address": {
    },
  • "business_type": "ASSOCIATION",
  • "total_assets": {
    },
  • "income": {
    },
  • "fund_source": "IPO",
  • "contact": {
    },
  • "business_phone": {
    },
  • "founded_date": {
    },
  • "incorporation_country": "PH",
  • "authorized_signatory": [
    ],
  • "related_document": [ ],
  • "allow_credit_line": true
}

Response samples

Content type
application/json
{
  • "cif_number": "12847",
  • "customer_id": "1234"
}

Update Corporate Record

Allows you to update details of a Corporate Customer.

path Parameters
customer_id
required
string

The id that is associated by our core banking platform to the corporate business customer record.
The customer_id is returned by the successful response of the Create Corporate Customer API.
Must be a valid customer_id that you have created within your Branch

Request Body schema: application/json
customer_id
required
string

The id that is associated by our core banking platform to the corporate business customer record.
The customer_id is returned by the successful response of the Create Corporate Customer API.
Must be a valid customer_id that you have created within your Branch

trade_name
string

Trade name of the business/company

object

Complete address of the business/company

object (Estimated size of the business/company)

Amount defines a transaction amount.

object (Estimated income of the business/company)

Amount defines a transaction amount.

object

Primary contact within the business/company

object

Contact number of the business/company

fund_source
string

Source of funding of the business/company

authorized_signatory
array

The list of customer_id/s of the business/company’s authorized signatories
Limited to 0-128 signatories

Responses

Request samples

Content type
application/json
{
  • "customer_id": "string",
  • "trade_name": "string",
  • "address": {
    },
  • "total_assets": {
    },
  • "income": {
    },
  • "contact": {
    },
  • "business_phone": {
    },
  • "fund_source": "string",
  • "authorized_signatory": [ ]
}

Response samples

Content type
application/json
{
  • "processed": "2022-02-02T02:10:52.880Z"
}

Update Individual Record

Allows you to update details of a Individual Customer.

path Parameters
customer_id
required
string

The id that is associated by our core banking platform to the individual customer record.
The customer_id is returned by the successful response of the Create Individual Customer API.
Must be a valid customer_id that you have created within your Branch

Request Body schema: application/json
customer_id
required
string

The id that is associated by our core banking platform to the individual customer record.
The customer_id is returned by the successful response of the Create Individual Customer API.
Must be a valid customer_id that you have created within your Branch

middle_name
string

middle name of the individual cutomer

last_name
string

last name of the individual cutomer

title
string

title of the individual cutomer
Must be UPPERCASE character

civil_status
string

civil_status of the individual cutomer
Must be UPPERCASE character

email
string

email of the individual cutomer

object

address of the individual cutomer

object

primary phone of the individual cutomer

object (income of the individual cutomer)

Amount defines a transaction amount.

income_type
string

income type of the individual cutomer
Must be UPPERCASE character

work_description
string

work description of the individual cutomer

tin
string

tin of the individual cutomer

sss
string

sss of the individual cutomer

customer_risk_level
string

customer risk_level of the individual cutomer
Must be UPPERCASE character

phone_numbers
array

phone numbers of the individual cutomer
Limited to 0-4 phone numbers

credit_line_allowed
boolean

creditLineAllowed of the individual cutomer

Responses

Request samples

Content type
application/json
{
  • "customer_id": "string",
  • "middle_name": "string",
  • "last_name": "string",
  • "title": "string",
  • "civil_status": "string",
  • "email": "string",
  • "address": {
    },
  • "primary_phone": {
    },
  • "income": {
    },
  • "income_type": "string",
  • "work_description": "string",
  • "tin": "string",
  • "sss": "string",
  • "customer_risk_level": "string",
  • "phone_numbers": [ ],
  • "credit_line_allowed": true
}

Response samples

Content type
application/json
{
  • "processed": "2022-02-02T02:10:52.880Z"
}

Retrieve KYC Document Types

Allows you to retrieve the list of valid values for the Perform KYC Document Upload API parameters that require a specific set of values.

Responses

Response samples

Content type
application/json
{
  • "document_type": {
    },
  • "id_status": {
    },
  • "id_type": {
    }
}

Verify Customer Existence

Allows you to quickly verify the existence of an Individual/Corporate customer profile (CIF) that you’ve created.

query Parameters
first_name
string

First Name of the customer.

middle_name
string

Middle Name of the customer.

last_name
string

Last Name of the customer.

dob
string

Date of birth in the format 'YYYY-MM-DD'.

Responses

Response samples

Content type
application/json
{
  • "active": true,
  • "exists": true
}

Retrieve Customer Record Library

Allows you to retrieve the list of valid values for the Create Customer API parameters that require a specific set of values

Responses

Response samples

Content type
application/json
{
  • "types": {
    }
}

Disburse-To-Account

PRODUCT OVERVIEW

Product Name Disburse-To-Account
Product Description A service that will allow you to disburse funds or payout directly to local bank/e-wallet accounts of your end-users or internal business partners. Process intra-bank fund transfer (Netbank Account to Netbank Account), inter-bank fund transfer (Netbank Account to Other Bank Account), and wallet top up (Netbank Account to e-Wallet) via a single API, via the File Upload Platform, or via a White-Labeled App.
Use Case To be able process intra-bank fund transfer (Disbursement to a Netbank Accounts), inter-bank fund transfer (Disbursement to Other Bank Accounts or e-Wallets) through PESONet via a single API Integration or File Upload. With this solution, you can offer or utilize a service that will allow you and your customers to send funds to any bank or select e-wallet accounts
Sandbox Base URL http://api-sandbox.netbank.ph
UAT Base URL http://api-uat.netbank.ph/
PROD Base URL -
FAQs link Disburse-To-Account

Retrieve A List Of Receiving Banks

Allows you to get the latest list of banks and wallets that can receive disbursement transactions.

Responses

Response samples

Content type
application/json
{
  • "banks": {
    }
}

Check the Health of the Disbursement Service

Allows you to check the system status of the PESONet, Instapay, and Netbank-to-Netbank Fund Transfer service.

path Parameters
service_name
required
string

Name of the service that you want to check.

Responses

Response samples

Content type
application/json
{
  • "status": "UP",
  • "system_date": "2021-12-05T18:31:32.000Z",
  • "target": "PESONET"
}

Cancel PESOnet Transaction

Allows you to cancel a PESONet transaction that you’ve triggered as long as it’s within the processing cut-off

  • Pesonet transactions may be cancelled through this API given that they are still in the “PENDING” status. Check FAQs for the updated processing cycle schedule.
  • However, due to the real-time settlement nature of Instapay transactions, once successfully passed, it is not possible to have them cancelled.

path Parameters
transaction_id
required
string

The id that is associated by our platform to the disbursement transaction

Responses

Response samples

Content type
application/json
{
  • "message": "Cancelled by User",
  • "status": "REVERTED",
  • "updated": "2024-05-27T01:11:54.037Z"
}

Process Account-To-Account Fund Transfer

Allows you to trigger a fund transfer from your Netbank Bank Account to another Netbank Bank Account (DIRECT) or a bank/e-wallet account in other financial institutions (INSTAPAY or PESONET).

Request Body schema: application/json
reference_id
required
string

API User’s own unique reference code.
Limited to 0-36 characters.

settlement_rail
required
string

The mode of fund transfer.
DIRECT = Netbank Account to Netbank Account Fund Transfer.
INSTAPAY = Real-time interbank fund transfer with a Php 50,000 limit per transaction.
PESONET = Interbank fund transfer without a transaction amount limit.

source_account_number
required
string

Netbank Bank Account Number where the funds will be drawn/debited from.
Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created.

required
object

Contains the details of the sending entity.

required
object

Contains the details of the bank account where funds will be credited to.

required
object

Contains the details of the receiving entity.
PesoNet and InstaPay transfers require recipient name.

remarks
string

Additional information regarding the transaction.
Note: Instapay and PesoNet rails will truncate to 35 characters in the memo line.

required
object

Amount defines a transaction amount.

Responses

Request samples

Content type
application/json
{
  • "reference_id": "PESONET1234",
  • "settlement_rail": "PESONET",
  • "source_account_number": "440-000-00001-1",
  • "sender": {
    },
  • "destination_account": {
    },
  • "recipient": {
    },
  • "remarks": "",
  • "amount": {
    }
}

Response samples

Content type
application/json
{
  • "status": "Pending",
  • "transaction_id": "7453766"
}

Retrieve Account-to-Account Transaction Details

Allows you to retrieve the details of a fund transfer transaction that you’ve triggered.

STATUSDESCRIPTIONSTATE OF FUNDS
PendingThe payout request has been received by NetbankDebited from the Source Bank Account (Netbank)
ForSettlementThe payout request has been forwarded by Netbank to the Automated Clearing Houses (ACHs) for processingSent to the Receiving Financial Institution
SettledThe payout request has been processed by the ACH and settled by the Receiving Financial Institution to the target bank accountCredited to the target bank account within the Receiving Financial Institution
RejectedThe payout request has been processed by the ACH but rejected by the Receiving Financial Institution for settlementReturned to the Source Bank Account (Netbank)

path Parameters
transaction_id
required
string

The id that is associated by our platform to the disbursement transaction.
The transaction_id is returned by the successful response of Process Account-to-Account Fund Transfer API.
Must be a valid transaction_id that you have created within your Branch.

Responses

Response samples

Content type
application/json
{
  • "amount": {
    },
  • "destination_account": {
    },
  • "recipient": {
    },
  • "reference_id": "01",
  • "remarks": "Remarks",
  • "sender": {
    },
  • "settlement_rail": "PESONET",
  • "source_account_number": "005-01-00007-2",
  • "status": "PENDING"
}

Webhook-Documentation

Introduction

A Webhook is a notification mechanism that allows you to receive information from specific events taking place in various kinds of transactions or operations such as when funds are credited to an account.

Compared to running cron jobs or polling an endpoint, webhooks are a more scalable alternative as it is a push notification service which is less system intensive.

Important:

Despite the convenience that it affords, implementation designs with complete dependency on webhook notifications should be avoided. Just like with any other service, 100% perpetual uptime cannot be expected.

Contingencies and backup exception handling should be put in place in the event that the webhook service is down or unavailable due to various reasons. These measures may include utilizing 1. the available Transaction History or Transaction Detail endpoints to confirm the status of a disbursement or collection and 2. the Transaction Page of the Netbank Virtual Partner Dashboard.

Configuration

In order to receive webhooks, a dedicated endpoint needs to be set up on your end as a receiver or listener that can accept HTTP POST requests. This endpoint needs to be provided to Netbank to be registered in the service for you to begin receiving notifications.

Your endpoint should expect to receive content-type text/plain;charset=ISO-8859-1

IP whitelisting is the security mechanism that Netbank employs on its webhook service. Notifications are sent from the following IP addresses:

  • UAT: 3.0.84.126
  • PROD: 52.74.254.158

Retry Mechanism

The retry mechanism is a way of ensuring that webhook events are delivered to the destination server in case of failures. The webhook service will retry if we are not able to establish any HTTP connection to your endpoint.

In case of non-200 responses, the webhook service will account for this response and will not retry.

Retries will follow the timing below:

1st retry: 1 min

2nd retry: 4 min

3rd retry: 16 min

4th retry: 64 min

5th retry: 256 min (~4h)

Events Available

Currently, we can support to provide webhooks for the following events:

ECPay Credit Notification

  • Event name: PROCESS_DIRECT_INCOMING_FUND_TRANSFER
  • Timing: whenever a fund transfer is credited to one of your accounts from an ECPAY deposit
  • Use Case: Local Collect
Request Body schema: application/json
object

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "alias": null,
  • "amount": null,
  • "channel": "string",
  • "commandId": null,
  • "externalTransferStatus": "string",
  • "operationId": null,
  • "productBranchCode": null,
  • "recipientAccountName": "string",
  • "recipientAccountNumber": "string",
  • "recipientAccountNumberBankFormat": "string",
  • "referenceCode": "string",
  • "referenceNumber": "string",
  • "registrationTime": null,
  • "remarks": "string"
}

Incoming Fund Transfer from Other Netbank Accounts via the "Direct" Settlement Rail

  • Event name: ACCOUNT_TRANSFER_TO_PRODUCT
  • Timing: whenever a fund transfer from other Netbank accounts via the DIRECT settlement rail is credited to one of your accounts
  • Use Case: Accounts-as-a-Service, Local Collect, Local Collect-via-QR
Request Body schema: application/json
object

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "Remarks": "string",
  • "Sender": {
    },
  • "alias": "string",
  • "amount": 0,
  • "channel": "string",
  • "commandId": null,
  • "operationId": 0,
  • "productBranchCode": "string",
  • "productId": "string",
  • "recipient": {
    },
  • "recipientAccountNumberBankFormat": "string",
  • "referenceCode": "string",
  • "registrationTime": "string",
  • "targetProductBranchCode": "string"
}

Incoming Fund Transfer from Instapay and Pesonet

  • Event name: PROCESS_PESONET_INCOMING_FUND_TRANSFER and SETTLE_INCOMING_INSTAPAY_TRANSFER
  • Timing: whenever a fund transfer is credited to one of your accounts from Instapay or Pesonet
  • Use Case: Local Collect and Local Collect-via-QR
Request Body schema: application/json
object

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "alias": "string",
  • "amount": 0,
  • "channel": "string",
  • "externalTransferStatus": "string",
  • "operationId": 0,
  • "productBranchCode": "string",
  • "recipientAccountNumber": "string",
  • "recipientAccountNumberBankFormat": "string",
  • "referenceCode": "string",
  • "referenceNumber": "string",
  • "registrationTime": "string",
  • "remarks": "string",
  • "sender": {
    },
  • "transferType": "string"
}

Incoming Fund Transfer from other Netbank accounts via the Direct settlement rail

  • Event name: ACCOUNT_TRANSFER_TO_PRODUCT
  • Timing: whenever a fund transfer from other Netbank accounts via the DIRECT settlement rail is credited to one of your accounts
  • Use Case: Accounts-as-a-Service, Local Collect, Local Collect-via-QR
Request Body schema: application/json
object

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "Remarks": "string",
  • "Sender": {
    },
  • "alias": "string",
  • "amount": 0,
  • "channel": "string",
  • "commandId": null,
  • "operationId": 0,
  • "productBranchCode": "string",
  • "recipient": {
    },
  • "recipientAccountNumberBankFormat": "string",
  • "referenceCode": "string",
  • "registrationTime": "string",
  • "targetProductBranchCode": "string"
}

Outgoing Fund Transfer via INSTAPAY - REJECTED

  • Event name:TRANSFER_STATUS_CHANGE

  • Timing: sent whenever a disbursement sent through Instapay or Pesonet changes its settlement status

    • INSTAPAY: 1 webhook is sent to update the status to either SETTLED or REJECTED

    • PESONET: 1 webhook is sent to update the status to FOR_SETTLEMENT; 1 webhook is sent again thereafter to update the status to either SETTLED or REJECTED

Request Body schema: application/json
object

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "amount": 0,
  • "channel": "string",
  • "operationId": 0,
  • "ownerCifNumber": "string",
  • "productBranchCode": "string",
  • "purpose": "string",
  • "recipientAccountNumber": "string",
  • "referenceNumber": "string",
  • "registrationTime": "string",
  • "remarks": "string",
  • "senderAccountNumber": "string",
  • "status": "string",
  • "statusCode": "string",
  • "transferType": "string",
  • "uuid": "string"
}

Outgoing Fund Transfer via INSTAPAY - SETTLED

  • Event name:TRANSFER_STATUS_CHANGE

  • Timing: sent whenever a disbursement sent through Instapay or Pesonet changes its settlement status

    • INSTAPAY: 1 webhook is sent to update the status to either SETTLED or REJECTED

    • PESONET: 1 webhook is sent to update the status to FOR_SETTLEMENT; 1 webhook is sent again thereafter to update the status to either SETTLED or REJECTED

Request Body schema: application/json
object

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "amount": 0,
  • "channel": "string",
  • "operationId": 0,
  • "ownerCifNumber": "string",
  • "productBranchCode": "string",
  • "purpose": "string",
  • "recipientAccountNumber": "string",
  • "referenceNumber": "string",
  • "registrationTime": "string",
  • "remarks": "string",
  • "senderAccountNumber": "string",
  • "status": "string",
  • "statusCode": "string",
  • "transferType": "string",
  • "uuid": "string"
}

Outgoing Fund Transfer via PESONET - FOR_SETTLEMENT

  • Event name:TRANSFER_STATUS_CHANGE

  • Timing: sent whenever a disbursement sent through Instapay or Pesonet changes its settlement status

    • INSTAPAY: 1 webhook is sent to update the status to either SETTLED or REJECTED

    • PESONET: 1 webhook is sent to update the status to FOR_SETTLEMENT; 1 webhook is sent again thereafter to update the status to either SETTLED or REJECTED

Request Body schema: application/json
object

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "amount": 0,
  • "channel": "string",
  • "operationId": 0,
  • "ownerCifNumber": "string",
  • "productBranchCode": "string",
  • "purpose": "string",
  • "recipientAccountNumber": "string",
  • "referenceNumber": "string",
  • "registrationTime": "string",
  • "remarks": "string",
  • "senderAccountNumber": "string",
  • "status": "string",
  • "statusCode": "string",
  • "transferType": "string",
  • "uuid": "string"
}

Outgoing Fund Transfer via PESONET - REJECTED

  • Event name:TRANSFER_STATUS_CHANGE

  • Timing: sent whenever a disbursement sent through Instapay or Pesonet changes its settlement status

    • INSTAPAY: 1 webhook is sent to update the status to either SETTLED or REJECTED

    • PESONET: 1 webhook is sent to update the status to SETTLED; 1 webhook is sent again thereafter to update the status to either SETTLED or REJECTED

Request Body schema: application/json
object

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "amount": 0,
  • "channel": "string",
  • "operationId": 0,
  • "ownerCifNumber": "string",
  • "productBranchCode": "string",
  • "purpose": "string",
  • "recipientAccountNumber": "string",
  • "referenceNumber": "string",
  • "registrationTime": "string",
  • "remarks": "string",
  • "senderAccountNumber": "string",
  • "status": "string",
  • "statusCode": "string",
  • "transferType": "string",
  • "uuid": "string"
}

Outgoing Fund Transfer via PESONET - SETTLED

  • Event name:TRANSFER_STATUS_CHANGE

  • Timing: sent whenever a disbursement sent through Instapay or Pesonet changes its settlement status

    • INSTAPAY: 1 webhook is sent to update the status to either SETTLED or REJECTED

    • PESONET: 1 webhook is sent to update the status to SETTLED; 1 webhook is sent again thereafter to update the status to either SETTLED or REJECTED

Request Body schema: application/json
object

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "amount": 0,
  • "channel": "string",
  • "operationId": 0,
  • "ownerCifNumber": "string",
  • "productBranchCode": "string",
  • "purpose": "string",
  • "recipientAccountNumber": "string",
  • "referenceNumber": "string",
  • "registrationTime": "string",
  • "remarks": "string",
  • "senderAccountNumber": "string",
  • "status": "string",
  • "statusCode": "string",
  • "transferType": "string",
  • "uuid": "string"
}

Repayments Received To Loan Accounts

  • Event name: PAY_LOAN
  • Timing: whenever a payment is posted to a loan account
  • Use Case: Loan-as-a-Service
Request Body schema: application/json
object

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "amount": 0,
  • "channel": "string",
  • "checkNo": 0,
  • "commandId": 0,
  • "currentAmortizationDueDate": "string",
  • "customerEffectiveName": "string",
  • "customerFirstName": "string",
  • "customerLastName": "string",
  • "loanAccountNumber": "string",
  • "loanId": "string",
  • "nextDueDate": "string",
  • "operationId": 0,
  • "outstandingAmortizations": "string",
  • "outstandingBalance": 0,
  • "paymentStatus": "string",
  • "paymentType": "string",
  • "productBranchCode": "string",
  • "sourceAccount": "string",
  • "sourceAccountBranchCode": "string",
  • "sourceAccountSenderName": "string",
  • "transactionDate": "string"
}

Direct-Checkout

PRODUCT OVERVIEW

Product Name Direct Checkout
Product Description A service that simplifies payment collection by integrating direct debit with a specific financial institution or providing a checkout page where users can select their preferred institution for fast, secure one-time transactions.

This solution is developed in partnership with SwiftPay, enhancing transaction efficiency and expanding payment options for end-users.
Sandbox Base URL http://api-sandbox.netbank.ph
UAT Base URL http://api-uat.netbank.ph
PROD Base URL -

You also need to obtain your access and secret keys. These keys are available once you log in to your account on the SwiftPay Merchant Portal. Make sure to include these keys in your request headers.

You can test using these credentials for GCash:

  • Mobile no: +639320641155
  • Password: MQGiHD5S
  • OTP: 123456

List values for payment_status:

PENDING The transaction has started, but confirmation from the financial institution is still pending. This status applies to transactions that are in progress or have not yet been confirmed, whether due to ongoing processing, timeouts, or any other reason that prevents confirmation.
EXECUTED The transaction has been successfully completed and confirmed by the financial institution.
CANCELED The transaction was stopped by the user before it was finalized.
REJECTED The transaction was submitted but declined by the financial institution, often due to reasons like insufficient funds.
EXPIRED The transaction was started but never completed. For example, the user might have closed the browser before finishing the process. Payments initiated by API will automatically expire 48 hours after creation if not completed. After this period, the status changes from PENDING to EXPIRED.

Initiate Collection via Direct Debit.

This API allows Netbank Clients to create a payment collection URL for the specified financial institution to which they can redirect end-users to the direct debit payment page of that institution. This allows for a streamlined user experience for direct debit where the end-users can proceed with payment via direct debit without selecting the financial institution on a custom checkout page.

Request Body schema: application/json
access_key
required
string

Access Key granted by Swiftpay. These keys are available once merchant logins to their account on SwiftPay Merchant Portal available here: https://merchant.live.swiftpay.ph/login

required
object

Amount defines a transaction amount.

object

Customer defines a Initiate Collection customer.

institution_code
string

The unique code representing the financial institution

reference_no
required
string

API User's own unique reference code. Maximum 64 alphanumeric characters

secret_key
required
string

Secret Key granted by Swiftpay. These keys are available once merchant logins to their account on SwiftPay Merchant Portal available here: https://merchant.live.swiftpay.ph/login

Responses

Request samples

Content type
application/json
{
  • "access_key": "string",
  • "amount": {
    },
  • "customer": {
    },
  • "institution_code": "string",
  • "reference_no": "string",
  • "secret_key": "string"
}

Retrieve List of Financial Institutions for Collection.

This API endpoint retrieves a list of financial institutions, including banks and wallets, that are available to support collection transactions.
If provided, the redirect_url parameter will bypass the institution selection screen and directly redirect the user to the selected financial institution (payment method) to complete the collection transaction.

Responses

Response samples

Content type
application/json
{}

Retrieve Collection Transaction by Reference Number.

This API retrieves detailed transaction information using the reference number.

header Parameters
reference-no
required
string

API User's own unique reference code. Maximum 64 alphanumeric characters.

x-access-key
required
string

Access Key granted by Swiftpay. These keys are available once merchant logins to their account on SwiftPay Merchant Portal available here: https://merchant.live.swiftpay.ph/login.

Responses

Response samples

Content type
application/json
{
  • "amount": {
    },
  • "payment_id": "5e3e83ac-8b6b-418f-a1c9-e515b23b352c",
  • "payment_status": "EXPIRED",
  • "reference_no": "000000SH2"
}

QR-PH

PRODUCT OVERVIEW

Product Name QRPH
Product Description A service that empowers partners to generate scannable and uploadable QR codes for seamless payment collection across various banking and payment apps. Additionally, you can upload a QRPH image, scan it, and seamlessly disburse the decoded QRPH data directly from your Netbank account
Use Case
  • LENDING: Be able to collect loan payments from borrowers by providing QR Codes (trackable with Virtual Collection Accounts)
  • PAYMENTS/E-COMMERCE: Be able to collect product and service payments from consumers by providing QR Codes (trackable with Virtual Collection Accounts)
  • WALLETS/NEOBANKS: For EMIs and non-EMIs: allow wallet holders the option to top up their wallet or make P2P transfers by providing QR Codes (trackable with Virtual Collection Accounts) within the wallet app/platform that can be scanned by local mobile banking and e-wallet apps
  • REMITTANCE: Be able to collect local funds to be sent out for outbound remittance by providing QR Codes (trackable with Virtual Collection Accounts) within the remittance app/platform/counter that can be scanned by local mobile banking and e-wallet apps
  • CONSUMER UTILITIES/SERVICES: Be able to collect utility and service bill payments from consumers by providing QR Codes (trackable with Virtual Collection Accounts) within the payment checkout page and/or bill statement that can be scanned by local mobile banking and e-wallet apps
Sandbox Base URL http://api-sandbox.netbank.ph
UAT Base URL http://api-uat.netbank.ph/
PROD Base URL -
FAQs link QR PH
Collect as a Service

Decode QRPH string

The QR Image needs to be processed / scanned to retrieve the qr_string. This string contains the encoded information necessary for further processing.

query Parameters
qr_string
string

Decoded string from QR code image
Example: qr_string=00020101021127740012com.p2pqrpay0111CUOBPHM2XXX02089996440303080415179-001-00001-852046016530360854045.005802PH5918MERCHANT NAME JUAN6007ROMBLON6304D6C7.

Responses

Response samples

Content type
application/json
{
  • "amount": {
    },
  • "destination_account": "179-001-00001-8",
  • "destination_bank_code": "CUOBPHM2XXX",
  • "disburse_id": "ce63ca37-0cc7-43f9-a01a-6f8959487f6f",
  • "merchant_city": "ROMBLON",
  • "merchant_id": "<string>",
  • "merchant_name": "MERCHANT NAME JUAN",
  • "qr_transaction_type": "P2P",
  • "qr_type": "Static"
}

Generate QRPH images

  • NetBank offers Virtual Collection Account that allows you to collect money from different bank accounts / e-wallets (of Instapay and PESOnet) and have it settled to a dedicated bank account for that specific use case. This eliminates the need for payors to manually send a proof of payment or deposit. You can contact your solutions manager or support@netbank.ph
  • The qr_code field returns a Base64 string representing the QR code. To display the QR code, the Base64 string must be converted into an image.
Request Body schema: application/json
qr_type
required
string (Type of the payment QR code. Either static or dynamic)
Enum: "UnknownQRType" "Static" "Dynamic"
  • Static: QRType_Static the payment amount may or may not be indicated.
    Supported by all banks. Same QR for multiple transaction. If the amount is not indicated, it needs to be entered by the consumer
    - Dynamic: QRType_Dynamic the payment amount is usually part of the QR code information
    Supported by some banks only. Unique QR for every transaction.
qr_transaction_type
required
string (Type of the payment QR code transaction. Either P2P or P2M)
Enum: "UnknownQRTransactionType" "P2P" "P2M"
  • P2P: Transaction between Person to Person. There is a limit of Php 50,000/transaction.
    - P2M: Transaction between Person to Merchant. There is a limit of Php 999,999/transaction.
    The Merchant referred to in this term corresponds to any registered and established institution with an acquiring relationship with its bank of account that provides goods and/or services to customers in exchange for a specific payment amount.
destination_account
required
string

Contains the details of the bank account where funds will be credited to.

resolution
integer

Defines the resolution in pixels of the image generated. Value of 480 will generate an image with dimension of 480x480.
Defaults to 720, valid range [ 480 .. 1080 ]

purpose
string

Additional Data. Purpose of the transaction. Maximum character length 25.

reference_id
string

Additional Data. Any value defined by the merchant in order to identify the transaction. Maximum character length 25.

store_label
string

A distinctive label associated to a store of the merchant. Maximum character length 15.

merchant_name
required
string

Name that may be displayed to the end user. Maximum character length is 25, without special characters.

merchant_city
required
string

City of the destination merchant.

merchant_id
string

Identifier of the merchant present in P2M codes.
This is the Partner ID found in the partner dashboard. It consists of the first 25 characters of the Partner ID, including the dashes (e.g., Partner ID: "8ff2c707-f44a-4972-9c3c-cb52df339029" = Merchant ID: "8ff2c707-f44a-4972-9c3c-c")

generate_additional_fields
boolean

GenerateAdditionalFields Identifies if the additional data will be included in the generated QR. Most of the bank do not support additional data and results to 'Invalid QR'. Defaults to false.

object

Amount defines a transaction amount.

Responses

Request samples

Content type
application/json
{
  • "qr_type": "Static",
  • "qr_transaction_type": "P2P",
  • "destination_account": "179-001-00001-8",
  • "resolution": "720",
  • "purpose": "cupcakeselling",
  • "reference_id": "MerchantDefinedRefID",
  • "store_label": "superbranch",
  • "merchant_name": "merchant name",
  • "merchant_city": "romblon",
  • "merchant_id": "c33048be-8cf4-47e2-8299-4",
  • "generate_additional_fields": true,
  • "amount": {
    }
}

Response samples

Content type
application/json
{
  • "qr_code": "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"
}

Process QRPH disbursement

Under Development. Available only on api-sandbox.netbank.ph and api-uat.netbank.ph.
Allows you to trigger a disbursement with the decoded QRPH disburse id from your Netbank Bank Account.

Request Body schema: application/json
disburse_id
required
string

Identifier from 'Decode QRPH string'. The details from the decoded QRPH code will be used to create a disbursement.

source_account_number
required
string

Netbank Bank Account Number where the funds will be drawn/debited from.
Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created.

reference_id
string

API User's own unique reference code.
Limited to 0-36 characters.

object

Amount defines a transaction amount.

Responses

Request samples

Content type
application/json
{
  • "disburse_id": "3265c1aa-1cfd-4450-8b05-1bf7f49e21de",
  • "source_account_number": "294-000-00021-4",
  • "reference_id": "Test123",
  • "amount": {
    }
}

Response samples

Content type
application/json
{
  • "status": "Pending",
  • "transaction_id": "7453762"
}

Loan

Create Loan

Create a customer loan.

Request Body schema: application/json
customer_id
required
string

The id that is associated by our banking platform
to the individual or corporate/business customer record.
The customer_id is returned by the successful response of either
the Create Customer API or Create Corporate Customer API.
The value must be a valid customer_id that exists within your branch.

issuance_type
required
string
Enum: "UNKNOWN" "IssueNew"

The type of loan issuance to process.
The value ust be a valid issuance_type from the Retrieve Loan Options Library API.

loan_type
required
string

The type of loan to issue.
The value must be a valid loan_type from the Retrieve Loan Options Library API.

required
object

The amount of money to be borrowed
Required if the issuance_type is not “RESTRUCTURED"
The value must be a positive number.

credit_line
string

Identifier of credit line to associate with the loan.

attach_documents
array

Attach submitted documents to the loan.

reference_id
string

API User’s own unique reference code.
Limited to 0-36 characters.

schedule_code
required
string

Schedule of repayment installments.
See installment schedule list in loan options for available schedules.

amortization_count
required
integer

Total number of planned installments in the full repayment schedule.

interest_rate
required
string

Annual interest rate applied to the loan interest accrual calculations.
Format as a decimal with up to five fractional digits (14.54323% => "14.54323").

object

First installment due date.

loan_officer
string

The id that is associated by our banking platform
to the individual or corporate/business customer record.
The customer_id is returned by the successful response of either
the Create Customer API or Create Corporate Customer API.
The value must be the customer_id of the Netbank Client calling the Create Loan API

loan_collector
string

The id that is associated by our banking platform
to the individual or corporate/business customer record.
The customer_id is returned by the successful response of either
the Create Customer API or Create Corporate Customer API.
The value must be the customer_id of the Netbank Client calling the Create Loan API

linked_account
string

Register an account for auto-debit on the installment due date.
This account must be owned by the borrower.
Deprecated: Use

co_signer
array

Customer ids of loan cosigners.
Must be a valid customer_id that exists within your branch.

remarks
string

Additional remarks/comment on the loan

object

Options for fund release. Default general ledger.

rate_type
string

The type of loan rate to process.
The value must be a valid rate_type from the Retrieve Loan Options Library API.

extra_number
string

Additional reference ID for the loan account

Responses

Request samples

Content type
application/json
{
  • "customer_id": "string",
  • "issuance_type": "UNKNOWN",
  • "loan_type": "string",
  • "principal_amount": {
    },
  • "credit_line": "string",
  • "attach_documents": [ ],
  • "reference_id": "string",
  • "schedule_code": "string",
  • "amortization_count": 0,
  • "interest_rate": "string",
  • "amortization_due": {
    },
  • "loan_officer": "string",
  • "loan_collector": "string",
  • "linked_account": "string",
  • "co_signer": [ ],
  • "remarks": "string",
  • "release_option": {
    },
  • "rate_type": "string",
  • "extra_number": "string"
}

Response samples

Content type
application/json
{
  • "account_number": "string",
  • "status": "string",
  • "transaction_id": "string"
}

Create Loan interbank

Request Body schema: application/json
customer_id
required
string

The id that is associated by our banking platform
to the individual or corporate/business customer record.
The customer_id is returned by the successful response of either
the Create Customer API or Create Corporate Customer API.
The value must be a valid customer_id that exists within your branch.

issuance_type
required
string
Enum: "UNKNOWN" "IssueNew"

The type of loan issuance to process.
The value ust be a valid issuance_type from the Retrieve Loan Options Library API.

loan_type
required
string

The type of loan to issue.
The value must be a valid loan_type from the Retrieve Loan Options Library API.

required
object

The amount of money to be borrowed
Required if the issuance_type is not “RESTRUCTURED"
The value must be a positive number.

credit_line
string

Identifier of credit line to associate with the loan.

attach_documents
array

Attach submitted documents to the loan.

reference_id
string

API User’s own unique reference code.
Limited to 0-36 characters.

schedule_code
required
string

Schedule of repayment installments.
See installment schedule list in loan options for available schedules.

amortization_count
required
integer

Total number of planned installments in the full repayment schedule.

interest_rate
required
string

Annual interest rate applied to the loan interest accrual calculations.
Format as a decimal with up to five fractional digits (14.54323% => "14.54323").

object

First installment due date.

loan_officer
string

The id that is associated by our banking platform
to the individual or corporate/business customer record.
The customer_id is returned by the successful response of either
the Create Customer API or Create Corporate Customer API.
The value must be the customer_id of the Netbank Client calling the Create Loan API

loan_collector
string

The id that is associated by our banking platform
to the individual or corporate/business customer record.
The customer_id is returned by the successful response of either
the Create Customer API or Create Corporate Customer API.
The value must be the customer_id of the Netbank Client calling the Create Loan API

linked_account
string

Register an account for auto-debit on the installment due date.
This account must be owned by the borrower.
Deprecated: Use

co_signer
array

Customer ids of loan cosigners.
Must be a valid customer_id that exists within your branch.

remarks
string

Additional remarks/comment on the loan

rate_type
string

The type of loan rate to process.
The value must be a valid rate_type from the Retrieve Loan Options Library API.

required
object

Transfer details

extra_number
string

Additional reference ID for the loan account

Responses

Request samples

Content type
application/json
{
  • "customer_id": "string",
  • "issuance_type": "UNKNOWN",
  • "loan_type": "string",
  • "principal_amount": {
    },
  • "credit_line": "string",
  • "attach_documents": [ ],
  • "reference_id": "string",
  • "schedule_code": "string",
  • "amortization_count": 0,
  • "interest_rate": "string",
  • "amortization_due": {
    },
  • "loan_officer": "string",
  • "loan_collector": "string",
  • "linked_account": "string",
  • "co_signer": [ ],
  • "remarks": "string",
  • "rate_type": "string",
  • "transfer": {
    },
  • "extra_number": "string"
}

Response samples

Content type
application/json
{
  • "account_number": "string",
  • "fund_transfer": {
    },
  • "status": "string"
}

Retrieve Loan Information

Get loan information using the loan account number

path Parameters
account_number
required
string

Responses

Response samples

Content type
application/json
{
  • "account_number": "string",
  • "accrual_limit": 0,
  • "accrual_period": "string",
  • "accrued_interest": {
    },
  • "advance_interest_amount": {
    },
  • "advance_interest_application": "string",
  • "advance_interest_no": 0,
  • "allow_accrual": true,
  • "amortization_schedule": {
    },
  • "application_fee": {
    },
  • "application_fee_already_paid": true,
  • "as_earned_interest_calculation": true,
  • "balance": {
    },
  • "calculated_first_amortization_due_date": {
    },
  • "category_ids": [
    ],
  • "cbu_fund_account_id": "string",
  • "cbu_hold_id": "string",
  • "cbu_savings_account_id": "string",
  • "check_preparation_id": "string",
  • "closed_on": "string",
  • "co_makers": [
    ],
  • "collector_id": "string",
  • "comments": "string",
  • "created_on": "string",
  • "creation_type": "string",
  • "credit_investigation_fee": {
    },
  • "credit_investigation_fee_already_paid": true,
  • "credit_line_id": "string",
  • "customer_id": "string",
  • "cycle": 0,
  • "days_in_year": 0,
  • "definition_id": "string",
  • "dep_ed_income_source_id": "string",
  • "dep_ed_policy_number": "string",
  • "diminishing_amortization_number": 0,
  • "discount_charges_ledger": {
    },
  • "discount_charges_rate": "string",
  • "doc_stamp": {
    },
  • "doc_stamp_already_paid": true,
  • "eir_annual": "string",
  • "eir_monthly": {
    },
  • "eir_periodic": "string",
  • "extra_bank_fee": {
    },
  • "extra_bank_fee_already_paid": true,
  • "extra_number": "string",
  • "first_amortization_due_date": {
    },
  • "grace_period": 0,
  • "grant_date": {
    },
  • "gross_eir_annual": "string",
  • "gross_eir_periodic": "string",
  • "group_loan_id": "string",
  • "group_loan_name": "string",
  • "holds_balance": {
    },
  • "id": "string",
  • "id_fee": {
    },
  • "id_fee_already_paid": true,
  • "insurance_fee": {
    },
  • "insurance_fee_already_paid": true,
  • "insurance_processing_fee": {
    },
  • "insurance_processing_fee_already_paid": true,
  • "insurance_service_fee": {
    },
  • "insurance_service_fee_already_paid": true,
  • "interest_amount": {
    },
  • "interest_balance": {
    },
  • "interest_calculation_parameter": 0,
  • "interest_rate": "string",
  • "interest_type": "string",
  • "last_accrual_date": {
    },
  • "last_customer_transaction": "string",
  • "last_transaction": "string",
  • "late_check_awaiting_amount": {
    },
  • "latest_irreversible_operation": "string",
  • "linked_deposit_account_id": "string",
  • "loan_documents": [
    ],
  • "loan_information": {
    },
  • "loss_allowance": {
    },
  • "mapping_attributes": {
    },
  • "maturity_date": {
    },
  • "membership_fee": {
    },
  • "membership_fee_already_paid": true,
  • "metadata": {
    },
  • "monthly_interest_rate": "string",
  • "negative_information": {
    },
  • "notarial_fee": {
    },
  • "notarial_fee_alreadyPaid": true,
  • "officer_id": "string",
  • "opening_deductions": {
    },
  • "origin": "string",
  • "override_amortization_amount": {
    },
  • "past_due_interest_charge": {
    },
  • "past_due_maturity_interest_charge": {
    },
  • "payment_interval_definition": {
    },
  • "penalty_maturity": {
    },
  • "penalty_maturity_collection_type": "string",
  • "pf_hold_id": "string",
  • "pf_savings_account_id": "string",
  • "principal_amount": {
    },
  • "principal_balance": {
    },
  • "release_allowed_date": {
    },
  • "release_amount": {
    },
  • "release_date": {
    },
  • "remade_from_loan_ids": [
    ],
  • "remade_to": "string",
  • "renewed_loan_id": "string",
  • "service_charge": {
    },
  • "service_charge_already_paid": true,
  • "simulated_amortized_fees": [
    ],
  • "simulated_fees": [
    ],
  • "status": "string",
  • "term": 0,
  • "term_adjustment": 0,
  • "total_amortization_number": 0,
  • "total_default_fees": {
    },
  • "tp_hold_id": "string",
  • "tp_savings_account_id": "string",
  • "type": "string",
  • "uid_amortization_number": 0,
  • "uid_application": "string",
  • "uid_ledger": {
    },
  • "write_off_date": {
    }
}

List Credit Lines

List all available lines of credit for a customer.

path Parameters
customer_id
required
string

The id that is associated by our banking platform
to the individual or corporate/business customer record.
The customer_id is returned by the successful response of either
the Create Customer API or Create Corporate Customer API.
Must be a valid customer_id that exists within your branch.

Responses

Response samples

Content type
application/json
{
  • "available_credit": {
    },
  • "credit_lines": [
    ],
  • "customer_id": "string",
  • "total_credit": {
    }
}

Process Loan Payment

Process immediate payment on a loan.

path Parameters
loan_account_number
required
string

The account number that was returned by the Create Loan endpoint.
Must be a valid loan account number.

Request Body schema: application/json
reference_id
string

API User’s own unique reference code.
Limited to 0-36 characters.

bank_account_number
required
string

Netbank Bank Account Number where the funds will be drawn/debited from to pay the loan.
Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created.

loan_account_number
required
string

The account number that was returned by the Create Loan endpoint.
Must be a valid loan account number.

receipt_type
required
string
Enum: "TemporaryReceipt" "OfficialReceipt"

Type of receipt issued to customer for payment records.

receipt_number
required
string

Receipt identifier.

remarks
string

Payment remarks.

required
object

Amount defines a transaction amount.

Responses

Request samples

Content type
application/json
{
  • "reference_id": "string",
  • "bank_account_number": "string",
  • "loan_account_number": "string",
  • "receipt_type": "TemporaryReceipt",
  • "receipt_number": "string",
  • "remarks": "string",
  • "amount": {
    }
}

Response samples

Content type
application/json
{
  • "transaction_id": "string"
}

Create Credit Line

Create a line of credit for a customer.

Request Body schema: application/json
customer_id
string

The id that is associated by our banking platform
to the individual or corporate/business customer record.
The customer_id is returned by the successful response of either
the Create Customer API or Create Corporate Customer API.
Must be a valid customer_id that exists within your branch.

object

Approved credit line amount.

loan_types
array

Allowed loan types that can use this credit line.

description
string

Credit line description.

object

Grant date of the line of credit.

object

Expiration date of the credit.

replenishment
string
Enum: "Revolving" "NonRevolving"

Credit replenishment pattern.

Responses

Request samples

Content type
application/json
{
  • "customer_id": "string",
  • "credit_line": {
    },
  • "loan_types": [ ],
  • "description": "string",
  • "grant_date": {
    },
  • "expiration_date": {
    },
  • "replenishment": "Revolving"
}

Response samples

Content type
application/json
{
  • "credit_line_id": "string"
}

Update Credit Line

This API will allow Netbank Partners to: Update the credit lines that they have created under their own branch

Request Body schema: application/json
customer_id
required
string

The id that is associated by our banking platform to the individual or corporate/business customer record. The customer_id is returned by the successful response of either the Create Customer API or Create Corporate Customer API.
Must be a valid customer_id that exists within your branch.

credit_line_id
required
string

The id that is associated by our banking platform to the created credit line. The credit_line_id is returned by the successful response of Create Credit Line API.
Must be a valid credit_line_id that exists within your branch.

object

The approved credit line amount that you intend to update.

loan_types
array

Allowed loan types that can use this credit line.
Must be a valid loan type

object

Expiration date of the line of credit.

replenishment
string
Enum: "Revolving" "NonRevolving"

Defines the approach on how the credit line will be replenished.

description
string

Additional notes and description about the credit line

Responses

Request samples

Content type
application/json
{
  • "customer_id": "string",
  • "credit_line_id": "string",
  • "credit_line": {
    },
  • "loan_types": [ ],
  • "expiration_date": {
    },
  • "replenishment": "Revolving",
  • "description": "string"
}

Response samples

Content type
application/json
{
  • "transaction_id": "string",
  • "updated_on": "string"
}

Loan Options

Available loans and repayment schedules for creating loans.

Responses

Response samples

Content type
application/json
{
  • "available_loans": {
    },
  • "installment_schedule": {
    },
  • "loan_rate_types": [
    ]
}

Retrieve Loan Payment Transaction Details

Allows you to retrieve the details of a loan payment transaction that you’ve triggered.

path Parameters
transaction_id
required
string

Transaction identifier.

Responses

Response samples

Content type
application/json
{
  • "transaction": {
    }
}

Retrieve Loan Payment Transactions

Retrieve Loan Payment Transactions using loan account number

path Parameters
account_number
required
string

AccountNumber is the actual account number of the loan account created loan record.

query Parameters
limit
integer <int32>

Limit is number of search return of transactions.

offset
integer <int32>

Offset is number of items that should be skipped from the beginning of the result set.

Responses

Response samples

Content type
application/json
{
  • "has_more": true,
  • "payments": [
    ]
}

Simulate Loan

Simulate a customer loan.

Request Body schema: application/json
customer_id
required
string

The id that is associated by our banking platform
to the individual or corporate/business customer record.
The customer_id is returned by the successful response of either
the Create Customer API or Create Corporate Customer API.
The value must be a valid customer_id that exists within your branch.

reference_id
string

API User’s own unique reference code.
Limited to 0-36 characters.

issuance_type
required
string
Enum: "UNKNOWN" "IssueNew"

The type of loan issuance to process.
The value ust be a valid issuance_type from the Retrieve Loan Options Library API.

loan_type
required
string

The type of loan to issue.
The value must be a valid loan_type from the Retrieve Loan Options Library API.

required
object

The amount of money to be borrowed
The value must be a positive number.

schedule_code
required
string

Schedule of repayment installments.
See installment schedule list in loan options for available schedules.

amortization_count
required
integer

Total number of planned installments in the full repayment schedule.

interest_rate
required
string

Annual interest rate applied to the loan interest accrual calculations.
Format as a decimal with up to five fractional digits (14.54323% => "14.54323").

required
object

Funds release scheduled date.

object

First installment due date.

rate_type
string

The type of loan rate to process.
The value must be a valid rate_type from the Retrieve Loan Options Library API.

Responses

Request samples

Content type
application/json
{
  • "customer_id": "string",
  • "reference_id": "string",
  • "issuance_type": "UNKNOWN",
  • "loan_type": "string",
  • "principal_amount": {
    },
  • "schedule_code": "string",
  • "amortization_count": 0,
  • "interest_rate": "string",
  • "release_date": {
    },
  • "amortization_due": {
    },
  • "rate_type": "string"
}

Response samples

Content type
application/json
{
  • "calculated_totals": {
    },
  • "customer_id": "string",
  • "fees": {
    },
  • "grace_period": 0,
  • "interest_rate": {
    },
  • "schedule": [
    ],
  • "simulated": {
    },
  • "term": 0,
  • "year_length": 0
}

Verify Loan Account Existence

Verify existence of a loan account

path Parameters
account_number
required
string

Responses

Response samples

Content type
application/json
{
  • "account_number": "string",
  • "active": true
}

Submit Loan Document.

Submit supporting documents for loan applications.

path Parameters
customer_id
required
string

The id that is associated by our core banking platform to the individual or corporate/ business customer record.
The customer_id is returned by the successful response of either the Create Customer API or Create Corporate Customer API.
Must be a valid customer_id that you have created within your Branch.

Request Body schema: application/json
customer_id
required
string

The id that is associated by our core banking platform to the individual or corporate/ business customer record.
The customer_id is returned by the successful response of either the Create Customer API or Create Corporate Customer API.
Must be a valid customer_id that you have created within your Branch.

document_name
required
string

Name of the id/document being uploaded.
Limited to 4-64 chars.

comments
string

Additional comments or remarks regarding the id/document being uploaded.

object

The date when id/document being uploaded was received.

file
required
string

The Base64 encoded value of the id/document being uploaded.

reference_id
string

Document reference identifier. Can be generated by partner system or input by a user.

Responses

Request samples

Content type
application/json
{
  • "customer_id": "string",
  • "document_name": "string",
  • "comments": "string",
  • "received": {
    },
  • "file": "string",
  • "reference_id": "string"
}

Response samples

Content type
application/json
{
  • "document_id": "string",
  • "processed": "2019-08-24T14:15:22Z"
}

Process Auto-Debit Loan Payment

Allow the Netbank Client to enroll a savings account to a recurring auto-debit payment to a loan account.

Request Body schema: application/json
reference_id
string

API User’s own unique reference code.
Limited to 0-36 characters.

bank_account_number
required
string

Netbank Bank Account Number where the funds will be drawn/debited from to pay the loan.
Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created.

loan_account_number
required
string

The productNumber that was returned by the Loan Approval Webhook for the loan that was created via Create Loan API.
Must be a valid loan product number.

remarks
string

Additional information regarding the transaction.

strategy
required
string
Enum: "UnknownStrategy" "PARTIAL" "FULL"

Determines how to collect the amount to be debited.

schedule
required
string
Enum: "UnknownSchedule" "DAILY" "DUE_DATE" "MONTH_END"

Determine on when debit will be processed.

Responses

Request samples

Content type
application/json
{
  • "reference_id": "string",
  • "bank_account_number": "string",
  • "loan_account_number": "string",
  • "remarks": "string",
  • "strategy": "UnknownStrategy",
  • "schedule": "UnknownSchedule"
}

Response samples

Content type
application/json
{
  • "autodebit_id": "string"
}

SMS

Send an SMS

Allows you to Send an SMS.

Request Body schema: application/json
body
required
string

The content body of the document.
For “text/plain” document, this is the UTF-8 text message.
Limited to 1-1500 characters

content_type
required
string

The MIME type of the content body.
Currently supported value is “text/plain”.

date
required
string

The date of the document.Format can be:
a. ISO 8601 – “yyyy-mm-ddThh:mm:ss+tzinfo”
b. “yyyymmddThhmmss”
The default timezone is “UTC” (GMT) if tzinfo is not present.

delivery_receipt_url
string

URL where the Messaging Gateway will attempt to POST the status of the document.
Limited to 350 characters

from_alias
string

alphanumeric up to 11 characters.
The alphanumeric sender ID, if enabled and allowed in your account.
Note that this differs from the ‘from‘ field – which refers to the VirtualShortcode assigned to you.
Limited to 11 characters

message_id
string

globally unique identifier of the document message.
If this is omitted in MT Documents, a unique id string is automatically generated.
API Clients MAY optionally inject and generate their own unique IDs for the DeliveryReceipt.
If this ID is not unique however, this may cause confusion in the tracking of DeliveryReceipts.
Limited to 1-50 characters

to
required
string

The destination of the document;For MT documents, this will be the mobile number OR a masked-mobile-number.
The mobile number is expected to follow the E.164 international format without the leading ‘+’,
i.e. country code + phone number (e.g. 639101234567)
Limited to 12 characters

Responses

Request samples

Content type
application/json
{
  • "body": "string",
  • "content_type": "string",
  • "date": "string",
  • "delivery_receipt_url": "string",
  • "from_alias": "string",
  • "message_id": "string",
  • "to": "string"
}

Response samples

Content type
application/json
{
  • "processed": "2022-02-02T02:10:52.880Z"
}

Collect-As-A-Service

Retrieve Details and Transactions by VCA

This API retrieves a specific Virtual Collect Account’s (VCA) transaction limits and transaction history, including timestamps, amounts, and statuses, by providing the VCA number.

path Parameters
vca_number
required
string

Virtual Collect Account number to help you identify the transaction.

query Parameters
destination_account_number
required
string

The Netbank Corporate Bank Account Number where the funds will be ultimately credited to.

start_date
string

Return transactions on or after this date (YYYY-MM-DD).

end_date
string

Return transactions before this date (YYYY-MM-DD).

limit
integer <int32>

Maximum number of transactions to return (up to 100).

offset
integer <int32>

Offset for the start of the returned transaction list.

Responses

Response samples

Content type
application/json
{
  • "destination_account_number": "string",
  • "limits": {
    },
  • "transactions": [
    ],
  • "vca_number": "string"
}

Create Valid VCA

This API allows merchants to create and list Virtual Collect Accounts (VCAs). This API enables merchants to assign customizable limits, such as amount, date, and usage, or create VCAs without limits, depending on their specific needs. This API ensures that only valid VCAs are listed and used for transactions.

Request Body schema: application/json
vca_number
required
string

Assigned Virtual Collect Account number to help you identify the transaction. You must use your 5-digit Partner Alias. If you don’t have this yet, kindly contact support@netbank.ph
Minimum 12 characters Should be VCA and not netbank corporate account

account_number
string

The Netbank bank account number that is linked to the alias that the VCA number will be created for. Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created.
Must be a valid account number under the Client’s branch/organization

object

Limits This object defines the allowed transaction limits for the Virtual Collect Account. It may include the following fields:
If left blank, no limits will be applied

Responses

Request samples

Content type
application/json
{
  • "vca_number": "string",
  • "account_number": "string",
  • "limits": {
    }
}

Response samples

Content type
application/json
{
  • "transaction_id": "string"
}

Deactivate Valid VCA

This API deactivates a VCA, making it unable to receive any transactions. While deactivated, the VCA is treated as inactive and cannot process payments. It can be reactivated if needed by calling the Update limits of VCA API endpoint. This API is available for use regardless of whether the VCA was created locally or not.

Request Body schema: application/json
vca_number
required
string

Assigned Virtual Collect Account number to help you identify the transaction. You must use your 5-digit Partner Alias. If you don’t have this yet, kindly contact support@netbank.ph
Minimum 12 characters Should be VCA and not netbank corporate account

account_number
required
string

The Netbank bank account number that is linked to the alias that the VCA number will be created for. Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created.
Must be a valid account number under the Client’s branch/organization

Responses

Request samples

Content type
application/json
{
  • "vca_number": "string",
  • "account_number": "string"
}

Response samples

Content type
application/json
{
  • "transaction_id": "string"
}

Retrieve VCA Details by Destination Account Number or VCA

This API offers flexibility for merchants to access VCA information based on either a destination account number for multiple VCAs or a specific VCA number for detailed information on one VCA. Merchants can use this API to view transaction limits and other relevant account details for either one or more VCAs.

query Parameters
account_number
required
string

The Netbank bank account number that is linked to the alias that the VCA number will be created for. Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created.
Must be a valid account number under the Client’s branch/organization.

vca_number
string

Assigned Virtual Collect Account number to help you identify the transaction.

start_date
string

Return transactions on or after this date.
Sample format: 2022-03-03T12:00:00.

end_date
string

Return transactions before this date.
Sample format: 2022-03-03T12:00:00.

limit
integer <int32>

Maximum number of transactions to return (up to 100).

offset
integer <int32>

Offset for the start of the returned transaction list.

Responses

Response samples

Content type
application/json
{
  • "result": [
    ]
}

Update Limits of VCA

This API does not create a new VCA but updates the transaction limits of an existing one. This API allows merchants or partners to modify the VCA’s limits based on changing business requirements or customer needs.

Request Body schema: application/json
vca_number
required
string

Assigned Virtual Collect Account number to help you identify the transaction. You must use your 5-digit Partner Alias. If you don’t have this yet, kindly contact support@netbank.ph
Minimum 12 characters Should be VCA and not netbank corporate account

account_number
string

The Netbank bank account number that is linked to the alias that the VCA number will be created for. Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created.
Must be a valid account number under the Client’s branch/organization

object

Limits This object defines the allowed transaction limits for the Virtual Collect Account. It may include the following fields:
If left blank, no limits will be applied

Responses

Request samples

Content type
application/json
{
  • "vca_number": "string",
  • "account_number": "string",
  • "limits": {
    }
}

Response samples

Content type
application/json
{
  • "transaction_id": "string"
}

Remove Limits of VCA

This API removes all transaction limits for a given Virtual Collect Account (VCA) by providing the VCA number. This API disables any predefined transaction restrictions for the account, allowing for unrestricted transactions, while keeping the VCA itself valid and active.

Request Body schema: application/json
vca_number
required
string

Assigned Virtual Collect Account number to help you identify the transaction. You must use your 5-digit Partner Alias. If you don’t have this yet, kindly contact support@netbank.ph
Minimum 12 characters Should be VCA and not netbank corporate account

account_number
required
string

The Netbank bank account number that is linked to the alias that the VCA number will be created for. Must be a valid Netbank account number with dash (e.g. 005-0010-00032-2) that you have created.
Must be a valid account number under the Client’s branch/organization

Responses

Request samples

Content type
application/json
{
  • "vca_number": "string",
  • "account_number": "string"
}

Response samples

Content type
application/json
{
  • "transaction_id": "string"
}