Skip to main content

Create Process

This endpoint handles two use cases that share the same path but differ in body parameters, capabilities, and response fields:

  • Onboarding — validates who the user is by comparing their face against Unico's identity base (subject.code required).
  • Transactional — verifies it's the same person from a previous process by comparing face-to-face (referenceProcessId OR references array with selfie / process id required).

The active use case is determined by the APIKEY sent in the request header.

For the full integration flow, see API Overview.

Endpoint

EnvironmentURL
ProductionPOST https://api.id.unico.app/processes/v1
SandboxPOST https://api.id.uat.unico.app/processes/v1

Request

Headers
HeaderValue
AuthorizationBearer <access_token> (see Authentication)
APIKEYProvisioned API key — defines the active use case and enabled capabilities.
Content-Typeapplication/json
Body parameters
FieldTypeRequiredDescription
subject.codestringyesCPF (BR) or CURP (MX).
subject.namestringyesFull name.
subject.genderstringnoM or F.
subject.birthDatestring (ISO 8601)noDate of birth (YYYY-MM-DD).
subject.emailstringnoEmail address.
subject.phonestringnoE.164 phone number.
useCasestringnoOperation context, e.g. Onboarding.
imageBase64stringyesSelfie captured by your front-end, in base64.
Image requirements
  • Minimum resolution: 640 × 480 (HD standard)
  • Maximum file size: 800 KB (JPEG92 compression recommended)
  • Accepted formats: PNG, JPEG, WebP
  • JWT tokens from the SDK expire after 10 minutes and can only be used once

Example

curl -X POST https://api.id.unico.app/processes/v1 \
-H "Authorization: Bearer $TOKEN" \
-H "APIKEY: $API_KEY" \
-H "Content-Type: application/json" \
-d '{
"subject": {
"code": "12345678909",
"name": "Luke Skywalker",
"gender": "M",
"birthDate": "2000-05-20",
"email": "[email protected]",
"phone": "5519725570707"
},
"useCase": "Onboarding",
"imageBase64": "/9j/4AAQSkZJR..."
}'

Responses

200 OK
{
"id": "80371b2a-3ac7-432e-866d-57fe37896ac6",
"status": 3,
"unicoId": { "result": "yes" },
"identityFraudsters": { "result": "inconclusive" },
"government": { "serpro": 87 },
"liveness": 1
}
FieldTypeDescription
idstring (UUID)Process identifier. Use with Get Process for re-queries.
statusinteger1 (processing), 3 (finished with success), 5 (error). For all possible values, see Get Process.
unicoId.resultstringyes, no, inconclusive — see Identity Verification.
identityFraudsters.resultstringyes, inconclusive — see Risk Fraud Classification.
government.serprointegerSerpro similarity score (0–100, -1, -2). See Serpro Similarity.
livenessinteger1 (passed), 2 (failed) — see Liveness.
info

When unicoId.result = inconclusive and Risk Score orchestration is active, the process may return status: 1 (processing). Poll Get Process or use webhooks to retrieve the final result.

400 Bad Request

The payload is malformed, the image is invalid, or required fields are missing. See Error Codes below.

403 Forbidden

Bearer token or APIKEY missing, expired, or invalid. See Authentication.

409 Conflict

The processId provided already exists for this tenant. See Error Codes below.

429 Too Many Requests

Rate limit reached. Retry after the interval indicated in the Retry-After response header. See Rate limits.

Error Codes

CodeMessageDescription
20900O base64 informado não é válido.The base64 parameter is invalid. Possible causes: it's not an image or it's an injection attempt.
20807A imagem precisa estar no padrão HD ou possuir uma resolução superior a 640 x 480.The resolution of the uploaded image is too low.
20513The referenced process was not found.The referenceProcessId points to a process that does not exist or is no longer accessible.
20512The referenced process is not available for reuse.The referenced process exists but is not available for reuse.
20509The subject.name field is invalid.subject.name contains invalid characters.
20508The subject.gender field is invalid.subject.gender must be M or F.
20507O parâmetro subject.code é inválido.Non-standard or non-existent CPF.
20506O base64 informado é muito grande. O tamanho máximo suportado é até 800kb.Image size exceeds 800 KB; compress to JPEG92.
20505O base64 informado não é suportado. Os formatos aceitos são png, jpeg e webp.The base64 format is invalid or unsupported.
20065The referenceProcessId field is invalid.The referenceProcessId is not a valid UUID.
20062The useCase field is invalid.Unrecognized value in the useCase field.
20024The referenceProcessId field is missing.The referenceProcessId parameter was not provided and references was not sent as an alternative.
20021The subject.phone field is invalid.subject.phone format is invalid (IDD + area code + number, 13 chars).
20019The subject.birthDate field is invalid.subject.birthDate is outside ISO 8601 format (YYYY-MM-DD).
20009O parâmetro imagebase64 não foi informado.The selfie image parameter is missing.
20008The subject.email field is invalid.Invalid email format in subject.email.
20006O parâmetro subject.name não foi informado.The subject.name parameter is missing.
20005O parâmetro subject.code não foi informado.The subject.code parameter is missing.
20004O parâmetro subject não foi informado.The subject parameter is missing.
20003The request body is missing or invalid.Null or invalid payload.
20002O parâmetro APIKey não foi informado.The APIKEY parameter is missing from the request header.
20001O parâmetro authtoken não foi informado.The integration token parameter is missing from the request header.
10508The JWT with the captured face has already been used.The JWT can only be used once.
10507The JWT with the captured face is expired.JWT expired; must be sent within 10 minutes.
10506The imageBase64 field is not a valid JWT from SDK.The imageBase64 is not a valid JWT generated by the SDK.

What's next

  • For querying an Onboarding process result, see Get Process.
  • For Document and Age Verification operations, see the respective pages in this section.