Overview
Welcome to the developer documentation for integrating our Age verification as a service solution.
Yoti Age Verification gives people simple ways to prove their age, using things like a selfie or a mobile number. Designed to only share the result of the age check with a business, it’s an easy way to deliver age-appropriate services without collecting user data.
This section will guide you through the implementation steps for our age verification service API on mobile or web, and leverages our hosted web user interface. This s incorporates multiple Yoti products and provides all user interaction.
If you are looking to implement checks without using our UI including email address check, please refer to Age Verification Headless instead.
The six services that can be added to the age verification service are:
| Service | Description | 
|---|---|
| Age estimation | User has their age estimated based on facial analysis from a real-time selfie. | 
| Digital ID | User shares an Over Age from their Yoti app by scanning a QR code. | 
| Identity document verification | User uploads a scan of their ID document and a selfie (optional). | 
| Credit card check | User enters their credit card details which are verified against the database. | 
| Mobile provider | User enters their mobile number which are verified against the database. | 
| Database check | User’s details are checked against a database. | 
Three types of age checks are available:
- A standard AGE check that returns the age of a user.
- An OVER check that informs you if a user is over a defined age threshold, but protects the user’s details by not sharing their actual age is not shared.
- An UNDER check that informs you if a user is under a defined age threshold, but protects the user’s details by not sharing their actual age is not shared.
The overview below sets out the entities and data flows involved.
Technical overview
This section describes the API interactions for a web and mobile web integration. Data is exchanged securely between the relying party (your backend), Yoti and the client (the end user’s browser or mobile device).

Technical Flow
A session represents one end-to-end request of the age verification service. The session identifier is in the create session request's response. Every time a user elects a method of age verification on your relying business app or website, you will need to create a session with Yoti to perform the checks.
Once the Yoti Client has launched, it will take the end user through the appropriate age capture flow. Once this flow is completed the end user is redirected back to the relying business, so that they may continue their journey. These redirects are defined when generating the session.
The session can be retrieved using the session ID. The response from this endpoint contains information on the age of the user, result and method.
Feature list
The Age verification service is very adaptable, please see below for features available for you to configure within your session.
| Feature | Description | Data requested | Data received | 
|---|---|---|---|
| Age estimation | User has their age estimated based on facial analysis from a real-time selfie. | Real-time selfie using camera on device. | Over or under age, or the age itself. | 
| Digital ID | User shares an Over Age from their Digital ID app by scanning a QR code. | ID document and biometric selfie in the Digital ID app. | Over or under age, or the age itself. | 
| ID verification | User uploads a scan of their ID document and a selfie (optional). | ID document and biometric selfie. | Over or under age, or the age itself. | 
| Credit card check | User enters their credit card details which are verified against the database. Please email us if you want this enabled. | PAN number, expiry date, CV2 number, zip code. | Over 18 | 
| Database check | User’s details are checked against a database. | Name, address, and date of birth. | Over or under age, or the age itself. | 
| Mobile provider | User enters their mobile number which are verified against the database. | Mobile provider details. | Over or under age, or the age itself. | 
| Age tokens | When someone uses the service to prove their age, an age token is added to their browser. This acts as a digital proof that they’ve been age checked by Yoti, and lets them freely access your site without having to prove their age every time. | N/A | N/A | 
| Age accounts | Users can store their age tokens in an age account. This allows users to access your website on another browser or device, without having to prove your age again. | N/A | N/A | 
The user flow
The user will be asked to prove their age and is taken through the Yoti verification steps where they will be presented with the options you have selected. You will then need to redirect them to a success or error URL, alternatively you can listen to post messaging from the iframe.

Age verification options
Our product will walk the user through their chosen option of age verification.

Translations supported
Our service will detect and support translations by browser locale settings.
Supported translations are:
- Arabic (العربية) 🇸🇦
- Brazilian Portuguese (Português Brasileiro) 🇧🇷
- Bosnian (bosanski) 🇧🇦
- Chinese (中文) 🇨🇳
- Croatian (hrvatski)
- Danish (Dansk) 🇩🇰
- Finnish (Suomi) 🇫🇮
- French (Français) 🇫🇷
- German (Deutsch) 🇩🇪
- Greek (Ελληνικά) 🇬🇷
- Italian (Italiano) 🇮🇹
- Indonesian (Bahasa Indonesia) 🇮🇩
- Japanese (日本語) 🇯🇵
- Korean (한국어) 🇰🇷
- Latin-American Spanish (Español Latinoamericano)
- Polish (Polski) 🇵🇱
- Portuguese (Português) 🇵🇹
- Russian (Русский) 🇷🇺
- Serbian (српски) 🇷🇸
- Spanish (Español) 🇪🇸
- Swedish (Svenska) 🇸🇪
- Tagalog 🇵🇭
- Thai (ไทย) 🇹🇭
- Turkish (Türkçe) 🇹🇷
- Urdu (اُردُو) 🇵🇰
- Vietnamese (Tiếng Việt) 🇻🇳
Please note: Some age verification methods may not be available in all the languages listed above. For queries around supported languages, please contact us via support.yoti.com.
Supported browsers

Supported browsers
Using Yoti responsibly
We pride ourselves on how we handle our users' data. We use tech for good and enable users to securely prove their identity or age, always being transparent about what happens to their details.
- Be transparent about why you're collecting data and only use this data for those reasons.
- Only collect the information you actually need. Data minimisation is one of the main benefits of Yoti, so people don't have to provide more information than is actually necessary.
- Make sure any information you export to your own systems is stored securely. Data security is at the heart of what we do and we think it should be important to every organisation.

