Control de edad sin subir un documento de identidad. Verifica con un selfie. Recurre al documento solo cuando sea necesario.
Estima la edad a partir de un selfie pasivo por $0.10. El respaldo documental solo se activa en casos límite. Preparado para la UK Online Safety Act y la ley SREN de Francia. 500 verificaciones gratis cada mes.
Con la confianza de más de 2.000 organizaciones en todo el mundo.
Age decisionRequired age · 18+
18
14
23
1050
UK Ofcom · France SREN · EU DSA
Verifica la edad en 1 segundo. Documento solo cuando sea necesario.
Obligar a cada visitante a subir un documento reduce las tasas de finalización entre un 25 y un 40 %.
El flujo adaptativo de Didit ejecuta primero la estimación de edad y solo dirige la
cola de casos límite al respaldo documental. Veredicto del selfie en menos de 2 segundos, $0.10
por verificación, coste combinado cercano a $0.115 por usuario. 500 verificaciones gratis cada
mes.
Cómo funciona
De registro a usuario verificado en cuatro pasos.
Paso 01
Crea el flujo de trabajo
Elige las verificaciones que quieras: identidad, prueba de vida, coincidencia facial, sanciones, dirección, edad, teléfono, correo electrónico, preguntas personalizadas. Arrástralas a un flujo en el panel de control, o publica el mismo flujo en nuestra API. Crea ramificaciones condicionales, ejecuta pruebas A/B, sin necesidad de código.
Paso 02
Integra
Integra de forma nativa con nuestro SDK para Web, iOS, Android, React Native o Flutter. Redirige a una página alojada. O simplemente envía a tu usuario un enlace, por correo electrónico, SMS, WhatsApp, donde quieras. Elige lo que mejor se adapte a tu stack.
Paso 03
El usuario pasa por el flujo
Didit aloja la cámara, las indicaciones de iluminación, la transferencia móvil y la accesibilidad. Mientras el usuario está en el flujo, puntuamos más de 200 señales de fraude en tiempo real y verificamos cada campo con fuentes de datos autorizadas. Resultado en menos de dos segundos.
Paso 04
Recibes los resultados
Los webhooks firmados en tiempo real mantienen tu base de datos sincronizada en el momento en que un usuario es aprobado, rechazado o enviado a revisión. Consulta la API bajo demanda. O abre la consola para inspeccionar cada sesión, cada señal y gestionar los casos a tu manera.
Diseñado para el control de edad · Precios de infraestructura
Seis funcionalidades. $0.115 de media por usuario.
Un flujo de trabajo adaptativo ejecuta la cascada que prioriza el selfie y solo escala la minoría de casos límite. Ajusta la banda de casos límite por flujo de trabajo, añade reglas de edad por país y deja que Didit se encargue del enrutamiento.
Un fotograma, sin desafío de movimiento, sin subida de documentos. Veredicto en menos de 2 segundos en Android de gama baja, $0.10 por verificación. La respuesta con datos mínimos a la Ley de Seguridad en Línea del Reino Unido y la SREN de Francia.
Define la banda de casos límite por flujo de trabajo. Los pases claros y los fallos claros terminan con el selfie; la banda escala al recurso a documento. Edita los puntos de corte en el Workflow Builder sin código, sin necesidad de volver a desplegar.
Solo los casos límite suben un documento. Pasaportes, documentos de identidad nacionales, permisos de conducir, permisos de residencia con reconocimiento óptico de caracteres (OCR) completo y análisis de zona de lectura mecánica (MRZ). Aproximadamente el 10% del tráfico típico pasa por este paso.
NombreGARCÍA LÓPEZ, MARÍARetratoNacimiento12 MAR 1991MRZPAE102331
Leído · válido
+211
04 · Reglas de edad por país
Bebe a los 21 en EE. UU. 18 en la UE. 19 en Corea.
Establece la edad mínima por país, con anulaciones a nivel estatal donde sea relevante (Misisipi 21, Alabama 19, EE. UU. por defecto 18). El recurso a documento valida automáticamente la fecha de nacimiento según la regla del país emisor.
Diseñado para el estándar de verificación de edad más exigente. El Tesoro y el SEPBLAC de España han certificado formalmente que el flujo remoto de Didit es más seguro que la verificación presencial, la única certificación gubernamental de este tipo en un estado miembro de la UE. El paquete de auditoría incluye iBeta Nivel 1 PAD, ISO/IEC 27001, SOC 2 Tipo 1.
Remote flow formally attested safer than in-person verification.
Formal government attestation · Spain
iBeta Level 1 PADISO/IEC 27001SOC 2 Type 1
Included in the audit pack
06 · Precios públicos
$0.10 selfie. $0.15 document. Only when needed.
La estimación de edad a $0.10 cubre al ~90% que pasa con un selfie. La verificación de documentos a $0.15 solo se activa para la minoría de casos límite (~10%). El coste medio se sitúa cerca de $0.115 por usuario. 500 verificaciones gratis cada mes, para siempre.
200OKestado Aprobado · En Revisión · Rechazado · No Finalizado
Integración lista para agentes
Implementa la verificación de edad con una sola instrucción.
Pégalo en Claude Code, Cursor, Codex, Devin, Aider o Replit Agent. Rellena tu stack. El agente construye el flujo de trabajo adaptativo, abre la sesión, conecta el webhook y lo implementa en cinco minutos.
didit-integration-prompt.md
You are integrating Didit's Age Verification recipe into <my_stack>. Selfie-first age estimation with an adaptive document fallback for the borderline tail. One Didit workflow. Two real endpoints.
1. Verify age on a selfie. ONE call to the Sessions API runs Age Estimation + Passive Liveness on the same passive frame.
2. Fall back to a document check ONLY when the estimate sits in the borderline band you define. Same Sessions API workflow handles the fallback automatically.
Bundle pricing (public):
- Age Estimation: $0.10 per check (Sessions API or standalone)
- ID Verification fallback: $0.15 per check, only when triggered
- Typical blended cost lands near $0.115 per user (~90% finish on the selfie, ~10% touch the document fallback)
- First 500 verifications free every month, forever
PRE-REQUISITES
- Production API key from https://business.didit.me (sandbox key in 60s, no card).
- Webhook endpoint with Hash-based Message Authentication Code (HMAC) SHA-256 verification using the X-Signature-V2 header and your webhook secret.
- A workflow_id from the Workflow Builder. The workflow must contain the AGE_ESTIMATION feature, and (recommended) the ID_VERIFICATION feature with adaptive_id_verification enabled so the borderline tail routes through automatically.
STEP 1 — Build the adaptive workflow once
POST https://verification.didit.me/v3/workflows/
Headers:
x-api-key: <your api key>
Content-Type: application/json
Body:
{
"workflow_label": "age_gate_uk_fr",
"features": [
{ "feature": "AGE_ESTIMATION" },
{ "feature": "ID_VERIFICATION" }
],
"age_estimation_decline_threshold": 18,
"face_liveness_score_decline_threshold": 30,
"adaptive_id_verification": true
}
Notes:
- "AGE_ESTIMATION" and "ID_VERIFICATION" are exact, case-sensitive feature names.
- age_estimation_decline_threshold defaults to 18; set 21 for US alcohol, 19 for South Korea, etc.
- adaptive_id_verification = true tells Didit to invoke the document fallback automatically when the estimate sits inside the borderline band.
STEP 2 — Open an age-verification session per user
POST https://verification.didit.me/v3/session/
Headers:
x-api-key: <your api key>
Content-Type: application/json
Body:
{
"workflow_id": "<the workflow_id from step 1>",
"vendor_data": "<your internal user id>",
"callback": "https://<your-app>/age-gate/callback",
"metadata": {
"purpose": "age_gate",
"surface": "<the page or feature being gated>"
}
}
Response: 201 Created with the hosted session_url. Redirect the user to it. The hosted flow opens the front camera, captures one passive frame, runs Age Estimation + Passive Liveness in sub-2-seconds, and either returns a verdict or routes the user into the document fallback automatically.
STEP 3 — Read the signed webhook on session completion
Didit POSTs to your callback. Session statuses are exact Title Case With Spaces.
Body (excerpted for an Age Estimation only finish):
{
"session_id": "<uuid>",
"vendor_data": "<your user id>",
"status": "Approved",
"liveness": {
"status": "Approved",
"method": "PASSIVE",
"score": 92,
"age_estimation": 27.3,
"warnings": []
}
}
Body (excerpted when the document fallback fired):
{
"session_id": "<uuid>",
"vendor_data": "<your user id>",
"status": "Approved",
"liveness": { "status": "Approved", "age_estimation": 17.9, "warnings": [{ "code": "AGE_NOT_DETECTED" }] },
"id_verification": {
"status": "Approved",
"date_of_birth": "1998-03-21",
"age": 27,
"document_type": "Passport",
"issuing_state": "GBR"
}
}
Verify X-Signature-V2 BEFORE trusting the body — HMAC SHA-256 of the raw bytes with your webhook secret.
Session status enum (exact case): Approved | Declined | In Review | Resubmitted | Expired | Not Finished | Kyc Expired | Abandoned.
Warning catalog:
- AGE_BELOW_MINIMUM estimated or computed age below the threshold
- AGE_NOT_DETECTED unable to estimate age (lighting / quality)
- LOW_LIVENESS_SCORE passive-liveness score below threshold
- NO_FACE_DETECTED no face in the capture
- LIVENESS_FACE_ATTACK presentation attack suspected
- POSSIBLE_DUPLICATED_FACE same face previously verified
STEP 4 — Branch your surface on the final verdict
Approved → grant access to the gated surface.
Declined → render the regulator-required age-gate notice.
In Review → hold; an analyst case is open in the Business Console.
Not Finished → user abandoned; safe to re-prompt.
STEP 5 — Alternate path (server-to-server, when you already have the selfie)
POST https://verification.didit.me/v3/age-estimation/
Headers:
x-api-key: <your api key>
Body (multipart/form-data):
user_image <single passive selfie>
age_estimation_decline_threshold 18 (optional, integer)
face_liveness_score_decline_threshold 30 (optional, integer)
Branch on the borderline band yourself, then optionally call:
POST https://verification.didit.me/v3/id-verification/
Body (multipart/form-data):
front_image <required>
back_image <optional>
vendor_data <optional, your user id>
This path is useful for native onboarding apps that capture the selfie locally.
CONSTRAINTS
- Base URL for /v3/* endpoints is verification.didit.me (NOT apx.didit.me).
- Feature enum is UPPERCASE: AGE_ESTIMATION, ID_VERIFICATION, LIVENESS, FACE_MATCH, AML, IP_ANALYSIS.
- Method enum is UPPERCASE: PASSIVE, FLASHING, ACTIVE_3D.
- 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, Expired, Not Finished, Resubmitted, Kyc Expired, Abandoned.
- Reference image URLs are signed and expire in 60 minutes. Store only the verdict + score; never the biometric media unless retention is explicitly enabled for fraud defence.
- 200+ fraud signals are evaluated on every session at no extra cost — surface the score via the session decision payload, do not re-query.
WEBHOOK EVENT NAMES
- Sessions: status changes flow through the standard session webhook.
- Verify X-Signature-V2 on every payload.
Read the docs:
- https://docs.didit.me/core-technology/age-estimation/overview
- https://docs.didit.me/sessions-api/create-session
- https://docs.didit.me/integration/webhooks
Start free at https://business.didit.me — sandbox key in 60 seconds, 500 verifications free every month, no credit card.
Cumplimiento por diseño
Abre un nuevo país en un clic. Nosotros hacemos el trabajo duro.
Abrimos las filiales locales, aseguramos las licencias, realizamos las pruebas de penetración, obtenemos las certificaciones y nos alineamos con cada nueva regulación. Para lanzar verificaciones en un nuevo país, activa un interruptor. Más de 220 países en vivo, auditados y probados trimestralmente, el único proveedor de identidad que un gobierno de un estado miembro de la UE ha calificado formalmente como más seguro que la verificación presencial.
Coste combinado por usuario: selfie más el 10% de respaldo documental para casos límite.
~90%
De los usuarios finalizan solo con el selfie pasivo, sin subir documentos.
<0s
Rango de edad devuelto por sesión en Android de gama baja.
0
Verificaciones gratuitas cada mes, para siempre.
Tres niveles, una lista de precios
Empieza gratis. Paga por uso. Escala a Enterprise.
500 verificaciones gratuitas cada mes, para siempre. Pago por uso para producción. Contratos personalizados, residencia de datos y SLAs (Acuerdos de Nivel de Servicio) en Enterprise.
Gratis
Gratis
$0 / mes. No se requiere tarjeta de crédito.
Paquete KYC gratuito (Verificación de ID + Prueba de vida pasiva + Coincidencia facial + Análisis de dispositivo e IP), 500 / mes, cada mes