Standing Orders

1. Version Control

Version

Date

Description of Changes

Bahrain OBF v1.0.0

28th Oct 2020

Initial Release

2. Overview

The standing-orders resource is used by an AISP to retrieve the standing orders for a specific AccountId or to retrieve the standing orders in bulk for all the accounts that the user/customer has consented to.

This resource description should be read in conjunction with a compatible Account Information Services API Profile.

3. Endpoints

S. No.

Resource

HTTP Operation

Endpoint

Mandatory

Scope

Grant Type

Idempotency Key

Parameters

Request Object

Response Object

3.1

standing-orders

GET

GET /accounts/{AccountId}/standing-orders

Conditional

accounts

Authorisation Code

No

 

 

OBReadStandingOrder

3.2

standing-orders

GET

GET /standing-orders

Optional

accounts

Authorisation Code

No

Pagination

 

OBReadStandingOrder

3.1 GET /accounts/{AccountId}/standing-orders

An AISP may retrieve the standing-order resource for a specific AccountId (which is retrieved in the call to GET /accounts).

3.2 GET /standing-orders

If an ASPSP has implemented the bulk retrieval endpoints, an AISP may optionally retrieve the standing-order resources in bulk. This will retrieve the resources for all authorised accounts linked to the account-request.

4. Data Models

4.1 OBReadStandingOrder

The OBReadStandingOrder object will be used for the call to:

  • GET /accounts/{AccountId}/standing-orders

  • GET /standing-orders

4.1.1 Resource Definition

A resource that contains a set of elements that describes the list of standing-orders that have been set up on a specific account (AccountId). An account (AccountId) may have no standing orders set up, or may have multiple standing orders set up.

4.1.2 UML Diagram

 

4.1.3 Notes

  • The CreditorAccount and CreditorAgent blocks replicate what is used consistently throughout the Account Information APIs to identify an account

  • For the /accounts/{AccountId}/standing-orders endpoint, the CreditorAccount and CreditorAgent blocks represent the account that is receiving funds (so has been named the CreditorAccount for consistency with the PISP use case)

  • A DateTime element has been used so that there is consistency across all API endpoints using dates. Where time elements do not exist in ASPSP systems, the time portion of the DateTime element will be defaulted to 00:00:00+03:00

  • The Amount elements all have embedded Currency elements for consistency is ISO 20022, and across the other API endpoints

  • ASPSPs must give AISPs at least three month's notice, prior to implementing any change in the code-lists of the fields, if such a change impacts the ability of AISPs to continue with the provision of their service

4.1.4 Frequency

Frequency

Example

Details

NotKnown

NotKnown

Not known

EvryDay

EvryDay

Every day

EvryWorkgDay

EvryWorkgDay

Every working day

IntrvlDay

IntrvlDay:15

Every 15 Calendar day

IntrvlWkDay

IntrvlWkDay:01:03

Every week, on the 3rd day of the week

IntrvlWkDay

IntrvlWkDay:02:03

Every 2nd week, on the 3rd day of the week

WkInMnthDay

WkInMnthDay:02:03

Every month, on the 2nd week of the month, and on the third day of the week

IntrvlMnthDay

IntrvlMnthDay:01:-01

Every month, on the last day of the month

IntrvlMnthDay

IntrvlMnthDay:06:15

Every 6th month, on the 15th day of the month

QtrDay

QtrDay:ENGLISH

Paid on the 25th March, 24th June, 29th September and 25th December

4.1.5 Permission Codes

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

  • These objects must not be returned without the ReadStandingOrdersDetail permission:

    • OBReadStandingOrder/Data/StandingOrder/CreditorAgent

    • OBReadStandingOrder/Data/StandingOrder/CreditorAccount

  • If the ReadStandingOrdersDetail is granted by the user/customer:

    • OBReadStandingOrder/Data/StandingOrder/CreditorAgent may be returned if applicable to the account and ASPSP (0..1)

    • OBReadStandingOrder/Data/StandingOrder/CreditorAccount must be returned (1..1)

If the ReadPAN permission is granted by the user/customer, the ASPSP may choose to populate the OBReadStandingOrder/Data/StandingOrder/CreditorAccount/Identification with the unmasked PAN (if the PAN is being populated in the response).

