By using the Play Age Signals API (beta), you agree to the terms of service and you agree to comply with all Google Play developer policies. To request the user's status and age range, you call the API from your app at runtime. The Play Age Signals API only returns data for users based in regions where Play is required by law to provide age category data.
Play returns an age range based on the age bands defined by the applicable jurisdiction and regions. The default ages the API returns in applicable jurisdictions and regions are 0-12, 13-15, 16-17, and 18+ but these may change based on regional requirements.
Integrate Play Age Signals API into your app
To integrate the Play Age Signals API into your app, add the following
dependency to your app's build.gradle
file:
implementation 'com.google.android.play:age-signals:0.0.1-beta02'
Request age signals
Here's an example of making an age signals request:
Kotlin
// Create an instance of a manager val ageSignalsManager = AgeSignalsManagerFactory.create(ApplicationProvider.getApplicationContext()) // Request an age signals check ageSignalsManager .checkAgeSignals(AgeSignalsRequest.builder().build()) .addOnSuccessListener { ageSignalsResult -> // Store the install ID for later... val installId = ageSignalsResult.installId() if (ageSignalsResult.userStatus() == AgeSignalsVerificationStatus.SUPERVISED_APPROVAL_DENIED) { // Disallow access... } else { // Do something else if the user is SUPERVISED, VERIFIED, etc. } }
Java
// Create an instance of a manager AgeSignalsManager ageSignalsManager = AgeSignalsManagerFactory.create(ApplicationProvider.getApplicationContext()); // Request an age signals check ageSignalsManager .checkAgeSignals(AgeSignalsRequest.builder().build()) .addOnSuccessListener( ageSignalsResult -> { // Store the install ID for later... String installId = ageSignalsResult.installId(); if (ageSignalsResult .userStatus() .equals(AgeSignalsVerificationStatus.SUPERVISED_APPROVAL_DENIED)) { // Disallow access ... } else { // Do something else if the user is SUPERVISED, VERIFIED, etc. } });
Age signals are stored by Google Play on the device for each user. When a user with a supervised Google Account ages into a new age range, Google Play automatically updates the cached age signals for that user within 2 to 8 weeks following the user's birthday.
(Optional) Receive custom age ranges
The default age ranges that the API returns in applicable jurisdictions and regions are 0-12, 13-15, 16-17, and 18+. These may change in the future based on local requirements.
Alternatively, to customize the age ranges according to your app's minimum ages, you can provide these minimum ages for your app on the Age signals page in your Google Play Console. The Age Signals API returns the customized age ranges. For example, if you provide minimum ages of 9, 15, and 17, a 14-year-old user would fall within the 10-15 age range. Minimum ages must be at least 2 years apart and can be changed once annually.
To customize the age ranges returned by the Age Signals API, you can provide minimum ages for your app:
- Go to the Age signals page in your Play Console.
- On the App's minimum ages tab, enter up to three minimum ages for your app.
- Click Save.
Age signals responses
The Play Age Signals API (beta) response includes the following fields and values. The values are subject to change. If you want the most recent values, request an API response when your app opens. You are responsible for providing age-appropriate experiences using these signals.
Response field | Values | Description |
---|---|---|
userStatus |
VERIFIED | The user is over 18. Google verified the user's age using a commercially reasonable method such as a government-issued ID, credit card, or facial age estimation. |
SUPERVISED | The user has a supervised Google Account managed by a parent who sets their age.
Use ageLower and ageUpper to determine the user's age range. |
|
SUPERVISED_APPROVAL_PENDING | The user has a supervised Google Account, and their supervising parent has not yet approved one or more pending significant changes.
Use ageLower and ageUpper to determine the user's age range.
Use mostRecentApprovalDate to determine the last significant change that was approved. |
|
SUPERVISED_APPROVAL_DENIED | The user has a supervised Google Account, and their supervising parent denied approval for one or more significant changes.
Use ageLower and ageUpper to determine the user's age range.
Use mostRecentApprovalDate to determine the last significant change that was approved. |
|
UNKNOWN | The user is not verified or supervised in applicable jurisdictions and regions. These users could be over or under 18. To obtain an age signal from Google Play, ask the user to visit the Play Store to resolve their status. | |
Empty (a blank value) | All other users return this value. | |
ageLower |
0 to 18 | The (inclusive) lower bound of a supervised user's age range.
Use the ageLower and ageUpper to determine the user's age range. |
Empty (a blank value) |
userStatus is unknown or empty. |
|
ageUpper |
2 to 18 | The (inclusive) upper bound of a supervised user's age range.
Use the ageLower and ageUpper to determine the user's age range. |
Empty (a blank value) | Either the userStatus is supervised and the user's parent attested age is over 18.
Or the userStatus is verified, unknown, or empty. |
|
mostRecentApprovalDate |
Datestamp | The effective from date of the most recent significant change that was approved. When an app is installed, the date of the most recent significant change prior to install is used. |
Empty (a blank value) | Either the userStatus is supervised and no significant change has been submitted.
Or userStatus is verified, unknown, or empty. |
|
installID |
Play-generated alphanumeric ID. | An ID assigned to supervised user installs by Google Play, used for the purposes of notifying you of revoked app approval. Review the documentation for revoked app approvals. |
Empty (a blank value) | userStatus is verified, unknown, or empty. |
Example responses
For a verified user, you would receive the following:
userStatus
would beAgeSignalsVerificationStatus.VERIFIED
.- Other response fields would be empty.
For a supervised user, you would receive the following:
userStatus
would beAgeSignalsVerificationStatus.SUPERVISED
.ageLower
would be a number (e.g. 13).ageUpper
would be a number (e.g. 15).mostRecentApprovalDate
would be a Java date object (e.g.2026-01-01
) or empty (if no significant change has been approved).installID
would be a Play-generated alphanumeric ID (e.g.550e8400-e29b-41d4-a716-446655441111
).
For a supervised user with a significant change approval pending, you would receive the following:
userStatus
would beAgeSignalsVerificationStatus.SUPERVISED_APPROVAL_PENDING
.ageLower
would be a number (e.g. 13).ageUpper
would be a number (e.g. 15).mostRecentApprovalDate
would be a Java date object (e.g.2026-01-01
) or empty (if no significant change has been approved).installID
would be a Play-generated alphanumeric ID (e.g.550e8400-e29b-41d4-a716-446655441111
).
Handle API error codes
If your app makes a Play Age Signals API (beta) request and the call fails, your app receives an error code. These errors can happen for various reasons, such as the Play Store app being out of date.
Retry strategy
In situations where the user is in session, we recommend implementing a retry strategy with a maximum number of attempts as an exit condition so that the error disrupts the user experience as little as possible.
Numerical value of error code | Error Code | Description | Retryable |
---|---|---|---|
-1 | API_NOT_AVAILABLE | The Play Age Signals API is not available. The Play Store app version installed on the device might be old. Possible resolution
|
Yes |
-2 | PLAY_STORE_NOT_FOUND | No Play Store app is found on the device. Ask the user to install or enable the Play Store. | Yes |
-3 | NETWORK_ERROR | No available network is found. Ask the user to check for a connection. | Yes |
-4 | PLAY_SERVICES_NOT_FOUND | Play Services is not available or its version is too old. Ask the user to install, update, or enable Play Services. | Yes |
-5 | CANNOT_BIND_TO_SERVICE | Binding to the service in the Play Store has failed. This can be due to having an old Play Store version installed on the device or device memory is overloaded. Ask the user to update the Play Store app. Retry with an exponential backoff. | Yes |
-6 | PLAY_STORE_VERSION_OUTDATED | The Play Store app needs to be updated. Ask the user to update the Play Store app. | Yes |
-7 | PLAY_SERVICES_VERSION_OUTDATED | Play Services needs to be updated. Ask the user to update Play Services. | Yes |
-8 | CLIENT_TRANSIENT_ERROR | There was a transient error in the client device. Implement a retry strategy with a maximum number of attempts as an exit condition. If the issue still doesn't resolve, ask the user to try again later. | Yes |
-9 | APP_NOT_OWNED | The app was not installed by Google Play. Ask the user to get your app from Google Play. | No |
-100 | INTERNAL_ERROR | Unknown internal error. Implement a retry strategy with a maximum number of attempts as an exit condition. If the issue still doesn't resolve, ask the user to try again later. If it fails consistently, contact Google Play Developer support, include Play Age Signals API in the subject, and include as much technical detail as possible (such as a bug report). | No |
Content and code samples on this page are subject to the licenses described in the Content License. Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
Last updated 2025-10-22 UTC.