- 
                        API- 
                                    The terms `API` (Application Programming Interface) and `Endpoint` are used somewhat interchangeablyMore...
- Create Bank Level Endpoint Tag
- Create System Level Endpoint Tag
- Delete Bank Level Endpoint Tag
- Delete System Level Endpoint Tag
- Get API Configuration
- Get API Info (root)
- Get API Tags
- Get Adapter Info
- Get Adapter Info for a bank
- Get Bank Level Endpoint Tags
- Get Connector Status (Loopback)
- Get JSON Web Key (JWK)
- Get JSON Web Key (JWK) URIs
- Get Log Cache
- Get Mapper Database Info
- Get Rate Limiting Info
- Get Suggested Session Timeout
- Get System Level Endpoint Tags
- Get Well Known URIs
- Get the Call Context of a current call
- Update Bank Level Endpoint Tag
- Update System Level Endpoint Tag
- Verify Request and Sign Response of a current call
- Waiting For Godot
 
- 
                                    
- 
                        ATM
- Create ATM
- Create ATM Attribute
- Delete ATM
- Delete ATM Attribute
- Get ATM Attribute By ATM_ATTRIBUTE_ID
- Get ATM Attributes
- Get Bank ATM
- Get Bank ATMS
- Head Bank ATMS
- UPDATE ATM
- Update ATM Accessibility Features
- Update ATM Attribute
- Update ATM Location Categories
- Update ATM Notes
- Update ATM Services
- Update ATM Supported Currencies
- Update ATM Supported Languages
 
- 
                        Account- 
                                    The thing that tokens of value (money) come in and out of. An account has one or more `owners` whichMore...
- Check Available Funds
- Create Account (POST)
- Create Account (PUT)
- Create Account Attribute
- Create Bank Account Balance
- Create or Update Account Attribute Definition
- Delete Account Attribute Definition
- Delete Account Cascade
- Delete Bank Account Balance
- Get Account Access by USER_ID
- Get Account Attribute Definition
- Get Account Balances by BANK_ID
- Get Account Balances by BANK_ID and ACCOUNT_ID through the VIEW_ID
- Get Account Balances by BANK_ID through the VIEW_ID
- Get Account by Account Routing
- Get Account by Id (Core)
- Get Account by Id (Core) through the VIEW_ID
- Get Account by Id (Full)
- Get Accounts Held
- Get Accounts Held By User
- Get Accounts Held By User
- Get Accounts Minimal for a Customer
- Get Accounts at Bank
- Get Accounts at Bank (IDs only)
- Get Accounts at Bank (Minimal)
- Get Accounts at all Banks (private)
- Get Accounts by Account Routing Regex
- Get Agent
- Get Agents at Bank
- Get All Bank Account Balances
- Get Bank Account Balance By ID
- Get Checkbook orders
- Get Fast Firehose Accounts at Bank
- Get Firehose Accounts at Bank
- Update Account
- Update Account Attribute
- Update Account Label
- Update Bank Account Balance
- Validate and check IBAN
 
- 
                                    
- 
                        Account Access- 
                                    Account Access governs access to Bank Accounts by end Users. It is an intersecting entity between tMore...
- Create (DAuth) User with Account Access
- Grant User access to View
- Revoke User access to View
 
- 
                                    
- 
                        Api Collection
- Create My Api Collection
- Create My Api Collection Endpoint
- Create My Api Collection Endpoint By Id
- Delete My Api Collection
- Delete My Api Collection Endpoint
- Delete My Api Collection Endpoint By Id
- Delete My Api Collection Endpoint By Id
- Get All API Collections
- Get Api Collection Endpoints
- Get Api Collections for User
- Get Featured Api Collections
- Get My Api Collection By Id
- Get My Api Collection By Name
- Get My Api Collection Endpoint
- Get My Api Collection Endpoints
- Get My Api Collection Endpoints By Id
- Get My Api Collections
- Get Sharable Api Collection By Id
- Update My Api Collection By API_COLLECTION_ID
 
- 
                        Bank- 
                                    A Bank (aka Space) represents a financial institution, brand or organizational unit under which resMore...
- Create Bank
- Create Bank Attribute
- Create Settlement Account
- Create Transaction Type at bank
- Create or Update Bank Attribute Definition
- Delete Bank Attribute
- Delete Bank Cascade
- Get Bank
- Get Bank Attribute By BANK_ATTRIBUTE_ID
- Get Bank Attributes
- Get Banks
- Get Settlement accounts at Bank
- Get Transaction Types at Bank
- Update Bank
- Update Bank Attribute
 
- 
                                    
- 
                        Connector Method- 
                                    Developers can override all the existing Connector methods. This function needs to be used togethMore...
- Create Connector Method
- Get Connector Method by Id
- Get all Connector Methods
- Update Connector Method
 
- 
                                    
- 
                        Consent- 
                                    Consents provide a mechanism through which a resource owner (e.g. a customer) can grant a third partMore...
- Add User to a Consent
- Answer Consent Challenge
- Create Consent (EMAIL)
- Create Consent (IMPLICIT)
- Create Consent (IMPLICIT)
- Create Consent (SMS)
- Create Consent By CONSENT_REQUEST_ID (EMAIL)
- Create Consent By CONSENT_REQUEST_ID (IMPLICIT)
- Create Consent By CONSENT_REQUEST_ID (SMS)
- Create Consent Request
- Create Consent Request VRP
- Get Consent By Consent Id via Consumer
- Get Consent By Consent Id via User
- Get Consent By Consent Request Id via Consumer
- Get Consent Request
- Get Consents
- Get Consents at Bank
- Get My Consents
- Get My Consents Info
- Get My Consents Info At Bank
- Get My Consents at Bank
- Provide client's certificate info of a current call
- Revoke Consent at Bank
- Revoke Consent used in the Current Call
- Revoke My Consent
- Update Consent Account Access by CONSENT_ID
- Update Consent Status
- Update Consent Status by CONSENT_ID
- Update Created by User of Consent by CONSENT_ID
 
- 
                                    
- 
                        Consumer- 
                                    The "consumer" of the API, i.e. the web, mobile or serverside "App" that calls on the OBP API on beMore...
- Create a Consumer
- Create a Consumer
- Enable or Disable Consumers
- Get Call Limits for a Consumer
- Get Consumer
- Get Consumers
- Get Consumers (logged in User)
- Set Rate Limits / Call Limits per Consumer
- Update Consumer Certificate
- Update Consumer LogoURL
- Update Consumer Name
- Update Consumer RedirectURL
 
- 
                                    
- 
                        Counterparty
- Create Counterparty (Explicit)
- Create Counterparty for any account (Explicit)
- Delete Counterparty (Explicit)
- Delete Counterparty for any account (Explicit)
- Get Counterparties (Explicit)
- Get Counterparties for any account (Explicit)
- Get Counterparty by Id (Explicit)
- Get Counterparty by Id for any account (Explicit)
- Get Counterparty by name for any account (Explicit)
- Get Other Account by Id
- Get Other Accounts of one Account
 
- 
                        Counterparty Metadata
- Add Corporate Location to Counterparty
- Add Counterparty More Info
- Add Open Corporates URL to Counterparty
- Add image url to other bank account
- Add physical location to other bank account
- Add public alias to other bank account
- Add url to other bank account
- Create Other Account Private Alias
- Delete Counterparty Corporate Location
- Delete Counterparty Image URL
- Delete Counterparty Open Corporates URL
- Delete Counterparty Physical Location
- Delete Counterparty Private Alias
- Delete Counterparty Public Alias
- Delete more info of other bank account
- Delete url of other bank account
- Get Other Account Metadata
- Get Other Account Private Alias
- Get public alias of other bank account
- Update Counterparty Corporate Location
- Update Counterparty Image Url
- Update Counterparty More Info
- Update Counterparty Physical Location
- Update Counterparty Private Alias
- Update Open Corporates Url of Counterparty
- Update public alias of other bank account
- Update url of other bank account
 