4.1.6 Data Dictionary

Name

Occurrence

XPath

Enhanced Definition

Class/ Datatype

Codes

Pattern

OBReadStandingOrder

 

OBReadStandingOrder

 

OBReadStandingOrder

 

 

Data

1..1

OBReadStandingOrder/Data

 

OBReadStandingOrder/Data

 

 

StandingOrder

0..n

OBReadStandingOrder/Data/StandingOrder

 

OBReadStandingOrder/Data/StandingOrder

 

 

AccountId

1..1

OBReadStandingOrder/Data/StandingOrder/AccountId

A unique and immutable identifier used to identify the account resource. This identifier has no meaning to the account owner

String

 

 

StandingOrderId

0..1

OBReadStandingOrder/Data/StandingOrder/StandingOrderId

A unique and immutable identifier used to identify the standing order resource. This identifier has no meaning to the account owner

String

 

 

Frequency

1..1

OBReadStandingOrder/Data/StandingOrder/Frequency

Individual Definitions:
NotKnown - Not known
EvryDay - Every day
EvryWorkgDay - Every working day
IntrvlDay - An interval specified in number of calendar days (02 to 31)
IntrvlWkDay - An interval specified in weeks (01 to 09), and the day within the week (01 to 07)
WkInMnthDay - A monthly interval, specifying the week of the month (01 to 05) and day within the week (01 to 07)
IntrvlMnthDay - An interval specified in months (between 01 to 06, 12, 24), specifying the day within the month (-05 to -01, 01 to 31)
QtrDay - Quarterly (ENGLISH)
ENGLISH = Paid on the 25th March, 24th June, 29th September and 25th December.

Individual Patterns:
NotKnown (ScheduleCode)
EvryDay (ScheduleCode)
EvryWorkgDay (ScheduleCode)
IntrvlDay:NoOfDay (ScheduleCode + NoOfDay)
IntrvlWkDay:IntervalInWeeks:DayInWeek (ScheduleCode + IntervalInWeeks + DayInWeek)
WkInMnthDay:WeekInMonth:DayInWeek (ScheduleCode + WeekInMonth + DayInWeek)
IntrvlMnthDay:IntervalInMonths:DayInMonth (ScheduleCode + IntervalInMonths + DayInMonth)
QtrDay: + either (ENGLISH) ScheduleCode + QuarterDay

The regular expression for this element combines five smaller versions for each permitted pattern. To aid legibility - the components are presented individually here:
NotKnown
EvryDay
EvryWorkgDay
IntrvlDay:((0[2-9])\|([1-2][0-9])\|3[0-1])
IntrvlWkDay:0[1-9]:0[1-7]
WkInMnthDay:0[1-5]:0[1-7]
IntrvlMnthDay:(0[1-6]\|12\|24):(-0[1-5]\|0[1-9]\|[12][0-9]\|3[01])
QtrDay:(ENGLISH)
Full Regular Expression:
^(NotKnown)$|^(EvryDay)$|^(EvryWorkgDay)$|^(IntrvlDay:((0[2-9])|([1-2][0-9])|3[0-1]))$|^(IntrvlWkDay:0[1-9]:0[1-7])$|^(WkInMnthDay:0[1-5]:0[1-7])$|^(IntrvlMnthDay:(0[1-6]|12|24):(-0[1-5]|0[1-9]|[12][0-9]|3[01]))$|^(QtrDay:(ENGLISH))$

String

 

^(NotKnown)$|^(EvryDay)$|^(EvryWorkgDay)$|^(IntrvlWkDay:0[1-9]:0[1-7])$|^(WkInMnthDay:0[1-5]:0[1-7])$|^(IntrvlMnthDay:(0[1-6]|12|24):(-0[1-5]|0[1-9]|[12][0-9]|3[01]))$|^(QtrDay:(ENGLISH))$

Reference

0..1

OBReadStandingOrder/Data/StandingOrder/Reference

Unique reference, as assigned by the creditor, to unambiguously refer to the payment transaction. Usage: If available, the initiating party should provide this reference in the structured remittance information, to enable reconciliation by the creditor upon receipt of the amount of money. If the business context requires the use of a creditor reference or a payment remit identification, and only one identifier can be passed through the end-to-end chain, the creditor's reference or payment remittance identification should be quoted in the end-to-end transaction identification

