1 /* 2 * Copyright (C) 2018 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License 15 */ 16 17 package com.android.server.telecom; 18 19 import android.content.Intent; 20 import android.os.UserHandle; 21 22 import java.util.List; 23 import java.util.concurrent.Executor; 24 import java.util.function.IntConsumer; 25 26 /** 27 * Provides a means of wrapping {@code RoleManager} operations which Telecom uses to aid in testing 28 * and remove direct dependencies. 29 */ 30 public interface RoleManagerAdapter { 31 32 /** 33 * The name of the dialer role. 34 * 35 * @see Intent#ACTION_DIAL 36 */ 37 String ROLE_DIALER = "android.app.role.DIALER"; 38 39 /** 40 * Returns the package name of the app which fills the {@link android.app.role.RoleManager} call 41 * redirection role. 42 * @return the package name of the app filling the role, {@code null} otherwise}. 43 */ 44 String getDefaultCallRedirectionApp(); 45 46 /** 47 * Override the {@link android.app.role.RoleManager} call redirection app with another value. 48 * Used for testing purposes only. 49 * @param packageName Package name of the app to fill the call redirection role. Where 50 * {@code null}, the override is removed. 51 */ 52 void setTestDefaultCallRedirectionApp(String packageName); 53 54 /** 55 * Returns the package name of the app which fills the {@link android.app.role.RoleManager} call 56 * screening role. 57 * @return the package name of the app filling the role, {@code null} otherwise}. 58 */ 59 String getDefaultCallScreeningApp(); 60 61 /** 62 * Override the {@link android.app.role.RoleManager} call screening app with another value. 63 * Used for testing purposes only. 64 * @param packageName Package name of the app to fill the call screening role. Where 65 * {@code null}, the override is removed. 66 */ 67 void setTestDefaultCallScreeningApp(String packageName); 68 69 /** 70 * Returns the package name of the app which fills the {@link android.app.role.RoleManager} 71 * {@link android.app.role.RoleManager#ROLE_DIALER} role. 72 * @return the package name of the app filling the role, {@code null} otherwise}. 73 */ 74 String getDefaultDialerApp(int user); 75 76 /** 77 * Observe changes to the package name of the app which fills the 78 * {@link android.app.role.RoleManager} {@link android.app.role.RoleManager#ROLE_DIALER} role. 79 */ 80 void observeDefaultDialerApp(Executor executor, IntConsumer observer); 81 82 /** 83 * Override the {@link android.app.role.RoleManager} default dialer app with another value. 84 * Used for testing purposes only. 85 * @param packageName Package name of the app to fill the default dialer role. Where 86 * {@code null}, the override is removed. 87 */ 88 void setTestDefaultDialer(String packageName); 89 90 /** 91 * @return List of package names of companion apps, or empty list if there are none. 92 */ 93 List<String> getCallCompanionApps(); 94 95 /** 96 * Set a package to be added to the list of the companion apps. Used for testing purposes only. 97 * @param packageName Package name of the app to be added or removed as an override call 98 * companion app. 99 * @param isAdded {@code true} if the specified package should be added, {@code false} if it 100 * should be removed. 101 */ 102 void addOrRemoveTestCallCompanionApp(String packageName, boolean isAdded); 103 104 /** 105 * Using role manager needs to know the current user handle. Need to make sure the role manager 106 * adapter can pass this to role manager. As it changes, we'll pass it in. 107 * @param currentUserHandle The new user handle. 108 */ 109 void setCurrentUserHandle(UserHandle currentUserHandle); 110 111 /** 112 * Returns the application label that corresponds to the given package name. 113 * @param packageName A valid package name. 114 * @return Application label for the given package name, or null if not found. 115 */ 116 String getApplicationLabelForPackageName(String packageName); 117 } 118