Merge "Integrate the active emergency session listener in TelephonyRegistry"
This commit is contained in:
@@ -7858,6 +7858,8 @@ package android.telephony {
|
||||
method public void onCallAttributesChanged(@NonNull android.telephony.CallAttributes);
|
||||
method @RequiresPermission("android.permission.READ_PRECISE_PHONE_STATE") public void onCallDisconnectCauseChanged(int, int);
|
||||
method @RequiresPermission("android.permission.READ_PRECISE_PHONE_STATE") public void onImsCallDisconnectCauseChanged(@NonNull android.telephony.ims.ImsReasonInfo);
|
||||
method public void onOutgoingEmergencyCall(@NonNull android.telephony.emergency.EmergencyNumber);
|
||||
method public void onOutgoingEmergencySms(@NonNull android.telephony.emergency.EmergencyNumber);
|
||||
method @RequiresPermission("android.permission.READ_PRECISE_PHONE_STATE") public void onPreciseCallStateChanged(@NonNull android.telephony.PreciseCallState);
|
||||
method @RequiresPermission("android.permission.READ_PRECISE_PHONE_STATE") public void onPreciseDataConnectionStateChanged(@NonNull android.telephony.PreciseDataConnectionState);
|
||||
method public void onRadioPowerStateChanged(int);
|
||||
|
||||
@@ -2890,6 +2890,11 @@ package android.telephony {
|
||||
method public static void setMinMatchForTest(int);
|
||||
}
|
||||
|
||||
public class PhoneStateListener {
|
||||
field @RequiresPermission("android.permission.READ_ACTIVE_EMERGENCY_SESSION") public static final int LISTEN_OUTGOING_CALL_EMERGENCY_NUMBER = 268435456; // 0x10000000
|
||||
field @RequiresPermission("android.permission.READ_ACTIVE_EMERGENCY_SESSION") public static final int LISTEN_OUTGOING_SMS_EMERGENCY_NUMBER = 536870912; // 0x20000000
|
||||
}
|
||||
|
||||
public class ServiceState implements android.os.Parcelable {
|
||||
method public void addNetworkRegistrationInfo(android.telephony.NetworkRegistrationInfo);
|
||||
method public void setCdmaSystemAndNetworkId(int, int);
|
||||
|
||||
@@ -65,6 +65,14 @@ public final class Telecom extends BaseCommand {
|
||||
private static final String COMMAND_UNREGISTER_PHONE_ACCOUNT = "unregister-phone-account";
|
||||
private static final String COMMAND_SET_DEFAULT_DIALER = "set-default-dialer";
|
||||
private static final String COMMAND_GET_DEFAULT_DIALER = "get-default-dialer";
|
||||
/**
|
||||
* Change the system dialer package name if a package name was specified,
|
||||
* Example: adb shell telecom set-system-dialer <PACKAGE>
|
||||
*
|
||||
* Restore it to the default if if argument is "default" or no argument is passed.
|
||||
* Example: adb shell telecom set-system-dialer default
|
||||
*/
|
||||
private static final String COMMAND_SET_SYSTEM_DIALER = "set-system-dialer";
|
||||
private static final String COMMAND_GET_SYSTEM_DIALER = "get-system-dialer";
|
||||
private static final String COMMAND_WAIT_ON_HANDLERS = "wait-on-handlers";
|
||||
private static final String COMMAND_SET_SIM_COUNT = "set-sim-count";
|
||||
@@ -193,6 +201,9 @@ public final class Telecom extends BaseCommand {
|
||||
case COMMAND_GET_DEFAULT_DIALER:
|
||||
runGetDefaultDialer();
|
||||
break;
|
||||
case COMMAND_SET_SYSTEM_DIALER:
|
||||
runSetSystemDialer();
|
||||
break;
|
||||
case COMMAND_GET_SYSTEM_DIALER:
|
||||
runGetSystemDialer();
|
||||
break;
|
||||
@@ -297,6 +308,12 @@ public final class Telecom extends BaseCommand {
|
||||
System.out.println("Success - " + packageName + " set as override default dialer.");
|
||||
}
|
||||
|
||||
private void runSetSystemDialer() throws RemoteException {
|
||||
final String packageName = nextArg();
|
||||
mTelecomService.setSystemDialerPackage(packageName.equals("default") ? null : packageName);
|
||||
System.out.println("Success - " + packageName + " set as override system dialer.");
|
||||
}
|
||||
|
||||
private void runGetDefaultDialer() throws RemoteException {
|
||||
System.out.println(mTelecomService.getDefaultDialerPackage());
|
||||
}
|
||||
|
||||
@@ -29,6 +29,7 @@
|
||||
<uses-permission android:name="android.permission.CALL_PHONE" />
|
||||
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
|
||||
<uses-permission android:name="android.permission.READ_PRECISE_PHONE_STATE" />
|
||||
<uses-permission android:name="android.permission.READ_ACTIVE_EMERGENCY_SESSION" />
|
||||
<uses-permission android:name="android.permission.READ_PRIVILEGED_PHONE_STATE" />
|
||||
<uses-permission android:name="android.permission.READ_CONTACTS" />
|
||||
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
|
||||
|
||||
@@ -208,6 +208,10 @@ public class TelephonyRegistry extends ITelephonyRegistry.Stub {
|
||||
|
||||
private Map<Integer, List<EmergencyNumber>> mEmergencyNumberList;
|
||||
|
||||
private EmergencyNumber[] mOutgoingSmsEmergencyNumber;
|
||||
|
||||
private EmergencyNumber[] mOutgoingCallEmergencyNumber;
|
||||
|
||||
private CallQuality[] mCallQuality;
|
||||
|
||||
private CallAttributes[] mCallAttributes;
|
||||
@@ -266,6 +270,10 @@ public class TelephonyRegistry extends ITelephonyRegistry.Stub {
|
||||
PhoneStateListener.LISTEN_PRECISE_CALL_STATE |
|
||||
PhoneStateListener.LISTEN_PRECISE_DATA_CONNECTION_STATE;
|
||||
|
||||
static final int READ_ACTIVE_EMERGENCY_SESSION_PERMISSION_MASK =
|
||||
PhoneStateListener.LISTEN_OUTGOING_CALL_EMERGENCY_NUMBER
|
||||
| PhoneStateListener.LISTEN_OUTGOING_SMS_EMERGENCY_NUMBER;
|
||||
|
||||
private static final int MSG_USER_SWITCHED = 1;
|
||||
private static final int MSG_UPDATE_DEFAULT_SUB = 2;
|
||||
|
||||
@@ -406,6 +414,8 @@ public class TelephonyRegistry extends ITelephonyRegistry.Stub {
|
||||
mImsReasonInfo = new ArrayList<>();
|
||||
mPhysicalChannelConfigs = new ArrayList<>();
|
||||
mEmergencyNumberList = new HashMap<>();
|
||||
mOutgoingCallEmergencyNumber = new EmergencyNumber[numPhones];
|
||||
mOutgoingSmsEmergencyNumber = new EmergencyNumber[numPhones];
|
||||
for (int i = 0; i < numPhones; i++) {
|
||||
mCallState[i] = TelephonyManager.CALL_STATE_IDLE;
|
||||
mDataActivity[i] = TelephonyManager.DATA_ACTIVITY_NONE;
|
||||
@@ -1909,6 +1919,56 @@ public class TelephonyRegistry extends ITelephonyRegistry.Stub {
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void notifyOutgoingEmergencyCall(int phoneId, int subId,
|
||||
EmergencyNumber emergencyNumber) {
|
||||
if (!checkNotifyPermission("notifyOutgoingEmergencyCall()")) {
|
||||
return;
|
||||
}
|
||||
synchronized (mRecords) {
|
||||
if (validatePhoneId(phoneId)) {
|
||||
mOutgoingCallEmergencyNumber[phoneId] = emergencyNumber;
|
||||
for (Record r : mRecords) {
|
||||
if (r.matchPhoneStateListenerEvent(
|
||||
PhoneStateListener.LISTEN_OUTGOING_CALL_EMERGENCY_NUMBER)
|
||||
&& idMatch(r.subId, subId, phoneId)) {
|
||||
try {
|
||||
r.callback.onOutgoingEmergencyCall(emergencyNumber);
|
||||
} catch (RemoteException ex) {
|
||||
mRemoveList.add(r.binder);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
handleRemoveListLocked();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void notifyOutgoingEmergencySms(int phoneId, int subId,
|
||||
EmergencyNumber emergencyNumber) {
|
||||
if (!checkNotifyPermission("notifyOutgoingEmergencySms()")) {
|
||||
return;
|
||||
}
|
||||
synchronized (mRecords) {
|
||||
if (validatePhoneId(phoneId)) {
|
||||
mOutgoingSmsEmergencyNumber[phoneId] = emergencyNumber;
|
||||
for (Record r : mRecords) {
|
||||
if (r.matchPhoneStateListenerEvent(
|
||||
PhoneStateListener.LISTEN_OUTGOING_SMS_EMERGENCY_NUMBER)
|
||||
&& idMatch(r.subId, subId, phoneId)) {
|
||||
try {
|
||||
r.callback.onOutgoingEmergencySms(emergencyNumber);
|
||||
} catch (RemoteException ex) {
|
||||
mRemoveList.add(r.binder);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
handleRemoveListLocked();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void notifyCallQualityChanged(CallQuality callQuality, int phoneId, int subId,
|
||||
int callNetworkType) {
|
||||
@@ -1981,6 +2041,8 @@ public class TelephonyRegistry extends ITelephonyRegistry.Stub {
|
||||
pw.println("mCallAttributes=" + mCallAttributes[i]);
|
||||
pw.println("mCallNetworkType=" + mCallNetworkType[i]);
|
||||
pw.println("mPreciseDataConnectionState=" + mPreciseDataConnectionState[i]);
|
||||
pw.println("mOutgoingCallEmergencyNumber=" + mOutgoingCallEmergencyNumber[i]);
|
||||
pw.println("mOutgoingSmsEmergencyNumber=" + mOutgoingSmsEmergencyNumber[i]);
|
||||
pw.decreaseIndent();
|
||||
}
|
||||
pw.println("mCarrierNetworkChangeState=" + mCarrierNetworkChangeState);
|
||||
@@ -2250,6 +2312,11 @@ public class TelephonyRegistry extends ITelephonyRegistry.Stub {
|
||||
android.Manifest.permission.READ_PRECISE_PHONE_STATE, null);
|
||||
}
|
||||
|
||||
if ((events & READ_ACTIVE_EMERGENCY_SESSION_PERMISSION_MASK) != 0) {
|
||||
mContext.enforceCallingOrSelfPermission(
|
||||
android.Manifest.permission.READ_ACTIVE_EMERGENCY_SESSION, null);
|
||||
}
|
||||
|
||||
if ((events & PhoneStateListener.LISTEN_OEM_HOOK_RAW_EVENT) != 0) {
|
||||
mContext.enforceCallingOrSelfPermission(
|
||||
android.Manifest.permission.READ_PRIVILEGED_PHONE_STATE, null);
|
||||
|
||||
@@ -301,6 +301,11 @@ interface ITelecomService {
|
||||
|
||||
void setTestAutoModeApp(String packageName);
|
||||
|
||||
/**
|
||||
* @see TelecomServiceImpl#setSystemDialerPackage
|
||||
*/
|
||||
void setSystemDialerPackage(in String packageName);
|
||||
|
||||
/**
|
||||
* @see TelecomServiceImpl#setTestDefaultDialer
|
||||
*/
|
||||
|
||||
@@ -20,6 +20,7 @@ import android.Manifest;
|
||||
import android.annotation.NonNull;
|
||||
import android.annotation.RequiresPermission;
|
||||
import android.annotation.SystemApi;
|
||||
import android.annotation.TestApi;
|
||||
import android.annotation.UnsupportedAppUsage;
|
||||
import android.os.Binder;
|
||||
import android.os.Build;
|
||||
@@ -366,6 +367,7 @@ public class PhoneStateListener {
|
||||
* @hide
|
||||
*/
|
||||
@SystemApi
|
||||
@TestApi
|
||||
@RequiresPermission(Manifest.permission.READ_ACTIVE_EMERGENCY_SESSION)
|
||||
public static final int LISTEN_OUTGOING_CALL_EMERGENCY_NUMBER = 0x10000000;
|
||||
|
||||
@@ -378,6 +380,7 @@ public class PhoneStateListener {
|
||||
* @hide
|
||||
*/
|
||||
@SystemApi
|
||||
@TestApi
|
||||
@RequiresPermission(Manifest.permission.READ_ACTIVE_EMERGENCY_SESSION)
|
||||
public static final int LISTEN_OUTGOING_SMS_EMERGENCY_NUMBER = 0x20000000;
|
||||
|
||||
@@ -869,6 +872,7 @@ public class PhoneStateListener {
|
||||
* to.
|
||||
* @hide
|
||||
*/
|
||||
@SystemApi
|
||||
public void onOutgoingEmergencyCall(@NonNull EmergencyNumber placedEmergencyNumber) {
|
||||
// default implementation empty
|
||||
}
|
||||
@@ -879,6 +883,7 @@ public class PhoneStateListener {
|
||||
* @param sentEmergencyNumber the emergency number {@link EmergencyNumber} the SMS is sent to.
|
||||
* @hide
|
||||
*/
|
||||
@SystemApi
|
||||
public void onOutgoingEmergencySms(@NonNull EmergencyNumber sentEmergencyNumber) {
|
||||
// default implementation empty
|
||||
}
|
||||
|
||||
@@ -93,6 +93,10 @@ interface ITelephonyRegistry {
|
||||
void notifyActiveDataSubIdChanged(int activeDataSubId);
|
||||
void notifyRadioPowerStateChanged(in int phoneId, in int subId, in int state);
|
||||
void notifyEmergencyNumberList(in int phoneId, in int subId);
|
||||
void notifyOutgoingEmergencyCall(in int phoneId, in int subId,
|
||||
in EmergencyNumber emergencyNumber);
|
||||
void notifyOutgoingEmergencySms(in int phoneId, in int subId,
|
||||
in EmergencyNumber emergencyNumber);
|
||||
void notifyCallQualityChanged(in CallQuality callQuality, int phoneId, int subId,
|
||||
int callNetworkType);
|
||||
void notifyImsDisconnectCause(int subId, in ImsReasonInfo imsReasonInfo);
|
||||
|
||||
Reference in New Issue
Block a user