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


" version: '1.1.0' title: 'API Bank Data Aggregation' termsOfService: 'https://developer.circulodecredito.com.mx/legal' contact: email: 'api@circulodecredito.com.mx' host: 'services.circulodecredito.com.mx' basePath: '/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' description: 'The Consumer Key assigned to the application you have registered in API Hub.' required: true type: 'string' username: in: 'header' name: 'username' description: 'Username of the inquiry user.' required: true type: 'string' password: in: 'header' name: 'password' description: 'Password of the inquiry user.' required: true type: 'string' x-signature_body: in: 'header' name: 'x-signature' description: 'Signature created with your private key (SHA256withECDSA - secp384r). API Hub verifies the signature matches with the request body using your public key. Your public key must be uploaded in the API Hub Portal Applications section.' required: true type: 'string' x-signature_url: in: 'header' name: 'x-signature' description: 'Signature created with your private key (SHA256withECDSA - secp384r). API Hub verifies the signature matches with the URL using your public key. Your public key must be uploaded in the API Hub Portal Applications section.' required: true type: 'string' 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/username' - $ref: '#/parameters/password' - $ref: '#/parameters/x-signature_url' - $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

' 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.

  1. Principal page elements
  2. Each element description as its icons.
  3. Terms and conditions text.
  4. 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: '

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.
ValueCurrency
MXMexican Pesos
USDollars
UDinvestment 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'