swagger: '2.0'
info:
description: "This API simulates the aggregation of bank data from a source.

"
version: '1.2.0'
title: 'API Bank Data Aggregation Sandbox'
termsOfService: 'https://developer.circulodecredito.com.mx/legal-mx'
contact:
email: 'api@circulodecredito.com.mx'
host: 'services.circulodecredito.com.mx'
basePath: '/sandbox/v1/ada'
tags:
- name: 'ADA - API for Bank Data Aggregation'
externalDocs:
description: 'API Hub'
url: 'https://developer.circulodecredito.com.mx/en/products/ada'
schemes:
- 'https'
parameters:
x-api-key:
in: 'header'
name: 'x-api-key'
required: true
type: 'string'
description: 'The Consumer Key assigned to the client application you have registered in API Hub.'
inquiryId:
in: 'path'
name: 'inquiryId'
description: 'The identifier of the inquiry.'
required: true
type: 'string'
page:
in: 'query'
name: 'page'
description: 'Page to query.'
required: false
type: 'string'
perPage:
in: 'query'
name: 'perPage'
description: 'Rows per page.'
required: false
type: 'string'
startAt:
in: 'query'
name: 'startAt'
description: 'Initial date. As defined by date-time - RFC3339.'
required: false
type: 'string'
format: 'date-time'
endAt:
in: 'query'
name: 'endAt'
description: 'End date. As defined by date-time - RFC3339.'
required: false
type: 'string'
format: 'date-time'
inquiryStatus:
in: 'query'
name: 'inquiryStatus'
description: 'Inquiry status.'
enum: ["WAOIR", "NAOIR", "AOIR", "TEAOIR", "TEIR", "TENAEIR", "AEIR", "NAEIR", "NAEIRMR", "RJTIR", "RCVIR", "SN", "DN", "NDN", "CI", "EI"]
required: false
type: 'string'
successCheck:
in: 'query'
name: 'successCheck'
description: 'Inquiry process result.'
required: false
type: 'string'
subscriptionId:
in: 'path'
name: 'subscriptionId'
description: 'Inquiry process result.'
required: true
type: 'string'
format: 'uuid'
minLength: 36
maxLength: 36
paths:
'/bankdataaggregations/{inquiryId}':
parameters:
- $ref: '#/parameters/x-api-key'
- $ref: '#/parameters/inquiryId'
get:
summary: 'Returns the bank data aggregation process payload.'
description: 'Returns the bank data aggregation process payload associated with the inquiry. The inquiry is identified by the {inquiryId} path parameter.
Remember the inquiry status of every bank data aggregation process gives you more information about the process stage.
Inquiry Status
Waiting Authorization for Inquiry Request | WAOIR | Círculo de Crédito has begin the authorization and authentication process for the bank data aggregation inquiry request and it generated the widget URL in order to get the consumer consent. Círculo de Crédito is waiting for the consumer authorization. |
Not Authorized Inquiry Request | NAOIR | The consumer has refused the authorization for the bank data aggregation inquiry request. |
Authorized Inquiry Request | AOIR | The consumer has accepted the authorization for the bank data aggregation inquiry request. Círculo de Crédito is waiting for the consumer authentication process. |
Authenticated Inquiry Request | AEIR | The consumer has been authenticated in the source. |
Not Authenticated Inquiry Request | NAEIR | The consumer has not been authenticated in the source. Círculo de Crédito is waiting for a new authentication attempt. |
Not Authenticated Inquiry Request and Maximum Number of Unsuccessful Login Attempts Reached | NAEIRMR | The consumer has not been authenticated in the source and the maximum number of unsuccessful login attempts has reached. |
Received Inquiry Request | RCVIR | Círculo de Crédito is going to begin the bank data aggregation process. It has received the consumer consent through the authorization and authentication process. |
Rejected Inquiry Request | RJTIR | Círculo de Crédito could not begin the bank data aggregation process. The bank data aggregation inquiry process has been halted. |
Inquiry Request Token Expired | TEIR | The consumer has not accessed to the widget in order to give the consent to aggregate his bank data. The maximum time in order to get the consumer consent has been reached. |
Authorized Inquiry Request Token Expired | TEAOIR | The consumer has authorized the bank data aggregation inquiry request but the maximum time in order to authenticate him has been reached. |
Not Authenticated Inquiry Request Token Expired | TENAEIR | The consumer has gave his credentials to login the source but the try has failed. The maximum time in order to authenticate him has been reached. |
Sending Notification | SN | Círculo de Crédito has processed the bank inquiry request. Círculo de Crédito is sending the event notification through the API Hub. |
Delivered Notification | DN | Círculo de Crédito has finished the processing of the inquiry. Círculo de Crédito sent the notification to the customer through API Hub and it received the respective acknowledge. |
Not Delivered Notification | NDN | Círculo de Crédito has completed the processing of the inquiry. Círculo de Crédito tried to send the notification to the customer’s API on several times, however, it never got the acknowledge from the customer. |
Consumed Inquiry | CI | The customer has consumed the response payload associated with the inquiry regardless of the outcome of the notification process. |
Expired Inquiry | EI | The inquiry and the associated result have been archived. Only inquiries that have been made in the last 30 days will be shown. |
When you create a subscription in the Sandbox environment for listening to the API for Bank Data Aggregation "ada" event, we create some inquiries in order you could test this method.
You could get the payload from different inquiries in different bank data aggregation process stages (Inquiry Status).
Sandbox Use Cases
Use case | Inquiry Status | InquiryId |
Círculo de Crédito is waiting for consumer authorization for the bank data aggregation inquiry process associated with the {inquiryId}. | WAOIR | a3b914e9-c0fb-485a-ab46-a82f29560f3e |
The consumer has not authorized Círculo de Crédito to begin the bank data aggregation process associated with the {inquiryId} path parameter. | NAOIR | 09571e9d-4350-42b5-8fab-c2c304b57c0e |
The consumer has authorized Círculo de Crédito to begin the bank data aggregation process associated with the {inquiryId} path parameter. Círculo de Crédito is waiting for the consumer authentication process. | AOIR | df338dc4-1d71-4702-9181-c64f409342d0 |
The consumer has been authenticated by the source. Círculo de Crédito is going to complete the authorization and authentication process of the bank data aggregation inquiry request associated with the {inquiryId} path parameter. | AEIR | 8ff4d198-0abf-4df9-90ca-4b3d8e23fa47 |
The consumer has not been authenticated in the source. Círculo de Crédito is waiting for a new authentication attempt for the bank data aggregation inquiry request associated with the {inquiryId} path parameter. | NAEIR | 74b2f279-e9fe-4650-99f7-14f90ce91bb3 |
The consumer has not been authenticated in the source. The maximum number of unsuccessful login attempts has reached. | NAEIRMR | 1ee29873-6054-44ba-88fe-f63da2eb1d3c |
Círculo de Crédito has received the consumer consent through the authorization and authentication widget. The bank data aggregation process associated with the {inquiryId} path parameter has begun. | RCVIR | cd021c98-761c-472c-b80f-19f3a13ac476 |
Círculo de Crédito could not begin the bank data aggregation process associated with the {inquiryId} path parameter. The bank data aggregation inquiry process has been halted and Círculo de Crédito is going to notify this event. | RJTIR | 1b1c636d-1729-45df-8594-6de7d92131be |
The maximum time in order to authenticate the consumer has been reached. The inquiry request token associated with the {inquiryId} path parameter has expired. | TEIR | 8d62ca8c-4c8c-46c9-8d6d-f550324fa559 |
The maximum time in order to authenticate the consumer has been reached. The authorized inquiry request token associated with the {inquiry Is} path parameter has expired. | TEAOIR | 2c35d19e-bcaf-4146-a544-e11ba19f62e3 |
The maximum time in order to authenticate the consumer has been reached. The not authenticated inquiry request token associated with the {inquiryId} path parameter has expired. | TENAEIR | 88da1f56-083a-4a60-aefe-060ffb7eeee8 |
The customer has consumed the response payload associated with the bank data aggregation inquiry regardless of the outcome of the notification process. | CI | b686be8f-e59a-4c5c-871e-359ff7c543ec |
'
tags:
- 'ADA - API for Bank Data Aggregation'
operationId: 'getInquiry'
consumes:
- 'application/json'
produces:
- 'application/json'
responses:
'200':
description: 'OK - Returns the bank data aggregation process information.'
headers:
x-signature:
type: 'string'
description: 'HTTP API response payload signature, this header contain the digital signature of the payload response from the API, this must be used to validate the authenticity of the response.'
x-iv:
type: 'string'
description: 'Initialization Vector you will use to decrypt the payload of the banking information.'
schema:
$ref: '#/definitions/AckSuccessADAConsumption'
'400':
description: 'Bad request.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "400"
message: "Missign parameters {x-api-key}."
'401':
description: 'Unauthorized.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '401.1'
message: 'Unauthorized, invalid x-api-key.'
- code: '401.2'
message: 'Unauthorized, invalid credentials.'
- code: '401.3'
message: 'Unauthorized, you do not have the product.'
- code: '401.4'
message: 'Unauthorized, you do not have access to the resource.'
'403':
description: 'Forbidden.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '403.1'
message: 'We could not verify the signature, x-signature is invalid.'
'404':
description: 'Inquiry not found.'
schema:
$ref: '#/definitions/AckFailureADAConsumption'
examples:
application/json:
acknowledgeId: 45f53c81-04e0-42df-abd8-de217e2edf2a
dateTime: '2020-09-01T03:36:38Z'
operation: consume
message: The request has been consumed.
bankDataAggregation:
errors:
- code: '400'
message: The inquiry does not exist.
request:
bankDataAggregationRequestId: 23fa2ec7-3294-4aa4-ba65-a0f49a75bfc4
subscriptionId: 51752e30-eab2-4368-a4eb-ce5a34d90f04
inquiryId: a99c3501-7b3a-4b3e-8ca5-1e48225b8176
curp: PUPJ970229HDFZZG61
categorization: 'false'
inquiryStatus: DN
successCheck: false
'410':
description: 'Gone - The maximum time in order to obtain the payload has expired.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "410"
message: "The maximum time in order to obtain the payload has expired."
'425':
description: 'Too early - The bank data aggregation process associated with the {inquiryId} path parameter has not yet been completed.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "425"
message: "The bank data aggregation process associated with the {inquiryId} path parameter has not yet been completed."
'429':
description: 'Too many requests.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "429"
message: "Too many requests."
'500':
description: "Internal server error."
schema:
$ref: '#/definitions/AckFailureADAConsumption'
examples:
application/json:
acknowledgeId: 6a2224ec-1e48-4bbd-ba2c-1971dd783735
dateTime: '2020-09-01T05:32:41Z'
operation: consume
message: The request has been consumed.
bankDataAggregation:
errors:
- code: "500"
message: "There was an unexpected error, try again later."
- code: '500.1'
message: "The request could not be processed."
request:
bankDataAggregationRequestId: d029a1ba-3566-4361-834a-f44add8cc4f7
subscriptionId: 51752e30-eab2-4368-a4eb-ce5a34d90f04
inquiryId: 43d21139-e1fa-4768-8b78-79aa3ca1993f
curp: PUPJ970229HDFZZG70
categorization: 'false'
inquiryStatus: RCVIR
successCheck: false
'503':
description: "Service unavailable."
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "503"
message: "Service unavailable."
'/bankdataaggregations':
parameters:
- $ref: '#/parameters/x-api-key'
get:
summary: 'Returns the list of bank data aggregation processes you have requested.'
description: 'Returns the list of bank data aggregation processes you have requested. You could filter the rows by date using the {startAt} and {endAt} parameters. You could filter the rows by inquiry status using the {inquiryStatus} parameter and the process result using the {sucessCheck} parameter. You could use the {page} and {perPage} parameters in order to navigate through the list.'
tags:
- 'ADA - API for Bank Data Aggregation'
operationId: 'getBankDataAggregations'
consumes:
- 'application/json'
produces:
- 'application/json'
parameters:
- $ref: '#/parameters/page'
- $ref: '#/parameters/perPage'
- $ref: '#/parameters/startAt'
- $ref: '#/parameters/endAt'
- $ref: '#/parameters/inquiryStatus'
- $ref: '#/parameters/successCheck'
responses:
'200':
description: 'OK - Returns a bank data aggregation processes list.'
schema:
$ref: '#/definitions/BankDataAggregationMetadata'
'400':
description: 'Bad request.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "400"
message: "Missign parameters {x-api-key}."
'401':
description: 'Unauthorized.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '401.1'
message: 'Unauthorized, invalid x-api-key.'
- code: '401.2'
message: 'Unauthorized, invalid credentials.'
- code: '401.3'
message: 'Unauthorized, you do not have the product.'
- code: '401.4'
message: 'Unauthorized, you do not have access to the resource.'
'403':
description: 'Forbidden.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '403.1'
message: 'We could not verify the signature, x-signature is invalid.'
'404':
description: 'Not found.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "404"
message: "Page not found."
'429':
description: 'Too many requests.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "429"
message: "Too many requests."
'500':
description: "Internal server error."
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "500"
message: "There was an unexpected error, try again later."
'503':
description: "Service unavailable."
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "503"
message: "Service unavailable."
post:
summary: 'Requests a bank data aggregation inquiry.'
description: 'Request a person bank data aggregation process.
The Sandbox environment has several use cases you can use to prototype your app. In this document we only have shown some of them. Please go to https://developer.circulodecredito.com.mx/en/products/ada and download the Postman Collection with the complete data set.
Note: Replace the field${subscriptionId} with your subscription, likewise replace ${bankDataAggregationRequestId} with an unique UUID.
Sandbox Use Cases
Use case number | Description | JSON request | Credentials |
---|
1 | The person has two accounts shown in the home banking application. | {"curp": "SEPJ910101HVZNNL67", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "BBVA Bancomer - Clientes" username: "JUAN67" password: "CIRCULO567" password_2FA: "456889" |
2 | The person has only wrong password authentication. | {"curp": "DIPJ910101HVZNNL16", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | |
3 | The person has four accounts shown in the home banking application. | {"curp": "SEPJ910101HVZNNL65", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "BanCoppel - Personas" username: "JUAN65" password: "CIRCULO569" password_2FA: "6588" |
4 | The person has only one account shown in the home banking application. | {"curp": "TRPJ910101HVZNNL38", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "BanCoppel - Personas" username: "JUAN38" password: "CIRCULO571" password_2FA: "4448" |
5 | The person has only one account shown in the home banking application. | {"curp": "CUPJ910101HVZNNL44", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "Afirme - Personas" username: "JUAN44" password: "CIRCULO572" password_2FA: "55466" |
6 | The person has only one account shown in the home banking application. | {"curp": "SEPJ910101HVZNNL66", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "BBVA Bancomer - Clientes" username: "JUAN66" password: "CIRCULO573" password_2FA: "55685" |
7 | The person has two accounts shown in the home banking application. | {"curp": "TRPJ910101HVZNNL32", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "BanCoppel - Personas" username: "JUAN32" password: "CIRCULO574" password_2FA: "55887" |
8 | The person has only one account shown in the home banking application. | {"curp": "CUPJ910101HVZNNL48", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "Afirme - Personas" username: "JUAN48" password: "CIRCULO575" password_2FA: "47889" |
9 | The person has three accounts shown in the home banking application. | {"curp": "TRPJ910101HVZNNL37", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "Afirme - Personas" username: "JUAN37" password: "CIRCULO575" password_2FA: "54578" |
10 | The person has two accounts shown in the home banking application. | {"curp": "EÑPJ910101HVZNNL00", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "BanCoppel - Personas" username: "JUANÑ" password: "CIRCULO577" password_2FA: "54785" |
11 | The person has only one account shown in the home banking application. | {"curp": "TRPJ910102HVZNNL37", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "Afirme - Personas" username: "JUAN37" password: "CIRCULO578" password_2FA: "55569" |
12 | The person has only one account shown in the home banking application. | {"curp": "ONPJ910101HVZNNL11", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "Afirme - Personas" username: "JUAN11" password: "CIRCULO579" password_2FA: "55215" |
13 | The person has two accounts shown in the home banking application. | {"curp": "CIPJ910101HVZNNL56", "bankDataAggregationRequestId": "${bankDataAggregationRequestId}", "subscriptionId": "${subscriptionId}"} | Bank: "BBVA Bancomer - Clientes" username: "JUAN56" password: "CIRCULO580" password_2FA: "55225" |
'
tags:
- 'ADA - API for Bank Data Aggregation'
operationId: 'postBankDataAggregation'
consumes:
- 'application/json'
produces:
- 'application/json'
parameters:
- in: 'body'
name: 'request'
description: 'Input parameters in order to start a bank data aggregation process.'
required: true
schema:
$ref: '#/definitions/BankDataAggregation'
responses:
'200':
description: 'OK - Returns an bank data request acknowledge.'
schema:
$ref: '#/definitions/AckADARequest'
'400':
description: 'Bad request.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "400"
message: "Missign parameters {bankDataAggregationRequestId, subscriptionId, curp, categorization}"
'401':
description: 'Unauthorized.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '401.1'
message: 'Unauthorized, invalid x-api-key.'
- code: '401.2'
message: 'Unauthorized, invalid credentials.'
- code: '401.3'
message: 'Unauthorized, you do not have the product.'
- code: '401.4'
message: 'Unauthorized, you do not have access to the resource.'
'403':
description: 'Forbidden.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '403.1'
message: 'We could not verify the signature, x-signature is invalid.'
'429':
description: 'Too many requests.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "429"
message: "Too many requests."
'500':
description: "Internal server error."
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "500"
message: "There was an unexpected error, try again later."
'503':
description: "Service unavailable."
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "503"
message: "Service unavailable."
'/configurations':
parameters:
- $ref: '#/parameters/x-api-key'
post:
summary: 'Set the customization page.'
description: 'You can define the text and icons that will be display.
- Principal page elements
- Each element description as its icons.
- Terms and conditions text.
- Two Factor authetication page, only if it is neccessary.
Note: Check the description of each element for more information.
'
tags:
- 'ADA - API for Bank Data Aggregation'
operationId: 'postConfBankDataAggregation'
consumes:
- 'application/json'
produces:
- 'application/json'
parameters:
- in: 'body'
name: 'request'
description: 'subcriptionId and the configuration to set.'
required: true
schema:
$ref: '#/definitions/BankDataAggregationConfiguration'
responses:
'200':
description: 'OK - Returns an bank data request acknowledge.'
schema:
$ref: '#/definitions/AckBankDataAggregation'
'400':
description: 'Bad request.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "400.1"
message: "Incorrect data in the request."
'401':
description: 'Unauthorized.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '401.1'
message: 'Unauthorized, invalid x-api-key.'
- code: '401.2'
message: 'Unauthorized, invalid credentials.'
- code: '401.3'
message: 'Unauthorized, you do not have the product.'
- code: '401.4'
message: 'Unauthorized, you do not have access to the resource.'
'403':
description: 'Forbidden.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '403.1'
message: 'We could not verify the signature, x-signature is invalid.'
'404':
description: 'Not found.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '403.1'
message: 'The subscriptionId does not exist.'
'429':
description: 'Too many requests.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "429"
message: "Too many requests."
'500':
description: "Internal server error."
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "500"
message: "There was an unexpected error, try again later."
'503':
description: "Service unavailable."
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "503"
message: "Service unavailable."
'/configurations/{subscriptionId}':
parameters:
- $ref: '#/parameters/x-api-key'
- $ref: '#/parameters/subscriptionId'
get:
summary: 'Returns the bank data aggregation process payload.'
description: ''
tags:
- 'ADA - API for Bank Data Aggregation'
operationId: 'getConfBankDataAggregation'
consumes:
- 'application/json'
produces:
- 'application/json'
responses:
'200':
description: 'OK - Returns the bank data aggregation process information.'
schema:
$ref: '#/definitions/BankDataAggregationConfigurationResponse'
'400':
description: 'Bad request.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "400.2"
message: "Path variable not valid (uuid)"
'401':
description: 'Unauthorized.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '401.1'
message: 'Unauthorized, invalid x-api-key.'
- code: '401.2'
message: 'Unauthorized, invalid credentials.'
- code: '401.3'
message: 'Unauthorized, you do not have the product.'
- code: '401.4'
message: 'Unauthorized, you do not have access to the resource.'
'403':
description: 'Forbidden.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '403.1'
message: 'We could not verify the signature, x-signature is invalid.'
'404':
description: 'Not found.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: '403.1'
message: 'The subscriptionId does not exist.'
'429':
description: 'Too many requests.'
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "429"
message: "Too many requests."
'500':
description: "Internal server error."
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "500"
message: "There was an unexpected error, try again later."
'503':
description: "Service unavailable."
schema:
$ref: '#/definitions/Errors'
examples:
application/json:
errors:
- code: "503"
message: "Service unavailable."
definitions:
Account:
type: object
description: Accounts information
properties:
customers:
type: array
description: Array of customers document number
items:
type: string
currency:
type: string
description: Account ISO 4217 Currency Code
last_update:
type: string
description: Account last update. ISO 8601 date format
bank_id:
type: integer
description: Account bank ID number
balance:
type: number
description: Account balance. Amount in cents
format: 'float'
_id:
type: string
description: 'Account ID, IBAN number'
pattern: ^(.*)$
name:
type: string
description: Account name
creation_date:
type: string
description: 'Account creation date.
**Format**: YYYY-MM-DDTHH:MM:SS'
bank_name:
type: string
description: Account bank name
bank_group_id:
type: integer
description: Account bank group ID
AccountsObj:
type: object
properties:
id:
type: string
description: Linked customer IBAN number
pattern: ^(.*)$
participation:
type: string
description: Ownership of the customer in the account
AllAccounts:
type: 'object'
properties:
bankId:
description: 'Id of the bank.'
type: 'integer'
format: 'int32'
example: 300
name:
description: 'name of the bank.'
type: 'string'
minLength: 2
maxLength: 30
example: 'BBVA Bancomer'
accountId:
description: 'Id of the bank account, could be only a part.'
type: 'string'
minLength: 2
maxLength: 30
example: '0000000167'
firstMovement:
description: 'Format based on the internet standard, RFC3339 - 5.6'
type: 'string'
format: 'date'
example: '2020-11-24'
lastMovement:
description: 'Format based on the internet standard, RFC3339 - 5.6'
type: 'string'
format: 'date'
example: '2021-1-24'
participation:
description: 'Format based on the internet standard, RFC3339 - 5.6'
type: 'string'
example: 'titular'
currency:
$ref: '#/definitions/CurrencyCatalogue'
currentBalance:
type: 'number'
description: 'Field current balance'
format: 'float'
example: 5082
balancesAvg:
type: 'number'
description: 'Field average balance'
format: 'float'
example: 9865.67
minTotalBalance:
type: 'number'
description: 'Field average total balance'
format: 'float'
example: 6067
maxTotalBalance:
type: 'number'
description: 'Field current balance'
format: 'float'
example: 8190.45
totalIncomeAvg:
type: 'number'
description: 'Field average total income'
format: 'float'
example: 11137.67
totalExpenseAvg:
type: 'number'
description: 'Field average total expenses'
format: 'float'
example: -7665.33
AccountingSummary:
type: 'object'
properties:
startDate:
description: 'Format based on the internet standard, RFC3339 - 5.6'
type: 'string'
format: 'date'
example: '2020-11-24'
endDate:
description: 'Format based on the internet standard, RFC3339 - 5.6'
type: 'string'
format: 'date'
example: '2021-2-19'
firstMovement:
description: 'Format based on the internet standard, RFC3339 - 5.6'
type: 'string'
format: 'date'
example: '2020-11-24'
lastMovement:
description: 'Format based on the internet standard, RFC3339 - 5.6'
type: 'string'
format: 'date'
example: '2021-1-24'
currentBalance:
type: 'number'
description: 'Field current balance'
format: 'float'
example: 5082
balancesAvg:
type: 'number'
description: 'Field average balance'
format: 'float'
example: 9865.67
minTotalBalance:
type: 'number'
description: 'Field minimum total balance'
format: 'float'
example: 6067
maxTotalBalance:
type: 'number'
description: 'Field maximum total balance'
format: 'float'
example: 8190.45
totalIncomeAvg:
type: 'number'
description: 'Field average total income'
format: 'float'
example: 11137.67
totalExpenseAvg:
type: 'number'
description: 'Field average total expenses'
format: 'float'
example: -7665.33
summaryMonths:
type: 'array'
items:
$ref: '#/definitions/MonthlyAccountingSummary'
AckADARequest:
description: 'Acknowledge of a bank data aggregation process.'
type: 'object'
properties:
acknowledgeId:
type: 'string'
format: 'uuid'
minLength: 36
maxLength: 36
description: 'Ackknowledge identifier (UUID).'
readOnly: true
example: '627aa72a-c799-4abf-b98e-0c4838af9bd5'
dateTime:
type: 'string'
format: 'date-time'
readOnly: true
description: 'Date and time of the acknowledge. As defined by date-time - RFC3339.'
example: '2020-04-12T22:20:50.52Z'
operation:
description: 'Bank data aggregation operation.'
type: 'string'
enum:
- 'request'
- 'consumption'
readOnly: true
example: 'request'
message:
type: 'string'
maxLength: 120
description: 'Descriptive and human-readable message.'
readOnly: true
example: 'The bank data aggregation request has been received.'
qr:
type: 'string'
description: 'URL with the widget URL embed as QR code.'
example: 'https://widget-qr-url'
widget_url:
type: 'string'
description: 'Widget URL'
example: 'https://widget-url'
bankDataAggregationRequestId:
type: 'string'
format: 'uuid'
minLength: 36
maxLength: 36
description: 'The identifier of the bank data aggregation request given by the API consumer (UUID).'
example: '391d151f-1cac-44e7-a05b-79a1199621d6'
subscriptionId:
type: 'string'
format: 'uuid'
minLength: 36
maxLength: 36
description: 'The API Hub event subscription identifier (UUID).'
example: '7c8a0230-36e0-43f4-9b7a-581dc55ea9c3'
inquiryId:
type: 'string'
format: 'uuid'
minLength: 36
maxLength: 36
description: 'The bank data aggregation process identifier given by Círculo de Crédito.'
example: 'a19fb6b8-2677-44f2-9cd7-3b2f78bb6f8c'
readOnly: true
AckBankDataAggregation:
properties:
acknowledgeId:
type: 'string'
format: 'uuid'
minLength: 36
maxLength: 36
description: 'Ackknowledge identifier (UUID).'
readOnly: true
example: '627aa72a-c799-4abf-b98e-0c4838af9bd5'
dateTime:
type: 'string'
format: 'date-time'
readOnly: true
description: 'Date and time of the acknowledge. As defined by date-time - RFC3339.'
example: '2020-04-12T22:20:50.52Z'
operation:
description: 'Bank data aggregation operation.'
type: 'string'
enum:
- 'request'
- 'consumption'
readOnly: true
example: 'request'
message:
type: 'string'
maxLength: 120
description: 'Descriptive and human-readable message.'
readOnly: true
example: 'The bank data aggregation request has been received.'
AckFailureADAConsumption:
description: 'Acknowledge of an unsuccessful bank data aggregation process.'
type: 'object'
allOf:
- $ref: '#/definitions/AckBankDataAggregation'
properties:
bankDataAggregation:
$ref: '#/definitions/FailureADAConsumption'
AckSuccessADAConsumption:
description: 'Acknowledge of a successful bank data aggregation process.'
type: 'object'
allOf:
- $ref: '#/definitions/AckBankDataAggregation'
properties:
bankDataAggregation:
$ref: '#/definitions/SuccessADAConsumption'
BankDataAggregation:
description: 'Bank data aggregation information'
type: 'object'
allOf:
- $ref: '#/definitions/BankDataAggregationId'
required:
- 'bankDataAggregationRequestId'
- 'subscriptionId'
- 'curp'
- 'categorization'
properties:
curp:
type: 'string'
minLength: 18
maxLength: 18
description: 'Clave Única de Registro de población for its initials in Spanish (CURP)'
example: 'BADD110313HCMLNS09'
categorization:
type: 'string'
description: 'categorization description'
pattern: '^([Tt][Rr][Uu][Ee]|[Ff][Aa][Ll][Ss][Ee])$'
example: 'false'
inquiryStatus:
type: 'string'
description: 'Inquiry status.'
enum: ["WAOIR", "NAOIR", "AOIR", "TEAOIR", "TEIR", "TENAEIR", "AEIR", "NAEIR", "NAEIRMR", "RJTIR", "RCVIR", "SN", "DN", "NDN", "CI", "EI"]
example: 'DN'
readOnly: true
successCheck:
description: 'It is true if the bank data aggregation process ended successfully.'
type: 'boolean'
example: true
readOnly: true
BankDataAggregations:
description: 'A list of bank data aggregation processes.'
type: 'array'
items:
$ref: '#/definitions/BankDataAggregation'
BankDataAggregationId:
description: 'Identifier of the bank data aggregation process.'
type: 'object'
properties:
bankDataAggregationRequestId:
type: 'string'
format: 'uuid'
minLength: 36
maxLength: 36
description: 'The identifier of the bank data aggregation request given by the API consumer (UUID).'
example: '391d151f-1cac-44e7-a05b-79a1199621d6'
subscriptionId:
type: 'string'
format: 'uuid'
minLength: 36
maxLength: 36
description: 'The API Hub event subscription identifier (UUID).'
example: '7c8a0230-36e0-43f4-9b7a-581dc55ea9c3'
inquiryId:
type: 'string'
format: 'uuid'
minLength: 36
maxLength: 36
description: 'The bank data aggregation process identifier given by Círculo de Crédito.'
example: 'a19fb6b8-2677-44f2-9cd7-3b2f78bb6f8c'
readOnly: true
BankDataAggregationConfiguration:
type: 'object'
description: 'Bank data Agregation configuration'
properties:
subscriptionId:
type: 'string'
format: 'uuid'
minLength: 36
maxLength: 36
description: 'The API Hub event subscription identifier (UUID).'
example: '7c8a0230-36e0-43f4-9b7a-581dc55ea9c3'
configuration:
$ref: '#/definitions/ConfigurationRequest'
BankDataAggregationConfigurationResponse:
description: 'Acknowledge of a successful bank data aggregation process.'
type: 'object'
allOf:
- $ref: '#/definitions/AckBankDataAggregation'
properties:
configuration:
$ref: '#/definitions/ConfigurationRequest'
BankDataAggregationMetadata:
description: 'Metadata (paging information) of the list of bank data aggregation processes.'
type: 'object'
properties:
_metadata:
$ref: '#/definitions/Metadata'
inquiries:
$ref: '#/definitions/BankDataAggregations'
Card:
type: object
properties:
_id:
type: integer
description: Unnax ID for the card
partial_card_number:
type: string
description: Card PAN (last 4 digits)
account:
type: string
description: Account linked to the card if available
bank_id:
type: integer
description: Associated card bank ID number
bank_name:
type: string
description: Associated card bank name
currency:
type: string
description: Card ISO 4217 Currency Code
name:
type: string
description: Card name
credit_available:
type: number
description: Card available credit. Amount in cents
format: 'float'
credit_limit:
type: number
description: Card limit. Amount in cents
format: 'float'
type:
type: integer
description: |-
ID of the card type:
debit = 0
credit = 1
charge = 2 (prepaid card)
enum:
- 0
- 1
- 2
network:
type: string
description: 'Card brand (VISA, Mastercard, etc)'
creation_date:
type: string
description: 'Card creation date if available.
**Format**: YYYY-MM-DD'
format: date
expiration_date:
type: string
description: 'Card expiration date if available.
**Format**: YYYY-MM-DD'
format: date
active:
type: boolean
description: Card status. Active = true
last_update:
type: string
description: 'Card last update date.
**Format**: YYYY-MM-DD'
period_ending_date:
type: string
description: Period ending date (Fecha de corte)
payment_due_date:
type: string
description: Payment due date (Fecha límite de pago)
minimum_payment:
type: number
description: Minimum payment to avoid arrears
format: 'float'
payment_to_avoid_interest:
type: number
description: Total payment up to the period ending date. (Adeudado al corte)
format: 'float'
CurrencyCatalogue:
type: 'string'
description: 'Value | Currency |
---|
MX | Mexican Pesos |
US | Dollars |
UD | investment units |
'
minLength: 2
maxLength: 2
example: 'MX'
enum:
- 'MX'
- 'US'
- 'UD'
Customer:
type: object
properties:
_id:
type: string
description: Customer document id
address:
type: array
description: Array of customer address
items:
type: string
document:
type: string
description: Customer document id
birth_date:
type: string
description: 'Customer birth date.
**Format**: YYYY-MM-DD'
names:
type: string
description: Customer full name
phones:
type: array
description: Array of phone numbers
items:
type: string
emails:
type: array
description: Array of customer email
items:
type: string
accounts_obj:
type: array
items:
$ref: '#/definitions/AccountsObj'
ConfigurationRequest:
type: 'object'
description: 'Gives you the availability of custom the main page as you want according to your needs.'
properties:
principal:
$ref: '#/definitions/ConfigurationRequest_Principal'
descriptions:
$ref: '#/definitions/ConfigurationRequest_Descriptions'
terms_and_conditions:
$ref: '#/definitions/ConfigurationRequest_Terms_and_conditions'
success_info:
$ref: '#/definitions/ConfigurationRequest_Success_info'
twoFa:
$ref: '#/definitions/ConfigurationRequest_2fA'
login_screen:
$ref: '#/definitions/ConfigurationRequestLoginScreen'
ConfigurationRequest_Principal:
type: 'object'
description: ''
properties:
user_name:
type: 'string'
description: 'Commercial name that will be display below the card title.'
example: 'Círculo de Crédito'
authorization_statement:
type: 'string'
description: 'Text shown next to the commercial name.'
example: 'INT (CIF: ) solicita su permiso para realizar las siguientes acciones:'
user_logo:
type: 'string'
description: 'Contains the base64 value of the logo, it is necessary begin with "data:image/png;base64, "'
pattern: '(http(s?):)|([/|.|\w|\s])*\.(?:png|jpg|jpeg|gif|png|svg)'
example: ''
primary_color:
type: 'string'
description: 'An hexadecimal value that contains the primary colour of th page.'
pattern: '^#([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$'
example: '#0E1D36'
secondary_color:
type: 'string'
description: 'An hexadecimal value that contains the secondary colour of th page.'
pattern: '^#([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$'
example: '#ECB330'
third_color:
type: 'string'
description: 'An hexadecimal value that contains the third color'
pattern: '^#([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$'
example: '#ECB330'
fourth_color:
type: 'string'
description: 'An hexadecimal value that contains the third color'
pattern: '^#([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$'
example: '#ECB330'
ConfigurationRequest_Descriptions:
type: 'object'
description: ''
properties:
first_highlighted_icon:
$ref: '#/definitions/Icons'
first_highlighted_text:
type: 'string'
description: 'First text in the card body.'
example: 'Cumplimos con la directiva Europea PSD2.'
second_highlighted_icon:
$ref: '#/definitions/Icons'
second_highlighted_text:
type: 'string'
description: 'Second text in the card body.'
example: 'Sus datos son encriptados con la última tecnología.'
third_highlighted_icon:
$ref: '#/definitions/Icons'
third_highlighted_text:
type: 'string'
description: 'Third text in the card body.'
example: 'Sus datos personales están regulados por la Ley Orgánica de Protección de Datos de Carácter Personal (GDPR).'
fourth_highlighted_icon:
$ref: '#/definitions/Icons'
fourth_highlighted_text:
type: 'string'
description: ''
example: 'Entra con tus credenciales de acceso al banco para completar el proceso.'
ConfigurationRequest_Terms_and_conditions:
type: 'object'
description: ''
properties:
terms_and_conditions_label:
type: 'string'
description: 'Text that will be display as link to open the modal that contains the terms and conditions.'
example: 'Al continuar, acepto y confirmo que he leido los terminos y condiciones. Que los entiendo, acepto y quedo vinculado por ellos'
terms_and_conditions_title:
type: 'string'
description: 'Text of terms and conditions, that will be display when the modal is open.'
example: 'Terminos y condiciones'
terms_and_conditions:
type: 'string'
description: ''
example: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Etiam vehicula tellus sed faucibus lacinia. Aenean faucibus, est in sollicitudin dapibus, justo velit venenatis magna, et aliquet lacus turpis sed nisl. Vestibulum maximus ante mi, vitae congue ipsum mollis vitae. Integer non sem ornare, hendrerit risus in, egestas tellus. Nam orci lectus, scelerisque nec commodo nec, suscipit ut nisl. Ut eu euismod erat, a dictum mi. Etiam aliquam neque nec hendrerit faucibus. Phasellus placerat finibus porta.
Nunc faucibus arcu nec metus euismod congue. Maecenas rutrum justo elit. Nunc viverra elementum semper. Proin scelerisque, sem id aliquam semper, erat orci volutpat leo, eget suscipit lectus velit id velit. Proin mattis in quam nec tristique. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia curae; Nam ut mi ligula.
Pellentesque elementum neque et dui consequat convallis. Aliquam blandit non urna vel ultrices. Curabitur viverra gravida nunc eu auctor. Maecenas ac efficitur enim. Etiam molestie id nulla ut volutpat. Praesent eu dui ac sem volutpat commodo. Suspendisse convallis cursus mollis. Suspendisse condimentum lorem varius, pharetra neque sed, mattis arcu. In feugiat, nibh ac vestibulum varius, libero risus tempus nulla, sed convallis nulla neque ut velit. Mauris sed metus ligula. Vivamus molestie vehicula felis, nec aliquet justo rutrum sit amet. Pellentesque et efficitur tellus, in pretium sem. Donec euismod orci nisl, ut imperdiet risus fringilla eget. Aliquam accumsan et ipsum sed convallis. Curabitur eros nisi, porta ac lorem vel, viverra venenatis mauris.
Fusce aliquet turpis sed dui luctus molestie. Maecenas eget metus dignissim, consequat orci eget, gravida augue. Sed porttitor nibh erat, eu tempor enim pharetra in. Sed vehicula, dolor id ultricies faucibus, nunc erat elementum mi, in gravida augue elit quis libero. Nulla ac ex et tortor dictum iaculis fringilla id quam. In feugiat leo vel est iaculis, non accumsan purus gravida. Vivamus orci augue, dignissim ac pulvinar sit amet, blandit pulvinar ante. Suspendisse pellentesque nibh eget dignissim faucibus. Pellentesque eu pellentesque tortor. Fusce efficitur ligula ligula.
Aenean rhoncus elit id nibh porttitor, in dictum lectus porttitor. Mauris metus nulla, rhoncus at odio in, mollis porta urna. Sed vestibulum eros malesuada nulla varius, sit amet viverra est consectetur. Cras fringilla ornare sagittis. Ut et erat eu odio pulvinar dapibus nec sit amet risus. Nam blandit mollis urna, quis tincidunt diam ultricies non. Suspendisse id libero suscipit, viverra ligula nec, viverra odio.
'
terms_and_conditions_hidden:
type: 'boolean'
description: 'Flag to enable/disable the the Terms And Conditions view in the UI'
example: true
ConfigurationRequest_Success_info:
type: 'object'
description: ''
properties:
success_info_label:
type: 'string'
description: 'Text that will be displayed as link to open the mail with the PDF report.'
example: 'Continúa con el paso 2'
success_info_title:
type: 'string'
description: 'Addintional text for Step 2 description.'
example: 'desde el correo de confirmación'
success_footer:
type: 'string'
description: 'Text for the footer section of the widget'
example: 'Su solicitud ha finalizado exitosamente.'
show_bank_logo:
type: 'boolean'
description: 'Flag to enable/disable the bank logo in the login success section of the widget'
show_close_button:
type: 'boolean'
description: 'Flag to enable/disable the close button in the login success section of the widget'
success_image:
type: 'string'
description: 'The image that is shown in the login success section of the widget'
example: ''
ConfigurationRequest_2fA:
type: 'object'
description: ''
properties:
twoFa_highlighted_icon:
$ref: '#/definitions/Icons'
twoFa_highlighted_text:
type: 'string'
description: ''
example: 'Confirme la transacción introduciendo el código'
ConfigurationRequestLoginScreen:
type: 'object'
description: 'Configuration object for bank login widget section'
properties:
title:
type: 'string'
description: 'Bank login title'
example: 'Bank Login'
label:
type: 'string'
description: 'Bank login brief text description'
show_bank_logo:
type: 'boolean'
show_trust_badges:
type: 'boolean'
Error:
type: 'object'
description: 'Error'
readOnly: true
properties:
code:
type: 'string'
description: 'Error code.'
example: '400'
message:
type: 'string'
maxLength: 120
description: 'Descriptive and human-readable error message.'
example: 'External data source not available.'
Errors:
description: 'A list of errors.'
type: 'object'
properties:
errors:
description: 'List of errors.'
type: 'array'
items:
$ref: '#/definitions/Error'
FailureADAConsumption:
description: 'Information about a failed bank data aggregation process.'
type: 'object'
properties:
request:
$ref: '#/definitions/BankDataAggregation'
errors:
description: 'List of errors.'
type: 'array'
items:
$ref: '#/definitions/Error'
Icons:
description: 'A set of the icons available.'
type: 'string'
enum: ['fas fa-cog','far fa-star','fas fa-star','fas fa-user','fas fa-user-shield','fas fa-user-lock','fas fa-key','far fa-comment-dots','fas fa-edit','fas fa-credit-card']
example: 'far fa-star'
Links:
description: 'Pagination information.'
type: 'object'
properties:
self:
description: 'URL of this page.'
type: 'string'
readOnly: true
example: 'https://services.circulodecredito.com.mx/v1/ada/bankdataaggregations?page=7&perPage=15'
first:
description: 'URL of the first page.'
type: 'string'
readOnly: true
example: 'https://services.circulodecredito.com.mx/v1/ada/bankdataaggregations?page=1&perPage=15'
previous:
description: 'URL of the previous page.'
type: 'string'
readOnly: true
example: 'https://services.circulodecredito.com.mx/v1/ada/bankdataaggregations?page=6&perPage=15'
next:
description: 'URL of the next page.'
type: 'string'
readOnly: true
example: 'https://services.circulodecredito.com.mx/v1/ada/bankdataaggregations?page=8&perPage=15'
last:
description: 'URL of the last page.'
type: 'string'
readOnly: true
example: 'https://services.circulodecredito.com.mx/v1/ada/bankdataaggregations?page=12&perPage=15'
Metadata:
description: 'Pagination information.'
type: 'object'
properties:
page:
type: 'integer'
description: 'Current page.'
readOnly: true
example: 7
perPage:
type: 'integer'
description: 'Rows per page.'
readOnly: true
example: 15
pageCount:
type: 'integer'
description: 'Total number of pages.'
readOnly: true
example: 12
totalCount:
type: 'integer'
description: 'Total number of rows.'
readOnly: true
example: 175
links:
$ref: '#/definitions/Links'
MonthlyAccountingSummary:
type: 'object'
properties:
date:
description: 'Sumary date'
type: 'string'
example: '2020-11'
avgBalance:
type: 'number'
description: 'Field average balance'
format: 'float'
example: 9865.67
minBalance:
type: 'number'
description: 'Field minimum balance'
format: 'float'
example: 6067
maxBalance:
type: 'number'
description: 'Field maximum balance'
format: 'float'
example: 8190.45
totalIncome:
type: 'number'
description: 'Field total income'
format: 'float'
example: 11137.67
totalExpense:
type: 'number'
description: 'Field total expenses'
format: 'float'
example: -7665.33
transactions:
type: number
description: total transactions
example: 1
Person:
type: 'object'
description: 'Encrypted Bank Information.'
readOnly: true
properties:
customers:
description: 'List of customers.'
type: 'array'
items:
$ref: '#/definitions/Customer'
cards:
description: 'List of cards.'
type: 'array'
items:
$ref: '#/definitions/Card'
accounts:
description: 'List of accounts.'
type: 'array'
items:
$ref: '#/definitions/Account'
summary:
$ref: '#/definitions/AccountingSummary'
SuccessADAConsumption:
description: 'Information about a successful bank data aggregation process.'
type: 'object'
properties:
request:
$ref: '#/definitions/BankDataAggregation'
payload:
description: 'Payload encrypt'
example: 'OR8BkEcX/i+DQ2IxMkT2nmII3V8yvm1MInlQrBX4NcgmIA=='
#person:
#$ref: '#/definitions/Person'