diff options
| -rw-r--r-- | api/current.txt | 1 | ||||
| -rw-r--r-- | core/api/current.txt | 1 | ||||
| -rw-r--r-- | telecomm/java/android/telecom/TelecomManager.java | 29 | ||||
| -rw-r--r-- | telecomm/java/com/android/internal/telecom/ITelecomService.aidl | 5 | 
4 files changed, 36 insertions, 0 deletions
| diff --git a/api/current.txt b/api/current.txt index b5cd13b254af..9860241c5e20 100644 --- a/api/current.txt +++ b/api/current.txt @@ -46296,6 +46296,7 @@ package android.telecom {      method @RequiresPermission(android.Manifest.permission.READ_PHONE_STATE) public String getVoiceMailNumber(android.telecom.PhoneAccountHandle);      method @RequiresPermission(android.Manifest.permission.MODIFY_PHONE_STATE) public boolean handleMmi(String);      method @RequiresPermission(android.Manifest.permission.MODIFY_PHONE_STATE) public boolean handleMmi(String, android.telecom.PhoneAccountHandle); +    method public boolean hasCompanionInCallServiceAccess();      method @RequiresPermission(android.Manifest.permission.READ_PHONE_STATE) public boolean isInCall();      method @RequiresPermission(android.Manifest.permission.READ_PHONE_STATE) public boolean isInManagedCall();      method public boolean isIncomingCallPermitted(android.telecom.PhoneAccountHandle); diff --git a/core/api/current.txt b/core/api/current.txt index 61a14241e4df..85d634af0063 100644 --- a/core/api/current.txt +++ b/core/api/current.txt @@ -44464,6 +44464,7 @@ package android.telecom {      method @RequiresPermission(android.Manifest.permission.READ_PHONE_STATE) public String getVoiceMailNumber(android.telecom.PhoneAccountHandle);      method @RequiresPermission(android.Manifest.permission.MODIFY_PHONE_STATE) public boolean handleMmi(String);      method @RequiresPermission(android.Manifest.permission.MODIFY_PHONE_STATE) public boolean handleMmi(String, android.telecom.PhoneAccountHandle); +    method public boolean hasCompanionInCallServiceAccess();      method @RequiresPermission(android.Manifest.permission.READ_PHONE_STATE) public boolean isInCall();      method @RequiresPermission(android.Manifest.permission.READ_PHONE_STATE) public boolean isInManagedCall();      method public boolean isIncomingCallPermitted(android.telecom.PhoneAccountHandle); diff --git a/telecomm/java/android/telecom/TelecomManager.java b/telecomm/java/android/telecom/TelecomManager.java index 724c17177f76..fbb1701dd52a 100644 --- a/telecomm/java/android/telecom/TelecomManager.java +++ b/telecomm/java/android/telecom/TelecomManager.java @@ -32,6 +32,7 @@ import android.content.Intent;  import android.net.Uri;  import android.os.Build;  import android.os.Bundle; +import android.os.Process;  import android.os.RemoteException;  import android.os.ServiceManager;  import android.os.UserHandle; @@ -1589,6 +1590,30 @@ public class TelecomManager {      }      /** +     * Returns whether the caller has {@link InCallService} access for companion apps. +     * +     * A companion app is an app associated with a physical wearable device via the +     * {@link android.companion.CompanionDeviceManager} API. +     * +     * @return {@code true} if the caller has {@link InCallService} access for +     *      companion app; {@code false} otherwise. +     */ +    public boolean hasCompanionInCallServiceAccess() { +        try { +            if (isServiceConnected()) { +                return getTelecomService().hasCompanionInCallServiceAccess( +                        mContext.getOpPackageName()); +            } +        } catch (RemoteException e) { +            Log.e(TAG, "RemoteException calling hasCompanionInCallServiceAccess().", e); +            if (!isSystemProcess()) { +                e.rethrowAsRuntimeException(); +            } +        } +        return false; +    } + +    /**       * Returns whether there is an ongoing call originating from a managed       * {@link ConnectionService}.  An ongoing call can be in dialing, ringing, active or holding       * states. @@ -2384,6 +2409,10 @@ public class TelecomManager {          }      } +    private boolean isSystemProcess() { +        return Process.myUid() == Process.SYSTEM_UID; +    } +      private ITelecomService getTelecomService() {          if (mTelecomServiceOverride != null) {              return mTelecomServiceOverride; diff --git a/telecomm/java/com/android/internal/telecom/ITelecomService.aidl b/telecomm/java/com/android/internal/telecom/ITelecomService.aidl index a28a999e8d19..6dc096daf4ea 100644 --- a/telecomm/java/com/android/internal/telecom/ITelecomService.aidl +++ b/telecomm/java/com/android/internal/telecom/ITelecomService.aidl @@ -179,6 +179,11 @@ interface ITelecomService {      boolean isInCall(String callingPackage, String callingFeatureId);      /** +     * @see TelecomServiceImpl#hasCompanionInCallServiceAccess +     */ +    boolean hasCompanionInCallServiceAccess(String callingPackage); + +    /**       * @see TelecomServiceImpl#isInManagedCall       */      boolean isInManagedCall(String callingPackage, String callingFeatureId); |