Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Contents

hidden

Table of Contents
outlinetrue

Page Properties

true

Resource

beneficiaries

Endpoints

GET /accounts/{AccountId}/beneficiaries

GET /beneficiaries

Mandatory?

Optional

Optional

SortOrder

05

Version Control


Version
Date
Author
Comments
1.0.001 March 2019Payments NZ API Working GroupBaseline specification for Accounts Beneficiaries resource


Endpoints

Endpoints for the resource - and available methods.


Resource

HTTP Operation

Endpoint

Mandatory?

Scope

Grant Type

Idempotent

Parameters

Request Object

Response Object

1

beneficiaries

GET

GET /accounts/{AccountId}/beneficiaries

Optional

accounts

Authorization Code




OBReadBeneficiary2

2

beneficiaries

GET

GET /beneficiaries

Optional

accounts

Authorization Code


Pagination


OBReadBeneficiary2

GET /accounts/{AccountId}/beneficiaries

A Third Party may retrieve the account beneficiaries information resource for a specific AccountId (which is retrieved in the call to GET /accounts).

GET /beneficiaries

If an API Provider has implemented the bulk retrieval endpoints for beneficiaries - a Third Party may optionally retrieve the beneficiaries information in bulk.

This endpoint will retrieve the beneficiaries resources for all authorised accounts linked to a specific account-request.

Data Model

The OBReadBeneficiary2 object will be used for the call to: 

  • GET /accounts/{AccountId}/beneficiaries
  • GET /beneficiaries

Resource Definition

A resource that contains a set of elements that describes the list of trusted beneficiaries linked to a specific account (AccountId).

An account (AccountId) may have no trusted beneficiaries set up, or may have multiple beneficiaries set up.

In the case an API Provider manages beneficiaries at a customer level (logged in user), instead of account level:

  • If a Customer selects multiple accounts for authorisation - then their beneficiaries apply consistently to all selected accounts (i.e., in the bulk endpoint /beneficiaries)
  • If a different Customer selects the same accounts - a different set of beneficiaries could be returned

This is the expected behaviour of the beneficiaries endpoints - in the case an API Provider manages beneficiaries at a customer level:

  • The bulk endpoint /beneficiaries will return the unique list of beneficiaries against the Customer. In this case - the AccountId in the OBReadBeneficiary2 payload would be set to empty (even if the Customer only has one account).
  • The selected account endpoint /accounts/{AccountId}/beneficiaries will return the beneficiaries that may be accessible to the AccountId - based on the Customer. In this case - the AccountId will be populated in the payload

UML Diagram

Notes:

  • The CreditorAccount is used consistently throughout the Account Information APIs to identify an account
  • The CreditorAgent object may be used to represent either (1) the BIC (with BICFI in the SchemeName field and the BIC in the Identification field), or (2) the Name and Address details for the financial instiution
  • The CreditorAccount/Identification field may only be used to represent NZ account numbers with a CreditorAccount/SchemeName of "BECSElectronicCredit" 
  • For the /accounts/{AccountId}/beneficiaries endpoint - the CreditorAccount and CreditorAgent blocks represent the account of the beneficiary that is receiving funds (so has been named the CreditorAccount - for consistency with the PISP use case).

Permission Codes

The resource differs depending on the permissions (ReadBeneficiariesBasic and ReadBeneficiariesDetail) used to access the resource. In the event the resource is accessed with both ReadBeneficiariesBasic and ReadBeneficiariesDetail, the most detailed level (ReadBeneficiariesDetail) must be used.

  • These objects must not be returned without the ReadBeneficiariesDetail permission:
    • OBReadBeneficiary2/Data/Beneficiary/CreditorAgent
    • OBReadBeneficiary2/Data/Beneficiary/CreditorAccount
  • If the ReadBeneficiariesDetail is granted by the Customer:
    • OBReadBeneficiary2/Data/Beneficiary/CreditorAgent may be returned if applicable to the account and API Provider (0..1)
    • OBReadBeneficiary2/Data/Beneficiary/CreditorAccount must be returned (1..1)

