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

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.
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. |
'
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-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
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
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/x-api-key'
- $ref: '#/parameters/username'
- $ref: '#/parameters/password'
- $ref: '#/parameters/x-signature_url'
- $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.
Note: Replace the field${subscriptionId} with your subscription, likewise replace ${bankDataAggregationRequestId} with an unique UUID.
'
tags:
- 'ADA - API for Bank Data Aggregation'
operationId: 'postBankDataAggregation'
consumes:
- 'application/json'
produces:
- 'application/json'
parameters:
- $ref: '#/parameters/x-signature_body'
- $ref: '#/parameters/x-api-key'
- $ref: '#/parameters/username'
- $ref: '#/parameters/password'
- 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}"
'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:
- $ref: '#/parameters/x-signature_body'
- $ref: '#/parameters/x-api-key'
- $ref: '#/parameters/username'
- $ref: '#/parameters/password'
- 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/username'
- $ref: '#/parameters/password'
- $ref: '#/parameters/x-signature_url'
- $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'
allOf:
- $ref: '#/definitions/AckBankDataAggregation'
- $ref: '#/definitions/BankDataAggregationId'
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.'
qr:
type: 'string'
description: 'The URL where you can get the QR code to redirect to the Widget.'
readOnly: true
example: 'https://chart.googleapis.com/chart?cht=qr&chl=https://dnuzbcecnnq5t.cloudfront.net//sandbox/v1/ada/apiwidget?token=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpbnF1aXJ5SWQiOiI1MjY5OWIyOS0xNWQ2LTQyMTUtOWI4ZC02NWUxZGI1NWQ5YjAiLCJ4LWFwaS1rZXkiOiJ3eWdhYmFXVGxGVW1wZWdXYzBBTXNVQWhyVWUzdDJXdiIsImlzcyI6InVybjpcL1wvQXBpZ2VlLWVkZ2UtSldULXBvbGljeS1kZW1vbnN0cmF0aW9uIiwiY2xhaW0iOiJ7XCJkYXRhXCI6e1wiaW5mb1wiOlwiZGV0YWxsZXNcIn0iLCJpZCI6IjAwZmY0ZTc0LWM1YjctNDkxMi1hMGZiLTYzMWU4NDc4MzM4YiIsInN1YnNjcmlwdGlvbklkIjoiMDM1MGEwZTUtODQ5Yy00NTE4LTlmMmYtY2E2OWIxY2FhZjFlIiwiZXhwIjoxNjE0MTg5OTY2LCJpYXQiOjE2MTQxODkzNjYsImN1cnAiOiJCQUREMTEwMzEzSENNTE5TMDkiLCJqdGkiOiI5YmMxN2JjMi0xZTYxLTRkOTYtOTIzYi04Mjg1OTU0YTA1ZWMifQ.ARu5czXKp9YNcEebdbJINm6krzWxXQcCFIQvAE6oiyY&choe=UTF-8&chs=200x200&chld=L'
widget_url:
type: 'string'
description: 'Direct url to the Widget.'
readOnly: true
example: 'https://dnuzbcecnnq5t.cloudfront.net/?token=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpbnF1aXJ5SWQiOiI1MjY5OWIyOS0xNWQ2LTQyMTUtOWI4ZC02NWUxZGI1NWQ5YjAiLCJ4LWFwaS1rZXkiOiJ3eWdhYmFXVGxGVW1wZWdXYzBBTXNVQWhyVWUzdDJXdiIsImlzcyI6InVybjpcL1wvQXBpZ2VlLWVkZ2UtSldULXBvbGljeS1kZW1vbnN0cmF0aW9uIiwiY2xhaW0iOiJ7XCJkYXRhXCI6e1wiaW5mb1wiOlwiZGV0YWxsZXNcIn0iLCJpZCI6IjAwZmY0ZTc0LWM1YjctNDkxMi1hMGZiLTYzMWU4NDc4MzM4YiIsInN1YnNjcmlwdGlvbklkIjoiMDM1MGEwZTUtODQ5Yy00NTE4LTlmMmYtY2E2OWIxY2FhZjFlIiwiZXhwIjoxNjE0MTg5OTY2LCJpYXQiOjE2MTQxODkzNjYsImN1cnAiOiJCQUREMTEwMzEzSENNTE5TMDkiLCJqdGkiOiI5YmMxN2JjMi0xZTYxLTRkOTYtOTIzYi04Mjg1OTU0YTA1ZWMifQ.ARu5czXKp9YNcEebdbJINm6krzWxXQcCFIQvAE6oiyY'
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'
- $ref: '#/definitions/Errors'
properties:
bankDataAggregation:
$ref: '#/definitions/SuccessADAConsumption'
BankDataAggregation:
description: 'Bank data aggregation information'
type: 'object'
allOf:
- $ref: '#/definitions/BankDataAggregationId'
required:
- 'bankDataAggregationRequestId'
- 'subscriptionId'
- 'curp'
properties:
curp:
type: 'string'
minLength: 18
maxLength: 18
description: 'Clave Única de Registro de población for its initials in Spanish (CURP)'
example: 'BADD110313HCMLNS09'
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'
CurrencyCatalogue:
type: 'string'
description: 'Value | Currency |
---|
MX | Mexican Pesos |
US | Dollars |
UD | investment units |
'
minLength: 2
maxLength: 2
example: 'MX'
enum:
- 'MX'
- 'US'
- 'UD'
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'
twoFa:
$ref: '#/definitions/ConfigurationRequest_2fA'
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'
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.
'
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'
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'
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'
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'