Compare qualquer identidade. Contra a fonte que o emitiu.
Compare um nome, número de identificação ou morada com a fonte que o emitiu, mais de 1.000 registos, agências e telecomunicações através de uma única chamada. A partir de $0.05 por verificação, 500 gratuitas/mês.
Confiado por mais de 2.000 organizações em todo o mundo.
SSN$0.35
CPF$0.18
Aadhaar$0.12
DNI$0.28
My Number$0.30
RFC$0.25
NIN$0.20
Registos governamentais
Valide IDs em bases de dados nacionais em tempo real.
Confirme a pessoa e a sua identificação contra o registo oficial, SSN, RFC, CPF,
Aadhaar, NIN e mais de 60 outros registos nacionais. Preço publicado por país.
Como funciona
Do registo ao utilizador verificado em quatro passos.
Passo 01
Crie o fluxo de trabalho
Escolha as verificações que pretende, ID, prova de vida, correspondência facial, sanções, morada, idade, telefone, e-mail, perguntas personalizadas. Arraste-as para um fluxo no dashboard, ou publique o mesmo fluxo na nossa API. Crie ramificações com base em condições, execute testes A/B, sem necessidade de código.
Passo 02
Integre
Integre nativamente com o nosso SDK para Web, iOS, Android, React Native ou Flutter. Redirecione para uma página alojada. Ou simplesmente envie um link ao seu utilizador, por e-mail, SMS, WhatsApp, onde quiser. Escolha o que melhor se adapta à sua stack.
Passo 03
O utilizador passa pelo fluxo
A Didit aloja a câmara, as indicações de iluminação, a transição para o telemóvel e a acessibilidade. Enquanto o utilizador está no fluxo, avaliamos mais de 200 sinais de fraude em tempo real e verificamos cada campo contra fontes de dados autorizadas. Resultado em menos de dois segundos.
Passo 04
Recebe os resultados
Webhooks assinados em tempo real mantêm a sua base de dados sincronizada no momento em que um utilizador é aprovado, recusado ou enviado para revisão. Consulte a API a pedido. Ou abra a consola para inspecionar cada sessão, cada sinal e gerir os casos à sua maneira.
Criado para developers · Criado contra a fraude · Aberto por design
Seis funcionalidades. Uma feature flag. DATABASE_VALIDATION.
Cada funcionalidade abaixo é um toggle no mesmo módulo. Sem níveis de upsell, sem planos separados, sem chamadas adicionais, ative os serviços que pretende por fluxo de trabalho.
Registos civis, autoridades fiscais, cadernos eleitorais, agências de crédito, operadoras de telecomunicações, registos judiciais e verificação de morada, tudo acessível através de um único endpoint. Uma nova fonte é adicionada todos os meses e aparece automaticamente.
Escolha o domínio de dados que corresponde à fraude que está a combater. As verificações de registo civil derrotam identidades sintéticas. As verificações de agências de crédito confirmam o histórico. As verificações de telecomunicações confirmam uma linha ativa. A verificação de morada prova a residência.
FightingSynthetic identities
RegistryBureauTelcoCourtsAddress
Civil registry lookupRegistro Civil · ES
Querying…
NameMatch
Date of birthMatch
National IDValid · on record
Identity exists — synthetic ruled out
Credit bureau checkBureau · US
Querying…
File age11 years
Tradelines6 active
IdentityMatch
History confirmed
Telco line checkCarrier · Vodafone ES
Querying…
Line statusActive
SIM age4.2 years
Name matchMatch
Active line confirmed
Court records searchCourts · UK
Querying…
JudgmentsNone found
BankruptciesNone found
IdentityMatch
No adverse records
Address verificationPostal DB · ES
Querying…
AddressOn record
OccupancyConfirmed
DeliverableYes
Residency proven
03 · Orquestração por fonte
Execute serviços em paralelo. A maior confiança vence.
Ative qualquer número de serviços por país e a Didit executa-os em paralelo. Uma fonte a confirmar é um sinal forte, duas fontes independentes a corroborar é o veredito mais forte que podemos devolver.
Database Validation
Per-source orchestration
ES · 3 services · fired in parallel
One request
National ID · ES
Government registry
Standby
Credit bureau
Standby
Mobile operator
Standby
Verdict
Awaiting sources…
APPROVED
Every enabled source, fired at once — highest confidence wins.
04 · Formato do relatório
Correspondência por campo. Dados de origem. Pontuação biométrica.
Cada fonte devolve um veredito por campo, código de resultado e registo limpo, nome completo, datas, foto, assinatura e uma pontuação de correspondência facial em serviços biométricos como o RENAPER da Argentina e o Tribunal Eleitoral do Panamá.
Registry reportRENAPER · Argentina
Code 1000 · Match
Full nameMarta López García
Match
Date of birth12 Mar 1991
Match
Document nº34.892.117
Match
Issue · Expiry2019 · 2029
Match
PhotoRegistry · cleaned
Signature
0.0%Face match
Registry reportTribunal Electoral · Panama
Code 1000 · Match
Full nameAna Souza Vega
Match
Date of birth04 Jul 1988
Match
Document nº8-712-1043
Match
Issue · Expiry2021 · 2031
Match
PhotoRegistry · cleaned
Signature
0.0%Face match
Registry reportRegistraduría · Colombia
Code 1000 · Match
Full nameCamila Restrepo Díaz
Match
Date of birth27 Nov 1995
Match
Document nº1.020.774.811
Match
Issue · Expiry2020 · 2030
Match
PhotoRegistry · cleaned
Signature
0.0%Face match
05 · Cobertura regional
América Latina, Espanha e mais de 45 países.
19 registos civis diretamente integrados na América Latina e Espanha. 156 conjuntos de dados em mais 45 países através da rede global de identidade. Uma nova integração geralmente fica ativa em duas a três semanas, mediante pedido.
Regional Coverage
One API
Direct integrations
0 civil registries
es
mx
br
ar
co
cl
pe
ec
uy
py
bo
ve
gt
hn
sv
ni
cr
pa
do
Identity network
0 datasets · 45+ countries
+37 more
New integration
2–3 weeks to live
Your market — on request
Native where it matters — two weeks from everywhere else.
06 · Pagamento variável por chamada
A partir de $0.05 por verificação. Sem mínimos. 500 grátis.
Faturado apenas em consultas bem-sucedidas. Nível mais barato $0.05 (República Dominicana). Nível padrão de registo governamental $0.20 (Argentina, Brasil, México, Espanha, Colômbia, Peru, Chile e mais). Serviços ignorados nunca são faturados.
Pay-per-call · June487 of 500 free left
Billed this monthSuccessful queries only · no minimums$41.20
Integrar
Dois endpoints. O mesmo JSON. O mesmo catálogo.
Deixe a Didit capturar a identificação e extrair os campos automaticamente, ou envie os dados de identidade diretamente se já os tiver. O mesmo formato JSON na saída.
Implemente a Validação de Base de Dados com um único prompt.
Cole o bloco abaixo no Claude Code, Cursor, Codex, Devin, Aider ou Replit Agent. Preencha a sua stack, framework, linguagem, caso de uso, e o agente implementa o workflow, webhook e código de decisão de ponta a ponta.
didit-integration-prompt.md
# Didit Database Validation — integrate in 5 minutes
You are integrating Didit's Database Validation module into <my_stack>.
Database Validation cross-references each user's identity data against the
authoritative source for that country — the national civil registry, tax
authority, electoral roll, credit bureau, telco database, court record or
biometric service that issued the document. 1,000+ data sources reachable
through one endpoint. Follow these steps exactly. Every URL, header, and
enum value below is canonical — do not paraphrase or "improve" them.
## 1. Provision an account
- Sign up: https://business.didit.me (no credit card required).
- Or provision programmatically: POST https://apx.didit.me/auth/v2/programmatic/register/
(returns an API key bound to the workspace + application).
## 2. Two integration paths — pick one
### Path A — Workflow Builder (hosted UI)
Best when you want Didit to capture the ID document, run Optical Character Recognition (OCR), derive the
required fields automatically, and trigger the right registry service per
issuing country.
1. Create a workflow that contains the DATABASE_VALIDATION feature:
POST https://verification.didit.me/v3/workflows/
Authorization header: x-api-key: <your-api-key>
Body: workflow_label, features array including
{ feature: "DATABASE_VALIDATION" } (UPPERCASE — strict enum)
Configure per-country service IDs (e.g. arg_renaper, bra_cpf,
mex_curp, dom_cedula) plus partialMatchAction / noMatchAction.
2. Create a verification session for an end user:
POST https://verification.didit.me/v3/session/
Body: workflow_id (from step 1), vendor_data (your own user id).
Response: session_url — redirect the user to it.
3. Listen for webhook callbacks (see "Webhooks" below).
### Path B — Standalone server-to-server API
Best when you already have the identity fields (mobile SDK capture,
existing onboarding pipeline, reseller flow). Single endpoint, every
country and every service routed through it.
POST https://verification.didit.me/v3/database-validation/
Content-Type: multipart/form-data
Body fields (all optional except issuing_state and at least one identifier):
- issuing_state (required, ISO 3166-1 alpha-3, e.g. ARG, BRA, MEX)
- services (optional, repeated, service IDs to run; omit
to run every configured service for that country)
- identification_number (e.g. DNI, CPF, CURP, cedula number)
- first_name
- last_name
- date_of_birth (YYYY-MM-DD)
- selfie (file, required for biometric services such as
arg_renaper, pan_cedula_sib, pan_cedula_sib_plus)
- address_element_1 (street + number)
- address_element_2 (unit / building / floor)
- address_element_3 (suburb / district)
- address_element_4 (city / state / region)
- address_element_5 (postal code; postal_code alias accepted)
- consent (boolean — required when the selected service
has requires_consent=true in the catalog)
- vendor_data (optional string, your user id)
Response: JSON report with match_type, validation_type (1x1 or 2x2),
per-service validations, source_data, and any warnings.
## 3. Webhooks (Path A only — Path B returns synchronously)
- Register a webhook destination once via
POST https://verification.didit.me/v3/webhook/destinations/
Body: url, subscribed_events: ["session.verified", "session.review_started",
"session.declined"]
- Response includes secret_shared_key — store it.
- Every webhook delivery carries an X-Signature-V2 header you MUST verify
before trusting the payload. HMAC-SHA256 verification MUST run against the raw body bytes (the raw payload as Didit sent it) BEFORE any JSON parsing — re-serialising the parsed body changes whitespace and key order, which invalidates the signature.Algorithm:
1. sortKeys(payload) recursively
2. shortenFloats (truncate trailing zeros after the decimal point)
3. JSON.stringify the result
4. HMAC-SHA256 with the secret_shared_key
5. Hex-encode, compare to the X-Signature-V2 header.
## 4. Reading the report (both paths return the same shape)
The database_validation object includes:
- status: "Approved" | "Declined" | "In Review" | "Not Finished"
- match_type: "full_match" | "partial_match" | "no_match"
- issuing_state: ISO 3166-1 alpha-3 country code
- validation_type: "1x1" (single source full-match) or "2x2" (two
independent sources corroborate the data)
- screened_data: the user fields submitted (identification_number,
first_name, last_name, date_of_birth, selfie, address fields, ...)
- validations: array of per-service results. Each entry carries
service_id (e.g. arg_renaper), service_name, outcome_code (MATCH,
NO_MATCH, DOCUMENT_NOT_FOUND, BIOMETRIC_IMAGE_UNUSABLE,
REGISTRY_UNAVAILABLE, ...), optional outcome_detail, a per-field
validation block (full_match / partial_match / no_match), and a
source_data block lifted from the registry record (photo, signature,
full_name, gender, dates, face_match_score for biometric services).
Configurable risks (action per workflow — Decline, Review, or Approve):
- DATABASE_VALIDATION_PARTIAL_MATCH (partialMatchAction)
- DATABASE_VALIDATION_NO_MATCH (noMatchAction)
Warnings raised when a service cannot run:
- COULD_NOT_PERFORM_DATABASE_VALIDATION — required input field missing
(e.g. CPF could not be OCR-extracted). You are NOT charged. Session
auto-moves to In Review; saving the missing field in the Console
retriggers the check.
## 5. Hard rules — do not change
- Base URL for /v3/* endpoints is verification.didit.me (NOT apx.didit.me).
- Feature enum is UPPERCASE: DATABASE_VALIDATION, ID_VERIFICATION,
LIVENESS, FACE_MATCH, AML, IP_ANALYSIS.
- Country codes are ISO 3166-1 alpha-3 UPPERCASE: ARG, BRA, MEX, ESP, ...
- Service IDs are lowercase snake-case with a country prefix:
arg_renaper, bra_cpf, mex_curp, dom_cedula, pan_cedula_sib_plus, ...
- Auth header is x-api-key (lowercase, hyphenated).
- Webhook signature header is X-Signature-V2 (NOT X-Signature).
- Status casing matches exactly: "Approved", "Declined", "In Review",
"Not Finished" (title-cased, space-separated).
- match_type casing matches exactly: full_match, partial_match, no_match
(lowercase snake-case).
- You are only billed when a service returns a result. Skipped services
(missing input, unsupported issuing_state) are never billed.
## 6. Pricing reference (public, pay-per-call)
- Variable per source. Lowest tier: $0.05 per check (Dominican Republic,
Junta Central Electoral).
- Standard government-registry tier: $0.20 per check (Argentina RENAPER,
Brazil Receita Federal CPF, Mexico RENAPO CURP, Spain DGP, Colombia
Registraduria, Peru RENIEC, Chile Registro Civil, Ecuador, Uruguay,
El Salvador, Guatemala, Honduras, Bolivia, Paraguay, Venezuela, Costa
Rica).
- Biometric premium tier: $0.75 (Panama SIB) up to $1.50 (Panama SIB
Plus elevated tier with stronger biometric thresholds).
- Global identity network: 156 datasets across 45 countries (AU, NZ,
UK, IE, FR, DE, IT, ES, PT, NL, BE, CH, AT, Nordics, Greece, Poland,
Czechia, Hungary, Romania, Slovakia, India, Indonesia, Philippines,
Thailand, Malaysia, Singapore, Hong Kong, China, Cambodia, Kenya,
Nigeria, South Africa, Morocco, USA, Canada). Per-service pricing
surfaced in the catalog and billing exports.
- 500 free checks every month, forever, on every account.
## 7. Verify your integration
- Sandbox starts on signup at https://business.didit.me — no separate flag.
- Test the full catalog of services with the per-country reference pages
under https://docs.didit.me/api-reference/database-validation/.
- Switch to live: flip the application's environment toggle in console.
When in doubt: https://docs.didit.me/core-technology/database-validation/overview
Cobertura de registos oficiais
147 registos oficiais — pesquisável.
Todos os fornecedores de Validação de Base de Dados que a Didit verifica, com o URL de referência canónica e a categoria de verificação. Proveniente do mesmo catálogo de documentação Mintlify que a Consola de Negócios utiliza, pesquise por nome do país, código ISO 3166-1 alfa-3 ou ID do serviço. 147 serviços · 53 países.
Abra um novo país com um clique. Nós fazemos o trabalho difícil.
Abrimos as subsidiárias locais, garantimos as licenças, realizamos os testes de penetração, obtemos as certificações e alinhamos com cada nova regulamentação. Para lançar verificações num novo país, basta ativar um botão. Mais de 220 países ativos, auditados e testados trimestralmente, o único fornecedor de identidade que um governo de um estado-membro da UE formalmente considerou mais seguro do que a verificação presencial.
Registos civis da América Latina e Espanha, diretamente integrados.
A partir de $0.05
Por verificação. Cobrado apenas com um resultado.
<0.0s
De ponta a ponta no tráfego de produção.
Três níveis, uma tabela de preços
Comece grátis. Pague por utilização. Expanda para Enterprise.
500 verificações gratuitas todos os meses, para sempre. Pague à medida que usa para produção. Contratos personalizados, residência de dados e SLAs (Acordos de Nível de Serviço) no Enterprise.
Grátis
Grátis
$0 / mês. Não é necessário cartão de crédito.
Pacote KYC gratuito (Verificação de ID + Prova de Vida Passiva + Correspondência Facial + Análise de Dispositivo e IP), 500 / mês, todos os meses
Comece grátis → pague apenas quando uma verificação for executada → desbloqueie o Enterprise para um contrato personalizado, SLA ou residência de dados.