Data Dictionary

NameOccurrenceXPathEnhancedDefinitionClassCodes
OBReadBeneficiary2
OBReadBeneficiary2
OBReadBeneficiary2
Data1..1OBReadBeneficiary2/Data
OBReadDataBeneficiary2
Beneficiary0..nOBReadBeneficiary2/Data/Beneficiary
OBBeneficiary2
AccountId0..1OBReadBeneficiary2/Data/Beneficiary/AccountIdA unique and immutable identifier used to identify the account resource. This identifier has no meaning to the account owner.Max40Text
BeneficiaryId0..1OBReadBeneficiary2/Data/Beneficiary/BeneficiaryIdA unique and immutable identifier used to identify the beneficiary resource. This identifier has no meaning to the account owner.Max40Text
Reference0..1OBReadBeneficiary2/Data/Beneficiary/ReferenceRemittance information for use with BECSElectronicCredit payment scheme.NZBECSRemittance1
CreditorName1..1OBReadBeneficiary2/Data/Beneficiary/Reference/CreditorNameThe Creditor's Name.Max20Text
DebtorName0..1OBReadBeneficiary2/Data/Beneficiary/Reference/DebtorNameThe Debtor's Name.Max20Text
CreditorReference0..1OBReadBeneficiary2/Data/Beneficiary/Reference/CreditorReferenceInformation supplied to enable the reconciling of the payment with the items that the transfer is intended to settle, such as commercial invoices in an accounts' receivable system.NZBECSReference1
Particulars0..1OBReadBeneficiary2/Data/Beneficiary/Reference/CreditorReference/ParticularsReference information, as assigned by the debtor, which when combined with Code and Reference, unambiguously refer to the payment transaction.Max12Text
Code0..1OBReadBeneficiary2/Data/Beneficiary/Reference/CreditorReference/CodeReference information, as assigned by the debtor, which when combined with Particulars and Reference, unambiguously refer to the payment transaction.Max12Text
Reference0..1OBReadBeneficiary2/Data/Beneficiary/Reference/CreditorReference/ReferenceReference information, as assigned by the debtor, which when combined with Particulars and Code, unambiguously refer to the payment transaction.Max12Text
DebtorReference0..1OBReadBeneficiary2/Data/Beneficiary/Reference/DebtorReferenceInformation supplied to enable the reconciling of the payment with the items that the transfer is intended to settle, such as commercial invoices in an accounts' receivable system.NZBECSReference1
Particulars0..1OBReadBeneficiary2/Data/Beneficiary/Reference/DebtorReference/ParticularsReference information, as assigned by the debtor, which when combined with Code and Reference, unambiguously refer to the payment transaction.Max12Text
Code0..1OBReadBeneficiary2/Data/Beneficiary/Reference/DebtorReference/CodeReference information, as assigned by the debtor, which when combined with Particulars and Reference, unambiguously refer to the payment transaction.Max12Text
Reference0..1OBReadBeneficiary2/Data/Beneficiary/Reference/DebtorReference/ReferenceReference information, as assigned by the debtor, which when combined with Particulars and Code, unambiguously refer to the payment transaction.Max12Text
CreditorAgent0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgentParty that manages the account on behalf of the account owner, that is manages the registration and booking of entries on the account, calculates balances on the account and provides information about the account.
This is the servicer of the beneficiary account.
OBBranchAndFinancialInstitutionIdentification3
SchemeName0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/SchemeNameName of the identification scheme, in a coded form as published in an external list.OBExternalFinancialInstitutionIdentification2CodeBICFI
Identification0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/IdentificationUnique and unambiguous identification of the servicing institution.Max35Text
Name0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/NameName by which an agent is known and which is usually used to identify that agent.Max140Text
PostalAddress0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddressInformation that locates and identifies a specific address, as defined by postal services.OBPostalAddress6
AddressType0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddress/AddressTypeIdentifies the nature of the postal address.OBAddressTypeCodeBusiness
Correspondence
DeliveryTo
MailTo
POBox
Postal
Residential
Statement
Department0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddress/DepartmentIdentification of a division of a large organisation or building.Max70Text
SubDepartment0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddress/SubDepartmentIdentification of a sub-division of a large organisation or building.Max70Text
StreetName0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddress/StreetNameName of a street or thoroughfare.Max70Text
BuildingNumber0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddress/BuildingNumberNumber that identifies the position of a building on a street.Max16Text
PostCode0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddress/PostCodeIdentifier consisting of a group of letters and/or numbers that is added to a postal address to assist the sorting of mail.Max16Text
TownName0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddress/TownNameName of a built-up area, with defined boundaries, and a local government.Max35Text
CountrySubDivision0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddress/CountrySubDivisionIdentifies a subdivision of a country such as state, region, county.Max35Text
Country0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddress/CountryNation with its own government.CountryCode^[A-Z]{2,2}$
AddressLine0..7OBReadBeneficiary2/Data/Beneficiary/CreditorAgent/PostalAddress/AddressLineInformation that locates and identifies a specific address, as defined by postal services, presented in free format text.Max70Text
CreditorAccount0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAccountProvides the details to identify the beneficiary account.OBCashAccount1
SchemeName1..1OBReadBeneficiary2/Data/Beneficiary/CreditorAccount/SchemeNameName of the identification scheme, in a coded form as published in an external list.OBExternalAccountIdentification2CodeBECSElectronicCredit
Identification1..1OBReadBeneficiary2/Data/Beneficiary/CreditorAccount/IdentificationIdentification assigned by an institution to identify an account. This identification is known by the account owner.Max34Text
Name0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAccount/NameName of the account, as assigned by the account servicing institution, in agreement with the account owner in order to provide an additional means of identification of the account.