String

 

 

FirstPaymentDateTime

0..1

OBReadStandingOrder/Data/StandingOrder/FirstPaymentDateTime

The date on which the first payment for a Standing Order schedule will be made

DateTime

 

 

NextPaymentDateTime

0..1

OBReadStandingOrder/Data/StandingOrder/NextPaymentDateTime


The date on which the next payment for a Standing Order schedule will be made

DateTime

 

 

LastPaymentDateTime

0..1

OBReadStandingOrder/Data/StandingOrder/LastPaymentDateTime

The date on which the last (most recent) payment for a Standing Order schedule was made

DateTime

 

 

FinalPaymentDateTime

0..1

OBReadStandingOrder/Data/StandingOrder/FinalPaymentDateTime

The date on which the final payment for a Standing Order schedule will be made

DateTime

 

 

NumberOfPayments

0..1

OBReadStandingOrder/Data/StandingOrder/NumberOfPayments

Number of the payments that will be made in completing this frequency sequence including any executed since the sequence start date

String

 

 

StandingOrderStatusCode

0..1

OBReadStandingOrder/Data/StandingOrder/StandingOrderStatusCode

Specifies the status of the standing order in code form

String

Enum:

  • Active

  • Inactive

 

FirstPaymentAmount

0..1

OBReadStandingOrder/Data/StandingOrder/FirstPaymentAmount

The amount of the first Standing Order

OBReadStandingOrder/Data/StandingOrder/FirstPaymentAmount

 

 

Amount

1..1

OBReadStandingOrder/Data/StandingOrder/FirstPaymentAmount/Amount

A number of monetary units specified in an active currency where the unit of currency is explicit and compliant with ISO 4217

String

 

^\d{1,13}$\|^\d{1,13}\.\d{1,5}$

Currency

1..1

OBReadStandingOrder/Data/StandingOrder/FirstPaymentAmount/Currency

A code allocated to currency by a Maintenance Agency under an international identification scheme, as described in the latest edition of the international standard ISO 4217 "Codes for the representation of currencies and funds"

String

 

^[A-Z]{3,3}$

NextPaymentAmount

0..1

OBReadStandingOrder/Data/StandingOrder/NextPaymentAmount

The amount of the next Standing Order

OBReadStandingOrder/Data/StandingOrder/NextPaymentAmount

 

 

Amount

1..1

OBReadStandingOrder/Data/StandingOrder/NextPaymentAmount/Amount

A number of monetary units specified in an active currency where the unit of currency is explicit and compliant with ISO 4217

String

 

^\d{1,13}$\|^\d{1,13}\.\d{1,5}$

Currency

1..1

OBReadStandingOrder/Data/StandingOrder/NextPaymentAmount/Currency

A code allocated to currency by a Maintenance Agency under an international identification scheme, as described in the latest edition of the international standard ISO 4217 "Codes for the representation of currencies and funds"

String

 

^[A-Z]{3,3}$

LastPaymentAmount

0..1

OBReadStandingOrder/Data/StandingOrder/LastPaymentAmount

The amount of the last (most recent) Standing Order instruction

OBReadStandingOrder/Data/StandingOrder/LastPaymentAmount

 

 

Amount

1..1

OBReadStandingOrder/Data/StandingOrder/LastPaymentAmount/Amount

A number of monetary units specified in an active currency where the unit of currency is explicit and compliant with ISO 4217

String

 

^\d{1,13}$\|^\d{1,13}\.\d{1,5}$

Currency

1..1

OBReadStandingOrder/Data/StandingOrder/LastPaymentAmount/Currency

A code allocated to currency by a Maintenance Agency under an international identification scheme, as described in the latest edition of the international standard ISO 4217 "Codes for the representation of currencies and funds"

String

 

^[A-Z]{3,3}$

FinalPaymentAmount

0..1

OBReadStandingOrder/Data/StandingOrder/FinalPaymentAmount

The amount of the final Standing Order

OBReadStandingOrder/Data/StandingOrder/FinalPaymentAmount

 

 

