Run the full bundle — ID, Liveness, Face Match, IP — free on the first 500 verifications/month, on every account. No card. Same engine paying customers use.
500 full KYC (know your customer) checks every month, forever. After that,
$0.33 per check. No contract, no minimums, no sales call — the same price
startups and large enterprises pay.
How it works
From sign-up to verified user in four steps.
Step 01
Create the workflow
Pick the checks you want — ID, liveness, face match, sanctions, address, age, phone, email, custom questions. Drag them into a flow in the dashboard, or post the same flow to our API. Branch on conditions, run A/B tests, no code required.
Step 02
Integrate
Embed natively with our Web, iOS, Android, React Native, or Flutter SDK. Redirect to a hosted page. Or just send your user a link — by email, SMS, WhatsApp, anywhere. Pick what fits your stack.
Step 03
User goes through the flow
Didit hosts the camera, the lighting cues, the mobile hand-off, and accessibility. While the user is in the flow, we score 200+ fraud signals in real time and verify every field against authoritative data sources. Result in under two seconds.
Step 04
You receive the results
Real-time signed webhooks keep your database in sync the moment a user is approved, declined, or sent to review. Poll the API on demand. Or open the console to inspect every session, every signal, and manage cases your way.
Built for developers · Built against fraud · Open by design
Same bundle as paid. Free for the first 500 every month.
Free KYC is not a separate product. Same modules, same pipeline, same response — the only thing that changes past 500 checks a month is who pays the next $0.33.
ID + Passive Liveness + Face Match + IP. Every session.
The same four-module bundle paying customers run at $0.33 a check. ID Verification across 220+ countries and 14,000+ document types. Passive Liveness, iBeta Level 1 PAD-certified. Face Match between portrait and selfie. IP signals for VPN, proxy, Tor, and hosting risk.
Workflow · Full KYC
Four features · every session
Bundle
1
ID Verification
ID_VERIFICATION
$0.15
2
Passive Liveness
LIVENESS
$0.10
3
Face Match 1:1
FACE_MATCH
$0.05
4
Device & IP Analysis
IP_ANALYSIS
$0.03
Bundle · same workflow as paid$0.33 / session
02 · Free quota
500 sessions, free, every month, forever.
The 500-check quota counts at the workspace level and resets at the start of each month, on every account, forever. Sandbox runs don't count. Current usage is visible live in the Business Console.
Monthly usage
Resets 1st · 00:00 UTC · workspace-level
Tier 1
312
Used
188
Remaining
500
Monthly cap
Sessions this month312/ 500 free
Burns on completed sessions62% of cap
Resets · 01 Jun 2026 · 00:00 UTC17d 4h
03 · No friction
No credit card. No sales call. No annual minimum.
Drop a work email, get an API key, open the sandbox — ~60 seconds end to end. No payment method to unlock the 500-check quota. No sales call, no order form, no commitment. Card details only if you scale past the free tier.
Sign up to first session
Self-serve · sandbox unlocked
~60s
Work emailRequired
API keyRequired
Sandbox openRequired
Credit cardSkipped
Sales callSkipped
Annual minimumSkipped
First session · t+58s · sandboxno card on file
04 · Who runs on it
Startups, bake-off pilots, side projects.
500 checks/month covers most early-stage onboarding — enough to take a fintech, marketplace, crypto product, or iGaming launch from prototype through early traction without a vendor invoice. Larger teams use the same quota for bake-off pilots and staging traffic. No spend until check 501.
Who runs on the free tier
500 / month covers each below
4 segments
SegmentVolumeStatus
Pre-seed startup0 – 200 / moEligible
Bake-off pilot0 – 500 / moEligible
Side project0 – 80 / moEligible
Staging traffic0 – 300 / moEligible
No spend · until session 501500 / month
05 · Overflow
Session 501 keeps running. $0.33, same workflow.
No rate limit at the cutoff, no fallback model, no auto-decline at check 500. Check 501 onward keeps running on the same workflow at $0.33 each — only the overflow is billed, not the whole month. Public price, same number paying customers pay.
Session 501 · response
Same workflow_id · billed only past 500
201
501
Session #
$0.33
Charge
0ms
Rate limit
POST /v3/session/201
{
"workflow_id":"wf_free_kyc_42",
"session_number":501,
"status":"Approved",
"billed":0.33,
"model_weights":"v3.4-prod"
}
Overflow · sessions 501+ billed at $0.33
06 · Same engine
No second-class model on the free tier.
Free-quota checks run on the same model weights, infrastructure, and regulator-attested pipeline (Spain's Tesoro, Banco de España, SEPBLAC) as every paid check. The response is identical. Free is a billing decision, not a product decision — check 1 and check 10 million ship the same.
Engine parity
Sessions 1–500 vs 501+
Identical
Sessions 1–500
Free quota
Sessions 501+
$0.33 overflow
Model weightsv3.4-prod
Edge clusterverification
Response shapebyte-equal
Spain attestationapplies
No second-class model · free and paid run on the same engine
Integrate
Two endpoints. Same JSON. Same workflow as paid.
No separate free-tier API. Create the bundle once, then start a session per user. The first 500 every month are simply not billed.
Free for the first 500 per month. $0.33 each past that.docs →
Agent-ready integration
Ship Free KYC in one prompt.
Paste the block below into Claude Code, Cursor, Codex, Devin, Aider, or Replit Agent. Fill in your framework, language, and use case. The agent provisions Didit, builds the four-module workflow, wires the webhook, and ships.
didit-integration-prompt.md
# Didit Free KYC — integrate in 5 minutes
You are integrating Didit's full KYC bundle (ID + Passive Liveness +
Face Match + Device & IP Analysis) into <my_stack>. The first 500 sessions every
month are free, forever, on every account — no credit card, no sales
call. Past 500 you keep using the same endpoint at $0.33 per session.
Every URL, header, and enum value below is canonical — do not paraphrase.
## 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).
- The 500-session monthly free quota is counted at the workspace level.
It resets at 00:00 UTC on the first of each month and applies to any
workflow that combines the four bundled features.
## 2. Create the KYC workflow (one time)
POST https://verification.didit.me/v3/workflows/
Authorization header: x-api-key: <your-api-key>
Body: workflow_label, features array with the four bundled entries
[
{ feature: "ID_VERIFICATION" },
{ feature: "LIVENESS" },
{ feature: "FACE_MATCH" },
{ feature: "IP_ANALYSIS" }
] (UPPERCASE — strict enum, do not lowercase)
This is the same workflow used in production at $0.33 per session.
Sessions counted under the 500-session free quota run on the same model
weights, the same edge nodes, the same Spain-Tesoro-attested pipeline.
There is no degraded model on the free tier.
## 3. Create a verification session for an end user
POST https://verification.didit.me/v3/session/
Body: workflow_id (from step 2), vendor_data (your own user id).
Response: session_url — redirect the user to it.
The hosted UI walks the user through document capture, selfie capture
(passive liveness), automatic face-match between portrait and selfie,
and Device & IP analysis on the originating connection. End-to-end inference is
sub-2 seconds across the full bundle.
## 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", "kyc_expired"]
- 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. Reading the session report
The session payload includes one object per bundled feature:
- id_verification — status, document_type, document_number, full_name,
date_of_birth, expiration_date, issuing_state, parsed address, image
quality scores, warnings.
- liveness — status, method ("PASSIVE"), score 0-100, reference_image,
warnings.
- face_match — status, similarity score 0-100, source ("DOCUMENT"),
target ("SELFIE").
- ip_analysis — status, ip, country, city, vpn, proxy, tor, hosting,
asn, abuse_score, risk warnings.
Statuses use exact casing: "Approved", "Declined", "In Review",
"Expired", "Not Finished".
## 6. Hard rules — do not change
- Base URL for /v3/* endpoints is verification.didit.me (NOT apx.didit.me).
- Feature enums are UPPERCASE: ID_VERIFICATION, LIVENESS, FACE_MATCH, IP_ANALYSIS.
- 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", "Declined", "In Review",
"Expired", "Not Finished" (title-cased, space-separated).
## 7. Pricing reference (public)
- First 500 sessions per workspace per month: free, forever, no credit
card, on every account. Quota resets 00:00 UTC on the first of each month.
- Overflow past 500 in a month: $0.33 per session, billed only for the
sessions above the free quota. Same workflow, same endpoint, same
features, same response shape.
- No minimums, no contracts, no overage surprises. The full price table:
didit.me/pricing.
## 8. Verify your integration
- Sandbox starts on signup at https://business.didit.me — no separate flag.
- Test data: deterministic synthetic documents and selfies returned in
sandbox. Sandbox sessions do not count against the 500 monthly free quota.
- Switch to live: flip the application's environment toggle in console.
When in doubt: https://docs.didit.me/sessions-api/create-session
Open a new country in one click. We do the hard work.
We open the local subsidiaries, secure the licenses, run the penetration tests, earn the certifications, and align with every new regulation. To ship verifications in a new country, flip a toggle. 220+ countries live, audited and pen-tested every quarter — the only identity provider an EU member-state government has formally called safer than in-person verification.
Verifications free every month, on every workspace, forever.
0
Modules in the bundle — ID, Liveness, Face Match, IP.
<0s
End-to-end decision on every full KYC check.
$0.00
Per check past the free quota. Public price, no minimums.
Three tiers, one price list
Start free. Pay per usage. Scale to Enterprise.
500 free verifications every month, forever. Pay-as-you-go for production. Custom contracts, data residency, and SLAs (Service Level Agreements) on Enterprise.
Free
Free
$0 / month. No credit card required.
Free KYC bundle (ID Verification + Passive Liveness + Face Match + Device & IP Analysis) — 500 / month, every month
Blocklisted Users
Duplicate Detection
200+ fraud signals on every session
Reusable KYC across the Didit network
Case Management Platform
Workflow Builder
Public docs, sandbox, SDKs, MCP (Model Context Protocol) server