Recull qualsevol dada. Dins de qualsevol flux de verificació.
Fes qualsevol pregunta que el teu equip de compliance necessiti,origen de fons, ocupació, volum esperat, autodeclaració de PEP (persona políticament exposada), amb respostes auditades a la mateixa sessió. Constructor sense codi, ramificació condicional, càrrega de fitxers. 0,10 $ per enviament, 500 gratuïts/mes.
Confiat per més de 2.000 organitzacions a tot el món.
Origen de fons, autodeclaració PEP
Pregunta el que vulguis. Bloqueja el registre d'auditoria.
Afegeix un qüestionari personalitzat al flux de treball, origen de fons, autodeclaració
PEP, ocupació, volum esperat. Les respostes apareixen a l'informe de la sessió.
0,10 $ per enviament.
Com funciona
Des del registre fins a l'usuari verificat en quatre passos.
Pas 01
Crea el flux de treball
Tria les comprovacions que vulguis, identificació, prova de vida, coincidència facial, sancions, adreça, edat, telèfon, correu electrònic, preguntes personalitzades. Arrossega-les a un flux al panell de control, o publica el mateix flux a la nostra API. Ramifica segons condicions, fes proves A/B, no cal codi.
Pas 02
Integra
Integra de forma nativa amb els nostres SDKs per a Web, iOS, Android, React Native o Flutter. Redirigeix a una pàgina allotjada. O simplement envia a l'usuari un enllaç, per correu electrònic, SMS, WhatsApp, on vulguis. Tria el que s'adapti al teu stack.
Pas 03
L'usuari passa pel flux
Didit allotja la càmera, les indicacions d'il·luminació, el traspàs mòbil i l'accessibilitat. Mentre l'usuari està en el flux, puntuam més de 200 senyals de frau en temps real i verifiquem cada camp amb fonts de dades autoritzades. Resultat en menys de dos segons.
Pas 04
Rebràs els resultats
Els webhooks signats en temps real mantenen la teva base de dades sincronitzada en el moment en què un usuari és aprovat, rebutjat o enviat a revisió. Consulta l'API sota demanda. O obre la consola per inspeccionar cada sessió, cada senyal i gestionar els casos a la teva manera.
Creat per a desenvolupadors · Creat contra el frau · Disseny obert
Sis funcionalitats. Una feature flag. QUESTIONNAIRE.
Cada funcionalitat següent és un interruptor al mateix mòdul. Sense nivells de venda addicional, sense SKUs separats, sense trucades addicionals. Activa-les per flux de treball, o encadena el pas del qüestionari després de la verificació d'identitat i la prova de vida en un únic flux de treball.
Formularis basats en esquemes. Sense codi. Sense SDK. Sense passos de compilació.
Dos modes. Mode simple per a formularis ràpids d'arrossegar i deixar anar en un sol idioma, ideal per a enquestes internes i atestacions ràpides. El mode avançat és un editor visual basat en nodes, necessari quan necessites ramificació condicional, traduccions, text de seguiment basat en eleccions o revisió manual forçada. Ambdós es publiquen en menys d'un minut.
Questionnaire schema
Simple · Advanced · drag-and-drop
Published
Question 1
Full legal name
element_type: SHORT_TEXT · required
Question 2
Country of residenceDROPDOWN
Question 3
Primary income sourceSINGLE_CHOICE
Question 4
Industries you serveMULTI_CHOICE
Question 5
Proof of fundsFILE_UPLOAD
Question 6
Source-of-funds detailLONG_TEXT
02 · Ramificació condicional
Mostra cada pregunta només a l'usuari que la necessita.
Els nodes de ramificació a l'editor de mode avançat inspeccionen qualsevol resposta anterior i encaminen l'usuari pel camí coincident. Pregunta al resident dels EUA el seguiment W-9, al resident de la UE l'autodeclaració de PEP (persona políticament exposada), omet ambdós on cap s'apliqui. Arrossega des de qualsevol punt de connexió a un espai buit per crear un nou node connectat. Desfés, refés, dreceres de teclat, zoom i desplaçament inclosos.
Branching rules
Advanced mode · graph editor
5 nodes
ConditionFollow-upAction
country == USW-9 tax form
Require
country == EUPEP self-declaration
Show
is_pep == trueSource of wealth
Require
income > 250kEDD attestation
Show
defaultStandard section
Skip
03 · Plantilles de grau AML
Origen dels fons. Residència fiscal. Declaracions d'UBO.
Sis plantilles de compliance preconstruïdes a la consola, Origen de Fons, Detalls d'Ocupació, Propòsit del Compte, Propietat Beneficiària, Residència Fiscal, Avaluació de Riscos. Cadascuna codifica el que els auditors esperen (font d'ingressos, desglossament, càrrega de proves, fons de tercers, declaració d'actius virtuals). Clona'n una i personalitza-la, o comença de zero.
Cada resposta es retorna com el mateix JSON auditable.
L'informe de la sessió conté un array `responses`, una entrada per cada pas del qüestionari. Cada element inclou el tipus d'element, la bandera de requerit, el títol localitzat, les opcions, el límit de càrrega i un objecte de resposta amb valor, text o fitxers. La mateixa estructura a l'API i a cada webhook, persisteix una vegada i no tornis a analitzar mai més.
Revisió manual forçada. Intervenció humana. Llest per a auditories.
Activa la revisió manual forçada i cada enviament es fixarà a 'En revisió' fins que un oficial de compliance humà l'aprovi. La consola mostra cada resposta, cada fitxer carregat i el text de la pregunta localitzat. L'aprovació amb un clic activa un webhook de sessió verificada amb l'informe final. Auditable de principi a fi per al regulador.
Submission queue
Forced manual review · webhook on every approval
Live
412
Approved
28
In review
6
Not finished
Webhook fired · usr_4d2b6e1 questionnaire Approved8s ago
Ausr_a8c4f02Source of Funds12 May 2026Approved
Musr_4d2b6e1Employment Details13 May 2026In review
Lusr_9f01a3cTax Residency14 May 2026Not finished
06 · Natiu del flux de treball
Integrat en el KYC. O executa'l com una verificació independent.
Encadena un QÜESTIONARI després de la VERIFICACIÓ D'IDENTITAT i la PROVA DE VIDA per recollir l'origen dels fons com a part d'un procés complet de KYC (Know Your Customer), una sessió, un webhook, un informe emmagatzemat. O llança un flux de treball la única funció del qual sigui el QÜESTIONARI per a la diligència deguda contínua, declaracions post-onboarding i re-certificacions periòdiques. 0,10 $ per enviament en qualsevol dels dos camins.
Workflow report
POST /v3/session/ · wf_kyc_sof
Verified
01ID_VERIFICATION
02LIVENESS
03QUESTIONNAIRE
Identity verifiedID_VERIFICATION · passed
Liveness confirmedLIVENESS · passed
Source of Funds submittedQUESTIONNAIRE · approved
Single session report$0.10 · one webhook
Integra
Dos patrons. El mateix JSON. El mateix preu.
Utilitza POST /v3/session/ en un flux de treball que encadena QUESTIONNAIRE amb ID_VERIFICATION i LIVENESS per recollir dades dins d'un KYC complet, o en un flux de treball la única característica del qual és QUESTIONNAIRE per executar el formulari com la seva pròpia Verificació de Qüestionari. Ambdós retornen la mateixa estructura de questionnaire_responses.
Envia qüestionaris personalitzats amb una sola instrucció.
Enganxa el bloc següent a Claude Code, Cursor, Codex, Devin, Aider o Replit Agent. Omple el marcador de posició `my_stack` amb el teu framework + llenguatge + cas d'ús. L'agent provisiona Didit, construeix el qüestionari, crea el flux de treball amb la funció QUESTIONNAIRE, connecta el webhook i ho envia.
didit-integration-prompt.md
# Didit Custom Questionnaires — integrate in 5 minutes
You are integrating Didit's Custom Questionnaires module into <my_stack>.
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. Build the questionnaire — Console OR API
### 2a. Visual builder in the Console (no code)
Questionnaires are authored visually — no schema upload, no SDK required.
1. Open https://business.didit.me, go to Questionnaires, click New.
2. Pick a mode:
- Simple Mode — single-language drag-and-drop builder. Best for fast
forms, internal surveys, single-locale flows.
- Advanced Mode — visual node-based graph editor. Required for
conditional branching, multi-language translations, choice-driven
follow-up text, and forced manual review.
3. Drag elements onto the canvas (input, choice, upload, layout — full
element catalog in section 5 below).
4. Optionally start from a pre-built template (Source of Funds,
Employment Details, Purpose of Account, Beneficial Ownership, Tax
Residency, Risk Assessment).
5. Localize titles, descriptions, placeholders, and choice labels for
every supported language; set a default_language.
6. Publish — the questionnaire is now addressable by its questionnaire_id.
### 2b. Create the questionnaire programmatically (Management API)
Use this path when you want the form to live in code, ship via CI, or be
authored by an LLM. Endpoint:
POST https://verification.didit.me/v3/questionnaires/
Headers: x-api-key: <your-api-key>
Content-Type: application/json
Required body:
- title — internal questionnaire name (string).
- languages — array of locale codes; MUST include "en".
- default_language — the default locale (string, e.g. "en").
- form_elements — ordered array of questions (≥1 entry).
Each form element requires id, element_type (lowercase OR uppercase enum
— "short_text", "multiple_choice", "email", "file_upload", "date_picker",
etc.), and a translated label keyed by locale. For dropdown,
single_choice, and multiple_choice add options: [{ value, label }].
Hard constraints:
- This endpoint supports SIMPLE LINEAR questionnaires only. Do NOT send
graph, branches, next, required_if, or conditional rules — use the
Console (section 2a) for those.
Example body:
{
"title": "Customer Onboarding",
"languages": ["en"],
"default_language": "en",
"form_elements": [
{
"id": "occupation",
"element_type": "short_text",
"label": { "en": "What is your occupation?" },
"is_required": true
},
{
"id": "source_of_funds",
"element_type": "multiple_choice",
"label": { "en": "Source of funds" },
"is_required": true,
"options": [
{ "value": "employment", "label": { "en": "Employment" } },
{ "value": "business", "label": { "en": "Business" } },
{ "value": "investments", "label": { "en": "Investments" } }
]
}
]
}
Response includes questionnaire_id — store it; you'll use it as
questionnaire_uuid when you wire the questionnaire into a workflow in
section 3 below. Full reference:
https://docs.didit.me/management-api/questionnaires/create
## 3. Two integration paths — pick one
### Path A — Workflow Builder (hosted UI, recommended)
Best when you want Didit to host the form, the file-upload UX, the
multi-language routing, the keyboard handling, and the mobile responsive
layout.
1. Create a workflow that contains the QUESTIONNAIRE feature:
POST https://verification.didit.me/v3/workflows/
Authorization header: x-api-key: <your-api-key>
Body: workflow_label, features array with the entry
{ feature: "QUESTIONNAIRE", questionnaire_id: "<id>" }
(UPPERCASE — strict enum)
Optional: chain QUESTIONNAIRE after ID_VERIFICATION + LIVENESS in the
same workflow to collect Source of Funds as part of a full Know Your Customer (KYC).
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 Questionnaire Verification
Run a questionnaire as its own verification — no KYC required.
Use a workflow whose only feature is QUESTIONNAIRE. Everything else is
identical to Path A. Useful for ongoing-due-diligence pulses,
post-onboarding declarations, periodic re-attestations.
## 4. Webhooks
- 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.
## 5. Element catalog (use these in the builder)
Input elements:
SHORT_TEXT, LONG_TEXT, NUMBER, EMAIL, PHONE, ADDRESS, DATE_PICKER, TIME
Choice elements:
DROPDOWN, SINGLE_CHOICE, MULTIPLE_CHOICE, COUNTRY, CONSENT
- DROPDOWN and SINGLE_CHOICE support per-option requires_text_input —
selecting "Other" can demand a free-text follow-up.
Upload elements:
IMAGE, FILE_UPLOAD
- max_files (1-5) per element.
Layout elements:
PARAGRAPH, SECTION_HEADER, SEPARATOR (read-only, not answerable).
## 6. Reading the report
The session report contains a questionnaire_responses array (one entry
per questionnaire step in the workflow graph). Each entry has:
- node_id: identifies the questionnaire step in the workflow graph
- questionnaire_id: which questionnaire this response is for
- title, description, languages, default_language, is_active
- sections: array of { title, description, items[] }
- each item: { uuid, order, element_type, is_required, title,
description, placeholder, choices, max_files, answer }
- answer: { value, text, files[] } — only the fields relevant to the
element_type are present.
- status: "Approved" | "In Review" | "Not Finished"
Status semantics:
- Not Finished — user has not completed the questionnaire yet.
- In Review — submitted, pending manual review. The Console flag
"force manual review" pins every response to this state until a human
approves it.
- Approved — reviewed and accepted.
Note: questionnaires do NOT emit risk warnings. Governance is achieved
through required fields, validation, manual review, and the workflow
graph (branching nodes route compliance-sensitive answers to In Review).
## 7. Hard rules — do not change
- Base URL for /v3/* endpoints is verification.didit.me (NOT apx.didit.me).
- Feature enum is UPPERCASE: QUESTIONNAIRE, ID_VERIFICATION, LIVENESS,
FACE_MATCH, AML, IP_ANALYSIS.
- Element type enums are UPPERCASE + underscored: SHORT_TEXT, LONG_TEXT,
FILE_UPLOAD, SINGLE_CHOICE, etc.
- Auth header is x-api-key (lowercase, hyphenated).
- Webhook signature header is X-Signature-V2 (NOT X-Signature).
- Always verify webhook signatures before trusting payload data.
- Status casing matches exactly: "Approved", "In Review", "Not Finished"
(title-cased, space-separated).
## 8. Pricing reference (public)
- $0.10 per questionnaire submission (Path A or Path B).
- No minimums. No per-language surcharge. No per-element surcharge.
Conditional branching, file uploads, manual review — all included at
the same per-submission price.
## 9. Verify your integration
- Sandbox starts on signup at https://business.didit.me — no separate flag.
- Use one of the pre-built templates (Source of Funds, Employment
Details, Purpose of Account, Beneficial Ownership, Tax Residency, Risk
Assessment) to ship a draft in under a minute, then customise.
- Switch to live: flip the application's environment toggle in console.
When in doubt: https://docs.didit.me/core-technology/questionnaires/overview
Compliment per disseny
Obre un nou país amb un clic. Nosaltres fem la feina difícil.
Obrim les filials locals, assegurem les llicències, realitzem les proves de penetració, obtenim les certificacions i ens alineem amb cada nova regulació. Per desplegar verificacions en un nou país, només has d'activar un interruptor. Més de 220 països en funcionament, auditats i provats trimestralment, l'únic proveïdor d'identitat que un govern d'un estat membre de la UE ha qualificat formalment com més segur que la verificació presencial.
Tipus d'elements: entrada, elecció, càrrega, disseny.
0
Plantilles predefinides, incloent-hi l'origen dels fons.
$0.00
Per enviament de qüestionari, qualsevol patró.
0
Verificacions gratuïtes cada mes, per sempre.
Tres nivells, una llista de preus
Comença gratis. Paga per ús. Escala a Enterprise.
500 verificacions gratuïtes cada mes, per sempre. Pagament per ús per a producció. Contractes personalitzats, residència de dades i SLA (Acords de Nivell de Servei) a Enterprise.
Gratuït
Gratuït
0 $ / mes. No es requereix targeta de crèdit.
Paquet KYC gratuït (Verificació d'identitat + Prova de vida passiva + Coincidència facial + Anàlisi de dispositius i IP), 500 / mes, cada mes