Amount

1..1

OBReadStandingOrder/Data/StandingOrder/FinalPaymentAmount/Amount

A number of monetary units specified in an active currency where the unit of currency is explicit and compliant with ISO 4217

String

 

^\d{1,13}$\|^\d{1,13}\.\d{1,5}$

Currency

1..1

OBReadStandingOrder/Data/StandingOrder/FinalPaymentAmount/Currency

A code allocated to currency by a Maintenance Agency under an international identification scheme, as described in the latest edition of the international standard ISO 4217 "Codes for the representation of currencies and funds"

String

 

^[A-Z]{3,3}$

CreditorAgent

0..1

OBReadStandingOrder/Data/StandingOrder/CreditorAgent

Party 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

OBReadStandingOrder/Data/StandingOrder/CreditorAgent

 

 

SchemeName

1..1

OBReadStandingOrder/Data/StandingOrder/CreditorAgent/SchemeName

Name of the identification scheme, in a coded form as published in an external list

String

Enum:

  • BH.OBF.BICFI

 

Identification

1..1

OBReadStandingOrder/Data/StandingOrder/CreditorAgent/Identification

Unique and unambiguous identification of the servicing institution

String

 

 

CreditorAccount

0..1

OBReadStandingOrder/Data/StandingOrder/CreditorAccount

Provides the details to identify the beneficiary account

OBReadStandingOrder/Data/StandingOrder/CreditorAccount

 

 

SchemeName

1..1

OBReadStandingOrder/Data/StandingOrder/CreditorAccount/SchemeName

Name of the identification scheme, in a coded form as published in an external list

String

Enum:

  • BH.OBF.IBAN

 

Identification

1..1

OBReadStandingOrder/Data/StandingOrder/CreditorAccount/Identification

Beneficiary account identification

String

 

 

Name

0..1

OBReadStandingOrder/Data/StandingOrder/CreditorAccount/Name

The account name is the name or names of the account owner(s) represented at an account level, as displayed by the ASPSP’s online channels. Note, the account name is not the product name or the nickname of the account

String

 

 

SupplementaryData

0..1

OBReadStandingOrder/Data/StandingOrder/SupplementaryData

Additional information that can not be captured in the structured fields and/or any other specific block

OBSupplementaryData

 

 

5. Usage Example

5.1 Bulk

5.1.1 Get Standing Orders Request

GET /standing-orders

Authorisation: Bearer 4ZopnFZFKjr5zDsicSQpLL

x-fapi-auth-date: Tue, 18 Mar 2020 19:43:31 GMT+03:00

x-fapi-customer-ip-address: 204.35.213.15

x-fapi-interaction-id: 75bdc714-b2dg-7676-c759-780d6815689f

Accept: application/json

5.1.2 Get Standing Orders Response

200 OK

x-fapi-interaction-id: 75bdc714-b2dg-7676-c759-780d6815689f

Content-Type: application/json

