Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Awesome api app render macro
authHeaderName
linksColor#0052cc
showInfotrue
allowSpecUrlLoadfalse
primaryColor#0052CC
schemaStyletable
methodGetColor#0065FF
authHeaderValue
methodPutColor#6554c0
generalThemeconfluence_light
allowTryfalse
layoutHeight800
allowAdvancedSearchtrue
codeBg#F4F5F7
methodHeadColor#ffab00
navHoverTextColor
showComponentstrue
allowServerSelectiontrue
textColor#172B4D
methodPatchColor#ffab00
navBgColor#FAFBFC
codeFg#172B4D
navTextColor#172B4D
fontSizedefault
sortEndpointsBymethod
usePathInNavBarfalse
navAccentColor#6554C0
methodDeleteColor#ff5630
headerColor#fff
allowAuthenticationfalse
bgColor#fff
allowSearchtrue
sortTagstrue
themelight
methodPostColor#36b37e
authTypeNone
inlineCodeFg#6554C0
resourceContentTypejson
showHeaderfalse
allowSpecFileLoadfalse
inlineCodeBg#F4F5F7
renderStyleread
layoutcolumn
headingText
navItemSpacingdefault
infoDescriptionHeadingsInNavbartrue
specUrl
navHoverBgColor
resourceTypeCONTENT
openapi: 3.0.0
info:
  title: UAE Pushed Authorization Endpoint
  description: >-
    ## UAE Open Finance Pushed Authorization Endpoint Specification


    This API description provides the definitions for the supported Rich
    Authorization Request (RAR) payloads in the context of the Pushed
    Authorization Request endpoint.


    Please note that RAR definitions are provided for information and **do not**
    accurately reflect a serialized, signed JSON Web Token. The Schema Object
    provide the correct message payload definition to create the RAR before
    creating a JWT-Secured Authorization Request (JAR).
  version: v1.0-draft5
tags:
  - name: Pushed Authorization Requests
paths:
  /open-finance/v1/par:
    post:
      tags:
        - Pushed Authorization Requests
      operationId: InsuranceConsents_create
      summary: >-
        Submit a Rich Authorization Request (RAR) to the Pushed Authorization
        Request (PAR) Endpoint
      parameters: []
      responses:
        '201':
          description: >-
            The request has succeeded and a new resource has been created as a
            result.
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/PushedAuthorizationResponseBody'
        '400':
          description: The server could not understand the request due to invalid syntax.
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/OAuthBadRequestErrorResponse'
        '405':
          description: Method Not Allowed
        '413':
          description: Content Too Large
        '429':
          description: Too Many Requests
          headers:
            retry-after:
              required: true
              description: Number in seconds to wait
              schema:
                type: integer
                format: int64
      requestBody:
        required: true
        content:
          application/x-www-form-urlencoded:
            schema:
              $ref: '#/components/schemas/PushedAuthorizationRequest'
