CustomAudienceManager
  public
  
  
  
  class
  CustomAudienceManager
  
    extends Object
  
  
  
  
  
  
| java.lang.Object | |
| ↳ | android.adservices.customaudience.CustomAudienceManager | 
CustomAudienceManager provides APIs for app and ad-SDKs to join / leave custom audiences.
Summary
| Public methods | |
|---|---|
| 
        
        
        
        
        
        void | 
      fetchAndJoinCustomAudience(FetchAndJoinCustomAudienceRequest fetchAndJoinCustomAudienceRequest, Executor executor, OutcomeReceiver<Object, Exception> receiver)
      Adds the user to the  | 
| 
        
        
        static
        
        
        CustomAudienceManager | 
      get(Context context)
      Factory method for creating an instance of CustomAudienceManager. | 
| 
        
        
        
        
        
        TestCustomAudienceManager | 
      getTestCustomAudienceManager()
      Create a service with test-enabling APIs | 
| 
        
        
        
        
        
        void | 
      joinCustomAudience(JoinCustomAudienceRequest joinCustomAudienceRequest, Executor executor, OutcomeReceiver<Object, Exception> receiver)
      Adds the user to the given  | 
| 
        
        
        
        
        
        void | 
      leaveCustomAudience(LeaveCustomAudienceRequest leaveCustomAudienceRequest, Executor executor, OutcomeReceiver<Object, Exception> receiver)
      Attempts to remove a user from a custom audience by deleting any existing  | 
| 
        
        
        
        
        
        void | 
      scheduleCustomAudienceUpdate(ScheduleCustomAudienceUpdateRequest request, Executor executor, AdServicesOutcomeReceiver<Object, Exception> receiver)
      Allows the API caller to schedule a deferred Custom Audience update. | 
| Inherited methods | |
|---|---|
Public methods
fetchAndJoinCustomAudience
public void fetchAndJoinCustomAudience (FetchAndJoinCustomAudienceRequest fetchAndJoinCustomAudienceRequest, Executor executor, OutcomeReceiver<Object, Exception> receiver)
Adds the user to the CustomAudience fetched from a fetchUri.
 
An attempt to register the user for a custom audience with the same combination of ownerPackageName, buyer, and name will cause the existing custom audience's
 information to be overwritten, including the list of ads data.
 
Note that the ads list can be completely overwritten by the daily background fetch job.
This call fails with an SecurityException if
 
- the ownerPackageNameis not calling app's package name and/or
- the buyer is not authorized to use the API.
This call fails with an IllegalArgumentException if
 
- the storage limit has been exceeded by the calling application and/or
- any URI parameters in the CustomAudiencegiven are not authenticated with theCustomAudiencebuyer.
This call fails with LimitExceededException if the calling package exceeds the
 allowed rate limits and is throttled.
 
This call fails with an IllegalStateException if an internal service error is
 encountered.
 
 Requires AdServicesPermissions.ACCESS_ADSERVICES_CUSTOM_AUDIENCE
| Parameters | |
|---|---|
| fetchAndJoinCustomAudienceRequest | FetchAndJoinCustomAudienceRequest: This value cannot benull. | 
| executor | Executor: This value cannot benull.
 Callback and listener events are dispatched through thisExecutor, providing an easy way to control which thread is
 used. To dispatch events through the main thread of your
 application, you can useContext.getMainExecutor().
 Otherwise, provide anExecutorthat dispatches to an appropriate thread. | 
| receiver | OutcomeReceiver: This value cannot benull. | 
get
public static CustomAudienceManager get (Context context)
Factory method for creating an instance of CustomAudienceManager.
| Parameters | |
|---|---|
| context | Context: TheContextto use
 This value cannot benull. | 
| Returns | |
|---|---|
| CustomAudienceManager | A CustomAudienceManagerinstance
 This value cannot benull. | 
getTestCustomAudienceManager
public TestCustomAudienceManager getTestCustomAudienceManager ()
Create a service with test-enabling APIs
| Returns | |
|---|---|
| TestCustomAudienceManager | This value cannot be null. | 
joinCustomAudience
public void joinCustomAudience (JoinCustomAudienceRequest joinCustomAudienceRequest, Executor executor, OutcomeReceiver<Object, Exception> receiver)
Adds the user to the given CustomAudience.
 
