From a8d677fce88d2add418cdcc868f2a00b2e2d702e Mon Sep 17 00:00:00 2001 From: linyuh Date: Wed, 7 Mar 2018 17:16:08 -0800 Subject: Support local emergency phone number check when there are multiple SIMs. Bug: 73994020 Test: PhoneNumberHelperTest PiperOrigin-RevId: 188260007 Change-Id: I23025e9b9454f487117c35e7a3b09307371ae825 --- .../dialer/phonenumberutil/PhoneNumberHelper.java | 37 ++++++++++++++++++++++ 1 file changed, 37 insertions(+) (limited to 'java/com/android/dialer/phonenumberutil') diff --git a/java/com/android/dialer/phonenumberutil/PhoneNumberHelper.java b/java/com/android/dialer/phonenumberutil/PhoneNumberHelper.java index e1051951e..33a94ea74 100644 --- a/java/com/android/dialer/phonenumberutil/PhoneNumberHelper.java +++ b/java/com/android/dialer/phonenumberutil/PhoneNumberHelper.java @@ -25,6 +25,7 @@ import android.support.annotation.NonNull; import android.support.annotation.Nullable; import android.telecom.PhoneAccountHandle; import android.telephony.PhoneNumberUtils; +import android.telephony.SubscriptionInfo; import android.telephony.TelephonyManager; import android.text.BidiFormatter; import android.text.TextDirectionHeuristics; @@ -34,10 +35,13 @@ import com.android.dialer.common.LogUtil; import com.android.dialer.compat.CompatUtils; import com.android.dialer.compat.telephony.TelephonyManagerCompat; import com.android.dialer.oem.MotorolaUtils; +import com.android.dialer.oem.PhoneNumberUtilsAccessor; import com.android.dialer.phonenumbergeoutil.PhoneNumberGeoUtilComponent; import com.android.dialer.telecom.TelecomUtil; +import com.google.common.base.Optional; import java.util.Arrays; import java.util.HashSet; +import java.util.List; import java.util.Set; public class PhoneNumberHelper { @@ -137,6 +141,39 @@ public class PhoneNumberHelper { return rawNumber1.equals(rawNumber2); } + /** + * An enhanced version of {@link PhoneNumberUtils#isLocalEmergencyNumber(Context, String)}. + * + *

This methods supports checking the number for all SIMs. + * + * @param context the context which the number should be checked against + * @param number the number to tbe checked + * @return true if the specified number is an emergency number for any SIM in the device. + */ + @SuppressWarnings("Guava") + public static boolean isLocalEmergencyNumber(Context context, String number) { + List phoneAccountHandles = + TelecomUtil.getSubscriptionPhoneAccounts(context); + + // If the number of phone accounts with a subscription is no greater than 1, only one SIM is + // installed in the device. We hand over the job to PhoneNumberUtils#isLocalEmergencyNumber. + if (phoneAccountHandles.size() <= 1) { + return PhoneNumberUtils.isLocalEmergencyNumber(context, number); + } + + for (PhoneAccountHandle phoneAccountHandle : phoneAccountHandles) { + Optional subscriptionInfo = + TelecomUtil.getSubscriptionInfo(context, phoneAccountHandle); + if (subscriptionInfo.isPresent() + && PhoneNumberUtilsAccessor.isLocalEmergencyNumber( + context, subscriptionInfo.get().getSubscriptionId(), number)) { + return true; + } + } + + return false; + } + /** * Returns true if the given number is the number of the configured voicemail. To be able to * mock-out this, it is not a static method. -- cgit v1.2.3