Usage: The account name is different from the account owner name. The account name is used in certain user communities to provide a means of identifying the account, in addition to the account owner's identity and the account number.
Max70Text
SecondaryIdentification0..1OBReadBeneficiary2/Data/Beneficiary/CreditorAccount/SecondaryIdentificationThis is secondary identification of the account, as assigned by the account servicing institution.
This can be used by building societies to additionally identify accounts with a roll number (in addition to a sort code and account number combination).
Max34Text

Enumerations

This section gives the definitions for enumerations used.


Code Class
Name 
Definition 
OBExternalAccountIdentification2CodeBECSElectronicCredit 

An identifier used to uniquely identify the account of a customer at a financial institution, structured in the form of 12-1234-1234567-12 where:

  • the first two digits are the bank number, which tells us which bank the account resides with;
  • the next four digits indicate the branch number, which tells us which branch of that bank the account is domiciled;
  • the next seven digits indicate the account number; and
  • the last two digits indicate the account number suffix.
OBExternalFinancialInstitutionIdentification2CodeBICFIValid BICs for financial institutions are registered by the ISO 9362 Registration Authority in the BIC directory, and consist of eight (8) or eleven (11) contiguous characters.
OBAddressTypeCode

Business

Address is the business address.
OBAddressTypeCode

Correspondence

Address is the address where correspondence is sent.
OBAddressTypeCode

DeliveryTo

Address is the address to which delivery is to take place.
OBAddressTypeCode

MailTo

Address is the address to which mail is sent.
OBAddressTypeCode

POBox

Address is a postal office (PO) box.
OBAddressTypeCode

Postal

Address is the complete postal address.
OBAddressTypeCode

Residential

Address is the home address.
OBAddressTypeCode

Statement

Address is the address where statements are sent.


Usage Examples

Specific Account

Request