components:
  schemas:
    AEAcceptedAuthorizationTypeRequestPayments:
      type: string
      enum:
        - UAEOF.Single
        - UAEOF.Multi
        - UAEOF.Both
      description: |2-
            Specifies to the LFI the type of consent authorization accepted by the TPP when staging the consent
            * Single - The consent should incur a single authorization Step with the LFI
            * Multi - The consent should incur a multi-authorization Step with the LFI
            * Both - The consent should incur either a single authorization or multi-authorization step with the LFI. The LFI decides.
    AEAccountAccessAuthorizationDetailConsentProperties:
      type: object
      required:
        - ConsentId
        - Permissions
      properties:
        ConsentId:
          $ref: '#/components/schemas/AEConsentId'
        Permissions:
          $ref: '#/components/schemas/AEAccountAccesssConsentPermissionCodes'
      allOf:
        - $ref: '#/components/schemas/AEAccountAccessAuthorizationDetailProperties'
      additionalProperties: false
    AEAccountAccessAuthorizationDetailProperties:
      type: object
      properties:
        BaseConsentId:
          $ref: '#/components/schemas/AEBaseConsentId'
        ExpirationDateTime:
          type: string
          format: date-time
          description: >-
            Specified date and time the permissions will expire.

            If this is not populated, the permissions will be open ended.All
            dates in the JSON payloads are represented in ISO 8601 date-time
            format. 

            All date-time fields in responses must include the timezone. An
            example is below:

            2017-04-05T10:43:07+00:00
        TransactionFromDateTime:
          type: string
          format: date-time
          description: |2-
                Specified start date and time for the transaction query period.

                If this is not populated, the start date will be open ended, and
                data will be returned from the earliest available
                transaction.All dates in the JSON payloads are represented in
                ISO 8601 date-time format. 

                All date-time fields in responses must include the timezone. An
                example is below:

                2017-04-05T10:43:07+00:00
        TransactionToDateTime:
          type: string
          format: date-time
          description: |2-
                Specified end date and time for the transaction query period.

                If this is not populated, the end date will be open ended, and
                data will be returned to the latest available transaction.All
                dates in the JSON payloads are represented in ISO 8601 date-time
                format. 

                All date-time fields in responses must include the timezone. An
                example is below:

                2017-04-05T10:43:07+00:00
        AccountType:
          type: array
          items:
            $ref: '#/components/schemas/AEAccountTypeCode'
        AccountSubType:
          type: array
          items:
            $ref: '#/components/schemas/AEAccountSubTypeCode'
        OnBehalfOf:
          $ref: '#/components/schemas/AEOnBehalfOf'
        Purpose:
          type: array
          items:
            $ref: '#/components/schemas/AEAccountAccessConsentPurpose'
      additionalProperties: false
    AEAccountAccessAuthorizationDetailReconsentProperties:
      type: object
      required:
        - ConsentId
      properties:
        ConsentId:
          $ref: '#/components/schemas/AEConsentId'
        Permissions:
          $ref: '#/components/schemas/AEAccountAccesssConsentPermissionCodes'
      allOf:
        - $ref: '#/components/schemas/AEAccountAccessAuthorizationDetailProperties'
      additionalProperties: false
    AEAccountAccessAuthorizationDetailsConsent:
      type: object
      required:
        - Type
        - Consent
        - Subscription
      properties:
        Type:
          type: string
          enum:
            - urn:openfinanceuae:account-access-consent:v1.0-draft5
        Consent:
          $ref: >-
            #/components/schemas/AEAccountAccessAuthorizationDetailConsentProperties
        Subscription:
          $ref: '#/components/schemas/EventNotification'
      description: >-
        Properties for creating a consent object for the first time a User
        consents to TPP access to account information data
      additionalProperties: false
    AEAccountAccessAuthorizationDetailsReconsent:
      type: object
      required:
        - Type
        - Consent
        - Subscription
      properties:
        Type:
          type: string
          enum:
            - urn:openfinanceuae:account-access-consent:v1.0-draft5
        Consent:
          $ref: >-
            #/components/schemas/AEAccountAccessAuthorizationDetailReconsentProperties
        Subscription:
          $ref: '#/components/schemas/EventNotification'
      description: >-
        Properties for creating a consent object when a User reconsents to TPP
        access to account information data
      additionalProperties: false
    AEAccountAccessConsentPurpose:
      type: string
      enum:
        - Account Aggregation
        - Personal Finance Manager
        - Credit Assessment
        - Tax Filing
        - Enterprise Financial Management
        - Other
    AEAccountAccesssConsentPermissionCodes:
      type: string
      enum:
        - ReadAccountsBasic
        - ReadAccountsDetail
        - ReadBalances
        - ReadBeneficiariesBasic
        - ReadBeneficiariesDetail
        - ReadTransactionsBasic
        - ReadTransactionsDetail
        - ReadTransactionsCredits
        - ReadTransactionsDebits
        - ReadProduct
        - ReadScheduledPaymentsBasic
        - ReadScheduledPaymentsDetail
        - ReadDirectDebits
        - ReadStandingOrdersBasic
        - ReadStandingOrdersDetail
        - ReadConsents
        - ReadPartyPSU
        - ReadPartyPSUIdentity
        - ReadParty
      description: >-
        Specifies the permitted account access policy data types. 

        This is a list of the data groups being consented by the User, and
        requested for authorization with the LFI.
    AEAccountSubTypeCode:
      type: string
      enum:
        - CurrentAccount
        - Savings
        - CreditCard
        - PrePaidCard
        - EMoney
        - ChargeCard
        - Other
      description: Specifies the sub type of account (product family group)
    AEAccountTypeCode:
      type: string
      enum:
        - UAEOF.Retail
        - UAEOF.Corporate
      description: Specifies the type of account (Retail or Corporate).
    AEAmountAndCurrency:
      type: object
      required:
        - Currency
        - Amount
      properties:
        Currency:
          $ref: '#/components/schemas/CurrencyCode'
        Amount:
          $ref: '#/components/schemas/Amount'
      description: >-
        The Currency and Amount relating to the Payment, Refund or Request to
        Pay
      additionalProperties: false
    AEBaseConsentId:
      type: string
      minLength: 1
      maxLength: 128
      description: >-
        The original ConsentId assigned by the TPP.


        It is used by the TPP for updating/renewing parameters associated with
        long-lived consents.

        It must be provided when long-lived consent parameters are
        updated/renewed for a current consent that has not yet finished.
    AEChargeBearerType1Code:
      type: string
      enum:
        - BorneByCreditor
        - BorneByDebtor
        - FollowingServiceLevel
        - Shared
      description: >-
        Specifies which party/parties will bear the charges associated with the
        processing of the payment transaction.
    AEConsentId:
      type: string
      minLength: 1
      maxLength: 128
      description: >-
        Unique identification assigned by the TPP to identify the consent
        resource.
    AECurrencyRequest:
      type: object
      required:
        - ExtendedPurpose
        - CurrencyOfTransfer
      properties:
        InstructionPriority:
          allOf:
            - $ref: '#/components/schemas/AEInstructionPriority'
          description: >-
            Indicator of the urgency or order of importance that the instructing
            party would like the instructed party to apply to the processing of
            the instruction.
        ExtendedPurpose:
          type: string
          minLength: 1
          maxLength: 140
          description: >-
            Specifies the purpose of an international payment, when there is no
            corresponding 4 character code available in the ISO20022 list of
            Purpose Codes.
        ChargeBearer:
          $ref: '#/components/schemas/AEChargeBearerType1Code'
        CurrencyOfTransfer:
          type: string
          pattern: ^[A-Z]{3,3}$
          description: >-
            Specifies the currency of the to be transferred amount, which is
            different from the currency of the debtor's account.
        DestinationCountryCode:
          type: string
          pattern: '[A-Z]{2,2}'
          description: >-
            Country in which Credit Account is domiciled. Code to identify a
            country, a dependency, or another area of particular geopolitical
            interest, on the basis of country names obtained from the United
            Nations (ISO 3166, Alpha-2 code).
        ExchangeRateInformation:
          $ref: '#/components/schemas/AEExchangeRateInformation'
      description: >-
        The details of the non-local currency or FX request that has been agreed
        between the User and the TPP.

        The requested ChargeBearer and ExchangeRateInformation are included in
        this object may be overwritten by the LFI in the returned Consent
        object.
      additionalProperties: false
    AEExchangeRateInformation:
      type: object
      required:
        - UnitCurrency
        - RateType
      properties:
        UnitCurrency:
          type: string
          pattern: ^[A-Z]{3,3}$
          description: >-
            Currency in which the rate of exchange is expressed in a currency
            exchange. In the example 1GBP = xxxCUR, the unit currency is GBP.
        ExchangeRate:
          type: number
          description: >-
            The factor used for conversion of an amount from one currency to
            another. This reflects the price at which one currency was bought
            with another currency.
        RateType:
          $ref: '#/components/schemas/AERateType'
        ContractIdentification:
          type: string
          minLength: 1
          maxLength: 256
          description: >-
            Unique and unambiguous reference to the foreign exchange contract
            agreed between the initiating party/creditor and the debtor agent.
      description: Provides details on the currency exchange rate and contract.
      additionalProperties: false
    AEExpectedInitiationTimeWindow:
      type: string
      pattern: >-
        ^(00[0-9]|0[1-9][0-9]|[1-6][0-9]{2}|7[01][0-9]|720):[0-5][0-9]:[0-5][0-9]$
      description: |2-
            A time window set by the TPP in which a Payment must be initated by the LFI.
            The time window is based on a custom time format hhh:mm:ss. e.g. 000:00:15 represents a time window of 15 seconds to initiate the Payment.
    AEInstructionPriority:
      type: string
      enum:
        - Normal
        - Urgent
    AEInsuranceAuthorizationDetailsConsent:
      type: object
      required:
        - Type
        - Consent
        - Subscription
      properties:
        Type:
          type: string
          enum:
            - urn:openfinanceuae:insurance-consent:v1.0-draft5
        Consent:
          $ref: '#/components/schemas/OBInsuranceAuthorizationDetailConsentProperties'
        Subscription:
          $ref: '#/components/schemas/EventNotification'
      description: >-
        Properties for creating a consent object for the first time a User
        consents to TPP access to insurance data or services
      additionalProperties: false
    AEInsuranceAuthorizationDetailsReconsent:
      type: object
      required:
        - Type
        - Consent
        - Subscription
      properties:
        Type:
          type: string
          enum:
            - urn:openfinanceuae:insurance-consent:v1.0-draft5
        Consent:
          $ref: >-
            #/components/schemas/OBInsuranceAuthorizationDetailReconsentProperties
        Subscription:
          $ref: '#/components/schemas/EventNotification'
      description: >-
        Properties for creating a consent object when a User reconsents to TPP
        access to insurance data or services
      additionalProperties: false
    AEJWEPaymentPII:
      type: string
      description: |2-
            A JSON Web Encryption (JWE) object, which encapsulates a JWS. The value is a compact serialization
            of a JWE, which is a string consisting of five base64url-encoded parts joined by dots. It encapsulates encrypted content using JSON data structures.

            The decrypted JWS content has the structure of the AEPaymentPII schema.
    AEPaymentPII:
      type: "object"
      additionalProperties: false
      description: "Elements of Personal Identifiable Information data"
      properties:
        Initiation:
          type: "object"
          additionalProperties: false
          description: "The Initiation payload is sent by the initiating party to the LFI. It is used to request movement of funds from the debtor account to a creditor."
          properties:
            DebtorAccount:
              type: "object"
              additionalProperties: false
              required:
                - "IdentificationType"
                - "Identification"
              description: "Unambiguous identification of the account of the debtor to which a debit entry will be made as a result of the transaction."
              properties:
                IdentificationType:
                  description: "Name of the identification scheme, in a coded form as published in an external list."
                  type: "string"
                  enum:
                    - "UAEOF.IBAN"
                    - "UAEOF.AccountNumber"
                Identification:
                  description: |
                    Identification for the account assigned by the LFI based on the Account Scheme Name. 
                    This identification is known by the User account owner.
                  type: "string"
                  minLength: 1
                MobileNumber:
                  description: |
                    Mobile number of the account owner.
                  type: "string"
                  maxLength: 16
                Name:
                  type: "object"
                  description: |
                    The Account Holder Name is the name or names of the Account owner(s) represented at the account level
                  properties:
                    en:
                      type: "string"
                      description: "English value of the string"
                      maxLength: 70
                    ar:
                      type: "string"
                      description: "Arabic value of the string"
                      maxLength: 70
                  additionalProperties: false
            CreditorAgent:
              description: |
                Refers to the Financial Institution.
              type: "object"
              required:
                - "IdentificationType"
                - "Identification"
              properties:
                IdentificationType:
                  type: "string"
                  description: |
                    Refers to the Identification scheme for uniquely identifying the Agent.

                    * UAEOF.OTHER: The ID; A Country Code followed by a Bank Code (UAEOF 4 character code). The full list of LFI names and 6 digits IDs are as follows:
                  enum:
                    - "UAEOF.OTHER"
                Identification:
                  description: |
                    The Agent is the Country Code followed by a Bank Code"
                  type: "string"
                  minLength: 6
                  maxLength: 6
                Name:
                  description: "Name by which an agent is known and which is usually used to identify that agent."
                  type: "string"
                  minLength: 1
                  maxLength: 140
                PostalAddress:
                  $ref: "#/components/schemas/AEAddress"
            Creditor:
              type: "object"
              additionalProperties: false
              description: "Party to which an amount of money is due."
              properties:
                Name:
                  description: | 
                    Name by which a party is known and which is usually used to identify that party.
                    This may be used to identify the Creditor for international payments.
                  type: "string"
                  minLength: 1
                  maxLength: 140
                PostalAddress:
                  description: |
                    (Array) Address information that locates and identifes a specific address, as defined by a national or international postal service."
                  type: "array"
                  minItems: 1
                  items:
                    type: "object"
                    required:
                      - "AddressType"
                      - "Country"
                    properties:
                      AddressType:
                        $ref: "#/components/schemas/AEAddressTypeCode"
                      ShortAddress:
                        $ref: "#/components/schemas/AEShortAddress"
                      UnitNumber:
                        $ref: "#/components/schemas/AEUnitNumber"
                      FloorNumber:
                        $ref: "#/components/schemas/AEFloorNumber"
                      BuildingNumber:
                        $ref: "#/components/schemas/AEBuildingNumber"
                      StreetName:
                        $ref: "#/components/schemas/AEStreetName"
                      SecondaryNumber:
                        $ref: "#/components/schemas/AESecondaryNumber"
                      District:
                        $ref: "#/components/schemas/AEDistrict"
                      PostalCode:
                        $ref: "#/components/schemas/AEPostalCode"
                      POBox:
                        $ref: "#/components/schemas/AEPOBox"
                      ZipCode:
                        $ref: "#/components/schemas/AEZipCode"
                      City:
                        $ref: "#/components/schemas/AECity"
                      Region:
                        $ref: "#/components/schemas/AERegion"
                      Country:
                        $ref: "#/components/schemas/AECountryCode"
                    additionalProperties: false
            CreditorAccount:
              description: "Unambiguous identification of the account of the creditor to which a credit entry will be posted."
              type: "object"
              additionalProperties: false
              required:
                - "IdentificationType"
                - "Identification"
                - "Name"
              properties:
                IdentificationType:
                  $ref: "#/components/schemas/AEExternalAccountIdentificationCode"
                Identification:
                  $ref: "#/components/schemas/AEIdentification"
                MobileNumber:
                  $ref: "#/components/schemas/AEMobileNumber"
                Name:
                  $ref: "#/components/schemas/AEName"
                TradingName:
                  $ref: "#/components/schemas/AETradingName"
        Risk:
          $ref: "#/components/schemas/AERisk"
    AERisk:
      additionalProperties: false
      description: |
        The Risk section is sent by the TPP to the LFI. It is used to specify additional details for risk/fraud scoring regarding Payments.
      type: "object"
      properties:
        UserIndicators:
          $ref: "#/components/schemas/AEUserIndicators"
        DestinationDeliveryAddress:
          type: "object"
          description: |
            Destination Delivery Address
          properties:
            RecipientType:
              type: "string"
              description: "The recipient of the goods whether an individual or a corporation."
              enum:
                - "UAEOF.Individual"
                - "UAEOF.Corporate"
            RecipientName:
              type: "object"
              description: "The name of the recipient of the goods, whether an individual or a corporation."
              properties:
                en:
                  type: "string"
                  description: "English value of the string"
                ar:
                  type: "string"
                  description: "Arabic value of the string"
            NationalAddress:
              $ref: "#/components/schemas/AEAddress"
        TransactionIndicators:
          $ref: "#/components/schemas/AETransactionIndicators"
        BeneficiaryIndicators:
          $ref: "#/components/schemas/AEBeneficiaryIndicators"
    AEUserIndicators:
      type: "object"
      description: |
        User (Payer) Indicators
      properties:
        UserName:
          type: "object"
          description: "The Name of the User initiating the Payment"
          properties:
            en:
              type: "string"
              description: "English value of the string"
            ar:
              type: "string"
              description: "Arabic value of the string"
        GeoLocation:
          type: "object"
          description: "GPS to identify and track the whereabouts of the connected electronic device."
          required:
            - "latitude"
            - "longitude"
          properties:
            latitude:
              type: "string"
              description: "latitude"
            longitude:
              type: "string"
              description: "longitude"
        DeviceId:
          type: "string"
          description: "IMEISV number of the connected electronic device"
        DeviceOperatingSystem:
          type: "string"
          description: "Device operating system"
        DeviceOperatingSystemVersion:
          type: "string"
          description: "Device operating system version"
        UserOnboardingDateTime:
          type: "string"
          format: "date-time"
          description: "The exact date and time when the User account was activated with the TPP."
        AuthenticationChannel:
          description: Channel on which the User was authenticated
          type: string
          enum:
            - UAEOF.App
            - UAEOF.Web
    AETransactionIndicators:
      type: "object"
      description: |
        Transaction Indicators
      properties:
        IsCustomerPresent:
          description: "This field differentiates between automatic and manual payment initiation."
          type: boolean
        IsContractPresent:
          description: "Indicates if the Payee has a contractual relationship with the TPP."
          type: boolean
        Channel:
          description: "Where the payment has been initiated from."
          type: "string"
          enum:
            - "UAEOF.Web"
            - "UAEOF.Mobile"
    AEBeneficiaryIndicators:
      type: "object"
      description: |
        Beneficiary Indicators
      properties:
        AccountType:
          $ref: "#/components/schemas/AEAccountTypeCode"
        IsBeneficiaryPrePopulated:
          $ref: "#/components/schemas/AEIsBeneficiaryPrePopulated"
        TradingName:
          $ref: "#/components/schemas/AETradingName"
        IsVerifiedByTPP:
          $ref: "#/components/schemas/AEIsVerifiedbyTPP"
        AdditionalAccountHolderIdentifiers:
          $ref: "#/components/schemas/AEAdditionalAccountHolderIdentifiers"
        MerchantDetails:
          type: "object"
          description: |
            Details of the Merchant involved in the transaction.
            Merchant Details are specified only for those merchant categories that are generally expected to originate retail financial transactions
          properties:
            MerchantId:
              description: "MerchantId"
              type: "string"
              minLength: 8
              maxLength: 20
            MerchantName:
              description: "Name by which the merchant is known."
              type: "string"
              minLength: 1
              maxLength: 350
            MerchantSICCode:
              description: |
                SIC code stands for standard industrial classification (SIC) code.
                This four digit-number identifies a very specific short descriptor of the type of business a company is engaged in.
                SIC can be obtained from the Chamber of Commerce.
              type: "string"
              minLength: 3
              maxLength: 4
          additionalProperties: false  MerchantCategoryCode:
      IsBeneficiaryConfirmed:           description: Beneficiary>
