O rosto é o bilhete. Sem QR. Sem código de barras. Sem impressão.
Registe o comprador uma vez na compra. Cada leitura de portão é uma correspondência facial 1:N em menos de 1 segundo. Gratuito por leitura após o registo. 500 verificações gratuitas todos os meses.
Confiado por mais de 2.000 organizações em todo o mundo.
Estádios · Festivais · Transportes · Conferências
Ignore o código QR. Passe direto.
Sem tirar o telemóvel, sem ansiedade com a bateria, sem fraude de revenda. O comprador regista-se uma vez na
compra por $0.25, e cada leitura futura no portão é uma correspondência gratuita de Pesquisa Facial 1:N
— em menos de 1 segundo à escala de festival. O mesmo fluxo funciona em estádios, festivais,
corredores de trânsito e conferências.
Como funciona
Do registo ao utilizador verificado em quatro passos.
Passo 01
Criar 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 painel de controlo, ou publique o mesmo fluxo na nossa API. Ramifique em condições, execute testes A/B, sem necessidade de código.
Passo 02
Integrar
Incorpore nativamente com o nosso SDK Web, iOS, Android, React Native ou Flutter. Redirecione para uma página alojada. Ou simplesmente envie ao seu utilizador um link — por e-mail, SMS, WhatsApp, em qualquer lugar. Escolha o que se adapta à sua pilha.
Passo 03
O utilizador passa pelo fluxo
A Didit aloja a câmara, as indicações de iluminação, a transferência móvel e a acessibilidade. Enquanto o utilizador está no fluxo, pontuamos mais de 200 sinais de fraude em tempo real e verificamos cada campo em relação a 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.
Construído para locais · Gratuito em cada leitura após o registo
Seis capacidades. $0.25 uma vez, grátis por leitura.
Um registo paga por cada entrada subsequente. A Pesquisa Facial 1:N está incluída gratuitamente em todas as contas Didit; o local paga apenas pela verificação de identidade única na compra.
Uma selfie na finalização da compra. Reutilizável para sempre.
Insira uma sessão da API de Sessões no seu fluxo de compra. A Verificação de ID confirma o comprador, a Prova de Vida Passiva rejeita todas as categorias de Deteção de Ataque de Apresentação (PAD), e o retrato resultante é armazenado como o modelo de índice de evento do comprador — vinculado aos seus vendor_data, reutilizável em todos os eventos futuros que o mesmo comprador participar.
Reutilizável em todos os eventos futuros a que o mesmo comprador comparecer.
02 · O rosto É o bilhete
Sem telemóvel. Sem impressão. Sem código de barras.
No portão, a câmara captura um quadro e o visitante passa. Sem tirar o telemóvel (sem ansiedade com a bateria), sem impressão (sem papel, sem fraude de revenda), sem código Quick Response (QR) de todo. O rosto do comprador É o token de acesso, e a Pesquisa Facial 1:N é gratuita em todos os planos.
Sem código QRSem tirar o telemóvel, sem ansiedade com a bateria
Sem impressãoSem impressão, sem fraude de revenda
Olhe para a câmaraO portão captura um fotograma
Veredito em ~1sCorrespondência com o índice do evento
Correspondência em menos de 1 segundo na entrada.Grátis por digitalização
03 · Matriz de decisão do portão
Entrada. Reentrada. Bloqueio. Configurável.
O payload de correspondência fornece a referência do comprador correspondente e um similarity_score. A sua lógica de portão ramifica: bilhete válido + primeira leitura = entrada; já dentro = política de reentrada; bilhete expirado ou cancelado = encaminhar para o pessoal; revendido ou sem correspondência = bloquear. Por evento, por portão, por nível de bilhete.
Rosto correspondido · já no interiorPolítica de reentrada
Rosto correspondido · bilhete expiradoEncaminhar para a equipa
Rosto correspondido · revendido a outro compradorBloquear
Sem correspondência · rosto desconhecidoBloquear
Configurável por evento, por portão, por nível de bilhete.
04 · Estádio, festival, trânsito
Mesma inscrição. Todas as categorias de locais.
Um modelo facial cobre estádios de futebol, festivais de vários dias, passes de temporada de trânsito e grandes conferências. O comprador regista-se uma vez consigo, e cada local alimentado por Didit que ele frequenta depois disso consome a credencial a custo zero — semântica de Credencial Reutilizável aplicada ao controlo de acesso.
Eventos em estádiosFutebol, concertos, campeonatos
FestivaisVários dias, várias entradas, reutilizável
Corredores de trânsitoPasses de época, passageiros diários
ConferênciasSessões, lounges, salas de exposição
Uma inscrição. Todos os eventos.Mais de 220 países
05 · Capacidade à escala de festival
Correspondência em menos de 1 segundo à escala de festival.
Testado em dezenas de milhares de rostos registados por índice de evento, correspondência de quadro único em aproximadamente um segundo, ~30 entradas por minuto por portão. O tempo de atividade da plataforma é de 99.99% — a mesma API /v3/ que todos os outros módulos Didit, então o manual de operações que já tem para KYC aplica-se ao portão.
Latência de correspondência · entrada única~1 segundo
Débito por entrada~30 / minuto
Tamanho do índice por eventoDezenas de milhares de rostos
Tempo de atividade da plataforma99.99%
Mesma API /v3/ que todos os outros módulos Didit.
06 · Gratuito no portão
$0.25 uma vez. Gratuito por digitalização. 500 gratuitos / mês.
Preços públicos, sem mínimo, sem contrato. Verificação de ID a $0.15 mais Prova de Vida Passiva a $0.10 cobrem o registo único a $0.25 por comprador. A Pesquisa Facial 1:N em cada leitura subsequente no portão é gratuita. Mais barato do que o pipeline de bilhetes de papel impresso, uma vez que se consideram as perdas por fraude e revenda.
Pesquisa facial 1:N na portaGrátis / digitalização
Mais barato do que o processo de bilhetes impressos.
Integrar
Um endpoint de registo. Um endpoint de portão.
Registe o comprador com uma chamada da API de Sessões no checkout. Corresponda o quadro da câmara no portão com uma chamada autónoma de Pesquisa Facial 1:N. O mesmo contrato /v3/ que todos os outros módulos Didit.
Grátis por digitalização. A correspondência retorna vendor_data + similarity_score.docs →
Integração pronta para agente
Envie bilhetes de eventos biométricos numa única solicitação.
Cole no Claude Code, Cursor, Codex, Devin, Aider ou Replit Agent. Preencha a sua stack. O agente provisiona o Didit, constrói o fluxo de trabalho de inscrição, conecta o endpoint de digitalização do portão e envia.
didit-integration-prompt.md
You are integrating Didit's biometric event-ticketing into <my_stack>. The face IS the ticket — no QR code, no barcode, no printout. Two phases:
1. Enrol the buyer ONCE at ticket purchase. A Sessions API call runs ID Verification + Passive Liveness and stores the buyer's portrait as the event-index template.
2. At every gate scan, call the standalone Face Search 1:N endpoint with the camera frame. Sub-1-second match against the event index. Verdict returned inline.
Pricing (public):
- Enrolment (one-time per buyer): $0.15 ID Verification + $0.10 Passive Liveness = $0.25
- Face Search 1:N at the gate: free per scan
- 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.
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. - A workflow_id from the Workflow Builder. The workflow MUST contain ID_VERIFICATION + LIVENESS (and optionally Anti-Money Laundering (AML) if you sell age-restricted access).
- One Didit account = one face index. Tag every enrolment with metadata.event_id so the gate-side search filters by the right event.
STEP 1 — Enrol at ticket purchase
POST https://verification.didit.me/v3/session/
Headers:
x-api-key: <your api key>
Content-Type: application/json
Body:
{
"workflow_id": "<your enrolment workflow>",
"vendor_data": "<your buyer id — must be unique per buyer>",
"callback": "https://<your-app>/ticketing/enrol/callback",
"metadata": {
"order_id": "<your order reference>",
"event_id": "<the event the buyer is entering>",
"ticket_tier": "<GA | VIP | accessible | etc>"
}
}
Response: 201 Created with the hosted session_url. Redirect the buyer. After the buyer completes ID Verification + Passive Liveness, the portrait is stored as their face template and bound to vendor_data.
STEP 2 — Read the signed verdict on enrolment completion
Body (excerpted):
{
"session_id": "<uuid>",
"vendor_data": "<your buyer id>",
"status": "Approved",
"id_verification": { "status": "Approved", "document_type": "Passport" },
"liveness": { "status": "Approved", "method": "PASSIVE", "score": 94 }
}
Verify X-Signature-V2 BEFORE trusting the body. On Approved, mark the order as enrolled and bind the order to vendor_data in your application database.
Session status enum (exact case): Approved | Declined | In Review | Resubmitted | Expired | Not Finished | Kyc Expired | Abandoned.
STEP 3 — At every gate scan, match the face against the event index
POST https://verification.didit.me/v3/face-search/
Headers:
x-api-key: <your api key>
Body (multipart/form-data):
image <the camera frame captured at the gate>
vendor_data <optional — restrict the search to a specific buyer>
metadata <optional JSON — e.g. { "event_id": "<...>" } to filter>
Response (excerpted):
{
"status": "Approved",
"matches": [
{
"vendor_data": "<buyer id>",
"similarity_score": 0.96
}
]
}
Match outcomes the gate logic should handle:
- Match found, ticket valid, no prior scan → grant entry, mark scanned
- Match found, already inside → apply re-entry policy
- Match found, ticket expired or canceled → route to staff
- Match found, ticket resold to another buyer → block, route to staff
- No match (similarity below threshold) → block, fall back to backup ticket flow
STEP 4 — Reusable across every event the same buyer attends
Because the buyer's face template is bound to vendor_data, the SAME enrolment works for every future event the same buyer holds a ticket for. No re-enrolment, no re-payment. Reusable Credential semantics applied to the venue use case.
CONSTRAINTS
- Base URL for /v3/* endpoints is verification.didit.me (NOT apx.didit.me).
- Feature enum is UPPERCASE: 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.
- The face template is irreversible (a one-way hash). End users can request deletion via the standard data-subject-request path.
ACCESS CONTROL CONSIDERATIONS
- For minor-attended events, run AGE_ESTIMATION during enrolment to gate age-restricted areas. See /solutions/age-verification.
- For high-value VIP areas, gate behind a Biometric Authentication step-up. See /solutions/biometric-2fa.
- For accessibility lanes, surface the ticket-tier metadata on the verdict payload and route the gate UI accordingly.
DATA-PROTECTION NOTES
- The enrolment selfie produces an irreversible face template; raw images are deleted unless retention is explicitly enabled.
- The gate frame is processed in memory and not persisted by default.
- Display the privacy notice (didit.me/terms/verification-privacy-notice) to the buyer before the enrolment selfie. EU GDPR Article 13 requires it.
Read the docs:
- https://docs.didit.me/core-technology/face-search/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.
Precisa de mais contexto? Consulte a documentação completa do módulo.docs.didit.me →
Conforme por design
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 enviar verificações num novo país, basta ativar um botão. Mais de 220 países em funcionamento, 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.
Inscrição única por comprador. Cada leitura de portão futura é gratuita.
~1s
Correspondência facial de um único fotograma em índices de eventos à escala de festivais.
0.00%
Tempo de atividade da plataforma — a mesma API /v3/ que todos os outros módulos Didit.
0
Verificações gratuitas todos os meses, para sempre.
Três níveis, uma lista de preços
Comece gratuitamente. Pague por uso. Escale para Enterprise.
500 verificações gratuitas todos os meses, para sempre. Pagamento conforme o uso para produção. Contratos personalizados, residência de dados e SLAs (Service Level Agreements) 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 gratuitamente → pague apenas quando uma verificação for executada → desbloqueie o Enterprise para um contrato personalizado, SLA ou residência de dados.