- 
                        Customer- 
                                    The legal entity that has the relationship to the bank. Customers are linked to Users via `User CusMore...
- Create Address
- Create Agent
- Create Customer
- Create Customer Account Link
- Create Customer Attribute
- Create Customer Social Media Handle
- Create Tax Residence
- Create User Customer Link
- Create or Update Customer Attribute Definition
- Delete Customer Account Link
- Delete Customer Address
- Delete Customer Attribute
- Delete Customer Attribute Definition
- Delete Customer Cascade
- Delete Tax Residence
- Delete User Customer Link
- Get CRM Events
- Get Correlated Entities for the current User
- Get Correlated User Info by Customer
- Get Customer Account Link by Id
- Get Customer Account Links by ACCOUNT_ID
- Get Customer Account Links by CUSTOMER_ID
- Get Customer Addresses
- Get Customer Attribute By Id
- Get Customer Attribute Definition
- Get Customer Attributes
- Get Customer Overview
- Get Customer Overview Flat
- Get Customer Social Media Handles
- Get Customer by CUSTOMER_ID
- Get Customer by CUSTOMER_NUMBER
- Get Customers Minimal at Any Bank
- Get Customers Minimal at Bank
- Get Customers at Any Bank
- Get Customers at Bank
- Get Customers by Legal Name
- Get Customers by MOBILE_PHONE_NUMBER
- Get Customers for Current User
- Get Customers for Current User (IDs only)
- Get Firehose Customers
- Get My Customers
- Get My Customers at Bank
- Get Tax Residences of Customer
- Get User Customer Links by Customer
- Get User Customer Links by User
- Update Agent status
- Update Customer Account Link by Id
- Update Customer Attribute
- Update the Address of a Customer
- Update the Branch of a Customer
- Update the credit limit of a Customer
- Update the credit rating and source of a Customer
- Update the email of a Customer
- Update the identity data of a Customer
- Update the mobile number of a Customer
- Update the number of a Customer
- Update the other data of a Customer
 
- 
                                    
- 
                        Directory
- Create Regulated Entity
- Create Regulated Entity Attribute
- Create a Consumer(Dynamic Registration)
- Delete Regulated Entity
- Delete Regulated Entity Attribute
- Get All Regulated Entity Attributes
- Get Regulated Entities
- Get Regulated Entity
- Get Regulated Entity Attribute By ID
- Update Regulated Entity Attribute
 
- 
                        Dynamic Endpoint Manage- 
                                    If you want to create endpoints from Swagger / Open API specification files, use Dynamic EndpointsMore...
- Delete Bank Level Dynamic Endpoint
- Delete Dynamic Endpoint
- Get Bank Level Dynamic Endpoint
- Get Dynamic Endpoints
- Update Bank Level Dynamic Endpoint Host
- Update Dynamic Endpoint Host
- Create Bank Level Dynamic Endpoint
- Create Dynamic Endpoint
- Delete My Dynamic Endpoint
- Get Bank Level Dynamic Endpoints
- Get Dynamic Endpoint
- Get My Dynamic Endpoints
 
- 
                                    
- 
                        Dynamic Entity Manage- 
                                    Dynamic Entities can be used to store and retrieve custom data objects (think your own tables andMore...
- Create Bank Level Dynamic Entity
- Create System Level Dynamic Entity
- Delete Bank Level Dynamic Entity
- Delete My Dynamic Entity
- Delete System Level Dynamic Entity
- Get Bank Level Dynamic Entities
- Get My Dynamic Entities
- Get System Dynamic Entities
- Update Bank Level Dynamic Entity
- Update My Dynamic Entity
- Update System Level Dynamic Entity
 
- 
                                    
- 
                        Dynamic Message Doc- 
                                    In OBP we represent messages sent by a Connector method / function as MessageDocs. A MessageDoc dMore...
- Create Bank Level Dynamic Message Doc
- Create Dynamic Message Doc
- Delete Bank Level Dynamic Message Doc
- Delete Dynamic Message Doc
- Get Bank Level Dynamic Message Doc
- Get Dynamic Message Doc
- Get all Bank Level Dynamic Message Docs
- Get all Dynamic Message Docs
- Update Bank Level Dynamic Message Doc
- Update Dynamic Message Doc
 
- 
                                    
- 
                        Dynamic Resource Doc- 
                                    In OBP we largely define our endpoints using an internal case class or model called ResourceDoc UsMore...
- A test endpoint
- Create Bank Level Dynamic Resource Doc
- Create Dynamic Resource Doc
- Create Dynamic Resource Doc endpoint code
- Delete Bank Level Dynamic Resource Doc
- Delete Dynamic Resource Doc
- Get Bank Level Dynamic Resource Doc by Id
- Get Dynamic Resource Doc by Id
- Get all Bank Level Dynamic Resource Docs
- Get all Dynamic Resource Docs
- Update Bank Level Dynamic Resource Doc
- Update Dynamic Resource Doc
 
- 
                                    
- 
                        Endpoint Mapping- 
                                    Endpoint Mapping can be used to map each JSON field in a Dynamic Endpoint to different Dynamic EntiMore...
- Create Bank Level Endpoint Mapping
- Create Endpoint Mapping
- Delete Bank Level Endpoint Mapping
- Delete Endpoint Mapping
- Get Bank Level Endpoint Mapping
- Get Endpoint Mapping by Id
- Get all Bank Level Endpoint Mappings
- Get all Endpoint Mappings
- Update Bank Level Endpoint Mapping
- Update Endpoint Mapping
 
- 
                                    
- 
                        JSON Schema Validation- 
                                    JSON Schema is "a vocabulary that allows you to annotate and validate JSON documents". By applyinMore...
- Create a JSON Schema Validation
- Delete a JSON Schema Validation
- Get a JSON Schema Validation
- Get all JSON Schema Validations
- Get all JSON Schema Validations - public
- Update a JSON Schema Validation
 
- 
                                    
- 
                        Method Routing- 
                                    Open Bank Project can have different connectors, to connect difference data sources. We supportMore...
- Create MethodRouting
- Delete MethodRouting
- Get MethodRoutings
- Update MethodRouting
 
- 
                                    
- 
                        Product
- Create Product
- Create Product Attribute
- Create Product Fee
- Create or Update Product Attribute Definition
- Delete Product Attribute
- Delete Product Attribute Definition
- Delete Product Cascade
- Delete Product Fee
- Get Bank Product
- Get Product Attribute
- Get Product Attribute Definition
- Get Product Fee
- Get Product Fees
- Get Product Tree
- Get Products
- Update Product Attribute
- Update Product Fee
 
- 
                        Role
- Add Entitlement for a User
- Create (DAuth) User with Roles
- Create Entitlement Request for current User
- Delete Entitlement
- Delete Entitlement Request
- Get Entitlement Requests for a User
- Get Entitlement Requests for the current User
- Get Entitlements and Permissions for a User
- Get Entitlements for One Bank
- Get Entitlements for User
- Get Entitlements for User at Bank
- Get Entitlements for the current User
- Get Roles
- Get all Entitlement Requests
- Get all Entitlements
 
- 
                        Transaction- 
                                    Transactions are records of successful movements of value into or out of an `Account`. OBP TransacMore...
- Create Transaction Attribute
- Create or Update Transaction Attribute Definition
- Delete Transaction Attribute Definition
- Delete Transaction Cascade
- Get Balancing Transaction
- Get Double Entry Transaction
- Get Firehose Transactions for Account
- Get Other Account of Transaction
- Get Transaction Attribute By Id
- Get Transaction Attribute Definition
- Get Transaction Attributes
- Get Transaction by Id
- Get Transactions for Account (Core)
- Get Transactions for Account (Full)
- Update Transaction Attribute
 
- 
                                    
- 
                        Transaction Metadata
- Add a Transaction Comment
- Add a Transaction Image
- Add a Transaction Narrative
- Add a Transaction Tag
- Add a Transaction where Tag
- Delete a Transaction Comment
- Delete a Transaction Image
- Delete a Transaction Narrative
- Delete a Transaction Tag
- Delete a Transaction Tag
- Get Transaction Comments
- Get Transaction Images
- Get Transaction Tags
- Get a Transaction Narrative
- Get a Transaction where Tag
- Update a Transaction Narrative
- Update a Transaction where Tag
 
- 
                        Transaction Request
- Answer Transaction Request Challenge
- Create Historical Transactions
- Create Transaction Request (ACCOUNT)
- Create Transaction Request (ACCOUNT_OTP)
- Create Transaction Request (AGENT_CASH_WITHDRAWAL)
- Create Transaction Request (CARD)
- Create Transaction Request (COUNTERPARTY)
- Create Transaction Request (FREE_FORM)
- Create Transaction Request (REFUND)
- Create Transaction Request (SANDBOX_TAN)
- Create Transaction Request (SEPA)
- Create Transaction Request (SIMPLE)
- Create Transaction Request Attribute
- Create or Update Transaction Request Attribute Definition
- Delete Transaction Request Attribute Definition
- Get Transaction Request
- Get Transaction Request Attribute By Id
- Get Transaction Request Attribute Definition
- Get Transaction Request Attributes
- Get Transaction Request Types at Bank
- Get Transaction Request Types for Account
- Get Transaction Request by ID
- Get Transaction Requests
- Save Historical Transactions
- Update Transaction Request Attribute
- Update Transaction Request Status
 
- 
                        User- 
                                    The entity that accesses the API with a login / authorisation token and has access to zero or moreMore...
- Answer User Auth Context Update Challenge
- Create My Personal User Attribute
- Create Non Personal User Attribute
- Create User
- Create User Auth Context
- Create User Auth Context Update Request
- Create password reset url
- Delete Non Personal User Attribute
- Delete User Auth Context
- Delete User's Auth Contexts
- Delete a User
- Get Logout Link
- Get My Personal User Attributes
- Get My Spaces
- Get Non Personal User Attributes
- Get User (Current)
- Get User Auth Contexts
- Get User Id (Current)
- Get User Lock Status
- Get User by USERNAME
- Get User by USER_ID
- Get User with Attributes by USER_ID
- Get Users by Email Address
- Get all Users
- Lock the user
- Refresh User
- Sync User
- Unlock the user
- Update My Personal User Attribute
- Validate a user
 
- 
                                    
- 
                        API
                        - 
                                Create Bank Level Endpoint Tag
- 
                                Create System Level Endpoint Tag
- 
                                Delete Bank Level Endpoint Tag
- 
                                Delete System Level Endpoint Tag
- 
                                Get API Configuration
- 
                                Get API Info (root)
- 
                                Get API Tags
- 
                                Get Adapter Info
- 
                                Get Adapter Info for a bank
- 
                                Get Bank Level Endpoint Tags
- 
                                Get Connector Status (Loopback)
- 
                                Get JSON Web Key (JWK)
- 
                                Get JSON Web Key (JWK) URIs
- 
                                Get Log Cache
- 
                                Get Mapper Database Info
- 
                                Get Rate Limiting Info
- 
                                Get Suggested Session Timeout
- 
                                Get System Level Endpoint Tags
- 
                                Get Well Known URIs
- 
                                Get the Call Context of a current call
- 
                                Update Bank Level Endpoint Tag
- 
                                Update System Level Endpoint Tag
- 
                                Verify Request and Sign Response of a current call
- 
                                Waiting For Godot
 
 
- 
                                Create Bank Level Endpoint Tag
- 
                        ATM
                        - 
                                Create ATM
- 
                                Create ATM Attribute
- 
                                Delete ATM
- 
                                Delete ATM Attribute
- 
                                Get ATM Attribute By ATM_ATTRIBUTE_ID
- 
                                Get ATM Attributes
- 
                                Get Bank ATM
- 
                                Get Bank ATMS
- 
                                Head Bank ATMS
- 
                                UPDATE ATM
- 
                                Update ATM Accessibility Features
- 
                                Update ATM Attribute
- 
                                Update ATM Location Categories
- 
                                Update ATM Notes
- 
                                Update ATM Services
- 
                                Update ATM Supported Currencies
- 
                                Update ATM Supported Languages
 
 
- 
                                Create ATM
- 
                        Account
                        - 
                                Check Available Funds
- 
                                Create Account (POST)
- 
                                Create Account (PUT)
- 
                                Create Account Attribute
- 
                                Create Bank Account Balance
- 
                                Create or Update Account Attribute Definition
- 
                                Delete Account Attribute Definition
- 
                                Delete Account Cascade
- 
                                Delete Bank Account Balance
- 
                                Get Account Access by USER_ID
- 
                                Get Account Attribute Definition
- 
                                Get Account Balances by BANK_ID
- 
                                Get Account Balances by BANK_ID and ACCOUNT_ID through the VIEW_ID
- 
                                Get Account Balances by BANK_ID through the VIEW_ID
- 
                                Get Account by Account Routing
- 
                                Get Account by Id (Core)
- 
                                Get Account by Id (Core) through the VIEW_ID
- 
                                Get Account by Id (Full)
- 
                                Get Accounts Held
- 
                                Get Accounts Held By User
- 
                                Get Accounts Held By User
- 
                                Get Accounts Minimal for a Customer
- 
                                Get Accounts at Bank
- 
                                Get Accounts at Bank (IDs only)
- 
                                Get Accounts at Bank (Minimal)
- 
                                Get Accounts at all Banks (private)
- 
                                Get Accounts by Account Routing Regex
- 
                                Get Agent
- 
                                Get Agents at Bank
- 
                                Get All Bank Account Balances
- 
                                Get Bank Account Balance By ID
- 
                                Get Checkbook orders
- 
                                Get Fast Firehose Accounts at Bank
- 
                                Get Firehose Accounts at Bank
- 
                                Update Account
- 
                                Update Account Attribute
- 
                                Update Account Label
- 
                                Update Bank Account Balance
- 
                                Validate and check IBAN
 
 
- 
                                Check Available Funds
- 
                        Account Access
                        
                        
 
- 
                        Account Application
                        - 
                                Create Account Application
- 
                                Get Account Application by Id
- 
                                Get Account Applications
- 
                                Update Account Application Status
 
 
- 
                                Create Account Application
- 
                        Account Metadata
                        
                        
 
- 
                        Account Public
                        
                        
 
- 
                        Api Collection
                        - 
                                Create My Api Collection
- 
                                Create My Api Collection Endpoint
- 
                                Create My Api Collection Endpoint By Id
- 
                                Delete My Api Collection
- 
                                Delete My Api Collection Endpoint
- 
                                Delete My Api Collection Endpoint By Id
- 
                                Delete My Api Collection Endpoint By Id
- 
                                Get All API Collections
- 
                                Get Api Collection Endpoints
- 
                                Get Api Collections for User
- 
                                Get Featured Api Collections
- 
                                Get My Api Collection By Id
- 
                                Get My Api Collection By Name
- 
                                Get My Api Collection Endpoint
- 
                                Get My Api Collection Endpoints
- 
                                Get My Api Collection Endpoints By Id
- 
                                Get My Api Collections
- 
                                Get Sharable Api Collection By Id
- 
                                Update My Api Collection By API_COLLECTION_ID
 
 
- 
                                Create My Api Collection
- 
                        Authentication Type Validation
                        - 
                                Create an Authentication Type Validation
- 
                                Delete an Authentication Type Validation
- 
                                Get all Authentication Type Validations
- 
                                Get all Authentication Type Validations - public
- 
                                Get an Authentication Type Validation
- 
                                Update an Authentication Type Validation
 
 
- 
                                Create an Authentication Type Validation
- 
                        Bank
                        - 
                                Create Bank
- 
                                Create Bank Attribute
- 
                                Create Settlement Account
- 
                                Create Transaction Type at bank
- 
                                Create or Update Bank Attribute Definition
- 
                                Delete Bank Attribute
- 
                                Delete Bank Cascade
- 
                                Get Bank
- 
                                Get Bank Attribute By BANK_ATTRIBUTE_ID
- 
                                Get Bank Attributes
- 
                                Get Banks
- 
                                Get Settlement accounts at Bank
- 
                                Get Transaction Types at Bank
- 
                                Update Bank
- 
                                Update Bank Attribute
 
 
- 
                                Create Bank
- 
                        Branch
                        
                        
 
- 
                        Card
                        - 
                                Create Card
- 
                                Create Card Attribute
- 
                                Create or Update Card Attribute Definition
- 
                                Delete Card
- 
                                Delete Card Attribute Definition
- 
                                Get Card Attribute Definition
- 
                                Get Card By Id
- 
                                Get Cards for the specified bank
- 
                                Get cards for the current user
- 
                                Get status of Credit Card order 
- 
                                Update Card
- 
                                Update Card Attribute
 
 
- 
                                Create Card
- 
                        Connector Method
                        - 
                                Create Connector Method
- 
                                Get Connector Method by Id
- 
                                Get all Connector Methods
- 
                                Update Connector Method
 
 
- 
                                Create Connector Method
- 
                        Consent
                        - 
                                Add User to a Consent
- 
                                Answer Consent Challenge
- 
                                Create Consent (EMAIL)
- 
                                Create Consent (IMPLICIT)
- 
                                Create Consent (IMPLICIT)
- 
                                Create Consent (SMS)
- 
                                Create Consent By CONSENT_REQUEST_ID (EMAIL)
- 
                                Create Consent By CONSENT_REQUEST_ID (IMPLICIT)
- 
                                Create Consent By CONSENT_REQUEST_ID (SMS)
- 
                                Create Consent Request
- 
                                Create Consent Request VRP
- 
                                Get Consent By Consent Id via Consumer
- 
                                Get Consent By Consent Id via User
- 
                                Get Consent By Consent Request Id via Consumer
- 
                                Get Consent Request
- 
                                Get Consents
- 
                                Get Consents at Bank
- 
                                Get My Consents
- 
                                Get My Consents Info
- 
                                Get My Consents Info At Bank
- 
                                Get My Consents at Bank
- 
                                Provide client's certificate info of a current call
- 
                                Revoke Consent at Bank
- 
                                Revoke Consent used in the Current Call
- 
                                Revoke My Consent
- 
                                Update Consent Account Access by CONSENT_ID
- 
                                Update Consent Status
- 
                                Update Consent Status by CONSENT_ID
- 
                                Update Created by User of Consent by CONSENT_ID
 
 
- 
                                Add User to a Consent
- 
                        Consumer
                        - 
                                Create a Consumer
- 
                                Create a Consumer
- 
                                Enable or Disable Consumers
- 
                                Get Call Limits for a Consumer
- 
                                Get Consumer
- 
                                Get Consumers
- 
                                Get Consumers (logged in User)
- 
                                Set Rate Limits / Call Limits per Consumer
- 
                                Update Consumer Certificate
- 
                                Update Consumer LogoURL
- 
                                Update Consumer Name
- 
                                Update Consumer RedirectURL
 
 
- 
                                Create a Consumer
- 
                        Counterparty
                        - 
                                Create Counterparty (Explicit)
- 
                                Create Counterparty for any account (Explicit)
- 
                                Delete Counterparty (Explicit)
- 
                                Delete Counterparty for any account (Explicit)
- 
                                Get Counterparties (Explicit)
- 
                                Get Counterparties for any account (Explicit)
- 
                                Get Counterparty by Id (Explicit)
- 
                                Get Counterparty by Id for any account (Explicit)
- 
                                Get Counterparty by name for any account (Explicit) 
- 
                                Get Other Account by Id
- 
                                Get Other Accounts of one Account
 
 
- 
                                Create Counterparty (Explicit)
- 
                        Counterparty Limits
                        - 
                                Create Counterparty Limit
- 
                                Delete Counterparty Limit
- 
                                Get Counterparty Limit
- 
                                Get Counterparty Limit Status
- 
                                Update Counterparty Limit
 
 
- 
                                Create Counterparty Limit
- 
                        Counterparty Metadata
                        - 
                                Add Corporate Location to Counterparty
- 
                                Add Counterparty More Info
- 
                                Add Open Corporates URL to Counterparty
- 
                                Add image url to other bank account
- 
                                Add physical location to other bank account
- 
                                Add public alias to other bank account
- 
                                Add url to other bank account
- 
                                Create Other Account Private Alias
- 
                                Delete Counterparty Corporate Location
- 
                                Delete Counterparty Image URL
- 
                                Delete Counterparty Open Corporates URL
- 
                                Delete Counterparty Physical Location
- 
                                Delete Counterparty Private Alias
- 
                                Delete Counterparty Public Alias
- 
                                Delete more info of other bank account
- 
                                Delete url of other bank account
- 
                                Get Other Account Metadata
- 
                                Get Other Account Private Alias
- 
                                Get public alias of other bank account
- 
                                Update Counterparty Corporate Location
- 
                                Update Counterparty Image Url
- 
                                Update Counterparty More Info
- 
                                Update Counterparty Physical Location
- 
                                Update Counterparty Private Alias
- 
                                Update Open Corporates Url of Counterparty
- 
                                Update public alias of other bank account
- 
                                Update url of other bank account
 
 
- 
                                Add Corporate Location to Counterparty
- 
                        Customer
                        - 
                                Create Address
- 
                                Create Agent
- 
                                Create Customer
- 
                                Create Customer Account Link
- 
                                Create Customer Attribute
- 
                                Create Customer Social Media Handle
- 
                                Create Tax Residence
- 
                                Create User Customer Link
- 
                                Create or Update Customer Attribute Definition
- 
                                Delete Customer Account Link
- 
                                Delete Customer Address
- 
                                Delete Customer Attribute
- 
                                Delete Customer Attribute Definition
- 
                                Delete Customer Cascade
- 
                                Delete Tax Residence
- 
                                Delete User Customer Link
- 
                                Get CRM Events
- 
                                Get Correlated Entities for the current User
- 
                                Get Correlated User Info by Customer
- 
                                Get Customer Account Link by Id
- 
                                Get Customer Account Links by ACCOUNT_ID
- 
                                Get Customer Account Links by CUSTOMER_ID
- 
                                Get Customer Addresses
- 
                                Get Customer Attribute By Id
- 
                                Get Customer Attribute Definition
- 
                                Get Customer Attributes
- 
                                Get Customer Overview
- 
                                Get Customer Overview Flat
- 
                                Get Customer Social Media Handles
- 
                                Get Customer by CUSTOMER_ID
- 
                                Get Customer by CUSTOMER_NUMBER
- 
                                Get Customers Minimal at Any Bank
- 
                                Get Customers Minimal at Bank
- 
                                Get Customers at Any Bank
- 
                                Get Customers at Bank
- 
                                Get Customers by Legal Name
- 
                                Get Customers by MOBILE_PHONE_NUMBER
- 
                                Get Customers for Current User
- 
                                Get Customers for Current User (IDs only)
- 
                                Get Firehose Customers
- 
                                Get My Customers
- 
                                Get My Customers at Bank
- 
                                Get Tax Residences of Customer
- 
                                Get User Customer Links by Customer
- 
                                Get User Customer Links by User
- 
                                Update Agent status
- 
                                Update Customer Account Link by Id
- 
                                Update Customer Attribute
- 
                                Update the Address of a Customer
- 
                                Update the Branch of a Customer
- 
                                Update the credit limit of a Customer
- 
                                Update the credit rating and source of a Customer
- 
                                Update the email of a Customer
- 
                                Update the identity data of a Customer
- 
                                Update the mobile number of a Customer
- 
                                Update the number of a Customer
- 
                                Update the other data of a Customer
 
 
- 
                                Create Address
- 
                        Customer Meeting
                        
                        
 
- 
                        Customer Message
                        - 
                                Create Customer Message
- 
                                Create Customer Message
- 
                                Get Customer Messages for a Customer
- 
                                Get Customer Messages for all Customers
 
 
- 
                                Create Customer Message
- 
                        Data Warehouse
                        
                        
 
- 
                        Direct Debit
                        
                        
 
- 
                        Directory
                        - 
                                Create Regulated Entity
- 
                                Create Regulated Entity Attribute
- 
                                Create a Consumer(Dynamic Registration)
- 
                                Delete Regulated Entity
- 
                                Delete Regulated Entity Attribute
- 
                                Get All Regulated Entity Attributes
- 
                                Get Regulated Entities
- 
                                Get Regulated Entity
- 
                                Get Regulated Entity Attribute By ID
- 
                                Update Regulated Entity Attribute
 
 
- 
                                Create Regulated Entity
- 
                        Documentation
                        - 
                                Get Bank Level Dynamic Resource Docs
- 
                                Get Glossary of the API
- 
                                Get Message Docs
- 
                                Get Message Docs Swagger
- 
                                Get Resource Docs
- 
                                Get Resource Docs
- 
                                Get Swagger documentation
- 
                                Get scanned API Versions
 
 
- 
                                Get Bank Level Dynamic Resource Docs
- 
                        Dynamic Endpoint Manage
                        - 
                                 Delete Bank Level Dynamic Endpoint
- 
                                 Delete Dynamic Endpoint
- 
                                 Get Bank Level Dynamic Endpoint
- 
                                 Get Dynamic Endpoints
- 
                                 Update Bank Level Dynamic Endpoint Host
- 
                                 Update Dynamic Endpoint Host
- 
                                Create Bank Level Dynamic Endpoint
- 
                                Create Dynamic Endpoint
- 
                                Delete My Dynamic Endpoint
- 
                                Get Bank Level Dynamic Endpoints
- 
                                Get Dynamic Endpoint
- 
                                Get My Dynamic Endpoints
 
 
- 
                                 Delete Bank Level Dynamic Endpoint
- 
                        Dynamic Entity Manage
                        - 
                                Create Bank Level Dynamic Entity
- 
                                Create System Level Dynamic Entity
- 
                                Delete Bank Level Dynamic Entity
- 
                                Delete My Dynamic Entity
- 
                                Delete System Level Dynamic Entity
- 
                                Get Bank Level Dynamic Entities
- 
                                Get My Dynamic Entities
- 
                                Get System Dynamic Entities
- 
                                Update Bank Level Dynamic Entity
- 
                                Update My Dynamic Entity
- 
                                Update System Level Dynamic Entity
 
 
- 
                                Create Bank Level Dynamic Entity
- 
                        Dynamic Message Doc
                        - 
                                Create Bank Level Dynamic Message Doc
- 
                                Create Dynamic Message Doc
- 
                                Delete Bank Level Dynamic Message Doc
- 
                                Delete Dynamic Message Doc
- 
                                Get Bank Level Dynamic Message Doc
- 
                                Get Dynamic Message Doc
- 
                                Get all Bank Level Dynamic Message Docs
- 
                                Get all Dynamic Message Docs
- 
                                Update Bank Level Dynamic Message Doc
- 
                                Update Dynamic Message Doc
 
 
- 
                                Create Bank Level Dynamic Message Doc
- 
                        Dynamic Resource Doc
                        - 
                                A test endpoint
- 
                                Create Bank Level Dynamic Resource Doc
- 
                                Create Dynamic Resource Doc
- 
                                Create Dynamic Resource Doc endpoint code
- 
                                Delete Bank Level Dynamic Resource Doc
- 
                                Delete Dynamic Resource Doc
- 
                                Get Bank Level Dynamic Resource Doc by Id
- 
                                Get Dynamic Resource Doc by Id
- 
                                Get all Bank Level Dynamic Resource Docs
- 
                                Get all Dynamic Resource Docs
- 
                                Update Bank Level Dynamic Resource Doc
- 
                                Update Dynamic Resource Doc
 
 
- 
                                A test endpoint
- 
                        Endpoint Mapping
                        - 
                                Create Bank Level Endpoint Mapping
- 
                                Create Endpoint Mapping
- 
                                Delete Bank Level Endpoint Mapping
- 
                                Delete Endpoint Mapping
- 
                                Get Bank Level Endpoint Mapping
- 
                                Get Endpoint Mapping by Id
- 
                                Get all Bank Level Endpoint Mappings
- 
                                Get all Endpoint Mappings
- 
                                Update Bank Level Endpoint Mapping
- 
                                Update Endpoint Mapping
 
 
- 
                                Create Bank Level Endpoint Mapping
- 
                        FX
                        
                        
 
- 
                        JSON Schema Validation
                        - 
                                Create a JSON Schema Validation
- 
                                Delete a JSON Schema Validation
- 
                                Get a JSON Schema Validation
- 
                                Get all JSON Schema Validations
- 
                                Get all JSON Schema Validations - public
- 
                                Update a JSON Schema Validation
 
 
- 
                                Create a JSON Schema Validation
- 
                        KYC
                        - 
                                Add KYC Check
- 
                                Add KYC Document
- 
                                Add KYC Media
- 
                                Add KYC Status
- 
                                Get Customer KYC Checks
- 
                                Get Customer KYC Documents
- 
                                Get Customer KYC statuses
- 
                                Get KYC Media for a customer
 
 
- 
                                Add KYC Check
- 
                        Method Routing
                        
                        
 
- 
                        Metric
                        - 
                                Get Aggregate Metrics
- 
                                Get Connector Metrics
- 
                                Get Metrics
- 
                                Get Metrics at Bank
- 
                                Get Top APIs
- 
                                Get Top Consumers
- 
                                Search API Metrics via Elasticsearch
 
 
- 
                                Get Aggregate Metrics
- 
                        Product
                        - 
                                Create Product
- 
                                Create Product Attribute
- 
                                Create Product Fee
- 
                                Create or Update Product Attribute Definition
- 
                                Delete Product Attribute
- 
                                Delete Product Attribute Definition
- 
                                Delete Product Cascade
- 
                                Delete Product Fee
- 
                                Get Bank Product
- 
                                Get Product Attribute
- 
                                Get Product Attribute Definition
- 
                                Get Product Fee
- 
                                Get Product Fees
- 
                                Get Product Tree
- 
                                Get Products
- 
                                Update Product Attribute
- 
                                Update Product Fee
 
 
- 
                                Create Product
- 
                        Product Collection
                        
                        
 
- 
                        Role
                        - 
                                Add Entitlement for a User
- 
                                Create (DAuth) User with Roles
- 
                                Create Entitlement Request for current User
- 
                                Delete Entitlement
- 
                                Delete Entitlement Request
- 
                                Get Entitlement Requests for a User
- 
                                Get Entitlement Requests for the current User
- 
                                Get Entitlements and Permissions for a User
- 
                                Get Entitlements for One Bank
- 
                                Get Entitlements for User
- 
                                Get Entitlements for User at Bank
- 
                                Get Entitlements for the current User
- 
                                Get Roles
- 
                                Get all Entitlement Requests
- 
                                Get all Entitlements
 
 
- 
                                Add Entitlement for a User
- 
                        Sandbox
                        
                        
 
- 
                        Scope
                        
                        
 
- 
                        Standing Order
                        
                        
 
- 
                        System Integrity
                        - 
                                Check Custom View Names
- 
                                Check System View Names
- 
                                Check Unique Index at Account Access
- 
                                Check for Orphaned Accounts
- 
                                Check for Sensible Currencies
 
 
- 
                                Check Custom View Names
- 
                        Transaction
                        - 
                                Create Transaction Attribute
- 
                                Create or Update Transaction Attribute Definition
- 
                                Delete Transaction Attribute Definition
- 
                                Delete Transaction Cascade
- 
                                Get Balancing Transaction
- 
                                Get Double Entry Transaction
- 
                                Get Firehose Transactions for Account
- 
                                Get Other Account of Transaction
- 
                                Get Transaction Attribute By Id
- 
                                Get Transaction Attribute Definition
- 
                                Get Transaction Attributes
- 
                                Get Transaction by Id
- 
                                Get Transactions for Account (Core)
- 
                                Get Transactions for Account (Full)
- 
                                Update Transaction Attribute
 
 
- 
                                Create Transaction Attribute
- 
                        Transaction Metadata
                        - 
                                Add a Transaction Comment
- 
                                Add a Transaction Image
- 
                                Add a Transaction Narrative
- 
                                Add a Transaction Tag
- 
                                Add a Transaction where Tag
- 
                                Delete a Transaction Comment
- 
                                Delete a Transaction Image
- 
                                Delete a Transaction Narrative
- 
                                Delete a Transaction Tag
- 
                                Delete a Transaction Tag
- 
                                Get Transaction Comments
- 
                                Get Transaction Images
- 
                                Get Transaction Tags
- 
                                Get a Transaction Narrative
- 
                                Get a Transaction where Tag
- 
                                Update a Transaction Narrative
- 
                                Update a Transaction where Tag
 
 
- 
                                Add a Transaction Comment
- 
                        Transaction Request
                        - 
                                Answer Transaction Request Challenge
- 
                                Create Historical Transactions 
- 
                                Create Transaction Request (ACCOUNT)
- 
                                Create Transaction Request (ACCOUNT_OTP)
- 
                                Create Transaction Request (AGENT_CASH_WITHDRAWAL)
- 
                                Create Transaction Request (CARD)
- 
                                Create Transaction Request (COUNTERPARTY)
- 
                                Create Transaction Request (FREE_FORM)
- 
                                Create Transaction Request (REFUND)
- 
                                Create Transaction Request (SANDBOX_TAN)
- 
                                Create Transaction Request (SEPA)
- 
                                Create Transaction Request (SIMPLE)
- 
                                Create Transaction Request Attribute
- 
                                Create or Update Transaction Request Attribute Definition
- 
                                Delete Transaction Request Attribute Definition
- 
                                Get Transaction Request
- 
                                Get Transaction Request Attribute By Id
- 
                                Get Transaction Request Attribute Definition
- 
                                Get Transaction Request Attributes
- 
                                Get Transaction Request Types at Bank
- 
                                Get Transaction Request Types for Account
- 
                                Get Transaction Request by ID
- 
                                Get Transaction Requests
- 
                                Save Historical Transactions 
- 
                                Update Transaction Request Attribute
- 
                                Update Transaction Request Status
 
 
- 
                                Answer Transaction Request Challenge
- 
                        User
                        - 
                                Answer User Auth Context Update Challenge
- 
                                Create My Personal User Attribute
- 
                                Create Non Personal User Attribute
- 
                                Create User
- 
                                Create User Auth Context
- 
                                Create User Auth Context Update Request
- 
                                Create password reset url
- 
                                Delete Non Personal User Attribute
- 
                                Delete User Auth Context
- 
                                Delete User's Auth Contexts
- 
                                Delete a User
- 
                                Get Logout Link
- 
                                Get My Personal User Attributes
- 
                                Get My Spaces
- 
                                Get Non Personal User Attributes
- 
                                Get User (Current)
- 
                                Get User Auth Contexts
- 
                                Get User Id (Current)
- 
                                Get User Lock Status
- 
                                Get User by USERNAME
- 
                                Get User by USER_ID
- 
                                Get User with Attributes by USER_ID
- 
                                Get Users by Email Address
- 
                                Get all Users
- 
                                Lock the user
- 
                                Refresh User
- 
                                Sync User
- 
                                Unlock the user
- 
                                Update My Personal User Attribute
- 
                                Validate a user
 
 
- 
                                Answer User Auth Context Update Challenge
- 
                        User Invitation
                        
                        
 
- 
                        View Custom
                        - 
                                Create Custom View
- 
                                Create Custom View
- 
                                Delete Custom View
- 
                                Delete Custom View
- 
                                Get Account access for User
- 
                                Get Custom View
- 
                                Get Views for Account
- 
                                Get access
- 
                                Update Custom View
- 
                                Update Custom View
 
 
- 
                                Create Custom View
- 
                        View System
                        - 
                                Add Permission to a System View
- 
                                Create System View
- 
                                Delete Permission to a System View
- 
                                Delete System View
- 
                                Get Ids of System Views
- 
                                Get System View
- 
                                Update System View
 
 
- 
                                Add Permission to a System View
- 
                        WebUi Props
                        
                        
 
- 
                        Webhook
                        - 
                                Create an Account Webhook
- 
                                Create bank level Account Notification Webhook
- 
                                Create system level Account Notification Webhook
- 
                                Enable/Disable an Account Webhook
- 
                                Get Account Webhooks
 
 
- 
                                Create an Account Webhook
v5.1.0 (569 APIs)
 
                                    Add Entitlement for a User
                                    
                                
                                
                            
                            Create Entitlement. Grant Role to User.
Entitlements are used to grant System or Bank level roles to Users. (For Account level privileges, see Views)
For a System level Role (.e.g CanGetAnyUser), set bank_id to an empty string i.e. "bank_id":""
For a Bank level Role (e.g. CanCreateAccount), set bank_id to a valid value e.g. "bank_id":"my-bank-id"
Authentication is required and the user needs to be a Super Admin. Super Admins are listed in the Props file.
User Authentication is Required. The User must be logged in. The Application must also be authenticated.
URL Parameters:
USER_ID: 9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1
JSON request body fields:
bank_id: gh.29.uk
JSON response body fields:
bank_id: gh.29.uk
								
									{
  "entitlement_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
  "role_name":"CanQueryOtherUser",
  "bank_id":"gh.29.uk"
}
								
							
                                -  
                                            CanCreateEntitlementAtOneBank
                                             - Please login to request this Role
                                            
-  
                                            CanCreateEntitlementAtAnyBank
                                             - Please login to request this Role
                                            
- Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-20005: User not found. Please specify a valid value for USER_ID.
- OBP-20050: Current User is not a Super Admin!
- OBP-10001: Incorrect json format.
- OBP-10007: Incorrect Role name:
- OBP-30205: This entitlement is a Bank Role. Please set bank_id to a valid bank id.
- OBP-30206: This entitlement is a System Role. Please set bank_id to empty string.
- OBP-30216: Entitlement already exists for the user.
- OBP-50000: Unknown Error.
- OBP-20006: User is missing one or more roles:
 
                                    Create (DAuth) User with Roles
                                    
                                
                                
                            
                            This endpoint is used as part of the DAuth solution to grant Entitlements for Roles to a smart contract on the blockchain.
Put the smart contract address in username
For provider use "dauth"
This endpoint will create the User with username and provider if the User does not already exist.
Then it will create Entitlements i.e. grant Roles to the User.
Entitlements are used to grant System or Bank level roles to Users. (For Account level privileges, see Views)
i.e. Entitlements are used to create / consume system or bank level resources where as views / account access are used to consume / create customer level resources.
For a System level Role (.e.g CanGetAnyUser), set bank_id to an empty string i.e. "bank_id":""
For a Bank level Role (e.g. CanCreateAccount), set bank_id to a valid value e.g. "bank_id":"my-bank-id"
Note: The Roles actually granted will depend on the Roles that the calling user has.
If you try to grant Entitlements to a user that already exist (duplicate entitilements) you will get an error.
For information about DAuth see below:
DAuth
DAuth Introduction, Setup and Usage
DAuth is an experimental authentication mechanism that aims to pin an ethereum or other blockchain Smart Contract to an OBP "User".
In the future, it might be possible to be more specific and pin specific actors (wallets) that are acting within the smart contract, but so far, one smart contract acts on behalf of one User.
Thus, if a smart contract "X" calls the OBP API using the DAuth header, OBP will get or create a user called X and the call will proceed in the context of that User "X".
DAuth is invoked by the REST client (caller) including a specific header (see step 3 below) in any OBP REST call.
When OBP receives the DAuth token, it creates or gets a User with a username based on the smart_contract_address and the provider based on the network_name. The combination of username and provider is unique in OBP.
If you are calling OBP-API via an API3 Airnode, the Airnode will take care of constructing the required header.
When OBP detects a DAuth header / token it first checks if the Consumer is allowed to make such a call. OBP will validate the Consumer ip address and signature etc.
Note: The DAuth flow does not require an explicit POST like Direct Login to create the token.
Permissions may be assigned to an OBP User at any time, via the UserAuthContext, Views, Entitlements to Roles or Consents.
Note: DAuth is NOT enabled on this instance!
Note: The DAuth client is responsible for creating a token which will be trusted by OBP absolutely!
To use DAuth:
1) Configure OBP API to accept DAuth.
Set up properties in your props file
# -- DAuth --------------------------------------
# Define secret used to validate JWT token
# jwt.public_key_rsa=path-to-the-pem-file
# Enable/Disable DAuth communication at all
# In case isn't defined default value is false
# allow_dauth=false
# Define comma separated list of allowed IP addresses
# dauth.host=127.0.0.1
# -------------------------------------- DAuth--
Please keep in mind that property jwt.public_key_rsa is used to validate JWT token to check it is not changed or corrupted during transport.
2) Create / have access to a JWT
The following videos are available:
* DAuth in local environment
HEADER:ALGORITHM & TOKEN TYPE
{
  "alg": "RS256",
  "typ": "JWT"
}
PAYLOAD:DATA
{
  "smart_contract_address": "0xe123425E7734CE288F8367e1Bb143E90bb3F051224",
  "network_name": "AIRNODE.TESTNET.ETHEREUM",
  "msg_sender": "0xe12340927f1725E7734CE288F8367e1Bb143E90fhku767",
  "consumer_key": "0x1234a4ec31e89cea54d1f125db7536e874ab4a96b4d4f6438668b6bb10a6adb",
  "timestamp": "2021-11-04T14:13:40Z",
  "request_id": "0Xe876987694328763492876348928736497869273649"
}
VERIFY SIGNATURE
RSASHA256(
  base64UrlEncode(header) + "." +
  base64UrlEncode(payload),
) your-RSA-key-pair
Here is an example token:
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzbWFydF9jb250cmFjdF9hZGRyZXNzIjoiMHhlMTIzNDI1RTc3MzRDRTI4OEY4MzY3ZTFCYjE0M0U5MGJiM0YwNTEyMjQiLCJuZXR3b3JrX25hbWUiOiJFVEhFUkVVTSIsIm1zZ19zZW5kZXIiOiIweGUxMjM0MDkyN2YxNzI1RTc3MzRDRTI4OEY4MzY3ZTFCYjE0M0U5MGZoa3U3NjciLCJjb25zdW1lcl9rZXkiOiIweDEyMzRhNGVjMzFlODljZWE1NGQxZjEyNWRiNzUzNmU4NzRhYjRhOTZiNGQ0ZjY0Mzg2NjhiNmJiMTBhNmFkYiIsInRpbWVzdGFtcCI6IjIwMjEtMTEtMDRUMTQ6MTM6NDBaIiwicmVxdWVzdF9pZCI6IjBYZTg3Njk4NzY5NDMyODc2MzQ5Mjg3NjM0ODkyODczNjQ5Nzg2OTI3MzY0OSJ9.XSiQxjEVyCouf7zT8MubEKsbOBZuReGVhnt9uck6z6k
3) Try a REST call using the header
Using your favorite http client:
GET https://obp-api-sandbox.nmbbank.co.tz/obp/v3.0.0/users/current
Body
Leave Empty!
Headers:
   DAuth: your-jwt-from-step-above
Here is it all together:
GET https://obp-api-sandbox.nmbbank.co.tz/obp/v3.0.0/users/current HTTP/1.1
Host: localhost:8080
User-Agent: curl/7.47.0
Accept: /
DAuth: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzbWFydF9jb250cmFjdF9hZGRyZXNzIjoiMHhlMTIzNDI1RTc3MzRDRTI4OEY4MzY3ZTFCYjE0M0U5MGJiM0YwNTEyMjQiLCJuZXR3b3JrX25hbWUiOiJFVEhFUkVVTSIsIm1zZ19zZW5kZXIiOiIweGUxMjM0MDkyN2YxNzI1RTc3MzRDRTI4OEY4MzY3ZTFCYjE0M0U5MGZoa3U3NjciLCJjb25zdW1lcl9rZXkiOiIweDEyMzRhNGVjMzFlODljZWE1NGQxZjEyNWRiNzUzNmU4NzRhYjRhOTZiNGQ0ZjY0Mzg2NjhiNmJiMTBhNmFkYiIsInRpbWVzdGFtcCI6IjIwMjEtMTEtMDRUMTQ6MTM6NDBaIiwicmVxdWVzdF9pZCI6IjBYZTg3Njk4NzY5NDMyODc2MzQ5Mjg3NjM0ODkyODczNjQ5Nzg2OTI3MzY0OSJ9.XSiQxjEVyCouf7zT8MubEKsbOBZuReGVhnt9uck6z6k
CURL example
curl -v -H 'DAuth: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzbWFydF9jb250cmFjdF9hZGRyZXNzIjoiMHhlMTIzNDI1RTc3MzRDRTI4OEY4MzY3ZTFCYjE0M0U5MGJiM0YwNTEyMjQiLCJuZXR3b3JrX25hbWUiOiJFVEhFUkVVTSIsIm1zZ19zZW5kZXIiOiIweGUxMjM0MDkyN2YxNzI1RTc3MzRDRTI4OEY4MzY3ZTFCYjE0M0U5MGZoa3U3NjciLCJjb25zdW1lcl9rZXkiOiIweDEyMzRhNGVjMzFlODljZWE1NGQxZjEyNWRiNzUzNmU4NzRhYjRhOTZiNGQ0ZjY0Mzg2NjhiNmJiMTBhNmFkYiIsInRpbWVzdGFtcCI6IjIwMjEtMTEtMDRUMTQ6MTM6NDBaIiwicmVxdWVzdF9pZCI6IjBYZTg3Njk4NzY5NDMyODc2MzQ5Mjg3NjM0ODkyODczNjQ5Nzg2OTI3MzY0OSJ9.XSiQxjEVyCouf7zT8MubEKsbOBZuReGVhnt9uck6z6k' https://obp-api-sandbox.nmbbank.co.tz/obp/v3.0.0/users/current
You should receive a response like:
{
    "user_id": "4c4d3175-1e5c-4cfd-9b08-dcdc209d8221",
    "email": "",
    "provider_id": "0xe123425E7734CE288F8367e1Bb143E90bb3F051224",
    "provider": "ETHEREUM",
    "username": "0xe123425E7734CE288F8367e1Bb143E90bb3F051224",
    "entitlements": {
        "list": []
    }
}
Under the hood
The file, dauth.scala handles the DAuth,
We:
-> Check if Props allow_dauth is true
  -> Check if DAuth header exists
    -> Check if getRemoteIpAddress is OK
      -> Look for "token"
        -> parse the JWT token and getOrCreate the user
          -> get the data of the user
More information
Parameter names and values are case sensitive.
Each parameter MUST NOT appear more than once per request.
User Authentication is Required. The User must be logged in. The Application must also be authenticated.
JSON request body fields:
bank_id: gh.29.uk
provider: ETHEREUM
roles: CanCreateMyUser
username: felixsmith
JSON response body fields:
bank_id: gh.29.uk
list:
user_id: 9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1
								
									{
  "list":[{
    "entitlement_id":"",
    "role_name":"",
    "bank_id":"gh.29.uk",
    "user_id":"9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1"
  }]
}
								
							
                                - Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-10001: Incorrect json format.
- OBP-10007: Incorrect Role name:
- OBP-30205: This entitlement is a Bank Role. Please set bank_id to a valid bank id.
- OBP-30206: This entitlement is a System Role. Please set bank_id to empty string.
- OBP-30216: Entitlement already exists for the user.
- OBP-20103: Invalid DAuth User Provider.
- OBP-50000: Unknown Error.
 
                                    Create Entitlement Request for current User
                                    
                                
                                
                            
                            Create Entitlement Request.
Any logged in User can use this endpoint to request an Entitlement
Entitlements are used to grant System or Bank level roles to Users. (For Account level privileges, see Views)
For a System level Role (.e.g CanGetAnyUser), set bank_id to an empty string i.e. "bank_id":""
For a Bank level Role (e.g. CanCreateAccount), set bank_id to a valid value e.g. "bank_id":"my-bank-id"
User Authentication is Required. The User must be logged in. The Application must also be authenticated.
JSON request body fields:
bank_id: gh.29.uk
JSON response body fields:
bank_id: gh.29.uk
list:
provider: ETHEREUM
user:
user_id: 9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1
username: felixsmith
								
									{
  "entitlement_request_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
  "user":{
    "user_id":"9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1",
    "email":"felixsmith@example.com",
    "provider_id":"Chris",
    "provider":"http://127.0.0.1:8080",
    "username":"felixsmith",
    "entitlements":{
      "list":[{
        "entitlement_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
        "role_name":"CanQueryOtherUser",
        "bank_id":"gh.29.uk"
      }]
    }
  },
  "role_name":"CanQueryOtherUser",
  "bank_id":"gh.29.uk",
  "created":"1099-12-31T21:00:00Z"
}
								
							
                                - Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-20005: User not found. Please specify a valid value for USER_ID.
- OBP-10001: Incorrect json format.
- OBP-10007: Incorrect Role name:
- OBP-30205: This entitlement is a Bank Role. Please set bank_id to a valid bank id.
- OBP-30206: This entitlement is a System Role. Please set bank_id to empty string.
- OBP-30214: Entitlement Request already exists for the user.
- OBP-30217: Entitlement Request cannot be added.
- OBP-50000: Unknown Error.
 
                                    Delete Entitlement
                                    
                                
                                
                            
                            Delete Entitlement specified by ENTITLEMENT_ID for an user specified by USER_ID
Authentication is required and the user needs to be a Super Admin.
Super Admins are listed in the Props file.
User Authentication is Required. The User must be logged in. The Application must also be authenticated.
URL Parameters:
USER_ID: 9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1
JSON response body fields:
								
									
								
							
                                - Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-30212: EntitlementId not found
- OBP-50000: Unknown Error.
 
                                    Delete Entitlement Request
                                    
                                
                                
                            
                            Delete the Entitlement Request specified by ENTITLEMENT_REQUEST_ID for a user specified by USER_ID
User Authentication is Required. The User must be logged in. The Application must also be authenticated.
URL Parameters:
JSON response body fields:
								
									
								
							
                                -  
                                            CanDeleteEntitlementRequestsAtAnyBank
                                             - Please login to request this Role
                                            
- Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-50200: Connector cannot return the data we requested.
- OBP-50000: Unknown Error.
- OBP-20006: User is missing one or more roles:
 
                                    Get Entitlement Requests for a User
                                    
                                
                                
                            
                            Get Entitlement Requests for a User.
User Authentication is Required. The User must be logged in. The Application must also be authenticated.
URL Parameters:
USER_ID: 9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1
JSON response body fields:
bank_id: gh.29.uk
list:
provider: ETHEREUM
user:
user_id: 9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1
username: felixsmith
								
									{
  "entitlement_requests":[{
    "entitlement_request_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
    "user":{
      "user_id":"9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1",
      "email":"felixsmith@example.com",
      "provider_id":"Chris",
      "provider":"http://127.0.0.1:8080",
      "username":"felixsmith",
      "entitlements":{
        "list":[{
          "entitlement_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
          "role_name":"CanQueryOtherUser",
          "bank_id":"gh.29.uk"
        }]
      }
    },
    "role_name":"CanQueryOtherUser",
    "bank_id":"gh.29.uk",
    "created":"1099-12-31T21:00:00Z"
  }]
}
								
							
                                -  
                                            CanGetEntitlementRequestsAtAnyBank
                                             - Please login to request this Role
                                            
- Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-50200: Connector cannot return the data we requested.
- OBP-50000: Unknown Error.
- OBP-20006: User is missing one or more roles:
 
                                    Get Entitlement Requests for the current User
                                    
                                
                                
                            
                            								
									{
  "entitlement_requests":[{
    "entitlement_request_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
    "user":{
      "user_id":"9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1",
      "email":"felixsmith@example.com",
      "provider_id":"Chris",
      "provider":"http://127.0.0.1:8080",
      "username":"felixsmith",
      "entitlements":{
        "list":[{
          "entitlement_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
          "role_name":"CanQueryOtherUser",
          "bank_id":"gh.29.uk"
        }]
      }
    },
    "role_name":"CanQueryOtherUser",
    "bank_id":"gh.29.uk",
    "created":"1099-12-31T21:00:00Z"
  }]
}
								
							
                                - Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-50200: Connector cannot return the data we requested.
- OBP-50000: Unknown Error.
 
                                    Get Entitlements and Permissions for a User
                                    
                                
                                
                            
                            User Authentication is Required. The User must be logged in. The Application must also be authenticated.
URL Parameters:
USER_ID: 9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1
JSON response body fields:
account_id: 8ca8a7e4-6d02-40e3-a129-0b2bf89de9f0
bank_id: gh.29.uk
list:
provider: ETHEREUM
user_id: 9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1
username: felixsmith
view_id: owner
								
									{
  "user_id":"9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1",
  "email":"felixsmith@example.com",
  "provider_id":"Chris",
  "provider":"http://127.0.0.1:8080",
  "username":"felixsmith",
  "entitlements":{
    "list":[{
      "entitlement_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
      "role_name":"CanQueryOtherUser",
      "bank_id":"gh.29.uk"
    }]
  },
  "views":{
    "list":[{
      "bank_id":"gh.29.uk",
      "account_id":"8ca8a7e4-6d02-40e3-a129-0b2bf89de9f0",
      "view_id":"owner"
    }]
  }
}
								
							
                                -  
                                            CanGetEntitlementsForAnyUserAtAnyBank
                                             - Please login to request this Role
                                            
- Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-20057: User not found by userId.
- OBP-20006: User is missing one or more roles:
- OBP-50000: Unknown Error.
 
                                    Get Entitlements for One Bank
                                    
                                
                                
                            
                            								
									{
  "list":[{
    "entitlement_id":"",
    "role_name":"",
    "bank_id":"gh.29.uk",
    "user_id":"9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1"
  }]
}
								
							
                                -  
                                            CanGetEntitlementsForOneBank
                                             - Please login to request this Role
                                            
-  
                                            CanGetEntitlementsForAnyBank
                                             - Please login to request this Role
                                            
- Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-20006: User is missing one or more roles:
- OBP-50000: Unknown Error.
 
                                    Get Entitlements for User
                                    
                                
                                
                            
                            								
									{
  "list":[{
    "entitlement_id":"",
    "role_name":"",
    "bank_id":"gh.29.uk",
    "user_id":"9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1"
  }]
}
								
							
                                -  
                                            CanGetEntitlementsForAnyUserAtAnyBank
                                             - Please login to request this Role
                                            
- Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-20006: User is missing one or more roles:
- OBP-50000: Unknown Error.
 
                                    Get Entitlements for User at Bank
                                    
                                
                                
                            
                            								
									{
  "list":[{
    "entitlement_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
    "role_name":"CanQueryOtherUser",
    "bank_id":"gh.29.uk"
  }]
}
								
							
                                -  
                                            CanGetEntitlementsForAnyUserAtOneBank
                                             - Please login to request this Role
                                            
-  
                                            CanGetEntitlementsForAnyUserAtAnyBank
                                             - Please login to request this Role
                                            
- Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-20006: User is missing one or more roles:
- OBP-50000: Unknown Error.
 
                                    Get Entitlements for the current User
                                    
                                
                                
                            
                            								
									{
  "list":[{
    "entitlement_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
    "role_name":"CanQueryOtherUser",
    "bank_id":"gh.29.uk"
  }]
}
								
							
                                - Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-50200: Connector cannot return the data we requested.
- OBP-50000: Unknown Error.
 
                                    Get Roles
                                    
                                
                                
                            
                            								
									{
  "roles":[{
    "role":"CanCreateBranch",
    "requires_bank_id":true
  }]
}
								
							
                                - Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-50000: Unknown Error.
 
                                    Get all Entitlement Requests
                                    
                                
                                
                            
                            								
									{
  "entitlement_requests":[{
    "entitlement_request_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
    "user":{
      "user_id":"9ca9a7e4-6d02-40e3-a129-0b2bf89de9b1",
      "email":"felixsmith@example.com",
      "provider_id":"Chris",
      "provider":"http://127.0.0.1:8080",
      "username":"felixsmith",
      "entitlements":{
        "list":[{
          "entitlement_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
          "role_name":"CanQueryOtherUser",
          "bank_id":"gh.29.uk"
        }]
      }
    },
    "role_name":"CanQueryOtherUser",
    "bank_id":"gh.29.uk",
    "created":"1099-12-31T21:00:00Z"
  }]
}
								
							
                                -  
                                            CanGetEntitlementRequestsAtAnyBank
                                             - Please login to request this Role
                                            
- Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-50200: Connector cannot return the data we requested.
- OBP-50000: Unknown Error.
- OBP-20006: User is missing one or more roles:
 
                                    Get all Entitlements
                                    
                                
                                
                            
                            								
									{
  "list":[{
    "entitlement_id":"6fb17583-1e49-4435-bb74-a14fe0996723",
    "role_name":"CanQueryOtherUser",
    "bank_id":"gh.29.uk"
  }]
}
								
							
                                - Required JSON Validation: No
- Allowed Authentication Types: Not set
- OBP-20001: User not logged in. Authentication is required!
- OBP-50000: Unknown Error.