account details have been confirmed successfully using Confirmation of Payee       Category code values are type:used booleanto enable the classification of
AEIsBeneficiaryPrePopulated:       description: "Is Beneficiary populated"      merchants type: "boolean"
    AEIsVerifiedbyTPP:
 into specific categories based on the type of business,
    description: "The TPP has onboarded the Beneficiary"      trade type: "boolean"
or services supplied. 

 AEAdditionalAccountHolderIdentifiers:       type: "array"       items:Category code conforms to ISO 18245, related to the type: "object"of services
       description: "Provides the details to identify an account."  or goods the merchant provides for the required:transaction."
          - "IdentificationType"   type: string
      - "Identification"       minLength: 3
properties:           IdentificationType:   maxLength: 4
        $ref: "#/components/schemas/AERiskExternalAccountIdentificationCode"
  additionalProperties: false
        IdentificationIsBeneficiaryConfirmed:
          description: Beneficiary $ref: "#/components/schemas/AEIdentification"account details have been confirmed successfully using Confirmation of Payee
          Nametype: boolean
    AEIsBeneficiaryPrePopulated:
      $refdescription: "#/components/schemas/AEName"
 Is Beneficiary populated"
      additionalPropertiestype: false"boolean"
    AERiskExternalAccountIdentificationCodeAEIsVerifiedbyTPP:
      description: "Name ofThe TPP has onboarded the identification scheme, in a coded form as published in an external list."Beneficiary"
      type: "boolean"
    AEAdditionalAccountHolderIdentifiers:
      type: "stringarray"
      enumitems:
        -type: "UAEOF.EmiratesIDobject"
        -description: "UAEOF.UnifiedCommercialNumber"Provides the details to identify an account."
  - "UAEOF.PassportNumber"     AEIdentificationrequired:
      description: |   - "IdentificationType"
    Identification   for the account assigned- by"Identification"
the LFI based on the Account Scheme Name. properties:
        This identification isIdentificationType:
known by the User account owner.       type$ref: "string#/components/schemas/AERiskExternalAccountIdentificationCode"
      minLength    Identification:
1     AEMobileNumber:       description: |$ref: "#/components/schemas/AEIdentification"
          Name:
Mobile number of the account owner.       type$ref: "string"#/components/schemas/AEName"
        maxLengthadditionalProperties: 16false
    AENameAERiskExternalAccountIdentificationCode:
      typedescription: "object"Name of the identification scheme, in a description:coded |form as published in an external list."
  The Account Holder Name is the name or names of the Account owner(s) represented at the account leveltype: "string"
      enum:
        - "UAEOF.EmiratesID"
 properties:       - "UAEOF.TradeLicenceNumber"
en:    AEIdentification:
      typedescription: "string"|
        Identification for description:the "Englishaccount valueassigned ofby the string"LFI based on the Account Scheme Name. 
   maxLength: 70    This identification is known by ar:the User account owner.
       type: "string"
      minLength: 1
    descriptionAEMobileNumber:
"Arabic value of the string"
        description: |
        Mobile number of the account owner.
      maxLengthtype: 70"string"
      additionalPropertiesmaxLength: false16
    AETradingNameAEName:
      type: "object"
      description: |
        The TradingAccount BrandHolder Name (if applicable) for is the Creditor.name or names of the Account owner(s) represented at the Applicableaccount tolevel
Payments.       properties:
        en:
          type: "string"
          description: "English value of the string"
          maxLength: 70
        ar:
          type: "string"
          description: "Arabic value of the string"
          maxLength: 70
      additionalProperties: false
    AEAddressAETradingName:
      descriptiontype: |"object"
      description: |
(Array)   Address information that locates and identifesThe aTrading specificBrand address,Name as(if definedapplicable) byfor athe nationalCreditor. or
international postal service."      Applicable type: "array"to Payments.
      minItemsproperties:
1        itemsen:
          type: "objectstring"
 
      required:    description: "English value of    - "AddressTypethe string"
          - "Country"maxLength: 70
        propertiesar:
          AddressTypetype: "string"
          description: $ref: "#/components/schemas/AEAddressTypeCode"
   "Arabic value of the string"
      ShortAddress:    maxLength: 70
      additionalProperties: $ref: "#/components/schemas/AEShortAddress"false
    AEAddress:
      UnitNumberdescription: |
        (Array) Address information $ref: "#/components/schemas/AEUnitNumber"
          FloorNumber:
  that locates and identifes a specific address, as defined by a national or international postal service."
         $reftype: "#/components/schemas/AEFloorNumberarray"
      minItems: 1
  BuildingNumber:    items:
        $reftype: "#/components/schemas/AEBuildingNumberobject"
          StreetNamerequired:
           - $ref: "#/components/schemas/AEStreetName"AddressType"
          SecondaryNumber:- "Country"
           $ref: "#/components/schemas/AESecondaryNumber"properties:
          DistrictAddressType:
            $ref: "#/components/schemas/AEDistrictAEAddressTypeCode"
          PostalCodeShortAddress:
            $ref: "#/components/schemas/AEPostalCodeAEShortAddress"
          POBoxUnitNumber:
            $ref: "#/components/schemas/AEPOBoxAEUnitNumber"
          ZipCodeFloorNumber:
            $ref: "#/components/schemas/AEZipCodeAEFloorNumber"
          CityBuildingNumber:
            $ref: "#/components/schemas/AECityAEBuildingNumber"
          RegionStreetName:
            $ref: "#/components/schemas/AERegionAEStreetName"
          CountrySecondaryNumber:
            $ref: "#/components/schemas/AECountryCodeAESecondaryNumber"
        additionalProperties  District:
false     AEAddressTypeCode:       description$ref: "Specifies the nature of the Address.""#/components/schemas/AEDistrict"
          typePostalCode:
"string"        enum:    $ref: "#/components/schemas/AEPostalCode"
   - "UAEOF.Business"      POBox:
  - "UAEOF.Correspondence"         -$ref: "UAEOF.Residential#/components/schemas/AEPOBox"
      example: "UAEOF.Residential"   ZipCode:
 AEShortAddress:       description: "A short address consists of four letters: region code, branch code, division code, unique code and a four-digit number for the building."$ref: "#/components/schemas/AEZipCode"
          City:
            type$ref: "string#/components/schemas/AECity"
      minLength:  1  Region:
    maxLength: 8       example$ref: "ABCD1234#/components/schemas/AERegion"
    AEUnitNumber:       descriptionCountry:
"Identifies the unit or apartment number."       type$ref: "string#/components/schemas/AECountryCode"
      minLength: 1 additionalProperties: false
    maxLengthAEAddressTypeCode:
10       exampledescription: "6"Specifies the nature of the AEFloorNumber:Address."
      descriptiontype: "Identifies the building floor number.""string"
      enum:
        type:- "string"UAEOF.Business"
         minLength: 1- "UAEOF.Correspondence"
        maxLength: 10- "UAEOF.Residential"
      example: "2UAEOF.Residential"
    AEBuildingNumberAEShortAddress:
      description: "IdentifiesA short address consists of four letters: region code, branch code, division code, unique code and a four-digit number for the building number."
      type: "string"
      minLength: 1
      maxLength: 108
      example: "34ABCD1234"
    AEStreetNameAEUnitNumber:
      description: "Identifies the streetunit nameor orapartment roadnumber."
      type: "string"
      minLength: 1
      maxLength: 7010
      example: "Omar Bin Hassan Street6"
    AEDistrictAEFloorNumber:
      description: "Identifies the districtbuilding offloor a citynumber."
      type: "string"
      minLength: 1
      maxLength: 3510
      example: "Olaya Dist.2"
    AECountryCodeAEBuildingNumber:
      description: "IndicatesIdentifies the countrybuilding codenumber."
in which the address is located (References ISO 3166-1 alpha-2).type: "string"
      typeminLength: "string"1
      patternmaxLength: "^[A-Z]{2,2}$"10
      example: "SA34"
    AEPostalCodeAEStreetName:
      description: " Identifies the postalstreet code;name a unique code assigned to a specific geographic area for efficient mail sorting and delivery purposesor road."
      type: "string"
      minLength: 1
      maxLength: 1070
      example: "12345Omar Bin Hassan Street"
    AEPOBoxAEDistrict:
      description: " Identifies the POBox district of a city."
      type: "string"
      minLength: 1
      maxLength: 1035
      example: "11562Olaya Dist."
    AEZipCodeAECountryCode:
      description: "IdentifiesIndicates the ZIPcountry code; ain uniquewhich codethe assignedaddress tois alocated specific(References geographicISO area for efficient mail sorting and delivery purposes3166-1 alpha-2)."
      type: "string"
      minLengthpattern: 1
"^[A-Z]{2,2}$"
      maxLength: 10example: "SA"
    AEPostalCode:
      exampledescription: "12366" Identifies the postal code; AESecondaryNumber:a unique code assigned to a specific description:geographic "4area numbersfor representingefficient themail accuratesorting locationand coordinates of the addressdelivery purposes."
      type: "string"
      minLength: 41
      maxLength: 410
      example: "123312345"
    AECityAEPOBox:
      description: " Identifies the name of the city or town where the address is situatedPOBox."
      type: "string"
      minLength: 1
      maxLength: 3510
      example: "Riyadh11562"
    AERegionAEZipCode:
      description: "Identifies the region ZIP code; a unique code assigned to a specific geographic area for efficient mail sorting and delivery purposes."
      type: "string"
      minLength: 1
      maxLength: 3510
      example: "North12366"
    AEExternalAccountIdentificationCodeAESecondaryNumber:
      description: "Name4 numbers ofrepresenting the identification scheme, in a coded form as published in an external list."
      accurate location coordinates of the address"
      type: "string"
      enumminLength: 4
      maxLength: -4
"UAEOF.IBAN"         -example: "UAEOF.AccountNumber1233"
    AEOnBehalfOfAECity:
      typedescription: object"Identifies the name of the city or properties:town where the address      TradingName:is situated."
          type: "string"
          descriptionminLength: Trading1
Name      maxLength: 35
 LegalName:     example: "Riyadh"
    typeAERegion:
string           description: Legal"Identifies Namethe region."
       IdentifierTypetype: "string"
      minLength: 1
 allOf:     maxLength: 35
      - $ref: '#/components/schemas/AEOnBehalfOfIdentifierType'example: "North"
    AEExternalAccountIdentificationCode:
      description: Identifier"Name Typeof the identification scheme, in a coded form as Identifier:published in an external list."
      type: "string"
      enum:
   description: Identifier    - "UAEOF.IBAN"
 additionalProperties: false     AEOnBehalfOfIdentifierType: - "UAEOF.AccountNumber"
    typeAEOnBehalfOf:
