Tines Automation
Tines is a security and workflow automation platform that uses a straightforward graphical design process to automate tasks.
Incode is an AI-powered identity verification platform that uses government-issued photo IDs and biometric matching to verify a person's identity over the Internet. It is built for workforce, financial, and enterprise use cases.
Tines' ability to work with APIs, combined with the Incode Workforce API, is the simplest way to add automated biometric identity verification to your security workflows, HR pipelines, or customer onboarding processes.
This article assumes you have some familiarity with Tines and no familiarity with Incode. For an introduction to Tines, see Tines University.
Collect Your Incode Credentials
You need three things from Incode to configure Tines:
- An API key (
*API_KEY*) - An integration ID (
*INTEGRATION_ID*) - An integration secret (
*INTEGRATION_SECRET*)
To retrieve these values:
- Open Dashboard and log in.
- Go to Settings > API Keys in the left menu.
- Select Create new API key.
- Enter a descriptive name such as
tines-integration. - Copy the generated key. This is your
*API_KEY*. - Go to Integrations in the left menu.
- Select the integration you want to use or create a new one.
- From the integration detail page, copy the Integration ID and Integration Secret. These are your
*INTEGRATION_ID*and*INTEGRATION_SECRET*.
NoteIf you are using Incode's sandbox environment, your API base URL will be
https://demo-api-incode-id.incodesmile.com. For production, use the base URL provided by your Incode Representative.
Add Credentials to Tines
- Go to Tines and click Credentials in the left menu.
- Add
*API_KEY*as a Text Credential namedincode_x_api_key. Addincodesmile.comin the Domains field. - Add
*INTEGRATION_ID*as a Text Credential namedincode_workforce_integrationid. Leave Domains blank. - Add
*INTEGRATION_SECRET*as a Text Credential namedincode_workforce_secret. Leave Domains blank.
All three credentials are entered as Text credentials and will look like this in the Tines Credentials panel:
| Name | Type | Domains |
|---|---|---|
incode_x_api_key | Text | incodesmile.com |
incode_workforce_integrationid | Text | — |
incode_workforce_secret | Text | — |
Set Up Tines Actions
The steps below configure Tines to:
- Authenticate with the Incode API to get a session token.
- Generate a personalized verification link for the customer.
- Deliver that link to the customer.
- Wait for a webhook from Incode when the user completes verification.
- Validate the webhook and use the result.
Authenticate with Incode
Before you can generate a verification link, the Incode API requires a short-lived session token obtained through a server-side authentication call. This token is used as the x-auth-token header in subsequent requests.
- Drag the HTTP Request action into your story from the sidebar and configure it as follows:
- Name:
GetIncodeToken - URL:
https://demo-api-incode-id.incodesmile.com/v1/integration/authorize/server - Content type: JSON
- Method:
POST - Headers:
x-api-key: {user.CREDENTIAL.incode_x_api_key} - Payload:
{ "integrationId": "CREDENTIAL.INCODE_WORKFORCE_INTEGRATIONID", "secret": "CREDENTIAL.INCODE_WORKFORCE_SECRET" }
{ "url": "https://demo-api-incode-id.incodesmile.com/v1/integration/authorize/server", "content_type": "application_json", "method": "post", "headers": { "x-api-key": "CREDENTIAL.INCODE_X_API_KEY" }, "payload": { "integrationId": "CREDENTIAL.INCODE_WORKFORCE_INTEGRATIONID", "secret": "CREDENTIAL.INCODE_WORKFORCE_SECRET" } } - Name:
- Select Play on this action. The events window should show a successful response from Incode:
{ "token": "eyJhbGci....", "expiresAt": 1714512000 }
The token field is the session token. It is short-lived, so this action should run at the beginning of each story run. Don't store it for reuse across separate executions.
Generate a Verification Link
Now that you have a session token, you can generate a personalized, time-limited verification link for the end-user.
-
Drag another HTTP Request action into your story and configure it as follows:
- Name:
GenerateVerificationLink - URL:
https://demo-api-incode-id.incodesmile.com/v1/workforce/verification/candidate/generate-verification-link - Content type: JSON
- Method:
POST - Headers:
x-auth-token: GETINCODETOKEN.BODY.TOKEN - Payload:
{ "integrationID": "CREDENTIAL.INCODE_WORKFORCE_INTEGRATIONID", "secret": "CREDENTIAL.INCODE_WORKFORCE_SECRET", "loginHint": "USER_EMAIL", "loginHintType": "EMAIL", "validityMinutes": 4320, "redirectUrl": "https://your-company.com", "givenNames": "USER_FIRST_NAME", "lastName": "USER_LAST_NAME" }
- Name:
-
Replace
USER_EMAIL,USER_FIRST_NAME, andUSER_LAST_NAMEwith the Tines variables from wherever you collect the user's information earlier in your story: for example, from a web form, a webhook payload, or a previous API call. -
The
validityMinutesfield controls how long the verification link stays active.4320equals 72 hours, which is a sensible default for most workflows. Adjust this to suit your use case.In the Editor view, this looks like:
{ "url": "https://demo-api-incode-id.incodesmile.com/v1/workforce/verification/candidate/generate-verification-link", "content_type": "application_json", "method": "post", "headers": { "x-auth-token": "GETINCODETOKEN.BODY.TOKEN" }, "payload": { "integrationID": "CREDENTIAL.INCODE_WORKFORCE_INTEGRATIONID", "secret": "CREDENTIAL.INCODE_WORKFORCE_SECRET", "loginHint": "USER_EMAIL", "loginHintType": "EMAIL", "validityMinutes": 4320, "redirectUrl": "https://your-company.com", "givenNames": "USER_FIRST_NAME", "lastName": "USER_LAST_NAME" } } -
Select Play on this action. The response from Incode looks like:
{ "verificationLink": "https://verify.incode.com/x/acme/abcd1234xyz", "verificationTraceId": "f78ee334-79a8-4a5e-be4a-d728e226df64" }
The two key fields are:
verificationLink: The URL you will send to the customer so they can complete biometric verification.verificationTraceId: A unique identifier for this verification session. Store this value. You will use it later to match the Incode webhook callback to this specific verification request
Deliver the Verification Link
Tines offers many methods to deliver data to end-users. Any of them will work for delivering this link: email, Slack, SMS, or a redirect from a Tines page.
To demonstrate the flow, we use email delivery. If your story has already collected the user's email address from a form or upstream system, skip the form step.
Collect the User's Email
- If you need to collect the user's details first, select + / Tools on the left of your Tines workspace.
- Drag a Page object onto your workspace.
- Name the page
Request Identity Verification. - Add input fields for the user's email address, first name, and last name.
Send the Email
- Drag the Send Email action from the sidebar onto your workspace and configure it as follows:
- Recipients:
USER_EMAIL(orREQUEST_IDENTITY_VERIFICATION.BODY.EMAILif using a Tines form) - Reply to: Your team's support email address
- Sender name: Your company or team name
- Subject:
Your identity verification request from *COMPANY* - Body: Write a message explaining the purpose of the verification. Include the link using the Tines variable
GENERATEVERIFICATIONLINK.BODY.VERIFICATIONLINK. For example:Hi USER_FIRST_NAME, Please complete your identity verification by clicking the link below. The process takes less than 5 minutes and requires a government-issued photo ID and a quick facial scan. Verify your identity: GENERATEVERIFICATIONLINK.BODY.VERIFICATIONLINK This link expires in 72 hours. If you have any questions, reply to this email and our team will be happy to help.
- Recipients:
- Connect the actions in your story so they run in this order:
GetIncodeToken→GenerateVerificationLink→Send Email. - To test the flow, run the story and confirm the email arrives with a working verification link.
Set Up the Incode Webhook
Incode can POST a signed message to a pre-defined HTTP endpoint when an end-user completes or fails verification. This is how you receive the result back into your Tines story.
Create the Webhook Action in Tines
- Go to your Tines story and drag a Webhook Action into your workspace.
- Select it to edit.
- Set Allowed verbs to
POSTonly. - Select Copy next to the Webhook URL to copy it. This is the
*DELIVERY_URL*you will register in Incode.
Register the Webhook in Incode
- Open Dashboard.
- Go to Configuration > Webhooks.
- Select your integration and open the Webhooks tab.
- Select Add Webhook and configure it as follows:
Field Value Delivery URL Paste the *DELIVERY_URL*you copied from TinesEvents verification.succeeded,verification.failedEnabled Toggle on - Save the webhook. Incode will now POST an event to your Tines story each time a user completes or fails a verification session on this integration.
Name the Webhook Action
Back in Tines, rename the Webhook Action to IncodeStatusWebhook to make it easy to reference in downstream actions.
Validate the Webhook in Tines
When Incode posts a verification result to your Tines story, the webhook body looks like this:
{
"event_type": "verification.succeeded",
"data": {
"verification_trace_id": "f78ee334-79a8-4a5e-be4a-d728e226df64",
"failure_reason": null,
"ip": "203.0.113.42",
"user_name": "Jane Smith",
"latitude": 37.7749,
"longitude": -122.4194
}
}The verification_trace_id in the callback matches the verificationTraceId you received when you generated the link. This is how you confirm that this callback belongs to the verification session you initiated.
Create a Trigger Action
- Drag a Trigger Action into your story.
- Configure a rule that checks the incoming
event_typeand passes only events for successfully completed verifications:{ "rules": [ { "type": "field==value", "value": "verification.succeeded", "path": "INCODESTATUSWEBHOOK.BODY.EVENT_TYPE" } ] }
This ensures that the rest of your story only runs when verification succeeds. To handle failures separately, add a second Trigger Action with "value": "verification.failed" and connect it to a different branch.
Confirm the Trace ID
If your story initiated the verification session and stored the verificationTraceId, you can add a second Trigger Action to confirm the callback matches the session you expect:
{
"rules": [
{
"type": "field==value",
"value": "GENERATEVERIFICATIONLINK.BODY.VERIFICATIONTRACEID",
"path": "INCODESTATUSWEBHOOK.BODY.DATA.VERIFICATION_TRACE_ID"
}
]
}
NoteIn asynchronous workflows where the verification link is sent and the result arrives in a separate story run, use Tines Records to store the
verificationTraceIdalongside any relevant identifiers—such as a user ID or opportunity ID—when the link is generated. Then look up that record using the incomingverification_trace_idwhen the callback arrives. See Tines Records documentation for details.
Use the Verification Result
The data object in the webhook payload contains the following fields:
| Field | Description |
|---|---|
verification_trace_id | Unique ID for this verification session |
failure_reason | Reason for failure if verification did not succeed; null on success |
ip | IP address of the device used for verification |
user_name | Name of the person as verified by Incode |
latitude / longitude | Approximate geolocation of the device at verification time |
Here are some examples of how you can use this data in Tines:
- ATS integration: Use an HTTP Request action to add a
biometric-verifiedtag and post a note to the candidate's profile in your applicant tracking system: for example, Lever, Greenhouse, or Workday. - IT provisioning: Trigger an account creation or password reset workflow after identity is confirmed, combining the verified name with a lookup in your corporate directory.
- Access control: Update a record in your IAM or HRIS system to reflect that this person has completed biometric verification.
- Helpdesk escalation: Send the verified identity details to a Slack channel or a support ticket so an agent can take over with confidence.
- Audit log: Write the
verification_trace_id, verified name, IP, and timestamp to a Tines Record or external data store for compliance.
To display the result for testing:
- Drag a Page object onto your workspace.
- Set the Page behavior to Show success message.
- Set the success message to:
Identity verification complete. Verified name: INCODESTATUSWEBHOOK.BODY.DATA.USER_NAME Trace ID: INCODESTATUSWEBHOOK.BODY.DATA.VERIFICATION_TRACE_ID Processed: <<DATE("now")>>
Summary
At the end of these steps, your Tines story will consist of two connected flows:
Flow 1: Send Verification
[Collect user details] → [GetIncodeToken] → [GenerateVerificationLink] → [Send Email]
Flow 2: Receive Result
[IncodeStatusWebhook] → [Check event_type] → [Use verified data]
This story shows how to use the Incode Workforce API in Tines to verify any user's identity and feed the result back into any downstream system Tines can reach.