{
  "Data": {
    "StandingOrder": [
      {
        "AccountId": "00345897",
        "StandingOrderId": "2276",
        "Frequency": "Monthly",
        "Reference": "Bill payment",
        "FirstPaymentDateTime": "2020-03-26T10:54:49.225+03:00”,
        "NextPaymentDateTime": "2020-04-26T10:54:49.225+03:00”,
        "LastPaymentDateTime": "2020-02-26T10:54:49.225+03:00”,
        "FinalPaymentDateTime": "2020-10-26T10:54:49.225+03:00”,
        "NumberOfPayments": "8",
        "StandingOrderStatusCode": "Active",
        "FirstPaymentAmount": {
          "Amount": "1000",
          "Currency": "BHD"
        },
        "NextPaymentAmount": {
          "Amount": "1000",
          "Currency": "BHD"
        },
        "LastPaymentAmount": {
          "Amount": "1000",
          "Currency": "BHD"
        },
        "FinalPaymentAmount": {
          "Amount": "1000",
          "Currency": "BHD"
        },
        "CreditorAgent": {
          "SchemeName": "BH.OBF.BBAN",
          "Identification": "BH10XYZU00100000001789"
        },
        "CreditorAccount": {
          "SchemeName": "BH.OBF.BBAN",
          "Identification": "BH10XYZU00100000008876",
          "Name": "Khalid Ahmed Ali",
        },
      },

"AccountId": "00135678",

        "StandingOrderId": "2277",

        "Frequency": "Monthly",

        "Reference": "Instalment",

        "FirstPaymentDateTime": "2020-03-26T10:54:49.225+03:00”,

        "NextPaymentDateTime": "2020-04-26T10:54:49.225+03:00”,

        "LastPaymentDateTime": "2020-02-26T10:54:49.225+03:00”,

        "FinalPaymentDateTime": "2020-10-26T10:54:49.225+03:00”,

        "NumberOfPayments": "8",

        "StandingOrderStatusCode": "Active",

        "FirstPaymentAmount": {

          "Amount": "1200",

          "Currency": "BHD"

        },

        "NextPaymentAmount": {

          "Amount": "1200",

          "Currency": "BHD"

        },

        "LastPaymentAmount": {

          "Amount": "1200",

          "Currency": "BHD"

        },

        "FinalPaymentAmount": {

          "Amount": "1200",

          "Currency": "BHD"

        },

        "CreditorAgent": {

          "SchemeName": "BH.OBF.BICFI",

          "Identification": "BH10BBKU00100000001789"

        },

        "CreditorAccount": {

          "SchemeName": "BH.OBF.IBAN",

          "Identification": "BH10XYZU00100000006789",

          "Name": "Mohammed Ahmed Abdulla",

        },

      }

    ]

  },

  "Links": {

    "Self": "www.TBC.com"

  },

  "Meta": {

    "TotalPages": 01,

    "FirstAvailableDateTime": "2020-03-26T09:10:17.596+03:00”,

    "LastAvailableDateTime": "2020-03-26T09:10:17.596+03:00”

  }

}

5.2 Specific Account

5.2.1 Get Account Standing Orders Request

GET /accounts/00345897/standing-orders

Authorisation: Bearer 4ZopnFZFKjr5zDsicSQpLL

x-fapi-auth-date: Tue, 18 Mar 2020 19:43:31 GMT+03:00

x-fapi-customer-ip-address: 204.35.213.15

x-fapi-interaction-id: 75bdc714

Accept: application/json

5.2.2 Get Account Standing Orders Response

200 OK

x-fapi-interaction-id: 75bdc714-b2dg-7676-c759-780d6815689f

Content-Type: application/json

{

  "Data": {

    "StandingOrder": [

      {

        "AccountId": "00345897",

        "StandingOrderId": "2276",

        "Frequency": "Monthly",

        "Reference": "Bill payment",

        "FirstPaymentDateTime": "2020-03-26T10:54:49.225+03:00”,

        "NextPaymentDateTime": "2020-04-26T10:54:49.225+03:00”,

        "LastPaymentDateTime": "2020-02-26T10:54:49.225+03:00”,

        "FinalPaymentDateTime": "2020-10-26T10:54:49.225+03:00”,

        "NumberOfPayments": "8",

        "StandingOrderStatusCode": "Active",

        "FirstPaymentAmount": {

          "Amount": "1000",

          "Currency": "BHD"

        },

        "NextPaymentAmount": {

          "Amount": "1000",

          "Currency": "BHD"

        },

        "LastPaymentAmount": {

          "Amount": "1000",

          "Currency": "BHD"

        },

        "FinalPaymentAmount": {

          "Amount": "1000",

          "Currency": "BHD"

        },

        "CreditorAgent": {

          "SchemeName": "BH.OBF.BBAN",

          "Identification": "BH10XYZU00100000001789"

        },

        "CreditorAccount": {

          "SchemeName": "BH.OBF.BBAN",

          "Identification": "BH10XYZU00100000008876",

          "Name": "Khalid Ahmed Ali",

        },

      }

    ]

  },

  "Links": {

    "Self": "www.TBC.com"

  },

  "Meta": {

    "TotalPages": 01,

    "FirstAvailableDateTime": "2020-03-26T09:10:17.596+03:00”,

    "LastAvailableDateTime": "2020-02-26T09:10:17.596+03:00”

  }

}

 

 

CENTRAL BANK OF BAHRAIN © 2020