string      type: object
enum:      properties:
  - Other     AEPeriodStartDateTradingName:
      type: string   type: string
  format: date       description: |2-Trading Name
        LegalName:
  * Payments: Specifies the start date of when atype: paymentstring
schedule begins.         description: Legal Name
  Where this is an optional field, ifIdentifierType:
a value is not provided, then it must default to theallOf:
Consent CreationDateTime, starting from midnight 00:00:00.     AEPeriodType:  - $ref: '#/components/schemas/AEOnBehalfOfIdentifierType'
  type: string       enumdescription: Identifier Type
      - UAEOF.Day  Identifier:
        - UAEOF.Week type: string
      - UAEOF.Month   description: Identifier
    - UAEOF.Year additionalProperties: false
    descriptionAEOnBehalfOfIdentifierType:
|2-      type: string
     A Periodenum:
may begin from the Consent CreationDateTime if a PeriodStartDate- isOther
not provided.   AEPeriodStartDate:
      type: string
  |Period Type|Description|   format: date
       description:  |-----------|-----------||2-
             |Day|A continuous period of time, consisting* Payments: Specifies the start date of 24when consecutivea hours,payment startingschedule frombegins.
midnight
(00:00:00) and finishing at 23:59:59 of the same day. |   Where this is an optional field, if a value is |Week|A continuous period of time, consisting of seven consecutive daysnot provided, then it must default to the Consent CreationDateTime, starting from midnight (00:00:00).
 and finishing at 23:59AEPeriodType:59
of the 7th day. |  type: string
      enum:
  |Month|A continuous period of time starting from- midnight (00:00:00) of the first day of a month and finishing at 23:59:59 of the last day of that month.|UAEOF.Day
        - UAEOF.Week
        - UAEOF.Month
            |Year|A continuous period of time, consisting of 12 months.|- UAEOF.Year
      description: |2-
    AERateType:       type: stringA Period may begin from the Consent enum:CreationDateTime if a PeriodStartDate is not provided.

 - Actual         - Agreed
|Period Type|Description| 
      - Indicative     |-----------|-----------| 
description: Specifies the type used to complete the currency exchange.   |Day|A continuous AERequestedExecutionDate:period of time, consisting of 24 consecutive type:hours, stringstarting from midnight (00:00:00) and finishing at format23:59:59 dateof the same day. |
  description: |2-         |Week|A continuous period of time, consisting of seven consecutive Thedays, datestarting whenfrom the TPP expects the LFI to execute the payment.
midnight (00:00:00) and finishing at 23:59:59 of the 7th day. |
           The date must be in the future and cannot be on the same day or a day in the past. 
     |Month|A continuous period of time starting from midnight (00:00:00) of the first day of a month and finishing at 23:59:59 of the last day of that month.|
      The maximum date in the future that can be specified is 1 year from the day of the consent of the User to the TPP. 
 |Year|A continuous period of time, consisting of 12 months.|
    AERateType:
      type: string
      enum:
   All dates in the JSON payloads- areActual
represented in ISO 8601 date format.   - Agreed
AEServiceInitiationAuthorizationDetailConsent:       type: - objectIndicative
      requireddescription: Specifies the type used to complete the currency -exchange.
Type    AERequestedExecutionDate:
    - Consent type: string
      -format: Subscriptiondate
      propertiesdescription: |2-
       Type:     The date when the TPP expects type:the stringLFI to execute the payment.
      enum:      The date must be in the future - urn:openfinanceuae:service-initiation-consent:v1.0-draft5
        Consent:
 and cannot be on the same day or a day in the past. 
       oneOf:     The maximum date in the future that can -be $ref: '#/components/schemas/AEServiceInitiationAuthorizationDetailProperties'
            - $ref: '#/components/schemas/AERequestToPayAuthorizationDetailProperties'specified is 1 year from the day of the consent of the User to the TPP. 
        Subscription:    All dates in the JSON payloads are $ref: '#/components/schemas/EventNotification'
      description: >-represented in ISO 8601 date format.
    AEServiceInitiationAuthorizationDetailConsent:
      type: object
   Properties for creating arequired:
consent object for the first time a User - Type
      consents to TPP- accessConsent
to service initiation APIs     - Subscription
additionalProperties: false     AEServiceInitiationAuthorizationDetailPropertiesproperties:
       type Type:
object       required:   type: string
    - ConsentId     enum:
   - AcceptedAuthorizationType        - urn:openfinanceuae:service-initiation- PersonalIdentifiableInformationconsent:v1.0-draft5
        Consent:
 - ControlParameters        $ref: >-
PaymentPurposeCode            properties:#/components/schemas/AEServiceInitiationAuthorizationDetailProperties
        ConsentIdSubscription:
          $ref: '#/components/schemas/AEConsentIdEventNotification'
      description: >-
BaseConsentId:        Properties for creating $ref: '#/components/schemas/AEBaseConsentId'
        AcceptedAuthorizationType:a consent object for the first time a User
        consents to TPP access $ref: '#/components/schemas/AEAcceptedAuthorizationTypeRequestPayments'
 to service initiation APIs
      AuthorizationExpirationTimeWindowadditionalProperties: false
    AEServiceInitiationAuthorizationDetailProperties:
      type: stringobject
      required:
       pattern: >- ConsentId
        -   ^(00[0-9]|0[1-9][0-9]|[1-6][0-9]{2}|7[01][0-9]|720):[0-5][0-9]:[0-5][0-9]$
          description: |2-
                A time window by which a Consent (in AwaitingAuthorization status) must be Authorized by the User.
                The time window starts from the actual CreationDateTime (when the Consent is staged with the LFI). 
                If the current time window exceeds the Authorization Expiration Time Window (and the Consent status is AwaitingAuthorization) then the Consent Status must be set to Rejected.
                The time window is based on a custom time format hhh:mm:ss. e.g. 720:00:00 represents a time window of 720 hours, 00 minutes, 00 seconds (30 days) after the CreationDateTime to Authorize the Consent.
        ExpirationDateTime:
          allOf:
            - $ref: '#/components/schemas/ARConsentExpirationDateTime'
          description: |2-
                Specified date and time the consent will expire.
                If this is not populated, the consent will remain active as a long lived consent until the maximum consent validity period as per section 4.1.1 Consent Elements in the API User Guide.
                All dates in the JSON payloads are represented in ISO 8601 date-time format.
                All date-time fields in responses must include the timezone. An example is :2023-04-05T10:43:07+00:00

                * For Payment Consents, the maximum expiration time limit should be 23:59:59 (1 second before 00:00:00)
        Permissions:
          type: array
          items:
            $ref: '#/components/schemas/AEServiceInitiationConsentPermissionCodes'
          description: |2-
              Specifies the permitted Account Access data types.
              This is a list of the data groups being consented by the User, and requested for authorization with the LFI.

              This allows a TPP to request a balance check permission.
        ReadRefundAccount:
          type: boolean
          description: Allows the LFI to share the refund account details with TPP
        CurrencyRequest:
          $ref: '#/components/schemas/AECurrencyRequest'
        PersonalIdentifiableInformation:
          $ref: '#/components/schemas/AEJWEPaymentPII'
        ControlParameters:
          $ref: '#/components/schemas/AEServiceInitiationConsentControlParameters'
        PayerReference:
          allOf:
            - $ref: '#/components/schemas/AEServiceInitiationReference'
          description: Reason or reference for the payer regarding the Payment
        BeneficiaryReference:
          allOf:
            - $ref: '#/components/schemas/AEServiceInitiationReference'
          description: Reason or reference for the beneficiary regarding the Payment
        PaymentPurposeCode:
          $ref: '#/components/schemas/AEServiceInitiationPaymentPurposeCode'
        SponsoredTPPInformation:
          $ref: '#/components/schemas/AEServiceInitiationSponsoredTPPInformation'
      additionalProperties: false
    AERequestToPayAuthorizationDetailProperties:
      type: object
      required:
        - ConsentId
        - AcceptedAuthorizationType
        - PersonalIdentifiableInformation
        - ControlParameters
        - PaymentPurposeCode
      properties:
        ConsentId:
          $ref: '#/components/schemas/AEConsentId'
        BaseConsentId:
          $ref: '#/components/schemas/AEBaseConsentId'
        AcceptedAuthorizationType:
          $ref: '#/components/schemas/AEAcceptedAuthorizationTypeRequestPayments'
        AuthorizationExpirationTimeWindow:
          type: string
          pattern: >-
            ^(00[0-9]|0[1-9][0-9]|[1-6][0-9]{2}|7[01][0-9]|720):[0-5][0-9]:[0-5][0-9]$
          description: |2-
                A time window by which a Consent (in AwaitingAuthorization status) must be Authorized by the User.
                The time window starts from the actual CreationDateTime (when the Consent is staged with the LFI). 
                If the current time window exceeds the Authorization Expiration Time Window (and the Consent status is AwaitingAuthorization) then the Consent Status must be set to Rejected.
                The time window is based on a custom time format hhh:mm:ss. e.g. 720:00:00 represents a time window of 720 hours, 00 minutes, 00 seconds (30 days) after the CreationDateTime to Authorize the Consent.
        ExpirationDateTime:
          allOf:
            - $ref: '#/components/schemas/ARConsentExpirationDateTime'
          description: |2-
                Specified date and time the consent will expire.
                If this is not populated, the consent will remain active as a long lived consent until the maximum consent validity period as per section 4.1.1 Consent Elements in the API User Guide.
                All dates in the JSON payloads are represented in ISO 8601 date-time format.AcceptedAuthorizationType
        - PersonalIdentifiableInformation
        - ControlParameters
                All date-time fieldsPaymentPurposeCode
