> ## Documentation Index
> Fetch the complete documentation index at: https://docs.didit.me/llms.txt
> Use this file to discover all available pages before exploring further.

# Mexico - INE credential validity verification

> Verifies a Mexican INE / IFE voter ID credential against the INE registry (modelo, vigencia, válida-como-identificación, derecho-a-votar). Authoritative real-time identity lookup for Mexico. Real-time lookup, pay-per-call.

<div hidden data-didit-db-validation-defaults="{&#x22;issuing_state&#x22;:&#x22;MEX&#x22;,&#x22;services&#x22;:&#x22;mex_ine_vigencia&#x22;,&#x22;cic&#x22;:&#x22;123456789&#x22;,&#x22;identificador_ciudadano&#x22;:&#x22;123456789&#x22;,&#x22;ocr&#x22;:&#x22;1234567890123&#x22;,&#x22;voter_number&#x22;:&#x22;ABCDEF123456&#x22;,&#x22;emission_number&#x22;:&#x22;01&#x22;,&#x22;first_name&#x22;:&#x22;John&#x22;,&#x22;last_name&#x22;:&#x22;Doe&#x22;,&#x22;date_of_birth&#x22;:&#x22;1990-01-01&#x22;,&#x22;vendor_data&#x22;:&#x22;user-1234&#x22;}" />

Verifies a Mexican INE / IFE voter ID credential against the INE registry (modelo, vigencia, válida-como-identificación, derecho-a-votar). Didit exposes this service through `POST /v3/database-validation/` so you can verify the submitted data against the authoritative source and receive normalized match results.

## Coverage

* **Coverage:** —
* **Country:** Mexico
* **Service ID:** `mex_ine_vigencia`
* **Data domain:** Identity
* **Category:** NationalIDRegistry

## Inputs

| Field                     | Required | Example         |
| ------------------------- | -------: | --------------- |
| `cic`                     |       No | `123456789`     |
| `identificador_ciudadano` |       No | `123456789`     |
| `ocr`                     |       No | `1234567890123` |
| `voter_number`            |       No | `ABCDEF123456`  |
| `emission_number`         |       No | `01`            |
| `first_name`              |       No | `John`          |
| `last_name`               |       No | `Doe`           |
| `date_of_birth`           |       No | `1990-01-01`    |
| `vendor_data`             |       No | `user-1234`     |

* **Required inputs:** —
* **Optional inputs:** `cic`, `identificador_ciudadano`, `ocr`, `voter_number`, `emission_number`, `first_name`, `last_name`, `date_of_birth`, `vendor_data`
* **Consent:** Not required
* **Workflow availability:** Available in workflow
* **Coverage:** —
* **Price:** \$0.20 per successful query

## Body parameters

<ParamField body="issuing_state" type="string" required default="MEX" placeholder="MEX">
  ISO 3166-1 alpha-3 country code for this database service.

  Example: `MEX`
</ParamField>

<ParamField body="services" type="string" required default="mex_ine_vigencia" placeholder="mex_ine_vigencia">
  Array containing this service ID. Pinning the service keeps the request scoped to this exact database.

  Example: `mex_ine_vigencia`
</ParamField>

<ParamField body="cic" type="string" default="123456789" placeholder="123456789">
  `cic` value required by this database service.

  Example: `123456789`
</ParamField>

<ParamField body="identificador_ciudadano" type="string" default="123456789" placeholder="123456789">
  `identificador_ciudadano` value required by this database service.

  Example: `123456789`
</ParamField>

<ParamField body="ocr" type="string" default="1234567890123" placeholder="1234567890123">
  `ocr` value required by this database service.

  Example: `1234567890123`
</ParamField>

<ParamField body="voter_number" type="string" default="ABCDEF123456" placeholder="ABCDEF123456">
  `voter_number` value required by this database service.

  Example: `ABCDEF123456`
</ParamField>

<ParamField body="emission_number" type="string" default="01" placeholder="01">
  `emission_number` value required by this database service.

  Example: `01`
</ParamField>

<ParamField body="first_name" type="string" default="John" placeholder="John">
  Given name to validate.

  Example: `John`
</ParamField>

