blob: 8d3d65aa5a6c69dad4d20ca994c2cc161ec854af [file] [log] [blame]
/*
* Copyright (C) 2022 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package android.adservices.common;
import static android.adservices.common.AdServicesPermissions.ACCESS_ADSERVICES_STATE;
import static android.adservices.common.AdServicesPermissions.MODIFY_ADSERVICES_STATE;
import android.annotation.CallbackExecutor;
import android.annotation.NonNull;
import android.annotation.RequiresPermission;
import android.annotation.SystemApi;
import android.content.Context;
import android.os.Build;
import android.os.OutcomeReceiver;
import android.os.RemoteException;
import androidx.annotation.RequiresApi;
import com.android.adservices.AdServicesCommon;
import com.android.adservices.LogUtil;
import com.android.adservices.ServiceBinder;
import java.util.concurrent.Executor;
/**
* AdServicesCommonManager contains APIs common across the various AdServices. It provides two
* SystemApis:
*
* <ul>
* <li>isAdServicesEnabled - allows to get AdServices state.
* <li>setAdServicesEntryPointEnabled - allows to control AdServices state.
* </ul>
*
* <p>The instance of the {@link AdServicesCommonManager} can be obtained using {@link
* Context#getSystemService} and {@link AdServicesCommonManager} class.
*
* @hide
*/
// TODO(b/269798827): Enable for R.
@RequiresApi(Build.VERSION_CODES.S)
@SystemApi
public class AdServicesCommonManager {
/** @hide */
public static final String AD_SERVICES_COMMON_SERVICE = "ad_services_common_service";
private final Context mContext;
private final ServiceBinder<IAdServicesCommonService>
mAdServicesCommonServiceBinder;
/**
* Factory method for creating an instance of AdServicesCommonManager.
*
* @param context The {@link Context} to use
* @return A {@link AdServicesCommonManager} instance
*/
@NonNull
public static AdServicesCommonManager get(@NonNull Context context) {
// On T+, context.getSystemService() does more than just call constructor.
return (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU)
? context.getSystemService(AdServicesCommonManager.class)
: new AdServicesCommonManager(context);
}
/**
* Create AdServicesCommonManager.
*
* @hide
*/
public AdServicesCommonManager(@NonNull Context context) {
mContext = context;
mAdServicesCommonServiceBinder = ServiceBinder.getServiceBinder(
context,
AdServicesCommon.ACTION_AD_SERVICES_COMMON_SERVICE,
IAdServicesCommonService.Stub::asInterface);
}
@NonNull
private IAdServicesCommonService getService() {
IAdServicesCommonService service =
mAdServicesCommonServiceBinder.getService();
if (service == null) {
throw new IllegalStateException("Unable to find the service");
}
return service;
}
/**
* Get the AdService's enablement state which represents whether AdServices feature is enabled
* or not.
*
* @hide
*/
@SystemApi
@RequiresPermission(ACCESS_ADSERVICES_STATE)
public void isAdServicesEnabled(
@NonNull @CallbackExecutor Executor executor,
@NonNull OutcomeReceiver<Boolean, Exception> callback) {
final IAdServicesCommonService service = getService();
try {
service.isAdServicesEnabled(
new IAdServicesCommonCallback.Stub() {
@Override
public void onResult(IsAdServicesEnabledResult result) {
executor.execute(
() -> {
callback.onResult(result.getAdServicesEnabled());
});
}
@Override
public void onFailure(int statusCode) {
executor.execute(
() ->
callback.onError(
AdServicesStatusUtils.asException(statusCode)));
}
});
} catch (RemoteException e) {
LogUtil.e(e, "RemoteException");
executor.execute(
() -> callback.onError(new IllegalStateException("Internal Error!", e)));
}
}
/**
* Sets the AdService's enablement state based on the provided parameters.
*
* <p>As a result of the AdServices state, {@code adServicesEntryPointEnabled}, {@code
* adIdEnabled}, appropriate notification may be displayed to the user. It's displayed only once
* when all the following conditions are met:
*
* <ul>
* <li>AdServices state - enabled.
* <li>adServicesEntryPointEnabled - true.
* </ul>
*
* @param adServicesEntryPointEnabled indicate entry point enabled or not
* @param adIdEnabled indicate user opt-out of adid or not
* @hide
*/
@SystemApi
@RequiresPermission(MODIFY_ADSERVICES_STATE)
public void setAdServicesEnabled(boolean adServicesEntryPointEnabled, boolean adIdEnabled) {
final IAdServicesCommonService service = getService();
try {
service.setAdServicesEnabled(adServicesEntryPointEnabled, adIdEnabled);
} catch (RemoteException e) {
LogUtil.e(e, "RemoteException");
}
}
}