in responses must include the timezone. An example is :2023-04-05T10:43:07+00:00 properties:
        ConsentId:
        * For Payment Consents, the maximum expiration time limit should be 23:59:59 (1 second before 00:00:00) $ref: '#/components/schemas/AEConsentId'
        PersonalIdentifiableInformationBaseConsentId:
          $ref: '#/components/schemas/AEJWEPaymentPIIAEBaseConsentId'
        ControlParametersAcceptedAuthorizationType:
          $ref: '#/components/schemas/AERequestToPayConsentControlParametersAEAcceptedAuthorizationTypeRequestPayments'
        PayerReferenceAuthorizationExpirationTimeWindow:
          allOftype: string
          pattern: >- $ref: '#/components/schemas/AEServiceInitiationReference'
            ^(00[0-9]|0[1-9][0-9]|[1-6][0-9]{2}|7[01][0-9]|720):[0-5][0-9]:[0-5][0-9]$
           description: Reason or reference for the payer regarding the Payment
        BeneficiaryReference:
      |2-
                A time window by which a Consent (in AwaitingAuthorization status) must be Authorized by the User.
                The time window starts from the actual CreationDateTime (when the Consent is staged with the LFI). 
   allOf:             -If $ref: '#/components/schemas/AEServiceInitiationReference'
          description: Reason or reference for the beneficiary regarding the Payment
the current time window exceeds the Authorization Expiration Time Window (and the Consent status is AwaitingAuthorization) then the Consent Status must be set to Rejected.
       PaymentPurposeCode:         The time $ref: '#/components/schemas/AEServiceInitiationPaymentPurposeCode'
      additionalProperties: false
    AEServiceInitiationConsentControlParameters:
      type: object
      properties:window is based on a custom time format hhh:mm:ss. e.g. 720:00:00 represents a time window of 720 hours, 00 minutes, 00 seconds (30 days) after the CreationDateTime to Authorize the Consent.
        IsPayByAccountExpirationDateTime:
          typeallOf:
boolean           description: A- flag to denote if the Payment is an E-Commerce transaction$ref: '#/components/schemas/ARConsentExpirationDateTime'
          description: |2-
  ConsentSchedule:           $ref: '#/components/schemas/AEServiceInitiationConsentSchedule'  Specified date and time the description:consent Controlwill Parametersexpire.
set the overall rules for the Payment Schedule       additionalProperties: false If this is not AERequestToPayConsentControlParameters:populated, the consent will remain active as type:a objectlong lived consent until the maximum consent required:validity period as per section 4.1.1 Consent Elements in -the ConsentScheduleAPI User Guide.
    properties:         ConsentSchedule:   All dates in the JSON payloads are represented $ref: '#/components/schemas/AERequestToPayConsentSchedule'
  in ISO 8601 date-time format.
   description: Control Parameters set the overall rules for the Request To Pay Payment ScheduleAll date-time fields in responses must include additionalProperties:the falsetimezone. An example   AEServiceInitiationConsentPermissionCodes:is :2023-04-05T10:43:07+00:00

     type: string       enum:   * For Payment Consents, the maximum -expiration ReadAccountsBasictime limit should be 23:59:59 (1 second before 00:00:00)
- ReadAccountsDetail         - ReadBalances
Permissions:
   AEServiceInitiationConsentSchedule:       type: objectarray
      properties:       items:
 SinglePayment:           $ref: '#/components/schemas/AEServiceInitiationSinglePaymentAEServiceInitiationConsentPermissionCodes'
        MultiPayment:  description: |2-
              Specifies the permitted  $ref: '#/components/schemas/AEServiceInitiationLongLivedPaymentConsent'Account Access data types.
           FilePayment:   This is a list of the data groups $ref: '#/components/schemas/AEServiceInitiationFilePaymentConsent'
      description: |2-
 being consented by the User, and requested for authorization with the LFI.

         The various payment types that canThis beallows initiated:a TPP to request a balance check permission.
     * A Single PaymentReadRefundAccount:
          type: boolean
* A Multi-Payment        description: Allows the LFI to *share Athe Combinedrefund Paymentaccount (onedetails SinglePaymentwith andTPP
one MultiPayment)       additionalPropertiesCurrencyRequest:
false     AERequestToPayConsentSchedule:     $ref:  type: "object"'#/components/schemas/AECurrencyRequest'
        descriptionPersonalIdentifiableInformation:
 |         $ref:  A long-lived consent that is used for a series of Requests To Pay'#/components/schemas/AEJWEPaymentPII'
        ControlParameters:
          required$ref: '#/components/schemas/AEServiceInitiationConsentControlParameters'
        -PayerReference:
"Type"         - "MaximumIndividualPaymentAmount"allOf:
        - "MaximumCumulativeNumberOfPayments"   - $ref: '#/components/schemas/AEServiceInitiationReference'
   - "MaximumCumulativeValueOfPayments"       propertiesdescription: Reason or reference for the payer regarding the Type:Payment
        BeneficiaryReference:
 description: |        allOf:
    The type of Request To Pay   - $ref: '#/components/schemas/AEServiceInitiationReference'
     type:  "string"   description: Reason or reference for the beneficiary regarding enum:the Payment
        PaymentPurposeCode:
- UAEOF.LongLivedRequestToPay         MaximumIndividualPaymentAmount$ref: '#/components/schemas/AEServiceInitiationPaymentPurposeCode'
         allOfSponsoredTPPInformation:

           - $ref: '#/components/schemas/AEAmountAndCurrencyAEServiceInitiationSponsoredTPPInformation'
          descriptionadditionalProperties: |2-false
    AEServiceInitiationConsentControlParameters:
      type: object
   This is the Maximumproperties:
amount a variable payment related to the Consent canIsPayByAccount:
take.          type: boolean
      All payment amounts must bedescription: smallerA or equalflag to thisdenote value.if the Payment is an E-Commerce transaction
  MaximumCumulativeValueOfPayments:           allOfConsentSchedule:
            - $ref: '#/components/schemas/AEAmountAndCurrencyAEServiceInitiationConsentSchedule'
   
      description: |2-Control Parameters set the overall rules for the Payment Schedule
      additionalProperties: Thefalse
maximum cumulative value of allAEServiceInitiationConsentPermissionCodes:
successful payment rails executions under the Consent.type: string
      enum:
        - EachReadAccountsBasic
successful payment rails execution amount (related to the Consent)- isReadAccountsDetail
added to the total cumulative value of the Consent- whichReadBalances
cannot exceed the maximum valueAEServiceInitiationConsentSchedule:
agreed with the User at the pointtype: ofobject
consent.      properties:
  MaximumCumulativeNumberOfPayments:      SinglePayment:
    type: integer     $ref: '#/components/schemas/AEServiceInitiationSinglePayment'
    description: |2-   MultiPayment:
          $ref: '#/components/schemas/AEServiceInitiationLongLivedPaymentConsent'
 The maximum cumulative number of all successful paymentFilePayment:
rails executions under the Consent.      $ref: '#/components/schemas/AEServiceInitiationFilePaymentConsent'
      description: |2-
  Each successful payment rails execution (related to the Consent) is addedThe tovarious thepayment totaltypes cumulativethat numbercan ofbe paymentsinitiated:
for the Consent which cannot exceed the maximum value agreed with the User* atA theSingle pointPayment
of consent.         PeriodicSchedule:  * A Multi-Payment
      $ref: >-     * A Combined Payment (one SinglePayment and  #/components/schemas/AEServiceInitiationVariablePeriodicScheduleone MultiPayment)
      additionalProperties: false
    AEServiceInitiationDefinedSchedule:
      type: object
      required:
        - Type
        - Schedule
      properties:
        Type:
          type: string
          enum:
            - UAEOF.DefinedSchedule
          description: The Periodic Schedule Type
        Schedule:
          type: array
          items:
            $ref: '#/components/schemas/AEServiceInitiationSchedule'
          minItems: 1
      description: >-
        Payment Schedule denoting a list of pre-defined future dated payments
        all with fixed amounts and dates.
      additionalProperties: false
    AEServiceInitiationFilePaymentConsent:
      type: object
      required:
        - FileType
        - FileHash
        - NumberOfTransactions
        - ControlSum
      properties:
        FileType:
          type: string
          minLength: 1
          maxLength: 40
          description: Specifies the payment file type
        FileHash:
          type: string
          minLength: 1
          maxLength: 44
          description: A base64 encoding of a SHA256 hash of the file to be uploaded.
        FileReference:
          $ref: '#/components/schemas/AEServiceInitiationReference'
        NumberOfTransactions:
          type: integer
          description: >-
            Number of individual transactions contained in the payment
            information group.
        ControlSum:
          type: string
          pattern: ^\d{1,16}\.\d{2}$
          description: >-
            Total of all individual amounts included in the group, irrespective
            of currencies.
        RequestedExecutionDateTime:
          $ref: '#/components/schemas/AERequestedExecutionDate'
      description: A Consent definition for defining Bulk/Batch Payments
      additionalProperties: false
    AEServiceInitiationFixedPeriodicSchedule:
      type: object
      required:
        - Type
        - PeriodType
        - PeriodStartDate
        - Amount
      properties:
        Type:
          type: string
          enum:
            - UAEOF.FixedPeriodicSchedule
        PeriodType:
          $ref: '#/components/schemas/AEPeriodType'
        PeriodStartDate:
          $ref: '#/components/schemas/AEPeriodStartDate'
        Amount:
          $ref: '#/components/schemas/AEAmountAndCurrency'
      description: >-
        Payment Controls that apply to all payment instructions in a given
        period under this payment consent.
      additionalProperties: false
    AEServiceInitiationFutureDatedPayment:
      type: object
      required:
        - Type
        - Amount
        - RequestedExecutionDate
      properties:
        Type:
          type: string
          enum:
            - UAEOF.SingleFutureDatedPayment
        Amount:
          $ref: '#/components/schemas/AEAmountAndCurrency'
        RequestedExecutionDate:
          $ref: '#/components/schemas/AERequestedExecutionDate'
      description: >-
        A long-lived consent that MUST be used for a single payment which will
        be authorized by the User during the payment journey, but the payment
        will be initiated by the TPP in the future.
      additionalProperties: false
    AEServiceInitiationLongLivedPaymentConsent:
      type: object
      required:
        - Amount
        - MaximumIndividualPaymentAmount
        - PeriodicSchedule
      properties:
        Amount:
          $ref: '#/components/schemas/AEAmountAndCurrency'
        MaximumIndividualPaymentAmount:
          allOf:
            - $ref: '#/components/schemas/AEAmountAndCurrency'
          description: |2-
                This is the Maximum amount a variable payment related to the Consent can take. 
                All payment amounts must be smaller or equal to this value.
        MaximumCumulativeValueOfPayments:
          allOf:
            - $ref: '#/components/schemas/AEAmountAndCurrency'
          description: |2-
                The maximum cumulative value of all successful payment rails executions under the Consent. 
                Each successful payment rails execution amount (related to the Consent) is added to the total cumulative value of the Consent which cannot exceed the maximum value agreed with the User at the point of consent.
        MaximumCumulativeNumberOfPayments:
          type: integer
          description: |2-
                The maximum cumulative number of all successful payment rails executions under the Consent. 
                Each successful payment rails execution (related to the Consent) is added to the total cumulative number of payments for the Consent which cannot exceed the maximum value agreed with the User at the point of consent.
        PeriodicSchedule:
          $ref: >-
            #/components/schemas/AEServiceInitiationLongLivedPaymentConsentPeriodicSchedule
      description: A Consent definition for defining Multi Payments
      additionalProperties: false
    AEServiceInitiationLongLivedPaymentConsentPeriodicSchedule:
      type: object
      required:
        - DefinedSchedule
        - FixedPeriodicSchedule
        - VariablePeriodicSchedule
      properties:
        DefinedSchedule:
          $ref: '#/components/schemas/AEServiceInitiationDefinedSchedule'
        FixedPeriodicSchedule:
          $ref: '#/components/schemas/AEServiceInitiationFixedPeriodicSchedule'
        VariablePeriodicSchedule:
          $ref: '#/components/schemas/AEServiceInitiationVariablePeriodicSchedule'
        Type:
          type: string
          description: >-
            Discriminator property for
            AEServiceInitiationLongLivedPaymentConsentPeriodicSchedule.
      discriminator:
        propertyName: Type
      description: The definition for a schedule
      additionalProperties: false
    AEServiceInitiationPaymentPurposeCode:
      type: string
      minLength: 1
      maxLength: 4
      pattern: ^[A-Z]{4}$
      description: |2-
            A Category code, related to the type of services or goods that corresponds to the underlying purpose of the Payment.
            * The ISO20022 External code sets
    AEServiceInitiationReference:
      type: string
      minLength: 1
      maxLength: 120
      description: A reason or reference in relation to a payment.
    AEServiceInitiationSchedule:
      type: object
      required:
        - PaymentExecutionDate
        - Amount
      properties:
        PaymentExecutionDate:
          type: string
          format: date
          description: |2-
                Used to specify the expected payment execution date/time.
                All dates in the JSON payloads are represented in ISO 8601 date format.
                An example is: 2023-04-05
        Amount:
          $ref: '#/components/schemas/AEAmountAndCurrency'
      additionalProperties: false
    AEServiceInitiationSingleInstantPayment:
      type: object
      required:
        - Type
        - Amount
      properties:
        Type:
          type: string
          enum:
            - UAEOF.SingleInstantPayment
          description: The Payment Type
        Amount:
          $ref: '#/components/schemas/AEAmountAndCurrency'
        ExpectedInitiationTimeWindow:
          $ref: '#/components/schemas/AEExpectedInitiationTimeWindow'
      description: >-
        A single immediate payment consent that MUST be be used for a single
        payment which will be initiated immediately after User authorization at
        the LFI.
      additionalProperties: false
    AEServiceInitiationSinglePayment:
      anyOf:
        - $ref: '#/components/schemas/AEServiceInitiationSingleInstantPayment'
        - $ref: '#/components/schemas/AEServiceInitiationFutureDatedPayment'
      discriminator:
        propertyName: Type
        mapping:
          UAEOF.SingleInstantPayment: '#/components/schemas/AEServiceInitiationSingleInstantPayment'
          UAEOF.SingleFutureDatedPayment: '#/components/schemas/AEServiceInitiationFutureDatedPayment'
      description: A Consent definition for defining Single Payments
    AEServiceInitiationSponsoredTPPInformation:
      type: object
      required:
        - Name
        - Identification
      properties:
        Name:
          type: string
          minLength: 1
          maxLength: 50
          description: The Sponsored TPP Name
        Identification:
          type: string
          minLength: 1
          maxLength: 50
          description: The Sponsored TPP Identification
      description: |2-
            The Sponsored TPP is:
            * A TPP that itself has no direct Open Banking API integrations. 
            * A TPP that is using the integration of another TPP that does have direct Open Banking API integrations.
      additionalProperties: false
    AEServiceInitiationVariablePeriodicSchedule:
      type: object
      required:
        - Type
        - PeriodType
        - MaximumCumulativeValueOfPaymentsPerPeriodType
        - MaximumCumulativeNumberOfPaymentsPerPeriodType
      properties:
        Type:
          type: string
          enum:
            - UAEOF.VariablePeriodicSchedule
        PeriodType:
          $ref: '#/components/schemas/AEPeriodType'
        PeriodStartDate:
          $ref: '#/components/schemas/AEPeriodStartDate'
        MaximumCumulativeValueOfPaymentsPerPeriodType:
          allOf:
            - $ref: '#/components/schemas/AEAmountAndCurrency'
          description: >-
            The maximum cumulative payment value of all payment initiations per
            Period Type.
        MaximumCumulativeNumberOfPaymentsPerPeriodType:
          type: integer
          description: The maximum frequency of payment initiations per Period Type.
      description: >-
        Payment Controls that apply to all payment instructions in a given
        period under this payment consent.
      additionalProperties: false
    ARConsentExpirationDateTime:
      type: string
      format: date-time
    Amount:
      type: number
    CurrencyCode:
      type: string
      pattern: ^[A-Z]{3}$
    EventNotification:
      type: object
      required:
        - Webhook
      properties:
        Webhook:
          $ref: '#/components/schemas/OBWebhook'
      additionalProperties: false
    OAuthBadRequestErrorResponse:
      type: object
      allOf:
        - $ref: '#/components/schemas/OAuthErrorResponse'
      description: Bad Request
      additionalProperties: false
    OAuthErrorCodes:
      type: string
      enum:
        - invalid_request
        - invalid_client
        - invalid_grant
        - unauthorized_client
        - unsupported_grant_type
        - invalid_scope
      description: >-
        Status code corresponding to error condition to be returned to the
        client
    OAuthErrorResponse:
      type: object
      required:
        - error
      properties:
        error:
          $ref: '#/components/schemas/OAuthErrorCodes'
        error_description:
          type: string
          description: Description of the error providing additional information
        error_uri:
          type: string
          description: >-
            A URI identifying a human-readable web page with information about
            the error
      description: Error returned from endpoints compliant with security profile
      additionalProperties: false
    OBBaseConsentId:
      type: string
      minLength: 1
      maxLength: 128
      description: >-
        The original ConsentId assigned by the TPP.


        It is used by the TPP for updating/renewing parameters associated with
        long-lived consents.

        It must be provided when long-lived consent parameters are
        updated/renewed for a current consent that has not yet finished.
    OBConsentId:
      type: string
      minLength: 1
      maxLength: 128
      description: >-
        Unique identification assigned by the TPP to identify the consent
        resource.
    OBConsentPermissions:
      type: string
      enum:
        - ReadInsurancePoliciesMotor
      description: >-
        Specifies the permitted insurance policy data types. 

        This is a list of the data groups being consented by the User, and
        requested for authorization with the LFI.
    OBConsentPurpose:
      type: string
      enum:
        - AccountAggregation
        - PersonalFinanceManager
        - CreditAssessment
        - MotorInsuranceQuote
        - EnterpriseFinancialManagement
        - Other
    OBInsuranceAuthorizationDetailConsentProperties:
      type: object
      required:
        - ConsentId
        - Permissions
      properties:
        ConsentId:
          $ref: '#/components/schemas/OBConsentId'
        BaseConsentId:
          $ref: '#/components/schemas/OBBaseConsentId'
        Permissions:
          type: array
          items:
            $ref: '#/components/schemas/OBConsentPermissions'
          minItems: 1
      allOf:
        - $ref: '#/components/schemas/OBInsuranceAuthorizationDetailProperties'
      additionalProperties: false
    OBInsuranceAuthorizationDetailProperties:
      type: object
      properties:
        ExpirationDateTime:
          type: string
          format: date-time
          description: >-
            Specified date and time the permissions will expire.

            If this is not populated, the permissions will be open ended.All
            dates in the JSON payloads are represented in ISO 8601 date-time
            format. 

            All date-time fields in responses must include the timezone. An
            example is below:

            2017-04-05T10:43:07+00:00
        OnBehalfOf:
          $ref: '#/components/schemas/AEOnBehalfOf'
        Purpose:
          type: array
          items:
            $ref: '#/components/schemas/OBConsentPurpose'
      description: Primary data for the resource
      additionalProperties: false
    OBInsuranceAuthorizationDetailReconsentProperties:
      type: object
      required:
        - ConsentId
      properties:
        ConsentId:
          $ref: '#/components/schemas/OBConsentId'
      allOf:
        - $ref: '#/components/schemas/OBInsuranceAuthorizationDetailProperties'
      additionalProperties: false
    OBWebhook:
      type: object
      required:
        - Url
        - IsActive
      properties:
        Url:
          type: string
          description: The TPP Callback URL being registered with the LFI
        IsActive:
          type: boolean
          description: >-
            The TPP specifying whether the LFI should send (IsActive true) or
            not send (IsActive false) Webhook Notifications to the TPP's Webhook
            URL
      description: A Webhook Subscription Schema
      additionalProperties: false
    PushedAuthorizationRequest:
      type: object
      required:
        - client_assertion_type
        - client_assertion
        - request
      properties:
        client_assertion_type:
          type: string
          enum:
            - urn%3Aietf%3Aparams%3Aoauth%3Aclient-assertion-type%3Ajwt-bearer
        client_assertion:
          type: string
          description: private_key_jwt client assertion
        request:
          allOf:
            - $ref: '#/components/schemas/RichAuthorizationJar'
          description: >-
            Rich Authorization Request (RAR) that defines the required JSON Web
            Token (JWT) payload. This **does not** represent a correctly
            serialized JWT, but provides a Schema Object that correctly defines
            the supported RARs.
      additionalProperties: false
    PushedAuthorizationRequestSigned:
      type: object
      required:
        - requestBody
      properties:
        requestBody:
          $ref: '#/components/schemas/PushedAuthorizationRequest'
      additionalProperties: false
    PushedAuthorizationResponseBody:
      type: object
      required:
        - request_uri
        - expires_in
      properties:
        request_uri:
          type: string
          description: The request URI corresponding to the authorization request posted
        expires_in:
          type: integer
          description: >-
            A JSON number that represents the lifetime of the request URI in
            seconds as a positive integer
      additionalProperties: false
    RichAuthorizationJar:
      type: object
      required:
        - iss
        - exp
        - nbf
        - client_id
        - response_type
        - redirect_uri
        - scope
        - code_challenge
        - code_challenge_method
        - authorization_details
      properties:
        iss:
          type: string
          description: >-
            [https://www.rfc-editor.org/rfc/rfc7519#section-4.1.1](https://www.rfc-editor.org/rfc/rfc7519#section-4.1.1)
        aud:
          anyOf:
            - type: string
            - type: array
              items:
                type: string
          description: >-
            [https://www.rfc-editor.org/rfc/rfc7519#section-4.1.3](https://www.rfc-editor.org/rfc/rfc7519#section-4.1.3)
        exp:
          type: number
          description: >-
            [https://www.rfc-editor.org/rfc/rfc7519#section-4.1.4](https://www.rfc-editor.org/rfc/rfc7519#section-4.1.4)
        nbf:
          type: number
          description: >-
            [https://www.rfc-editor.org/rfc/rfc7519#section-4.1.5](https://www.rfc-editor.org/rfc/rfc7519#section-4.1.5)
        client_id:
          type: string
        response_type:
          type: string
          enum:
            - code
        redirect_uri:
          type: string
        scope:
          type: string
        state:
          type: string
        nonce:
          type: string
        max_age:
          type: integer
        code_challenge:
          type: string
          description: Code challenge (PKCE)
        code_challenge_method:
          type: string
          enum:
            - S256
          description: >-
            Code verifier transformation method, set to S256 as per clause
            [5.3.1.2.5](https://openid.net/specs/fapi-2_0-security-profile-ID2.html#section-5.3.1.2-2.5.1)
            of the FAPI 2.0 Security Profile
        authorization_details:
          type: array
          items:
            $ref: '#/components/schemas/RichAuthorizationRequestObjects'
      additionalProperties: false
    RichAuthorizationRequestObjects:
      oneOf:
        - $ref: '#/components/schemas/AEAccountAccessAuthorizationDetailsConsent'
        - $ref: '#/components/schemas/AEAccountAccessAuthorizationDetailsReconsent'
        - $ref: '#/components/schemas/AEInsuranceAuthorizationDetailsConsent'
        - $ref: '#/components/schemas/AEInsuranceAuthorizationDetailsReconsent'
        - $ref: '#/components/schemas/AEServiceInitiationAuthorizationDetailConsent'
    Versions:
      type: string
      enum:
        - v1.0-draft5

...