🇹🇭 Thailand
Thailand National ID
Verifies input data against government agency sourced National ID. Authoritative real-time identity lookup for Thailand. Real-time lookup, pay-per-call.
POST
Verifies input data against government agency sourced National ID. 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: ~ 90%
- Country: Thailand
- Service ID:
tha_national_id - Data domain: Identity
- Category: NationalIDRegistry
Inputs
| Field | Required | Example |
|---|---|---|
first_name | Yes | John |
last_name | Yes | Doe |
date_of_birth | Yes | 1990-01-01 |
national_id | Yes | 1111111111111 |
address.street_1 | No | 123 Sample Street |
address.street_2 | No | Unit 4 |
address.city | No | Sample City |
address.region | No | Sample State |
address.postal_code | No | 10001 |
vendor_data | No | user-1234 |
- Required inputs:
first_name,last_name,date_of_birth,national_id - Optional inputs:
address.street_1,address.street_2,address.city,address.region,address.postal_code,vendor_data - Consent: Required
- Workflow availability: Available in workflow
- Coverage: ~ 90%
- Price: $0.16 per successful query
Body parameters
ISO 3166-1 alpha-3 country code for this database service.Example:
THAArray containing this service ID. Pinning the service keeps the request scoped to this exact database.Example:
tha_national_idExplicit end-user consent for this service.Example:
trueGiven name to validate.Example:
JohnFamily name to validate.Example:
DoeDate of birth in
YYYY-MM-DD format.Example: 1990-01-01National identity number for this service.Example:
1111111111111Structured residential address object. Use
street_1, street_2, city, region, postal_code, and country. A complete legacy address string is still accepted but not recommended.Example: {"street_1":"123 Sample Street","street_2":"Unit 4","city":"Sample City","region":"Sample State","postal_code":"10001","country":"US"}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-1234Input rules & validation notes
addressis optional for this service. You can send one completeaddressstring and Didit will split it into structured address elements when possible, or you can send the structured fields explicitly.national_idmust contain digits only; remove spaces, hyphens, and punctuation before sending the request.national_idmust be exactly 13 characters long.- For address services, send structured address fields instead of a single
addressstring when possible. address.street_1is the street address, including street number and street type.address.street_2is apartment, unit, building, floor, or extra address line. Send it only when you have it.address.cityis city, suburb, district, locality, or neighborhood.address.regionis state, province, region, or town.address.postal_codeis postcode or postal code.- Address-based database services require at least street address and postal code; requests rejected before source lookup are not charged.
How to call it
Returned data
The exact fields surfaced insource_data depend on what the registry returns. The generated example for tha_national_id currently documents this normalized shape:
address_match_scoredate_of_birthidentification_numbername_match_score
Pricing & SLAs
Thailand National ID queries are billed only when Didit receives a conclusive result from the validation source.- Per-call price: $0.16 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.