Code Block
languagejs
themeMidnight
titleGet Account Beneficiaries Request
linenumberstrue
GET /accounts/22289/beneficiaries HTTP/1.1
Authorization: Bearer Az90SAOJklae
x-fapi-financial-id: OB/2017/001
x-fapi-customer-last-logged-time:  Sun, 10 Sep 2017 19:43:31 UTC
x-fapi-customer-ip-address: 104.25.212.99
x-fapi-interaction-id: 93bac548-d2de-4546-b106-880a5018460d
Accept: application/json


Response

Code Block
languagejs
themeMidnight
titleGet Account Beneficiaries Response
linenumberstrue
HTTP/1.1 200 OK
x-fapi-interaction-id: 93bac548-d2de-4546-b106-880a5018460d
Content-Type: application/json

{
  "Data": {
    "Beneficiary": [
      {
        "AccountId": "22289",
        "BeneficiaryId": "Ben1",
        "Reference": {
          "CreditorName": "Towbar",
          "CreditorReference": {
            "Particulars": "CreditorPart",
            "Code": "CreditorCode",
            "Reference": "CreditorRef"
          },
          "DebtorName": "The Debtor",
          "DebtorReference": {
            "Particulars": "DebtorPart",
            "Code": "DebtorCode",
            "Reference": "DebtorRef"
          }
        },
        "CreditorAccount": {
          "SchemeName": "BECSElectronicCredit",
          "Identification": "01-1234-1234567-00",
          "Name": "Mrs Juniper"
        }
      }
    ]
  },
  "Links": {
    "Self": "https://api.alphabank.com/open-banking-nz/v1.0/accounts/22289/beneficiaries/"
  },
  "Meta": {
    "TotalPages": 1
  }
}



Bulk

Request

Code Block
languagejs
themeMidnight
titleGet Beneficiaries Request
linenumberstrue
GET /beneficiaries HTTP/1.1
Authorization: Bearer Az90SAOJklae
x-fapi-financial-id: OB/2017/001
x-fapi-customer-last-logged-time:  Sun, 10 Sep 2017 19:43:31 UTC
x-fapi-customer-ip-address: 104.25.212.99
x-fapi-interaction-id: 93bac548-d2de-4546-b106-880a5018460d
Accept: application/json


Response

Code Block
languagejs
themeMidnight
titleGet Beneficiaries Response
linenumberstrue
HTTP/1.1 200 OK
x-fapi-interaction-id: 93bac548-d2de-4546-b106-880a5018460d
Content-Type: application/json

{
  "Data": {
    "Beneficiary": [
      {
        "AccountId": "22289",
        "BeneficiaryId": "Ben1",
        "Reference": {
          "CreditorName": "Towbar",
          "CreditorReference": {
            "Particulars": "CreditorPart",
            "Code": "CreditorCode",
            "Reference": "CreditorRef"
          },
          "DebtorName": "The Debtor",
          "DebtorReference": {
            "Particulars": "DebtorPart",
            "Code": "DebtorCode",
            "Reference": "DebtorRef"
          }
        },
        "CreditorAccount": {
          "SchemeName": "BECSElectronicCredit",
          "Identification": "12-0234-0013231-00",
          "Name": "Mrs Juniper"
        }
      },
      {
        "AccountId": "31820",
        "BeneficiaryId": "Ben37",
        "Reference": {
          "CreditorName": "Golf",
          "CreditorReference": {
            "Particulars": "CreditorPart",
            "Code": "CreditorCode",
            "Reference": "CreditorRef"
          },
          "DebtorName": "The Debtor",
          "DebtorReference": {
            "Particulars": "DebtorPart",
            "Code": "DebtorCode",
            "Reference": "DebtorRef"
          }
        },
        "CreditorAccount": {
          "SchemeName": "BECSElectronicCredit",
          "Identification": "02-0500-0204051-00",
          "Name": "Mr Large"
        }
      }
    ]
  },
  "Links": {
    "Self": "https://api.alphabank.com/open-banking-nz/v1.0/beneficiaries/"
  },
  "Meta": {
    "TotalPages": 1
  }
}