<ParamField body="last_name" type="string" default="Doe" placeholder="Doe">
  Family name to validate.

  Example: `Doe`
</ParamField>

<ParamField body="date_of_birth" type="string" default="1990-01-01" placeholder="1990-01-01">
  Date of birth in `YYYY-MM-DD` format.

  Example: `1990-01-01`
</ParamField>

<ParamField body="vendor_data" type="string" default="user-1234" placeholder="user-1234">
  Your stable user reference for this person, such as your internal user ID. Didit uses it to link standalone checks to the same end user and reduce duplicate-detection noise.

  Example: `user-1234`
</ParamField>

## Input rules & validation notes

* Send the fields listed above exactly as captured from the user or document.
* Didit validates required fields before calling the database. Requests rejected before source lookup are not charged.

## How to call it

<RequestExample>
  ```bash cURL theme={null}
  curl -X POST "https://verification.didit.me/v3/database-validation/" \
    -H "x-api-key: YOUR_API_KEY" \
    -F "issuing_state=MEX" \
    -F "services=mex_ine_vigencia" \
    -F "vendor_data=user-1234"
  ```
</RequestExample>

<ResponseExample>
  Every successful call returns HTTP `200`. The **`outcome_code`** field tells you what actually happened — distinguishing, for example, a real biometric mismatch (`BIOMETRIC_NO_MATCH`) from a selfie that could not be read (`BIOMETRIC_IMAGE_UNUSABLE`). The `status` shown is the default feature status; your configured [Partial Match / No Match actions](/core-technology/database-validation/database-validation-warnings) can override it.

  **`MATCH`** — The registry confirmed the identity and every checked field matched.

  ```json 200 OK — MATCH theme={null}
  {
    "request_id": "req_01H…",
    "status": "Approved",
    "issuing_state": "MEX",
    "match_type": "full_match",
    "validations": [
      {
        "outcome_code": "MATCH",
        "service_id": "mex_ine_vigencia",
        "service_name": "Mexico - INE credential validity verification",
        "source_data": {
          "emission_number": "SAMPLE-12345",
          "emission_year": "sample_value",
          "expiration_date": "1990-01-01",
          "federal_district": "sample_value",
          "identification_number": "SAMPLE-ID-12345",
          "message": "sample_value",
          "message_code": "sample_value",
          "ocr": "sample_value",
          "registration_year": "sample_value",
          "validation_code": "SAMPLE-12345",
          "voter_number": "SAMPLE-12345"
        },
        "validation": {
          "identification_number": "full_match"
        }
      }
    ]
  }
  ```

  **`NO_MATCH`** — The registry returned no match for the submitted data.

  ```json 200 OK — NO_MATCH theme={null}
  {
    "request_id": "req_01H…",
    "status": "Declined",
    "issuing_state": "MEX",
    "match_type": "no_match",
    "validations": [
      {
        "outcome_code": "NO_MATCH",
        "service_id": "mex_ine_vigencia",
        "service_name": "Mexico - INE credential validity verification",
        "source_data": {
          "identification_number": "NO_MATCH"
        },
        "validation": {
          "identification_number": "no_match"
        }
      }
    ]
  }
  ```
</ResponseExample>

## Returned data

The exact fields surfaced in `source_data` depend on what the registry returns. The generated example for `mex_ine_vigencia` currently documents this normalized shape:

* `emission_number`
* `emission_year`
* `expiration_date`
* `federal_district`
* `identification_number`
* `message`
* `message_code`
* `ocr`
* `registration_year`
* `validation_code`
* `voter_number`

## Pricing & SLAs

Mexico - INE credential validity verification queries are billed only when Didit receives a conclusive result from the validation source.

* **Per-call price:** \$0.20 USD.
* **Billing:** per successful query. You are not charged when the registry is unreachable, when required fields are missing, or when the request is rejected before reaching the source.
* **Latency:** typical p95 \< 2 s.
* **Availability:** 99.9% per quarter on Didit's side; downstream source availability varies by country and dataset.

## Continue reading

* [Mexico Database Validation overview](/api-reference/database-validation/mexico)
* [Database Validation overview](/core-technology/database-validation/overview)
* [Outcome Codes](/core-technology/database-validation/database-validation-outcome-codes)