An attempt to register the user for a custom audience with the same combination of ownerPackageName, buyer, and name will cause the existing custom audience's
 information to be overwritten, including the list of ads data.
 
Note that the ads list can be completely overwritten by the daily background fetch job.
This call fails with an SecurityException if
 
- the ownerPackageNameis not calling app's package name and/or
- the buyer is not authorized to use the API.
This call fails with an IllegalArgumentException if
 
- the storage limit has been exceeded by the calling application and/or
- any URI parameters in the CustomAudiencegiven are not authenticated with theCustomAudiencebuyer.
This call fails with LimitExceededException if the calling package exceeds the
 allowed rate limits and is throttled.
 
This call fails with an IllegalStateException if an internal service error is
 encountered.
 
 Requires AdServicesPermissions.ACCESS_ADSERVICES_CUSTOM_AUDIENCE
| Parameters | |
|---|---|
| joinCustomAudienceRequest | JoinCustomAudienceRequest: This value cannot benull. | 
| executor | Executor: This value cannot benull.
 Callback and listener events are dispatched through thisExecutor, providing an easy way to control which thread is
 used. To dispatch events through the main thread of your
 application, you can useContext.getMainExecutor().
 Otherwise, provide anExecutorthat dispatches to an appropriate thread. | 
| receiver | OutcomeReceiver: This value cannot benull. | 
leaveCustomAudience
public void leaveCustomAudience (LeaveCustomAudienceRequest leaveCustomAudienceRequest, Executor executor, OutcomeReceiver<Object, Exception> receiver)
Attempts to remove a user from a custom audience by deleting any existing CustomAudience data, identified by ownerPackageName, buyer, and name.
 
This call fails with an SecurityException if
 
- the ownerPackageNameis not calling app's package name; and/or
- the buyer is not authorized to use the API.
This call fails with LimitExceededException if the calling package exceeds the
 allowed rate limits and is throttled.
 
This call does not inform the caller whether the custom audience specified existed in
 on-device storage. In other words, it will fail silently when a buyer attempts to leave a
 custom audience that was not joined.
 
 Requires AdServicesPermissions.ACCESS_ADSERVICES_CUSTOM_AUDIENCE
| Parameters | |
|---|---|
| leaveCustomAudienceRequest | LeaveCustomAudienceRequest: This value cannot benull. | 
| executor | Executor: This value cannot benull.
 Callback and listener events are dispatched through thisExecutor, providing an easy way to control which thread is
 used. To dispatch events through the main thread of your
 application, you can useContext.getMainExecutor().
 Otherwise, provide anExecutorthat dispatches to an appropriate thread. | 
| receiver | OutcomeReceiver: This value cannot benull. | 
scheduleCustomAudienceUpdate
public void scheduleCustomAudienceUpdate (ScheduleCustomAudienceUpdateRequest request, Executor executor, AdServicesOutcomeReceiver<Object, Exception> receiver)
Allows the API caller to schedule a deferred Custom Audience update. For each update the user will be able to join or leave a set of CustomAudiences.
This API only guarantees minimum delay to make the update, and does not guarantee a maximum deadline within which the update request would be made. Scheduled updates could be batched and queued together to preserve system resources, thus exact delay time is not guaranteed.
If the provided shouldReplacePendingUpdates is true, all the currently scheduled
 pending updates matching the owner i.e. calling app and buyer inferred from
 Update Uri will be deleted.
 
In order to conserve system resources the API will make and update request only if the following constraints are satisfied
- The device is using an un-metered internet connection
- The device battery is not low
- The device storage is not low
When the deferred update is triggered the API makes a POST request to the provided updateUri with the request body containing a JSON of Partial Custom Audience list.
An example of request body containing list of Partial Custom Audiences would look like:
{
     "partial_custom_audience_data": [
         {
             "name": "running_shoes",
             "activation_time": 1644375856883,
             "expiration_time": 1644375908397
         },
         {
             "name": "casual_shirt",
             "user_bidding_signals": {
                 "signal1": "value1"
             }
         }
     ]
 }
 In response the API expects a JSON in return with following keys:
- "join" : Should contain list containing full data for a CustomAudienceobject
- "leave" : List of CustomAudiencenames that user is intended to be removed from
An example of JSON in response would look like:
{
     "join": [
         {
             "name": "running-shoes",
             "activation_time": 1680603133,
             "expiration_time": 1680803133,
             "user_bidding_signals": {
                 "signal1": "value"
             },
             "trusted_bidding_data": {
                 "trusted_bidding_uri": "https://example-dsp.com/",
                 "trusted_bidding_keys": [
                     "k1",
                     "k2"
                 ]
             },
             "bidding_logic_uri": "https://example-dsp.com/...",
             "ads": [
                 {
                     "render_uri": "https://example-dsp.com/...",
                     "metadata": {},
                     "ad_filters": {
                         "frequency_cap": {
                             "win": [
                                 {
                                     "ad_counter_key": "key1",
                                     "max_count": 2,
                                     "interval_in_seconds": 60
                                 }
                             ],
                             "view": [
                                 {
                                     "ad_counter_key": "key2",
                                     "max_count": 10,
                                     "interval_in_seconds": 3600
                                 }
                             ]
                         },
                         "app_install": {
                             "package_names": [
                                 "package.name.one"
                             ]
                         }
                     }
                 }
             ]
         },
         {}
     ],
     "leave": [
         "tennis_shoes",
         "formal_shirt"
     ]
 }
 An attempt to register the user for a custom audience from the same application with the
 same combination of buyer inferred from Update Uri, and name will cause the
 existing custom audience's information to be overwritten, including the list of ads data.
 
In case information related to any of the CustomAudience to be joined is malformed, the deferred update would silently ignore that single Custom Audience
When removing this API attempts to remove a user from a custom audience by deleting any
 existing CustomAudience identified by owner i.e. calling app, buyer inferred
 from Update Uri, and name
 
Any partial custom audience field set by the caller cannot be overridden by the custom
 audience fetched from the updateUri. Given multiple Custom Audiences could be
 returned by a buyer ad tech we will match the override restriction based on the names of the
 Custom Audiences. A buyer may skip returning a full Custom Audience for any Partial Custom
 Audience in request.
 
In case the API encounters transient errors while making the network call for update, like 5xx, connection timeout, rate limit exceeded it would employ retries, with backoff up to a 'retry limit' number of times. The API would also honor 'retry-after' header specifying the min amount of seconds by which the next request should be delayed.
In a scenario where server responds with a '429 status code', signifying 'Too many requests', API would place the deferred update and other updates for the same requester i.e. caller package and buyer combination, in a quarantine. The quarantine records would be referred before making any calls for requesters, and request will only be made once the quarantine period has expired. The applications can leverage the `retry-after` header to self-quarantine for traffic management to their servers and prevent being overwhelmed with requests. The default quarantine value will be set to 30 minutes.
This call fails with an SecurityException if
 
- the ownerPackageNameis not calling app's package name; and/or
- the buyer, inferred from updateUri, is not authorized to use the API.
This call fails with an IllegalArgumentException if
 
- the provided updateUriis invalid or malformed.
- the provided delayTimeis not within permissible bounds
- the combined size of partialCustomAudiencelist is larger than allowed limits
This call fails with LimitExceededException if the calling package exceeds the
 allowed rate limits and is throttled.
 
This call fails with IllegalStateException if the provided shouldReplacePendingUpdates is false, and there exists a pending update in the queue.
 
 Requires AdServicesPermissions.ACCESS_ADSERVICES_CUSTOM_AUDIENCE
| Parameters | |
|---|---|
| request | ScheduleCustomAudienceUpdateRequest: This value cannot benull. | 
| executor | Executor: This value cannot benull.
 Callback and listener events are dispatched through thisExecutor, providing an easy way to control which thread is
 used. To dispatch events through the main thread of your
 application, you can useContext.getMainExecutor().
 Otherwise, provide anExecutorthat dispatches to an appropriate thread. | 
| receiver | AdServicesOutcomeReceiver: This value cannot benull. | 
