Found 135314 results in 28682 files, showing top 50 files (show more).
android.googlesource.com/platform/packages/services/Telephony:src/com/android/phone/PhoneInterfaceManager.java: [ master, ]
429:         public Phone phone;
17: package com.android.phone;
219: public class PhoneInterfaceManager extends ITelephony.Stub {
2093:     private PhoneInterfaceManager(PhoneGlobals app) {
2111:     private Phone getDefaultPhone() {
2145:     private Phone getPhone(int subId) {
2797:     public String getNetworkCountryIsoForPhone(int phoneId) {
6548:     public int checkCarrierPrivilegesForPackageAnyPhone(String pkgName) {
6571:     public List<String> getCarrierPackageNamesForIntentAndPhone(Intent intent, int phoneId) {
7069:     public boolean isWorldPhone(int subId, String callingPackage, String callingFeatureId) {
347:     private PhoneConfigurationManager mPhoneConfigurationManager;
2125:     private Phone getPhoneFromRequest(MainThreadRequest request) {
2133:     private Phone getPhoneFromSubId(int subId) {
2294:         private final int mPhoneId;
2573:     private void shutdownRadioUsingPhoneId(int phoneId) {
3215:     public int getActivePhoneType() {
3220:     public int getActivePhoneTypeForSlot(int slotIndex) {
4261:     private void checkModifyPhoneStatePermission(int subId, String message) {
4913:     private Phone getPhoneFromSlotIdOrThrowException(int slotIndex) {
6615:     public List<String> getPackagesWithCarrierPrivilegesForAllPhones() {
7195:     public int getSubIdForPhoneAccount(PhoneAccount phoneAccount) {
7205:     public int getSubIdForPhoneAccountHandle(
7220:     public @Nullable PhoneAccountHandle getPhoneAccountHandleForSubscriptionId(int subscriptionId) {
21: import static com.android.internal.telephony.PhoneConstants.PHONE_TYPE_IMS;
155: import com.android.internal.telephony.Phone;
191: import com.android.phone.settings.PickSmsSubscriptionActivity;
192: import com.android.phone.vvm.PhoneAccountHandleConverter;
193: import com.android.phone.vvm.RemoteVvmTaskManager;
194: import com.android.phone.vvm.VisualVoicemailSettingsUtil;
195: import com.android.phone.vvm.VisualVoicemailSmsFilterConfig;
428:         // In cases where subId is unavailable, the caller needs to specify the phone.
437:         MainThreadRequest(Object argument, Phone phone, WorkSource workSource) {
439:             if (phone != null) {
440:                 this.phone = phone;
468:      * A handler that processes messages on the main thread in the phone process. Since many
469:      * of the Phone calls are not thread safe this is needed to shuttle the requests from the
470:      * inbound binder threads to the main thread in the phone process.  The Binder thread
487:             final Phone defaultPhone = getDefaultPhone();
492:                     final Phone phone = getPhoneFromRequest(request);
511:                         request.result = phone != null
512:                                 ? phone.handleUssdRequest(ussdRequest, wrappedCallback) : false;
523:                     final Phone phone = getPhoneFromRequest(request);
524:                     request.result = phone != null ?
801:                     Phone phone = getPhoneFromRequest(request);
802:                     if (phone != null) {
803:                         phone.isNrDualConnectivityEnabled(onCompleted, request.workSource);
805:                         loge("isNRDualConnectivityEnabled: No phone object");
840:                     Phone phone = getPhoneFromRequest(request);
841:                     if (phone != null) {
842:                         phone.setNrDualConnectivityState((int) request.argument, onCompleted,
845:                         loge("enableNrDualConnectivity: No phone object");
978:                     request.phone.getCallForwardingOption(callForwardingReason, onCompleted);
1040:                     request.phone.setCallForwardingOption(
1464:                     request.phone.requestCellInfoUpdate(request.workSource, onCompleted);
1478:                     request.phone.requestCellInfoUpdate(request.workSource,
1506:                     Phone phone = getPhoneFromRequest(request);
1507:                     phone.getCellIdentity(ws, obtainMessage(EVENT_GET_CELL_LOCATION_DONE, request));
1516:                         Phone phone = getPhoneFromRequest(request);
1517:                         request.result = (phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA)
1540:                             .enablePhone(request.phone, enable, onCompleted);
1546:                     int phoneId = request.phone.getPhoneId();
1562:                             .getPhoneStatusFromModem(request.phone, onCompleted);
1567:                     int id = request.phone.getPhoneId();
1590:                     request.phone.setSystemSelectionChannels(args.first, onCompleted);
1605:                     Phone phone = getPhoneFromRequest(request);
1606:                     if (phone != null) {
1607:                         phone.getSystemSelectionChannels(onCompleted);
1609:                         loge("getSystemSelectionChannels: No phone object");
1750:                     Phone phone = getPhoneFromRequest(request);
1751:                     if (phone != null) {
1752:                         phone.setDataThrottling(onCompleted,
1756:                         loge("setDataThrottling: No phone object");
1800:                     request.phone.setSimPowerState(stateToSet, onCompleted, request.workSource);
1844:                     final Phone phone = getPhoneFromRequest(request);
1845:                     if (phone == null || phone.getServiceStateTracker() == null) {
1846:                         request.result = new IllegalStateException("Phone or SST is null");
1855:                     phone.getServiceStateTracker().setSignalStrengthUpdateRequest(
1872:                     Phone phone = getPhoneFromRequest(request);
1873:                     if (phone == null || phone.getServiceStateTracker() == null) {
1874:                         request.result = new IllegalStateException("Phone or SST is null");
1883:                     phone.getServiceStateTracker().clearSignalStrengthUpdateRequest(
1986:     private Object sendRequest(int command, Object argument, Phone phone, WorkSource workSource) {
1987:         return sendRequest(command, argument, SubscriptionManager.INVALID_SUBSCRIPTION_ID, phone,
1997:     private @Nullable Object sendRequest(int command, Object argument, Integer subId, Phone phone,
2004:         if (subId != SubscriptionManager.INVALID_SUBSCRIPTION_ID && phone != null) {
2005:             throw new IllegalArgumentException("subId and phone cannot both be specified!");
2006:         } else if (phone != null) {
2007:             request = new MainThreadRequest(argument, phone, workSource);
2067:      * Same as {@link #sendRequestAsync(int,Object)} except it takes a Phone and WorkSource.
2071:             int command, Object argument, Phone phone, WorkSource workSource) {
2072:         MainThreadRequest request = new MainThreadRequest(argument, phone, workSource);
2112:         Phone thePhone = getPhone(getDefaultSubscription());
2126:         if (request.phone != null) {
2127:             return request.phone;
2139:         Phone phone = getPhoneFromRequest(request);
2140:         return phone == null ? null :
2141:                 UiccController.getInstance().getUiccCard(phone.getPhoneId());
2144:     // returns phone associated with the subId.
2149:     private void sendEraseModemConfig(Phone phone) {
2150:         if (phone != null) {
2152:                   mApp, phone.getSubId(), "eraseModemConfig");
2190:             // PENDING: should we just silently fail if phone is offhook or ringing?
2211:         // from the context of the phone app.
2214:         if (mAppOps.noteOp(AppOpsManager.OPSTR_CALL_PHONE, Binder.getCallingUid(), callingPackage)
2264:             Phone phone = getPhone(subId);
2265:             final UnlockSim checkSimPin = new UnlockSim(phone.getPhoneId(), phone.getIccCard());
2278:             Phone phone = getPhone(subId);
2279:             final UnlockSim checkSimPuk = new UnlockSim(phone.getPhoneId(), phone.getIccCard());
2441:             final Phone phone = getPhone(getDefaultSubscription());
2442:             if (phone != null) {
2443:                 phone.updateServiceLocation(workSource);
2488:             final Phone phone = getPhone(subId);
2489:             if (phone != null) {
2490:                 return phone.getServiceState().getState() != ServiceState.STATE_POWER_OFF;
2508:             final Phone phone = getPhone(subId);
2509:             if (phone != null) {
2510:                 phone.setRadioPower(!isRadioOnForSubscriber(subId));
2526:             final Phone phone = getPhone(subId);
2527:             if (phone == null) {
2530:             if ((phone.getServiceState().getState() != ServiceState.STATE_POWER_OFF) != turnOn) {
2548:                 Phone phone = PhoneFactory.getPhone(i);
2549:                 if (phone != null && phone.isRadioAvailable()) return true;
2565:                 logv("Shutting down Phone " + i);
2574:         Phone phone = PhoneFactory.getPhone(phoneId);
2575:         if (phone != null && phone.isRadioAvailable()) {
2576:             phone.shutdownRadio();
2585:             final Phone defaultPhone = PhoneFactory.getDefaultPhone();
2590:                 loge("There's no default phone.");
2603:             final Phone phone = getPhone(subId);
2604:             if (phone != null) {
2605:                 phone.setRadioPower(turnOn);
2623:             final Phone phone = getPhone(subId);
2624:             if (phone != null) {
2625:                 phone.getDataEnabledSettings().setDataEnabled(
2644:             final Phone phone = getPhone(subId);
2645:             if (phone != null) {
2646:                 phone.getDataEnabledSettings().setDataEnabled(
2661:             final Phone phone = getPhone(subId);
2662:             if (phone != null) {
2663:                 return phone.isDataAllowed(ApnSetting.TYPE_DEFAULT);
2712:             Phone phone = PhoneFactory.getPhone(slotIndex);
2713:             return phone == null ? TelephonyManager.CALL_STATE_IDLE :
2714:                     PhoneConstantConversions.convertCallState(phone.getState());
2729:             final Phone phone = getPhone(subId);
2730:             if (phone != null) {
2731:                 return PhoneConstantConversions.convertDataState(phone.getDataConnectionState());
2750:             final Phone phone = getPhone(subId);
2751:             if (phone != null) {
2752:                 return DefaultPhoneNotifier.convertDataActivityState(phone.getDataActivityState());
2781:                 return (getDefaultPhone().getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA)
2802:             if (phoneId == SubscriptionManager.INVALID_PHONE_INDEX) {
2803:                 // Get default phone in this case.
2804:                 phoneId = SubscriptionManager.DEFAULT_PHONE_INDEX;
2807:             Phone phone = PhoneFactory.getPhone(phoneId);
2808:             if (phone == null) return "";
2809:             ServiceStateTracker sst = phone.getServiceStateTracker();
2878:         for (Phone phone : PhoneFactory.getPhones()) {
2879:             List<CellInfo> info = phone.getAllCellInfo();
2918:             for (Phone phone : PhoneFactory.getPhones()) {
2920:                         CMD_GET_ALL_CELL_INFO, null, phone, workSource);
2982:         final Phone phone = getPhoneFromSubId(subId);
2983:         if (phone == null) throw new IllegalArgumentException("Invalid Subscription Id: " + subId);
2985:         sendRequestAsync(CMD_REQUEST_CELL_INFO_UPDATE, cb, phone, workSource);
3003:         Phone phone = PhoneFactory.getPhone(slotIndex);
3004:         if (phone == null) {
3007:         int subId = phone.getSubId();
3015:             return phone.getImei();
3023:         Phone phone = PhoneFactory.getPhone(slotIndex);
3025:         if (phone != null) {
3026:             String imei = phone.getImei();
3034:         Phone phone = PhoneFactory.getPhone(slotIndex);
3035:         if (phone == null) {
3039:         int subId = phone.getSubId();
3047:             return phone.getMeid();
3055:         Phone phone = PhoneFactory.getPhone(slotIndex);
3057:         if (phone != null) {
3058:             String meid = phone.getMeid();
3067:         Phone phone = PhoneFactory.getPhone(slotIndex);
3068:         if (phone == null) {
3071:         int subId = phone.getSubId();
3080:             return phone.getDeviceSvn();
3090:             final Phone phone = getPhone(subId);
3091:             return phone == null ? TelephonyManager.UNKNOWN_CARRIER_ID : phone.getCarrierId();
3101:             final Phone phone = getPhone(subId);
3102:             return phone == null ? null : phone.getCarrierName();
3112:             final Phone phone = getPhone(subId);
3113:             return phone == null ? TelephonyManager.UNKNOWN_CARRIER_ID
3114:                     : phone.getSpecificCarrierId();
3124:             final Phone phone = getPhone(subId);
3125:             return phone == null ? null : phone.getSpecificCarrierName();
3136:         final Phone phone = PhoneFactory.getPhone(slotIndex);
3137:         if (phone == null) {
3142:             return CarrierResolver.getCarrierIdFromMccMnc(phone.getContext(), mccmnc);
3153:      * Make sure the caller has the MODIFY_PHONE_STATE permission.
3158:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.MODIFY_PHONE_STATE, null);
3178:      * Make sure the caller has the CALL_PHONE permission.
3183:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.CALL_PHONE, null);
3223:             final Phone phone = PhoneFactory.getPhone(slotIndex);
3224:             if (phone == null) {
3225:                 return PhoneConstants.PHONE_TYPE_NONE;
3227:                 return phone.getPhoneType();
3254:             final Phone phone = getPhone(subId);
3255:             if (phone != null) {
3256:                 return phone.getCdmaEriIconIndex();
3287:             final Phone phone = getPhone(subId);
3288:             if (phone != null) {
3289:                 return phone.getCdmaEriIconMode();
3318:             final Phone phone = getPhone(subId);
3319:             if (phone != null) {
3320:                 return phone.getCdmaEriText();
3339:             final Phone phone = getPhone(subId);
3340:             if (phone != null && phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA) {
3341:                 return phone.getLine1Number();
3343:                 loge("getCdmaMdn: no phone found. Invalid subId: " + subId);
3361:             final Phone phone = getPhone(subId);
3362:             if (phone != null && phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA) {
3363:                 return phone.getCdmaMin();
3375:         if (mApp.checkCallingOrSelfPermission(android.Manifest.permission.MODIFY_PHONE_STATE)
3377:             throw new SecurityException("Caller must hold the MODIFY_PHONE_STATE permission");
3543:             final Phone phone = getPhone(subId);
3544:             if (phone != null) {
3545:                 phone.setVoiceActivationState(activationState);
3564:             final Phone phone = getPhone(subId);
3565:             if (phone != null) {
3566:                 phone.setDataActivationState(activationState);
3582:         final Phone phone = getPhone(subId);
3585:             if (phone != null) {
3586:                 return phone.getVoiceActivationState();
3602:         final Phone phone = getPhone(subId);
3605:             if (phone != null) {
3606:                 return phone.getDataActivationState();
3628:             final Phone phone = getPhone(subId);
3629:             if (phone != null) {
3630:                 return phone.getVoiceMessageCount();
3647:             final Phone phone = getPhone(subId);
3648:             return (phone == null ? false : phone.isConcurrentVoiceAndDataAllowed());
3661:         final Phone defaultPhone = getDefaultPhone();
3699:             for (Phone phone : PhoneFactory.getPhones()) {
3700:                 if (phone.isInEmergencySmsMode()) {
3711:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3738:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3776:             Phone phone = getPhone(subId);
3777:             if (phone == null) {
3782:             phone.getImsRegistrationState(regState -> {
3809:             Phone phone = getPhone(subId);
3810:             if (phone == null) {
3815:             phone.getImsRegistrationTech(regTech -> {
3834:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3860:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3911:             Phone phone = getPhone(subId);
3912:             if (phone == null) return false;
3913:             return phone.isImsCapabilityAvailable(capability, regTech);
3961:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3998:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4032:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4067:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4119:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4201:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4268:         Phone phone = getPhone(subId);
4269:         if (phone == null) {
4270:             loge("phone instance null for subid " + subId);
4274:             if (!doesImsCapabilityRequireProvisioning(phone.getContext(), subId, capability)) {
4278:             if (!doesRcsCapabilityRequireProvisioning(phone.getContext(), subId, capability)) {
4725:             final Phone phone = getPhone(subId);
4726:             if (phone != null) {
4727:                 return phone.getServiceState().getDataNetworkType();
4759:             final Phone phone = getPhone(subId);
4760:             if (phone != null) {
4761:                 return phone.getServiceState().getDataNetworkType();
4784:             final Phone phone = getPhone(subId);
4785:             if (phone != null) {
4786:                 return phone.getServiceState().getVoiceNetworkType();
4811:             final Phone phone = PhoneFactory.getPhone(slotIndex);
4812:             if (phone != null) {
4813:                 return phone.getIccCard().hasIccCard();
4828:      * @return {@link Phone#LTE_ON_CDMA_UNKNOWN}, {@link Phone#LTE_ON_CDMA_FALSE}
4829:      * or {@link Phone#LTE_ON_CDMA_TRUE}
4848:             final Phone phone = getPhone(subId);
4849:             if (phone == null) {
4917:                     + " does not correspond to an active phone");
4948:     private IccOpenLogicalChannelResponse iccOpenLogicalChannelWithPermission(Phone phone,
4965:                     CMD_OPEN_CHANNEL, new Pair<String, Integer>(aid, p2), phone,
4990:     private boolean iccCloseLogicalChannelWithPermission(Phone phone, int channel) {
4996:             Boolean success = (Boolean) sendRequest(CMD_CLOSE_CHANNEL, channel, phone,
5033:     private String iccTransmitApduLogicalChannelWithPermission(Phone phone, int channel, int cla,
5042:                     new IccAPDUArgument(channel, cla, command, p1, p2, p3, data), phone,
5089:     private String iccTransmitApduBasicChannelWithPermission(Phone phone, String callingPackage,
5107:                     new IccAPDUArgument(0, cla, command, p1, p2, p3, data), phone,
5341:         Phone phone = PhoneFactory.getPhone(slotIndex);
5342:         if (phone != null) {
5344:                     mApp, phone.getSubId(), "resetModemConfig");
5367:         Phone phone = PhoneFactory.getPhone(slotIndex);
5368:         if (phone != null) {
5370:                     mApp, phone.getSubId(), "rebootModem");
5386:         final Phone defaultPhone = getDefaultPhone();
5664:      * Sets the ims registration state on all valid {@link Phone}s.
5671:             // NOTE: Before S, this method only set the default phone.
5672:             for (final Phone phone : PhoneFactory.getPhones()) {
5673:                 if (SubscriptionManager.isValidSubscriptionId(phone.getSubId())) {
5674:                     phone.setImsRegistrationState(registered);
5757:             final Phone phone = getPhone(subId);
5758:             if (phone == null) {
5761:             OperatorInfo networkSelection = phone.getSavedNetworkSelection();
5763:                 ? phone.getManualNetworkSelectionPlmn() : networkSelection.getOperatorNumeric();
5820:             Phone phone = getPhone(subId);
5821:             if (phone == null) {
5851:             sendRequestAsync(CMD_GET_CALL_FORWARDING, argument, phone, null);
5872:             Phone phone = getPhone(subId);
5873:             if (phone == null) {
5886:             sendRequestAsync(CMD_SET_CALL_FORWARDING, arguments, phone, null);
5900:             Phone phone = getPhone(subId);
5901:             if (phone == null) {
5909:             CarrierConfigManager configManager = new CarrierConfigManager(phone.getContext());
5916:                 CarrierXmlParser carrierXmlParser = new CarrierXmlParser(phone.getContext(),
5936:                 sendRequestAsync(CMD_GET_CALL_WAITING, argument, phone, null);
5953:             Phone phone = getPhone(subId);
5954:             if (phone == null) {
5963:             CarrierConfigManager configManager = new CarrierConfigManager(phone.getContext());
5970:                 CarrierXmlParser carrierXmlParser = new CarrierXmlParser(phone.getContext(),
5993:                 sendRequestAsync(CMD_SET_CALL_WAITING, arguments, phone, null);
6250:         final Phone phone = getPhone(subId);
6252:             if (phone != null) {
6253:                 return phone.hasMatchedTetherApnSetting();
6273:         final Phone phone = getPhone(subId);
6275:             if (phone != null) {
6280:                 phone.setAlwaysReportSignalStrength(isEnable);
6282:                 loge("setAlwaysReportSignalStrength: no phone found for subId="
6311:      * Accepts either ACCESS_NETWORK_STATE, MODIFY_PHONE_STATE or carrier privileges.
6329:             Phone phone = PhoneFactory.getPhone(phoneId);
6330:             if (phone != null) {
6331:                 boolean retVal = phone.isUserDataEnabled();
6335:                 if (DBG) loge("isUserDataEnabled: no phone subId=" + subId + " retVal=false");
6358:                 mApp.enforceCallingOrSelfPermission(android.Manifest.permission.READ_PHONE_STATE,
6369:             Phone phone = PhoneFactory.getPhone(phoneId);
6370:             if (phone != null) {
6371:                 boolean retVal = phone.getDataEnabledSettings().isDataEnabled();
6375:                 if (DBG) loge("isDataEnabled: no phone subId=" + subId + " retVal=false");
6396:             mApp.enforceCallingOrSelfPermission(android.Manifest.permission.READ_PHONE_STATE,
6408:             Phone phone = PhoneFactory.getPhone(phoneId);
6409:             if (phone != null) {
6412:                     retVal = phone.isUserDataEnabled();
6414:                     retVal = phone.getDataEnabledSettings().isDataEnabledForReason(reason);
6420:                     loge("isDataEnabledForReason: no phone subId="
6431:             Phone phone) {
6432:         if (uid == Process.PHONE_UID) {
6433:             // Skip the check if it's the phone UID (system UID removed in b/184713596)
6434:             // TODO (b/184954344): Check for system/phone UID at call site instead of here
6443:         PackageManager pkgMgr = phone.getContext().getPackageManager();
6448:             int subId = phone.getSubId();
6456:                     phone.getContext().getSystemService(Context.TELEPHONY_SUBSCRIPTION_SERVICE);
6468:     private int getCarrierPrivilegeStatusFromCarrierConfigRules(int privilegeFromSim, Phone phone,
6477:             int subId = phone.getSubId();
6485:                     phone.getContext().getSystemService(Context.TELEPHONY_SUBSCRIPTION_SERVICE);
6495:         final Phone phone = getPhone(subId);
6496:         if (phone == null) {
6500:         UiccCard card = UiccController.getInstance().getUiccCard(phone.getPhoneId());
6508:                 phone.getContext().getPackageManager()), Binder.getCallingUid(), phone);
6514:         final Phone phone = getPhone(subId);
6515:         if (phone == null) {
6520:                 UiccController.getInstance().getUiccProfileForPhone(phone.getPhoneId());
6527:                         phone.getContext().getPackageManager(), uid), uid, phone);
6632:         final Phone phone = getPhone(subId);
6633:         UiccCard card = phone == null ? null : phone.getUiccCard();
6650:             Phone phone = getPhone(subId);
6651:             if (phone != null) {
6652:                 Phone defaultPhone = phone.getImsPhone();
6653:                 if (defaultPhone != null && defaultPhone.getPhoneType() == PHONE_TYPE_IMS) {
6673:             Phone phone = getPhone(subId);
6674:             if (phone != null) {
6675:                 Phone defaultPhone = phone.getImsPhone();
6676:                 if (defaultPhone != null && defaultPhone.getPhoneType() == PHONE_TYPE_IMS) {
6696:             final Phone phone = getPhone(subId);
6697:             if (phone == null) {
6700:             final String subscriberId = phone.getSubscriberId();
6923:             final Phone phone = getPhone(subId);
6924:             return phone == null ? false : phone.setOperatorBrandOverride(brand);
6939:             final Phone phone = getPhone(subId);
6940:             if (phone == null) {
6943:             return phone.setRoamingOverride(gsmRoamingList, gsmNonRoamingList, cdmaRoamingList,
6985:         Phone phone = PhoneFactory.getPhone(phoneId);
6989:                             mApp, phone.getSubId(), "getRadioAccessFamily");
6995:         if (phone == null) {
7002:                             mApp, phone.getSubId(), "getRadioAccessFamily");
7012:         final Phone defaultPhone = getDefaultPhone();
7026:         final Phone defaultPhone = getDefaultPhone();
7080:                     .getBoolean(CarrierConfigManager.KEY_WORLD_PHONE_BOOL);
7111:         final Phone phone = getPhone(subscriptionId);
7112:         if (phone == null) {
7113:             loge("isRttSupported: no Phone found. Invalid subId:" + subscriptionId);
7120:                     phone.getContext().getResources().getBoolean(R.bool.config_support_rtt);
7153:      * Returns the unique device ID of phone, for example, the IMEI for
7157:      *   {@link android.Manifest.permission#READ_PHONE_STATE READ_PHONE_STATE}
7161:         final Phone phone = PhoneFactory.getPhone(0);
7162:         if (phone == null) {
7165:         int subId = phone.getSubId();
7173:             return phone.getDeviceId();
7186:         Phone phone = getPhone(subId);
7187:         if (phone != null) {
7188:             return phone.isImsRegistered();
7209:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
7225:             Phone phone = getPhone(subscriptionId);
7226:             if (phone == null) {
7229:             return PhoneUtils.makePstnPhoneAccountHandle(phone);
7241:             Phone phone = getPhone(subId);
7242:             if (phone != null) {
7243:                 return phone.isWifiCallingEnabled();
7258:             Phone phone = getPhone(subId);
7259:             if (phone != null) {
7260:                 return phone.isVideoEnabled();
7276:             Phone phone = getPhone(subId);
7277:             if (phone != null) {
7278:                 return phone.getImsRegistrationTech();
7302:                 Phone phone = getPhone(subId);
7303:                 if (phone != null) {
7308:                     phone.loadAllowedNetworksFromSubscriptionDatabase();
7344:         final Phone phone = getPhone(subId);
7345:         if (phone == null) {
7352:                     phone.getContext().getOpPackageName(), phone.getContext().getAttributionTag());
7361:             final Locale localeFromDefaultSim = phone.getLocaleFromSimAndCarrierPrefs();
7493:             // isActiveSubId requires READ_PHONE_STATE, which we already check for above
7500:             final Phone phone = getPhone(subId);
7501:             if (phone == null) {
7505:             ServiceState ss = phone.getServiceState();
7518:      * Returns the URI for the per-account voicemail ringtone set in Phone settings.
7529:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(accountHandle);
7530:             if (phone == null) {
7531:                 phone = getDefaultPhone();
7534:             return VoicemailNotificationSettingsUtil.getRingtoneUri(phone.getContext());
7544:      * has permission {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
7554:         final Phone defaultPhone = getDefaultPhone();
7565:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(phoneAccountHandle);
7566:             if (phone == null) {
7567:                 phone = defaultPhone;
7569:             VoicemailNotificationSettingsUtil.setRingtoneUri(phone.getContext(), uri);
7576:      * Returns whether vibration is set for voicemail notification in Phone settings.
7586:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(accountHandle);
7587:             if (phone == null) {
7588:                 phone = getDefaultPhone();
7591:             return VoicemailNotificationSettingsUtil.isVibrationEnabled(phone.getContext());
7601:      * has permission {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
7611:         final Phone defaultPhone = getDefaultPhone();
7622:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(phoneAccountHandle);
7623:             if (phone == null) {
7624:                 phone = defaultPhone;
7626:             VoicemailNotificationSettingsUtil.setVibrationEnabled(phone.getContext(), enabled);
7633:      * Make sure either called from same process as self (phone) or IPC caller has read privilege.
7638:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.READ_PRIVILEGED_PHONE_STATE,
7643:      * Make sure either called from same process as self (phone) or IPC caller has send SMS
7686:         Phone phone = getPhone(subId);
7690:             if (phone == null) {
7695:                 aid = UiccController.getInstance().getUiccCard(phone.getPhoneId())
7715:         Phone phone = getPhone(subId);
7719:             if (phone == null) {
7724:                 esn = phone.getEsn();
7743:         Phone phone = getPhone(subId);
7747:             if (phone == null) {
7752:                 cdmaPrlVersion = phone.getCdmaPrlVersion();
7846:         final Phone phone = getPhone(subId);
7849:         if (phone == null) {
7854:             phone.carrierActionSetRadioEnabled(enabled);
7874:         final Phone phone = getPhone(subId);
7877:         if (phone == null) {
7882:             phone.carrierActionReportDefaultNetworkStatus(report);
7898:         final Phone phone = getPhone(subId);
7899:         if (phone == null) {
7904:             phone.carrierActionResetAll();
7911:      * Called when "adb shell dumpsys phone" is invoked. Dump is also automatically invoked when a
7918:             writer.println("Permission Denial: can't dump Phone from pid="
7961:             Phone phone = getPhone(subId);
7962:             if (phone != null) {
7964:                     phone.carrierActionSetMeteredApnsEnabled(enabled);
7966:                     phone.getDataEnabledSettings().setDataEnabled(reason, enabled);
7986:         Phone phone = getPhone(subId);
7990:             if (phone != null) {
7991:                 return phone.getClientRequestStats();
8018:         Phone phone = PhoneFactory.getPhone(slotIndex);
8024:             if (phone != null) {
8025:                 phone.setSimPowerState(state, null, workSource);
8047:         Phone phone = PhoneFactory.getPhone(slotIndex);
8053:             if (phone != null) {
8055:                 sendRequestAsync(CMD_SET_SIM_POWER, arguments, phone, workSource);
8077:      * Check if phone is in emergency callback mode
8078:      * @return true if phone is in emergency callback mode
8084:         final Phone phone = getPhone(subId);
8088:             if (phone != null) {
8089:                 return phone.isInEcm();
8109:             Phone p = getPhone(subId);
8129:         Phone phone = PhoneFactory.getPhone(slotIndex);
8130:         if (phone != null) {
8131:             if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, phone.getSubId(),
8138:                 return phone.getRadioPowerState();
8151:      * {@link android.Manifest.permission#READ_PHONE_STATE} or that the calling app has carrier
8171:             Phone phone = getPhone(subId);
8172:             isEnabled =  phone != null ? phone.getDataRoamingEnabled() : false;
8184:      * {@link android.Manifest.permission#MODIFY_PHONE_STATE} or that the calling app has carrier
8197:             Phone phone = getPhone(subId);
8198:             if (phone != null) {
8199:                 phone.setDataRoamingEnabled(isEnabled);
8215:             Phone phone = getPhone(subId);
8216:             if (phone != null) {
8217:                 isAllowed = phone.isCspPlmnEnabled();
8236:             // even without READ_PRIVILEGED_PHONE_STATE, we allow the call to continue if the caller
8373:      * {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
8382:             Phone phone = getPhone(subId);
8383:             if (phone == null) {
8386:             UiccCard uiccCard = phone.getUiccCard();
8423:      * not set, return {@link Phone#PREFERRED_NT_MODE}.
8431:         return Phone.PREFERRED_NT_MODE;
8441:             final Phone phone = getPhone(subId);
8442:             if (phone == null) {
8446:             phone.setCarrierTestOverride(mccmnc, imsi, iccid, gid1, gid2, plmn, spn,
8464:             final Phone phone = getPhone(subId);
8465:             if (phone == null) {
8469:             return phone.getCarrierIdListVersion();
8552:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
8557:             for (Phone phone: PhoneFactory.getPhones()) {
8558:                 if (phone.getEmergencyNumberTracker() != null
8559:                         && phone.getEmergencyNumberTracker().getEmergencyNumberList() != null) {
8561:                             phone.getSubId(),
8562:                             phone.getEmergencyNumberTracker().getEmergencyNumberList());
8573:         final Phone defaultPhone = getDefaultPhone();
8581:             for (Phone phone: PhoneFactory.getPhones()) {
8582:                 if (phone.getEmergencyNumberTracker() != null
8583:                         && phone.getEmergencyNumberTracker()
8604:             for (Phone phone: PhoneFactory.getPhones()) {
8605:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8626:             for (Phone phone: PhoneFactory.getPhones()) {
8627:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8646:             final Phone phone = getPhone(subId);
8647:             if (phone == null) {
8651:             return phone.getEmergencyNumberDbVersion();
8663:             for (Phone phone: PhoneFactory.getPhones()) {
8664:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8680:             for (Phone phone: PhoneFactory.getPhones()) {
8681:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8697:             for (Phone phone: PhoneFactory.getPhones()) {
8698:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8711:         Phone phone = getPhone(subId);
8712:         if (phone == null) {
8718:                     .getUiccProfileForPhone(phone.getPhoneId());
8737:             Phone phone = PhoneFactory.getPhone(slotIndex);
8738:             if (phone == null) {
8741:                 return (Boolean) sendRequest(CMD_REQUEST_ENABLE_MODEM, enable, phone, null);
8754:         Phone phone = PhoneFactory.getPhone(slotIndex);
8755:         if (phone == null) return false;
8758:                 mApp, phone.getSubId(), callingPackage, callingFeatureId,
8760:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
8766:                 return mPhoneConfigurationManager.getPhoneStatusFromCache(phone.getPhoneId());
8768:                 return (Boolean) sendRequest(CMD_GET_MODEM_STATUS, null, phone, null);
8836:      * Note: Switch from multi-sim to single-sim is only possible with MODIFY_PHONE_STATE
8837:      * permission, but the other way around is possible with either MODIFY_PHONE_STATE
8866:         Phone phone = getPhone(subId);
8867:         if (phone == null) {
8872:             UiccCard uiccCard = phone.getUiccCard();
8942:         Phone phone = getDefaultPhone();
8943:         if (phone == null) return -1;
8944:         HalVersion hv = phone.getHalVersion();
8974:         enforceReadPrivilegedPermission("Needs READ_PRIVILEGED_PHONE_STATE for "
8980:             Phone phone = getPhone(subId);
8981:             if (phone == null) return false;
8983:             boolean isMetered = ApnSettingUtils.isMeteredApnType(apnType, phone);
8984:             return !isMetered || phone.getDataEnabledSettings().isDataEnabled(apnType);
8997:             Phone phone = getPhone(subId);
8998:             if (phone == null) return true; // By default return true.
9000:             return ApnSettingUtils.isMeteredApnType(apnType, phone);
9012:             Phone phone = getPhone(subscriptionId);
9013:             if (phone == null) {
9033:             sendRequestAsync(CMD_SET_SYSTEM_SELECTION_CHANNELS, argument, phone, null);
9133:             Phone phone = getPhone(subscriptionId);
9134:             if (phone == null) return false;
9138:                     return phone.getDataEnabledSettings().isDataAllowedInVoiceCall();
9140:                     return phone.getDataEnabledSettings().isMmsAlwaysAllowed();
9156:             Phone phone = getPhone(subscriptionId);
9157:             if (phone == null) return;
9161:                     phone.getDataEnabledSettings().setAllowDataDuringVoiceCall(enabled);
9164:                     phone.getDataEnabledSettings().setAlwaysAllowMmsData(enabled);
9186:             for (Phone phone : PhoneFactory.getPhones()) {
9187:                 Phone defaultPhone = phone.getImsPhone();
9188:                 if (defaultPhone != null && defaultPhone.getPhoneType() == PHONE_TYPE_IMS) {
9237:             Phone phone = getPhone(subId);
9238:             if (phone != null && phone.getIccCard() != null) {
9239:                 return phone.getIccCard().getIccLockEnabled();
9263:         Phone phone = getPhone(subId);
9264:         if (phone == null) {
9271:                     new Pair<Boolean, String>(enabled, password), phone, null);
9295:         Phone phone = getPhone(subId);
9296:         if (phone == null) {
9303:                     new Pair<String, String>(oldPassword, newPassword), phone, null);
9362:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
9365:         Phone phone = getPhone(subId);
9366:         if (phone == null) {
9367:             throw new RuntimeException("phone is not available");
9372:             return phone.getEquivalentHomePlmns();
9397:                 Manifest.permission.MODIFY_PHONE_STATE);
9435:      * @param subId the subscription ID of the phone requesting to set the radio power state.
9437:      * @return {@code true} if phone setRadioPowerForReason was called. Otherwise, returns {@code
9441:         Phone phone = getPhone(subId);
9442:         if (phone != null) {
9443:             phone.setRadioPowerForReason(enable, Phone.RADIO_POWER_REASON_THERMAL);
9458:         // Ensure that radio is on. If not able to power on due to phone being unavailable, return
9554:                     // Ensure that radio is on. If not able to power on due to phone being
9576:                         Phone phone = getPhone(subId);
9577:                         if (phone == null) {
9583:                         if (PhoneConstantConversions.convertCallState(phone.getState())
9585:                                 || phone.isInEmergencySmsMode() || phone.isInEcm()
9587:                             String errorMessage = "Phone state is not valid. call state = "
9588:                                     + PhoneConstantConversions.convertCallState(phone.getState())
9589:                                     + " isInEmergencySmsMode = " + phone.isInEmergencySmsMode()
9590:                                     + " isInEmergencyCallbackMode = " + phone.isInEcm();
9606:                     // Turn radio off. If not able to power off due to phone being unavailable,
9730:                 permission.READ_PRIVILEGED_PHONE_STATE);
9757:                 permission.READ_PRIVILEGED_PHONE_STATE);
9788:                 permission.READ_PRIVILEGED_PHONE_STATE);
10233:         if (callingUid == Process.PHONE_UID || callingUid == Process.SYSTEM_UID) {
10234:             // phone/system process do not have further restriction on request
22: import static com.android.internal.telephony.PhoneConstants.SUBSCRIPTION_KEY;
64: import android.telecom.PhoneAccount;
65: import android.telecom.PhoneAccountHandle;
87: import android.telephony.PhoneCapability;
88: import android.telephony.PhoneNumberRange;
156: import com.android.internal.telephony.PhoneConfigurationManager;
157: import com.android.internal.telephony.PhoneConstantConversions;
158: import com.android.internal.telephony.PhoneConstants;
159: import com.android.internal.telephony.PhoneFactory;
174: import com.android.internal.telephony.imsphone.ImsPhone;
175: import com.android.internal.telephony.imsphone.ImsPhoneCallTracker;
220:     private static final String LOG_TAG = "PhoneInterfaceManager";
221:     private static final boolean DBG = (PhoneGlobals.DBG_LEVEL >= 2);
336:     private static PhoneInterfaceManager sInstance;
339:     private PhoneGlobals mApp;
742:                     defaultPhone.nvReadItem((Integer) request.argument, onCompleted,
769:                     defaultPhone.nvWriteItem(idValue.first, idValue.second, onCompleted,
780:                     defaultPhone.nvWriteCdmaPrl((byte[]) request.argument, onCompleted);
790:                     defaultPhone.resetModemConfig(onCompleted);
932:                     defaultPhone.invokeOemRilRequestRaw((byte[]) request.argument, onCompleted);
1213:                     if (defaultPhone != null) {
1214:                         defaultPhone.getModemActivityInfo(onCompleted, request.workSource);
1277:                     defaultPhone.setAllowedCarriers(argument, onCompleted, request.workSource);
1305:                     defaultPhone.getAllowedCarriers(onCompleted, request.workSource);
1529:                     defaultPhone.rebootModem(onCompleted);
1539:                     PhoneConfigurationManager.getInstance()
1549:                         mPhoneConfigurationManager.addToPhoneStatusCache(phoneId, msg.arg1 == 1);
1561:                     PhoneConfigurationManager.getInstance()
1678:                     defaultPhone.eraseModemConfig(onCompleted);
1698:                         int phoneId = getPhoneFromRequest(request).getPhoneId();
1700:                                 .storePin(passwords.second, phoneId);
1722:                         int phoneId = getPhoneFromRequest(request).getPhoneId();
1725:                                     .storePin(enabled.second, phoneId);
1727:                             UiccController.getInstance().getPinStorage().clearPin(phoneId);
1741:                     getDefaultPhone().getContext().sendBroadcastAsUser(
2078:      * Initialize the singleton PhoneInterfaceManager instance.
2079:      * This is only done once, at startup, from PhoneApp.onCreate().
2081:     /* package */ static PhoneInterfaceManager init(PhoneGlobals app) {
2082:         synchronized (PhoneInterfaceManager.class) {
2084:                 sInstance = new PhoneInterfaceManager(app);
2095:         mCM = PhoneGlobals.getInstance().mCM;
2104:         mPhoneConfigurationManager = PhoneConfigurationManager.getInstance();
2113:         return (thePhone != null) ? thePhone : PhoneFactory.getDefaultPhone();
2135:                 ? getDefaultPhone() : getPhone(subId);
2146:         return PhoneFactory.getPhone(mSubscriptionController.getPhoneId(subId));
2164:         PackageManager pm = getDefaultPhone().getContext().getPackageManager();
2191:             PhoneConstants.State state = mCM.getState(subId);
2192:             if (state != PhoneConstants.State.OFFHOOK && state != PhoneConstants.State.RINGING) {
2251:         return (resultArray[0] == PhoneConstants.PIN_RESULT_SUCCESS) ? true : false;
2256:         return (resultArray[0] == PhoneConstants.PIN_RESULT_SUCCESS) ? true : false;
2297:         private int mResult = PhoneConstants.PIN_GENERAL_FAILURE;
2306:         UnlockSim(int phoneId, IccCard simCard) {
2307:             mPhoneId = phoneId;
2328:                                             mResult = PhoneConstants.PIN_PASSWORD_INCORRECT;
2333:                                             mResult = PhoneConstants.PIN_OPERATION_ABORTED;
2335:                                             mResult = PhoneConstants.PIN_GENERAL_FAILURE;
2338:                                         mResult = PhoneConstants.PIN_RESULT_SUCCESS;
2390:             if (mResult == PhoneConstants.PIN_RESULT_SUCCESS && pin.length() > 0) {
2551:             logv(TelephonyManager.getDefault().getPhoneCount() + " Phones are shutdown.");
2586:             if (defaultPhone != null) {
2587:                 defaultPhone.setRadioPower(turnOn);
2733:                 return PhoneConstantConversions.convertDataState(
2734:                         PhoneConstants.DataState.DISCONNECTED);
2806:             final int subId = mSubscriptionController.getSubIdUsingPhoneId(phoneId);
2995:             getDefaultPhone().setCellInfoListRate(rateInMillis, workSource);
3203:         Log.d(LOG_TAG, "[PhoneIntfMgr] " + msg);
3207:         Log.v(LOG_TAG, "[PhoneIntfMgr] " + msg);
3211:         Log.e(LOG_TAG, "[PhoneIntfMgr] " + msg);
3373:     public void requestNumberVerification(PhoneNumberRange range, long timeoutMillis,
3404:             return getDefaultPhone().needsOtaServiceProvisioning();
3439:             PhoneAccountHandle phoneAccountHandle = PhoneAccountHandleConverter.fromSubId(subId);
3440:             if (phoneAccountHandle == null) {
3443:             return VisualVoicemailSettingsUtil.dump(mApp, phoneAccountHandle);
3528:         SmsController smsController = PhoneFactory.getSmsController();
3663:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
3672:             defaultPhone.sendDialerSpecialCode(inputCode);
3727:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3751:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone.
3847:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3874:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone.
3890:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3969:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3987:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4007:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4022:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4041:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4057:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4076:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4092:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4108:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4128:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4144:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4159:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4175:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4191:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4210:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4229:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4247:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4292:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4322:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4355:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4420:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4596:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4621:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4647:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4673:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4843:             return PhoneConstants.LTE_ON_CDMA_UNKNOWN;
4850:                 return PhoneConstants.LTE_ON_CDMA_UNKNOWN;
4853:                         .orElse(PhoneConstants.LTE_ON_CDMA_FALSE);
4914:         int phoneId = UiccController.getInstance().getPhoneIdFromSlotId(slotIndex);
4915:         if (phoneId == -1) {
4919:         return PhoneFactory.getPhone(phoneId);
4954:                 ComponentInfo bestComponent = EuiccConnector.findBestComponent(getDefaultPhone()
5096:                 ComponentInfo bestComponent = EuiccConnector.findBestComponent(getDefaultPhone()
5387:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, defaultPhone.getSubId(),
5394:             return defaultPhone.getPcscfAddress(apnType);
6041:                     request, messenger, binder, getPhone(subId),
6327:             int phoneId = mSubscriptionController.getPhoneId(subId);
6328:             if (DBG) log("isUserDataEnabled: subId=" + subId + " phoneId=" + phoneId);
6367:             int phoneId = mSubscriptionController.getPhoneId(subId);
6368:             if (DBG) log("isDataEnabled: subId=" + subId + " phoneId=" + phoneId);
6403:             int phoneId = mSubscriptionController.getPhoneId(subId);
6405:                 log("isDataEnabledForReason: subId=" + subId + " phoneId=" + phoneId
6536:         int phoneId = SubscriptionManager.getPhoneId(subId);
6537:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
6544:             getPhone(phoneId), pkgName);
6561:                 getPhone(i), pkgName);
6572:         if (!SubscriptionManager.isValidPhoneId(phoneId)) {
6573:             loge("phoneId " + phoneId + " is not valid.");
6576:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
6578:             loge("getCarrierPackageNamesForIntentAndPhone: No UICC");
6585:     public List<String> getPackagesWithCarrierPrivileges(int phoneId) {
6589:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
6654:                     ImsPhone imsPhone = (ImsPhone) defaultPhone;
6655:                     imsPhone.setCallComposerStatus(status);
6677:                     ImsPhone imsPhone = (ImsPhone) defaultPhone;
6678:                     return imsPhone.getCallComposerStatus();
6984:     public int getRadioAccessFamily(int phoneId, String callingPackage) {
7003:             raf = ProxyController.getInstance().getRadioAccessFamily(phoneId);
7017:             ImsManager.getInstance(defaultPhone.getContext(),
7018:                     defaultPhone.getPhoneId()).setVtSetting(enable);
7027:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, defaultPhone.getSubId(),
7039:                     ImsManager.getInstance(defaultPhone.getContext(), defaultPhone.getPhoneId());
7154:      * GSM and the MEID for CDMA phones. Return null if device ID is not available.
7198:             return PhoneUtils.getSubIdForPhoneAccount(phoneAccount);
7206:             PhoneAccountHandle phoneAccountHandle, String callingPackage, String callingFeatureId) {
7213:             return PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle);
7317:             cleanUpSmsRawTable(getDefaultPhone().getContext());
7328:               sendEraseModemConfig(getDefaultPhone());
7520:      * @param accountHandle The handle for the {@link PhoneAccount} for which to retrieve the
7523:      * PhoneAccount.
7526:     public Uri getVoicemailRingtoneUri(PhoneAccountHandle accountHandle) {
7546:      * @param phoneAccountHandle The handle for the {@link PhoneAccount} for which to set the
7549:      * PhoneAccount.
7553:             PhoneAccountHandle phoneAccountHandle, Uri uri) {
7556:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
7559:                     mApp, PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle),
7578:      * @param accountHandle The handle for the {@link PhoneAccount} for which to retrieve the
7580:      * @return {@code true} if the vibration is set for this PhoneAccount, {@code false} otherwise.
7583:     public boolean isVoicemailVibrationEnabled(PhoneAccountHandle accountHandle) {
7603:      * @param phoneAccountHandle The handle for the {@link PhoneAccount} for which to set the
7606:      * specific PhoneAccount.
7610:             PhoneAccountHandle phoneAccountHandle, boolean enabled) {
7613:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
7616:                     mApp, PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle),
7932:         return new TelephonyShellCommand(this, getDefaultPhone().getContext()).exec(
8238:             if (checkCarrierPrivilegesForPackageAnyPhone(callingPackage)
8427:         int phoneId = mSubscriptionController.getPhoneId(subId);
8428:         if (phoneId >= 0 && phoneId < list.size() && list.get(phoneId) != null) {
8429:             return list.get(phoneId);
8577:                             mApp, defaultPhone.getSubId(), "isEmergencyNumber(Potential)");
8793:                 getDefaultPhone().getSubId(), callingPackage, callingFeatureId,
8816:         PhoneCapability staticCapability =
8922:             int phoneCount = TelephonyManager.getDefault().getPhoneCount();
8924:             int[] logicalSlotsMapping = new int[phoneCount];
9077:         SmsPermissions permissions = new SmsPermissions(getDefaultPhone(), mApp,
9103:             return SubscriptionManager.getResourcesForSubId(getDefaultPhone().getContext(), subId)
9120:             return SubscriptionManager.getResourcesForSubId(getDefaultPhone().getContext(), subId)
9189:                     ImsPhone imsPhone = (ImsPhone) defaultPhone;
9191:                             (ImsPhoneCallTracker) imsPhone.getCallTracker();
9193:                     Rlog.i(LOG_TAG, "setCepEnabled isCepEnabled=" + isCepEnabled + ", for imsPhone "
9194:                             + imsPhone.getMsisdn());
9332:         // *  Inherited from PhoneWindowManager  *
9433:      * PhoneInternalInterface#setRadioPowerForReason} for more details.
9530:         if (!getThermalMitigationAllowlist(getDefaultPhone().getContext())
9992:             return getDefaultPhone().getMobileProvisioningUrl();
10007:             return EabUtil.getContactFromEab(getDefaultPhone().getContext(), contact);
10022:             return EabUtil.removeContactFromEab(subId, contacts, getDefaultPhone().getContext());
143: import com.android.internal.telephony.DefaultPhoneNotifier;
525:                             getPhoneFromRequest(request).handlePinMmi((String) request.argument)
889:                     getPhoneFromRequest(request).getAllowedNetworkTypesBitmask(onCompleted);
919:                     getPhoneFromRequest(request).setAllowedNetworkTypes(
946:                     getPhoneFromRequest(request).setVoiceMailNumber(tagNum.first, tagNum.second,
958:                     getPhoneFromRequest(request).setNetworkSelectionModeAutomatic(onCompleted);
968:                     getPhoneFromRequest(request).getAvailableNetworks(onCompleted);
1081:                     getPhoneFromRequest(request).getCallWaiting(onCompleted);
1127:                     getPhoneFromRequest(request).setCallWaiting(enable, onCompleted);
1193:                     getPhoneFromRequest(request).selectNetworkManually(selArg.operatorInfo,
1388:                     getPhoneFromRequest(request).getNetworkSelectionMode(onCompleted);
1409:                     getPhoneFromRequest(request).queryCdmaRoamingPreference(onCompleted);
1425:                     getPhoneFromRequest(request).setCdmaRoamingPreference(mode, onCompleted);
1436:                     getPhoneFromRequest(request).queryCdmaSubscriptionMode(onCompleted);
1452:                     getPhoneFromRequest(request).setCdmaSubscriptionMode(
1571:                         mPhoneConfigurationManager.addToPhoneStatusCache(id,
1688:                     getPhoneFromRequest(request).getIccCard().changeIccLockPassword(
1711:                     getPhoneFromRequest(request).getIccCard().setIccLockEnabled(
2129:             return getPhoneFromSubId(request.subId);
2391:                 UiccController.getInstance().getPinStorage().storePin(pin, mPhoneId);
2472:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
2547:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
2564:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
2566:                 shutdownRadioUsingPhoneId(i);
3072:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3216:         return getActivePhoneTypeForSlot(getSlotForDefaultSubscription());
3246:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3279:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3310:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3453:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3621:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3681:                     .enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3718:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3744:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3801:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3841:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3866:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3966:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4003:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4037:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4072:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4124:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4206:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4288:         checkModifyPhoneStatePermission(subId, "setRcsProvisioningStatusForCapability");
4352:         checkModifyPhoneStatePermission(subId, "setImsProvisioningStatusForCapability");
4717:                 && !TelephonyPermissions.checkCallingOrSelfReadPhoneStateNoThrow(
4751:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
4776:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
4869:         return mSubscriptionController.getPhoneId(getDefaultSubscription());
4931:         return iccOpenLogicalChannelWithPermission(getPhoneFromSubId(subId), callingPackage, aid,
4944:         return iccOpenLogicalChannelWithPermission(getPhoneFromSlotIdOrThrowException(slotIndex),
4979:         return iccCloseLogicalChannelWithPermission(getPhoneFromSubId(subId), channel);
4986:         return iccCloseLogicalChannelWithPermission(getPhoneFromSlotIdOrThrowException(slotIndex),
5015:         return iccTransmitApduLogicalChannelWithPermission(getPhoneFromSubId(subId), channel, cla,
5029:                 getPhoneFromSlotIdOrThrowException(slotIndex), channel, cla, command, p1, p2, p3,
5068:         return iccTransmitApduBasicChannelWithPermission(getPhoneFromSubId(subId), callingPackage,
5084:                 getPhoneFromSlotIdOrThrowException(slotIndex), callingPackage, cla, command, p1,
5169:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
5207:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, subId, callingPackage,
5611:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5748:                     .enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
6101:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
6126:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
6130:             return getPhoneFromSubId(subId).getAllowedNetworkTypes(reason);
6179:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
6221:         if (allowedNetworkTypes == getPhoneFromSubId(subId).getAllowedNetworkTypes(reason)) {
6552:         for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
6616:         enforceReadPrivilegedPermission("getPackagesWithCarrierPrivilegesForAllPhones");
6622:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
6743:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneNumber(
6770:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6793:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6988:                     .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
7001:                     .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
7051:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7070:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7207:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, getDefaultSubscription(),
7208:                 callingPackage, callingFeatureId, "getSubIdForPhoneAccountHandle")) {
7221:         enforceReadPrivilegedPermission("getPhoneAccountHandleForSubscriptionId, "
7453:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7982:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8164:             TelephonyPermissions.enforceCallingOrSelfReadPhoneStatePermissionOrCarrierPrivilege(
8209:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
8337:                         slot.getPhoneId(),
8478:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8486:             return mPhoneConfigurationManager.getNumberOfModemsWithSimultaneousDataConnections();
8495:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
8522:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
8549:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8576:                     .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
8757:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8792:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp,
8817:                 mPhoneConfigurationManager.getStaticPhoneCapability();
8857:             mPhoneConfigurationManager.switchMultiSimConfig(numOfSims);
8897:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8904:             return mPhoneConfigurationManager.isRebootRequiredForModemConfigChange();
8913:         metrics.updateEnabledModemBitmap((1 << TelephonyManager.from(mApp).getPhoneCount()) - 1);
8927:                 if (SubscriptionManager.isValidPhoneId(slotInfos[i].getLogicalSlotIdx())) {
9042:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
9063:                 SubscriptionManager.getPhoneId(subId), UiccController.APP_FAM_3GPP);
9190:                     ImsPhoneCallTracker imsPhoneCallTracker =
9192:                     imsPhoneCallTracker.setConferenceEventPackageEnabled(isCepEnabled);
9360:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
android.googlesource.com/platform/superproject:packages/services/Telephony/src/com/android/phone/PhoneInterfaceManager.java: [ master, ]
384:         public Phone phone;
17: package com.android.phone;
198: public class PhoneInterfaceManager extends ITelephony.Stub {
1655:     private PhoneInterfaceManager(PhoneGlobals app) {
1672:     private Phone getDefaultPhone() {
1706:     private Phone getPhone(int subId) {
2347:     public String getNetworkCountryIsoForPhone(int phoneId) {
5936:     public int checkCarrierPrivilegesForPackageAnyPhone(String pkgName) {
5959:     public List<String> getCarrierPackageNamesForIntentAndPhone(Intent intent, int phoneId) {
6417:     public boolean isWorldPhone(int subId, String callingPackage, String callingFeatureId) {
308:     private PhoneConfigurationManager mPhoneConfigurationManager;
1686:     private Phone getPhoneFromRequest(MainThreadRequest request) {
1694:     private Phone getPhoneFromSubId(int subId) {
2125:     private void shutdownRadioUsingPhoneId(int phoneId) {
2780:     public int getActivePhoneType() {
2785:     public int getActivePhoneTypeForSlot(int slotIndex) {
3824:     private void checkModifyPhoneStatePermission(int subId, String message) {
4463:     private Phone getPhoneFromSlotIdOrThrowException(int slotIndex) {
6003:     public List<String> getPackagesWithCarrierPrivilegesForAllPhones() {
6543:     public int getSubIdForPhoneAccount(PhoneAccount phoneAccount) {
6553:     public int getSubIdForPhoneAccountHandle(
6568:     public @Nullable PhoneAccountHandle getPhoneAccountHandleForSubscriptionId(int subscriptionId) {
21: import static com.android.internal.telephony.PhoneConstants.PHONE_TYPE_IMS;
140: import com.android.internal.telephony.Phone;
174: import com.android.phone.settings.PickSmsSubscriptionActivity;
175: import com.android.phone.vvm.PhoneAccountHandleConverter;
176: import com.android.phone.vvm.RemoteVvmTaskManager;
177: import com.android.phone.vvm.VisualVoicemailSettingsUtil;
178: import com.android.phone.vvm.VisualVoicemailSmsFilterConfig;
383:         // In cases where subId is unavailable, the caller needs to specify the phone.
392:         MainThreadRequest(Object argument, Phone phone, WorkSource workSource) {
394:             if (phone != null) {
395:                 this.phone = phone;
423:      * A handler that processes messages on the main thread in the phone process. Since many
424:      * of the Phone calls are not thread safe this is needed to shuttle the requests from the
425:      * inbound binder threads to the main thread in the phone process.  The Binder thread
442:             final Phone defaultPhone = getDefaultPhone();
447:                     final Phone phone = getPhoneFromRequest(request);
466:                         request.result = phone != null
467:                                 ? phone.handleUssdRequest(ussdRequest, wrappedCallback) : false;
478:                     final Phone phone = getPhoneFromRequest(request);
479:                     request.result = phone != null ?
1266:                     request.phone.requestCellInfoUpdate(request.workSource, onCompleted);
1280:                     request.phone.requestCellInfoUpdate(request.workSource,
1308:                     Phone phone = getPhoneFromRequest(request);
1309:                     phone.getCellIdentity(ws, obtainMessage(EVENT_GET_CELL_LOCATION_DONE, request));
1317:                         phone = getPhoneFromRequest(request);
1318:                         request.result = (phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA)
1340:                             .enablePhone(request.phone, enable, onCompleted);
1346:                     int phoneId = request.phone.getPhoneId();
1361:                             .getPhoneStatusFromModem(request.phone, onCompleted);
1366:                     int id = request.phone.getPhoneId();
1389:                     request.phone.setSystemSelectionChannels(args.first, onCompleted);
1569:     private Object sendRequest(int command, Object argument, Phone phone, WorkSource workSource) {
1571:                 command, argument, SubscriptionManager.INVALID_SUBSCRIPTION_ID, phone, workSource);
1580:             int command, Object argument, Integer subId, Phone phone, WorkSource workSource) {
1586:         if (subId != SubscriptionManager.INVALID_SUBSCRIPTION_ID && phone != null) {
1587:             throw new IllegalArgumentException("subId and phone cannot both be specified!");
1588:         } else if (phone != null) {
1589:             request = new MainThreadRequest(argument, phone, workSource);
1629:      * Same as {@link #sendRequestAsync(int,Object)} except it takes a Phone and WorkSource.
1633:             int command, Object argument, Phone phone, WorkSource workSource) {
1634:         MainThreadRequest request = new MainThreadRequest(argument, phone, workSource);
1673:         Phone thePhone = getPhone(getDefaultSubscription());
1687:         if (request.phone != null) {
1688:             return request.phone;
1700:         Phone phone = getPhoneFromRequest(request);
1701:         return phone == null ? null :
1702:                 UiccController.getInstance().getUiccCard(phone.getPhoneId());
1705:     // returns phone associated with the subId.
1710:     private void sendEraseModemConfig(Phone phone) {
1711:         if (phone != null) {
1713:                   mApp, phone.getSubId(), "eraseModemConfig");
1751:             // PENDING: should we just silently fail if phone is offhook or ringing?
1772:         // from the context of the phone app.
1775:         if (mAppOps.noteOp(AppOpsManager.OPSTR_CALL_PHONE, Binder.getCallingUid(), callingPackage)
1993:             final Phone phone = getPhone(getDefaultSubscription());
1994:             if (phone != null) {
1995:                 phone.updateServiceLocation(workSource);
2040:             final Phone phone = getPhone(subId);
2041:             if (phone != null) {
2042:                 return phone.getServiceState().getState() != ServiceState.STATE_POWER_OFF;
2060:             final Phone phone = getPhone(subId);
2061:             if (phone != null) {
2062:                 phone.setRadioPower(!isRadioOnForSubscriber(subId));
2078:             final Phone phone = getPhone(subId);
2079:             if (phone == null) {
2082:             if ((phone.getServiceState().getState() != ServiceState.STATE_POWER_OFF) != turnOn) {
2100:                 Phone phone = PhoneFactory.getPhone(i);
2101:                 if (phone != null && phone.isRadioAvailable()) return true;
2117:                 logv("Shutting down Phone " + i);
2126:         Phone phone = PhoneFactory.getPhone(phoneId);
2127:         if (phone != null && phone.isRadioAvailable()) {
2128:             phone.shutdownRadio();
2137:             final Phone defaultPhone = PhoneFactory.getDefaultPhone();
2142:                 loge("There's no default phone.");
2155:             final Phone phone = getPhone(subId);
2156:             if (phone != null) {
2157:                 phone.setRadioPower(turnOn);
2175:             final Phone phone = getPhone(subId);
2176:             if (phone != null) {
2177:                 phone.getDataEnabledSettings().setUserDataEnabled(true);
2195:             final Phone phone = getPhone(subId);
2196:             if (phone != null) {
2197:                 phone.getDataEnabledSettings().setUserDataEnabled(false);
2211:             final Phone phone = getPhone(subId);
2212:             if (phone != null) {
2213:                 return phone.isDataAllowed(ApnSetting.TYPE_DEFAULT);
2262:             Phone phone = PhoneFactory.getPhone(slotIndex);
2263:             return phone == null ? TelephonyManager.CALL_STATE_IDLE :
2264:                     PhoneConstantConversions.convertCallState(phone.getState());
2279:             final Phone phone = getPhone(subId);
2280:             if (phone != null) {
2281:                 return PhoneConstantConversions.convertDataState(phone.getDataConnectionState());
2300:             final Phone phone = getPhone(subId);
2301:             if (phone != null) {
2302:                 return DefaultPhoneNotifier.convertDataActivityState(phone.getDataActivityState());
2331:                 return (getDefaultPhone().getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA)
2352:             if (phoneId == SubscriptionManager.INVALID_PHONE_INDEX) {
2353:                 // Get default phone in this case.
2354:                 phoneId = SubscriptionManager.DEFAULT_PHONE_INDEX;
2357:             Phone phone = PhoneFactory.getPhone(phoneId);
2358:             if (phone == null) return "";
2359:             ServiceStateTracker sst = phone.getServiceStateTracker();
2364:             EmergencyNumberTracker ent = phone.getEmergencyNumberTracker();
2449:         for (Phone phone : PhoneFactory.getPhones()) {
2450:             List<CellInfo> info = phone.getAllCellInfo();
2489:             for (Phone phone : PhoneFactory.getPhones()) {
2491:                         CMD_GET_ALL_CELL_INFO, null, phone, workSource);
2551:         final Phone phone = getPhoneFromSubId(subId);
2552:         if (phone == null) throw new IllegalArgumentException("Invalid Subscription Id: " + subId);
2554:         sendRequestAsync(CMD_REQUEST_CELL_INFO_UPDATE, cb, phone, workSource);
2572:         Phone phone = PhoneFactory.getPhone(slotIndex);
2573:         if (phone == null) {
2576:         int subId = phone.getSubId();
2584:             return phone.getImei();
2592:         Phone phone = PhoneFactory.getPhone(slotIndex);
2594:         if (phone != null) {
2595:             String imei = phone.getImei();
2603:         Phone phone = PhoneFactory.getPhone(slotIndex);
2604:         if (phone == null) {
2608:         int subId = phone.getSubId();
2616:             return phone.getMeid();
2624:         Phone phone = PhoneFactory.getPhone(slotIndex);
2626:         if (phone != null) {
2627:             String meid = phone.getMeid();
2636:         Phone phone = PhoneFactory.getPhone(slotIndex);
2637:         if (phone == null) {
2640:         int subId = phone.getSubId();
2649:             return phone.getDeviceSvn();
2659:             final Phone phone = getPhone(subId);
2660:             return phone == null ? TelephonyManager.UNKNOWN_CARRIER_ID : phone.getCarrierId();
2670:             final Phone phone = getPhone(subId);
2671:             return phone == null ? null : phone.getCarrierName();
2681:             final Phone phone = getPhone(subId);
2682:             return phone == null ? TelephonyManager.UNKNOWN_CARRIER_ID
2683:                     : phone.getSpecificCarrierId();
2693:             final Phone phone = getPhone(subId);
2694:             return phone == null ? null : phone.getSpecificCarrierName();
2705:         final Phone phone = PhoneFactory.getPhone(slotIndex);
2706:         if (phone == null) {
2711:             return CarrierResolver.getCarrierIdFromMccMnc(phone.getContext(), mccmnc);
2722:      * Make sure the caller has the MODIFY_PHONE_STATE permission.
2727:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.MODIFY_PHONE_STATE, null);
2747:      * Make sure the caller has the CALL_PHONE permission.
2752:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.CALL_PHONE, null);
2788:             final Phone phone = PhoneFactory.getPhone(slotIndex);
2789:             if (phone == null) {
2790:                 return PhoneConstants.PHONE_TYPE_NONE;
2792:                 return phone.getPhoneType();
2819:             final Phone phone = getPhone(subId);
2820:             if (phone != null) {
2821:                 return phone.getCdmaEriIconIndex();
2852:             final Phone phone = getPhone(subId);
2853:             if (phone != null) {
2854:                 return phone.getCdmaEriIconMode();
2883:             final Phone phone = getPhone(subId);
2884:             if (phone != null) {
2885:                 return phone.getCdmaEriText();
2904:             final Phone phone = getPhone(subId);
2905:             if (phone != null && phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA) {
2906:                 return phone.getLine1Number();
2908:                 loge("getCdmaMdn: no phone found. Invalid subId: " + subId);
2926:             final Phone phone = getPhone(subId);
2927:             if (phone != null && phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA) {
2928:                 return phone.getCdmaMin();
2940:         if (mApp.checkCallingOrSelfPermission(android.Manifest.permission.MODIFY_PHONE_STATE)
2942:             throw new SecurityException("Caller must hold the MODIFY_PHONE_STATE permission");
3106:             final Phone phone = getPhone(subId);
3107:             if (phone != null) {
3108:                 phone.setVoiceActivationState(activationState);
3127:             final Phone phone = getPhone(subId);
3128:             if (phone != null) {
3129:                 phone.setDataActivationState(activationState);
3145:         final Phone phone = getPhone(subId);
3148:             if (phone != null) {
3149:                 return phone.getVoiceActivationState();
3165:         final Phone phone = getPhone(subId);
3168:             if (phone != null) {
3169:                 return phone.getDataActivationState();
3191:             final Phone phone = getPhone(subId);
3192:             if (phone != null) {
3193:                 return phone.getVoiceMessageCount();
3210:             final Phone phone = getPhone(subId);
3211:             return (phone == null ? false : phone.isConcurrentVoiceAndDataAllowed());
3224:         final Phone defaultPhone = getDefaultPhone();
3262:             for (Phone phone : PhoneFactory.getPhones()) {
3263:                 if (phone.isInEmergencySmsMode()) {
3274:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3301:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3339:             Phone phone = getPhone(subId);
3340:             if (phone == null) {
3345:             phone.getImsRegistrationState(regState -> {
3372:             Phone phone = getPhone(subId);
3373:             if (phone == null) {
3378:             phone.getImsRegistrationTech(regTech -> {
3397:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3423:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3474:             Phone phone = getPhone(subId);
3475:             if (phone == null) return false;
3476:             return phone.isImsCapabilityAvailable(capability, regTech);
3524:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3561:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3595:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3630:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3682:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3764:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3831:         Phone phone = getPhone(subId);
3832:         if (phone == null) {
3833:             loge("phone instance null for subid " + subId);
3837:             if (!doesImsCapabilityRequireProvisioning(phone.getContext(), subId, capability)) {
3841:             if (!doesRcsCapabilityRequireProvisioning(phone.getContext(), subId, capability)) {
4275:             final Phone phone = getPhone(subId);
4276:             if (phone != null) {
4277:                 return phone.getServiceState().getDataNetworkType();
4309:             final Phone phone = getPhone(subId);
4310:             if (phone != null) {
4311:                 return phone.getServiceState().getDataNetworkType();
4334:             final Phone phone = getPhone(subId);
4335:             if (phone != null) {
4336:                 return phone.getServiceState().getVoiceNetworkType();
4361:             final Phone phone = PhoneFactory.getPhone(slotIndex);
4362:             if (phone != null) {
4363:                 return phone.getIccCard().hasIccCard();
4378:      * @return {@link Phone#LTE_ON_CDMA_UNKNOWN}, {@link Phone#LTE_ON_CDMA_FALSE}
4379:      * or {@link Phone#LTE_ON_CDMA_TRUE}
4398:             final Phone phone = getPhone(subId);
4399:             if (phone == null) {
4467:                     + " does not correspond to an active phone");
4498:     private IccOpenLogicalChannelResponse iccOpenLogicalChannelWithPermission(Phone phone,
4515:                     CMD_OPEN_CHANNEL, new Pair<String, Integer>(aid, p2), phone,
4540:     private boolean iccCloseLogicalChannelWithPermission(Phone phone, int channel) {
4546:             Boolean success = (Boolean) sendRequest(CMD_CLOSE_CHANNEL, channel, phone,
4583:     private String iccTransmitApduLogicalChannelWithPermission(Phone phone, int channel, int cla,
4592:                     new IccAPDUArgument(channel, cla, command, p1, p2, p3, data), phone,
4639:     private String iccTransmitApduBasicChannelWithPermission(Phone phone, String callingPackage,
4657:                     new IccAPDUArgument(0, cla, command, p1, p2, p3, data), phone,
4891:         Phone phone = PhoneFactory.getPhone(slotIndex);
4892:         if (phone != null) {
4894:                     mApp, phone.getSubId(), "resetModemConfig");
4917:         Phone phone = PhoneFactory.getPhone(slotIndex);
4918:         if (phone != null) {
4920:                     mApp, phone.getSubId(), "rebootModem");
4936:         final Phone defaultPhone = getDefaultPhone();
5268:             final Phone phone = getPhone(subId);
5269:             if (phone == null) {
5272:             OperatorInfo networkSelection = phone.getSavedNetworkSelection();
5274:                 ? phone.getManualNetworkSelectionPlmn() : networkSelection.getOperatorNumeric();
5484:         final Phone defaultPhone = getDefaultPhone();
5670:         final Phone phone = getPhone(subId);
5672:             if (phone != null) {
5673:                 return phone.hasMatchedTetherApnSetting();
5697:             Phone phone = PhoneFactory.getPhone(phoneId);
5698:             if (phone != null) {
5700:                 phone.getDataEnabledSettings().setUserDataEnabled(enable);
5702:                 loge("setUserDataEnabled: no phone found. Invalid subId=" + subId);
5720:         final Phone phone = getPhone(subId);
5722:             if (phone != null) {
5727:                 phone.setAlwaysReportSignalStrength(isEnable);
5729:                 loge("setAlwaysReportSignalStrength: no phone found for subId="
5758:      * Accepts either ACCESS_NETWORK_STATE, MODIFY_PHONE_STATE or carrier privileges.
5776:             Phone phone = PhoneFactory.getPhone(phoneId);
5777:             if (phone != null) {
5778:                 boolean retVal = phone.isUserDataEnabled();
5782:                 if (DBG) loge("isUserDataEnabled: no phone subId=" + subId + " retVal=false");
5805:             Phone phone = PhoneFactory.getPhone(phoneId);
5806:             if (phone != null) {
5807:                 boolean retVal = phone.getDataEnabledSettings().isDataEnabled();
5811:                 if (DBG) loge("isDataEnabled: no phone subId=" + subId + " retVal=false");
5820:             Phone phone) {
5821:         if (uid == Process.SYSTEM_UID || uid == Process.PHONE_UID) {
5831:         PackageManager pkgMgr = phone.getContext().getPackageManager();
5836:             int subId = phone.getSubId();
5844:                     phone.getContext().getSystemService(Context.TELEPHONY_SUBSCRIPTION_SERVICE);
5856:     private int getCarrierPrivilegeStatusFromCarrierConfigRules(int privilegeFromSim, Phone phone,
5865:             int subId = phone.getSubId();
5873:                     phone.getContext().getSystemService(Context.TELEPHONY_SUBSCRIPTION_SERVICE);
5883:         final Phone phone = getPhone(subId);
5884:         if (phone == null) {
5888:         UiccCard card = UiccController.getInstance().getUiccCard(phone.getPhoneId());
5896:                 phone.getContext().getPackageManager()), Binder.getCallingUid(), phone);
5902:         final Phone phone = getPhone(subId);
5903:         if (phone == null) {
5908:                 UiccController.getInstance().getUiccProfileForPhone(phone.getPhoneId());
5915:                         phone.getContext().getPackageManager(), uid), uid, phone);
6020:         final Phone phone = getPhone(subId);
6021:         UiccCard card = phone == null ? null : phone.getUiccCard();
6043:             final Phone phone = getPhone(subId);
6044:             if (phone == null) {
6047:             final String subscriberId = phone.getSubscriberId();
6270:             final Phone phone = getPhone(subId);
6271:             return phone == null ? false : phone.setOperatorBrandOverride(brand);
6286:             final Phone phone = getPhone(subId);
6287:             if (phone == null) {
6290:             return phone.setRoamingOverride(gsmRoamingList, gsmNonRoamingList, cdmaRoamingList,
6341:         Phone phone = PhoneFactory.getPhone(phoneId);
6343:         if (phone == null) {
6350:                             mApp, phone.getSubId(), "getRadioAccessFamily");
6360:         final Phone defaultPhone = getDefaultPhone();
6374:         final Phone defaultPhone = getDefaultPhone();
6428:                     .getBoolean(CarrierConfigManager.KEY_WORLD_PHONE_BOOL);
6459:         final Phone phone = getPhone(subscriptionId);
6460:         if (phone == null) {
6461:             loge("isRttSupported: no Phone found. Invalid subId:" + subscriptionId);
6468:                     phone.getContext().getResources().getBoolean(R.bool.config_support_rtt);
6501:      * Returns the unique device ID of phone, for example, the IMEI for
6505:      *   {@link android.Manifest.permission#READ_PHONE_STATE READ_PHONE_STATE}
6509:         final Phone phone = PhoneFactory.getPhone(0);
6510:         if (phone == null) {
6513:         int subId = phone.getSubId();
6521:             return phone.getDeviceId();
6534:         Phone phone = getPhone(subId);
6535:         if (phone != null) {
6536:             return phone.isImsRegistered();
6557:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
6573:             Phone phone = getPhone(subscriptionId);
6574:             if (phone == null) {
6577:             return PhoneUtils.makePstnPhoneAccountHandle(phone);
6589:             Phone phone = getPhone(subId);
6590:             if (phone != null) {
6591:                 return phone.isWifiCallingEnabled();
6606:             Phone phone = getPhone(subId);
6607:             if (phone != null) {
6608:                 return phone.isVideoEnabled();
6624:             Phone phone = getPhone(subId);
6625:             if (phone != null) {
6626:                 return phone.getImsRegistrationTech();
6684:         final Phone phone = getPhone(subId);
6685:         if (phone == null) {
6692:                     phone.getContext().getOpPackageName(), phone.getContext().getAttributionTag());
6701:             final Locale localeFromDefaultSim = phone.getLocaleFromSimAndCarrierPrefs();
6829:             final Phone phone = getPhone(subId);
6830:             if (phone == null) {
6834:             ServiceState ss = phone.getServiceState();
6847:      * Returns the URI for the per-account voicemail ringtone set in Phone settings.
6858:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(accountHandle);
6859:             if (phone == null) {
6860:                 phone = getDefaultPhone();
6863:             return VoicemailNotificationSettingsUtil.getRingtoneUri(phone.getContext());
6873:      * has permission {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
6883:         final Phone defaultPhone = getDefaultPhone();
6894:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(phoneAccountHandle);
6895:             if (phone == null) {
6896:                 phone = defaultPhone;
6898:             VoicemailNotificationSettingsUtil.setRingtoneUri(phone.getContext(), uri);
6905:      * Returns whether vibration is set for voicemail notification in Phone settings.
6915:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(accountHandle);
6916:             if (phone == null) {
6917:                 phone = getDefaultPhone();
6920:             return VoicemailNotificationSettingsUtil.isVibrationEnabled(phone.getContext());
6930:      * has permission {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
6940:         final Phone defaultPhone = getDefaultPhone();
6951:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(phoneAccountHandle);
6952:             if (phone == null) {
6953:                 phone = defaultPhone;
6955:             VoicemailNotificationSettingsUtil.setVibrationEnabled(phone.getContext(), enabled);
6962:      * Make sure either called from same process as self (phone) or IPC caller has read privilege.
6967:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.READ_PRIVILEGED_PHONE_STATE,
6972:      * Make sure either called from same process as self (phone) or IPC caller has send SMS
7015:         Phone phone = getPhone(subId);
7019:             if (phone == null) {
7024:                 aid = UiccController.getInstance().getUiccCard(phone.getPhoneId())
7044:         Phone phone = getPhone(subId);
7048:             if (phone == null) {
7053:                 esn = phone.getEsn();
7072:         Phone phone = getPhone(subId);
7076:             if (phone == null) {
7081:                 cdmaPrlVersion = phone.getCdmaPrlVersion();
7175:         final Phone phone = getPhone(subId);
7178:         if (phone == null) {
7183:             phone.carrierActionSetMeteredApnsEnabled(enabled);
7200:         final Phone phone = getPhone(subId);
7203:         if (phone == null) {
7208:             phone.carrierActionSetRadioEnabled(enabled);
7228:         final Phone phone = getPhone(subId);
7231:         if (phone == null) {
7236:             phone.carrierActionReportDefaultNetworkStatus(report);
7252:         final Phone phone = getPhone(subId);
7253:         if (phone == null) {
7258:             phone.carrierActionResetAll();
7265:      * Called when "adb shell dumpsys phone" is invoked. Dump is also automatically invoked when a
7272:             writer.println("Permission Denial: can't dump Phone from pid="
7303:             Phone phone = getPhone(subId);
7304:             if (phone != null) {
7305:                 phone.getDataEnabledSettings().setPolicyDataEnabled(enabled);
7324:         Phone phone = getPhone(subId);
7328:             if (phone != null) {
7329:                 return phone.getClientRequestStats();
7356:         Phone phone = PhoneFactory.getPhone(slotIndex);
7362:             if (phone != null) {
7363:                 phone.setSimPowerState(state, workSource);
7385:      * Check if phone is in emergency callback mode
7386:      * @return true if phone is in emergency callback mode
7392:         final Phone phone = getPhone(subId);
7396:             if (phone != null) {
7397:                 return phone.isInEcm();
7417:             Phone p = getPhone(subId);
7437:         Phone phone = PhoneFactory.getPhone(slotIndex);
7438:         if (phone != null) {
7439:             if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, phone.getSubId(),
7446:                 return phone.getRadioPowerState();
7459:      * {@link android.Manifest.permission#READ_PHONE_STATE} or that the calling app has carrier
7479:             Phone phone = getPhone(subId);
7480:             isEnabled =  phone != null ? phone.getDataRoamingEnabled() : false;
7492:      * {@link android.Manifest.permission#MODIFY_PHONE_STATE} or that the calling app has carrier
7505:             Phone phone = getPhone(subId);
7506:             if (phone != null) {
7507:                 phone.setDataRoamingEnabled(isEnabled);
7523:             Phone phone = getPhone(subId);
7524:             if (phone != null) {
7525:                 isAllowed = phone.isCspPlmnEnabled();
7544:             // even without READ_PRIVILEGED_PHONE_STATE, we allow the call to continue if the caller
7681:      * {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
7690:             Phone phone = getPhone(subId);
7691:             if (phone == null) {
7694:             UiccCard uiccCard = phone.getUiccCard();
7731:      * not set, return {@link Phone#PREFERRED_NT_MODE}.
7739:         return Phone.PREFERRED_NT_MODE;
7749:             final Phone phone = getPhone(subId);
7750:             if (phone == null) {
7754:             phone.setCarrierTestOverride(mccmnc, imsi, iccid, gid1, gid2, plmn, spn,
7772:             final Phone phone = getPhone(subId);
7773:             if (phone == null) {
7777:             return phone.getCarrierIdListVersion();
7846:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
7851:             for (Phone phone: PhoneFactory.getPhones()) {
7852:                 if (phone.getEmergencyNumberTracker() != null
7853:                         && phone.getEmergencyNumberTracker().getEmergencyNumberList() != null) {
7855:                             phone.getSubId(),
7856:                             phone.getEmergencyNumberTracker().getEmergencyNumberList());
7867:         final Phone defaultPhone = getDefaultPhone();
7875:             for (Phone phone: PhoneFactory.getPhones()) {
7876:                 if (phone.getEmergencyNumberTracker() != null
7877:                         && phone.getEmergencyNumberTracker()
7898:             for (Phone phone: PhoneFactory.getPhones()) {
7899:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
7920:             for (Phone phone: PhoneFactory.getPhones()) {
7921:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
7940:             final Phone phone = getPhone(subId);
7941:             if (phone == null) {
7945:             return phone.getEmergencyNumberDbVersion();
7957:             for (Phone phone: PhoneFactory.getPhones()) {
7958:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
7974:             for (Phone phone: PhoneFactory.getPhones()) {
7975:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
7991:             for (Phone phone: PhoneFactory.getPhones()) {
7992:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8005:         Phone phone = getPhone(subId);
8006:         if (phone == null) {
8012:                     .getUiccProfileForPhone(phone.getPhoneId());
8031:             Phone phone = PhoneFactory.getPhone(slotIndex);
8032:             if (phone == null) {
8035:                 return (Boolean) sendRequest(CMD_REQUEST_ENABLE_MODEM, enable, phone, null);
8048:         Phone phone = PhoneFactory.getPhone(slotIndex);
8049:         if (phone == null) return false;
8052:                 mApp, phone.getSubId(), callingPackage, callingFeatureId,
8054:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
8060:                 return mPhoneConfigurationManager.getPhoneStatusFromCache(phone.getPhoneId());
8062:                 return (Boolean) sendRequest(CMD_GET_MODEM_STATUS, null, phone, null);
8130:      * Note: Switch from multi-sim to single-sim is only possible with MODIFY_PHONE_STATE
8131:      * permission, but the other way around is possible with either MODIFY_PHONE_STATE
8160:         Phone phone = getPhone(subId);
8161:         if (phone == null) {
8166:             UiccCard uiccCard = phone.getUiccCard();
8236:         Phone phone = getDefaultPhone();
8237:         if (phone == null) return -1;
8238:         HalVersion hv = phone.getHalVersion();
8268:         enforceReadPrivilegedPermission("Needs READ_PRIVILEGED_PHONE_STATE for "
8274:             Phone phone = getPhone(subId);
8275:             if (phone == null) return false;
8277:             boolean isMetered = ApnSettingUtils.isMeteredApnType(apnType, phone);
8278:             return !isMetered || phone.getDataEnabledSettings().isDataEnabled(apnType);
8291:             Phone phone = getPhone(subId);
8292:             if (phone == null) return true; // By default return true.
8294:             return ApnSettingUtils.isMeteredApnType(apnType, phone);
8306:             Phone phone = getPhone(subscriptionId);
8307:             if (phone == null) {
8327:             sendRequestAsync(CMD_SET_SYSTEM_SELECTION_CHANNELS, argument, phone, null);
8408:             Phone phone = getPhone(subId);
8409:             if (phone == null) return false;
8411:             return phone.getDataEnabledSettings().setAllowDataDuringVoiceCall(allow);
8424:             Phone phone = getPhone(subId);
8425:             if (phone == null) return false;
8427:             return phone.getDataEnabledSettings().isDataAllowedInVoiceCall();
8440:             Phone phone = getPhone(subId);
8441:             if (phone == null) return false;
8443:             return phone.getDataEnabledSettings().setAlwaysAllowMmsData(alwaysAllow);
8461:             for (Phone phone : PhoneFactory.getPhones()) {
8462:                 Phone defaultPhone = phone.getImsPhone();
8463:                 if (defaultPhone != null && defaultPhone.getPhoneType() == PHONE_TYPE_IMS) {
8508:             Phone phone = getPhone(subId);
8509:             if (phone != null && phone.getIccCard() != null) {
8510:                 return phone.getIccCard().getIccLockEnabled();
8534:         Phone phone = getPhone(subId);
8535:         if (phone == null) {
8542:                     new Pair<Boolean, String>(enabled, password), phone, null);
8566:         Phone phone = getPhone(subId);
8567:         if (phone == null) {
8574:                     new Pair<String, String>(oldPassword, newPassword), phone, null);
8633:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
8636:         Phone phone = getPhone(subId);
8637:         if (phone == null) {
8638:             throw new RuntimeException("phone is not available");
8643:             return phone.getEquivalentHomePlmns();
22: import static com.android.internal.telephony.PhoneConstants.SUBSCRIPTION_KEY;
63: import android.telecom.PhoneAccount;
64: import android.telecom.PhoneAccountHandle;
83: import android.telephony.PhoneCapability;
84: import android.telephony.PhoneNumberRange;
141: import com.android.internal.telephony.PhoneConfigurationManager;
142: import com.android.internal.telephony.PhoneConstantConversions;
143: import com.android.internal.telephony.PhoneConstants;
144: import com.android.internal.telephony.PhoneFactory;
158: import com.android.internal.telephony.imsphone.ImsPhone;
159: import com.android.internal.telephony.imsphone.ImsPhoneCallTracker;
199:     private static final String LOG_TAG = "PhoneInterfaceManager";
200:     private static final boolean DBG = (PhoneGlobals.DBG_LEVEL >= 2);
298:     private static PhoneInterfaceManager sInstance;
300:     private PhoneGlobals mApp;
697:                     defaultPhone.nvReadItem((Integer) request.argument, onCompleted,
724:                     defaultPhone.nvWriteItem(idValue.first, idValue.second, onCompleted,
735:                     defaultPhone.nvWriteCdmaPrl((byte[]) request.argument, onCompleted);
745:                     defaultPhone.resetModemConfig(onCompleted);
793:                     defaultPhone.invokeOemRilRequestRaw((byte[]) request.argument, onCompleted);
1031:                     if (defaultPhone != null) {
1032:                         defaultPhone.getModemActivityInfo(onCompleted, request.workSource);
1095:                     defaultPhone.setAllowedCarriers(argument, onCompleted, request.workSource);
1123:                     defaultPhone.getAllowedCarriers(onCompleted, request.workSource);
1329:                     defaultPhone.rebootModem(onCompleted);
1339:                     PhoneConfigurationManager.getInstance()
1349:                         mPhoneConfigurationManager.addToPhoneStatusCache(phoneId, msg.arg1 == 1);
1360:                     PhoneConfigurationManager.getInstance()
1448:                     defaultPhone.eraseModemConfig(onCompleted);
1494:                     getDefaultPhone().getContext().sendBroadcastAsUser(
1640:      * Initialize the singleton PhoneInterfaceManager instance.
1641:      * This is only done once, at startup, from PhoneApp.onCreate().
1643:     /* package */ static PhoneInterfaceManager init(PhoneGlobals app) {
1644:         synchronized (PhoneInterfaceManager.class) {
1646:                 sInstance = new PhoneInterfaceManager(app);
1657:         mCM = PhoneGlobals.getInstance().mCM;
1658:         mImsResolver = PhoneGlobals.getInstance().getImsResolver();
1666:         mPhoneConfigurationManager = PhoneConfigurationManager.getInstance();
1674:         return (thePhone != null) ? thePhone : PhoneFactory.getDefaultPhone();
1696:                 ? getDefaultPhone() : getPhone(subId);
1707:         return PhoneFactory.getPhone(mSubscriptionController.getPhoneId(subId));
1725:         PackageManager pm = getDefaultPhone().getContext().getPackageManager();
1752:             PhoneConstants.State state = mCM.getState(subId);
1753:             if (state != PhoneConstants.State.OFFHOOK && state != PhoneConstants.State.RINGING) {
1812:         return (resultArray[0] == PhoneConstants.PIN_RESULT_SUCCESS) ? true : false;
1817:         return (resultArray[0] == PhoneConstants.PIN_RESULT_SUCCESS) ? true : false;
1825:             final UnlockSim checkSimPin = new UnlockSim(getPhone(subId).getIccCard());
1838:             final UnlockSim checkSimPuk = new UnlockSim(getPhone(subId).getIccCard());
1855:         private int mResult = PhoneConstants.PIN_GENERAL_FAILURE;
1885:                                             mResult = PhoneConstants.PIN_PASSWORD_INCORRECT;
1890:                                             mResult = PhoneConstants.PIN_OPERATION_ABORTED;
1892:                                             mResult = PhoneConstants.PIN_GENERAL_FAILURE;
1895:                                         mResult = PhoneConstants.PIN_RESULT_SUCCESS;
2103:             logv(TelephonyManager.getDefault().getPhoneCount() + " Phones are shutdown.");
2138:             if (defaultPhone != null) {
2139:                 defaultPhone.setRadioPower(turnOn);
2283:                 return PhoneConstantConversions.convertDataState(
2284:                         PhoneConstants.DataState.DISCONNECTED);
2356:             final int subId = mSubscriptionController.getSubIdUsingPhoneId(phoneId);
2564:             getDefaultPhone().setCellInfoListRate(rateInMillis, workSource);
2768:         Log.d(LOG_TAG, "[PhoneIntfMgr] " + msg);
2772:         Log.v(LOG_TAG, "[PhoneIntfMgr] " + msg);
2776:         Log.e(LOG_TAG, "[PhoneIntfMgr] " + msg);
2938:     public void requestNumberVerification(PhoneNumberRange range, long timeoutMillis,
2967:             return getDefaultPhone().needsOtaServiceProvisioning();
3002:             PhoneAccountHandle phoneAccountHandle = PhoneAccountHandleConverter.fromSubId(subId);
3003:             if (phoneAccountHandle == null) {
3006:             return VisualVoicemailSettingsUtil.dump(mApp, phoneAccountHandle);
3091:         SmsController smsController = PhoneFactory.getSmsController();
3226:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
3235:             defaultPhone.sendDialerSpecialCode(inputCode);
3290:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3314:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone.
3410:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3437:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone.
3453:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3532:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3550:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3570:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3585:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3604:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3620:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3639:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3655:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3671:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3691:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3707:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3722:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3738:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3754:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3773:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3792:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3810:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3855:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3885:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3918:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3977:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4146:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4171:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4197:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4223:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4393:             return PhoneConstants.LTE_ON_CDMA_UNKNOWN;
4400:                 return PhoneConstants.LTE_ON_CDMA_UNKNOWN;
4403:                         .orElse(PhoneConstants.LTE_ON_CDMA_FALSE);
4464:         int phoneId = UiccController.getInstance().getPhoneIdFromSlotId(slotIndex);
4465:         if (phoneId == -1) {
4469:         return PhoneFactory.getPhone(phoneId);
4504:                 ComponentInfo bestComponent = EuiccConnector.findBestComponent(getDefaultPhone()
4646:                 ComponentInfo bestComponent = EuiccConnector.findBestComponent(getDefaultPhone()
4937:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, defaultPhone.getSubId(),
4944:             return defaultPhone.getPcscfAddress(apnType);
5188:             getDefaultPhone().setImsRegistrationState(registered);
5424:                     request, messenger, binder, getPhone(subId),
5485:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, defaultPhone.getSubId(),
5493:             return PhoneFactory.calculatePreferredNetworkType(defaultPhone.getContext(), 0);
5695:             int phoneId = mSubscriptionController.getPhoneId(subId);
5696:             if (DBG) log("setUserDataEnabled: subId=" + subId + " phoneId=" + phoneId);
5774:             int phoneId = mSubscriptionController.getPhoneId(subId);
5775:             if (DBG) log("isUserDataEnabled: subId=" + subId + " phoneId=" + phoneId);
5803:             int phoneId = mSubscriptionController.getPhoneId(subId);
5804:             if (DBG) log("isDataEnabled: subId=" + subId + " phoneId=" + phoneId);
5924:         int phoneId = SubscriptionManager.getPhoneId(subId);
5925:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
5932:             getPhone(phoneId), pkgName);
5949:                 getPhone(i), pkgName);
5960:         if (!SubscriptionManager.isValidPhoneId(phoneId)) {
5961:             loge("phoneId " + phoneId + " is not valid.");
5964:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
5966:             loge("getCarrierPackageNamesForIntentAndPhone: No UICC");
5973:     public List<String> getPackagesWithCarrierPrivileges(int phoneId) {
5977:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
6340:     public int getRadioAccessFamily(int phoneId, String callingPackage) {
6351:             raf = ProxyController.getInstance().getRadioAccessFamily(phoneId);
6365:             ImsManager.getInstance(defaultPhone.getContext(),
6366:                     defaultPhone.getPhoneId()).setVtSetting(enable);
6375:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, defaultPhone.getSubId(),
6387:                     ImsManager.getInstance(defaultPhone.getContext(), defaultPhone.getPhoneId());
6502:      * GSM and the MEID for CDMA phones. Return null if device ID is not available.
6546:             return PhoneUtils.getSubIdForPhoneAccount(phoneAccount);
6554:             PhoneAccountHandle phoneAccountHandle, String callingPackage, String callingFeatureId) {
6561:             return PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle);
6657:             cleanUpSmsRawTable(getDefaultPhone().getContext());
6668:               sendEraseModemConfig(getDefaultPhone());
6849:      * @param accountHandle The handle for the {@link PhoneAccount} for which to retrieve the
6852:      * PhoneAccount.
6855:     public Uri getVoicemailRingtoneUri(PhoneAccountHandle accountHandle) {
6875:      * @param phoneAccountHandle The handle for the {@link PhoneAccount} for which to set the
6878:      * PhoneAccount.
6882:             PhoneAccountHandle phoneAccountHandle, Uri uri) {
6885:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
6888:                     mApp, PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle),
6907:      * @param accountHandle The handle for the {@link PhoneAccount} for which to retrieve the
6909:      * @return {@code true} if the vibration is set for this PhoneAccount, {@code false} otherwise.
6912:     public boolean isVoicemailVibrationEnabled(PhoneAccountHandle accountHandle) {
6932:      * @param phoneAccountHandle The handle for the {@link PhoneAccount} for which to set the
6935:      * specific PhoneAccount.
6939:             PhoneAccountHandle phoneAccountHandle, boolean enabled) {
6942:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
6945:                     mApp, PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle),
7286:         return new TelephonyShellCommand(this, getDefaultPhone().getContext()).exec(
7546:             if (checkCarrierPrivilegesForPackageAnyPhone(callingPackage)
7735:         int phoneId = mSubscriptionController.getPhoneId(subId);
7736:         if (phoneId >= 0 && phoneId < list.size() && list.get(phoneId) != null) {
7737:             return list.get(phoneId);
7871:                             mApp, defaultPhone.getSubId(), "isEmergencyNumber(Potential)");
8087:                 getDefaultPhone().getSubId(), callingPackage, callingFeatureId,
8110:         PhoneCapability staticCapability =
8216:             int phoneCount = TelephonyManager.getDefault().getPhoneCount();
8218:             int[] logicalSlotsMapping = new int[phoneCount];
8351:         SmsPermissions permissions = new SmsPermissions(getDefaultPhone(), mApp,
8377:             return SubscriptionManager.getResourcesForSubId(getDefaultPhone().getContext(), subId)
8394:             return SubscriptionManager.getResourcesForSubId(getDefaultPhone().getContext(), subId)
8464:                     ImsPhone imsPhone = (ImsPhone) defaultPhone;
8466:                             (ImsPhoneCallTracker) imsPhone.getCallTracker();
8468:                     Rlog.i(LOG_TAG, "setCepEnabled isCepEnabled=" + isCepEnabled + ", for imsPhone "
8469:                             + imsPhone.getMsisdn());
8603:         // *  Inherited from PhoneWindowManager  *
130: import com.android.internal.telephony.DefaultPhoneNotifier;
480:                             getPhoneFromRequest(request).handlePinMmi((String) request.argument)
755:                     getPhoneFromRequest(request).getPreferredNetworkType(onCompleted);
783:                     getPhoneFromRequest(request).setPreferredNetworkType(networkType, onCompleted);
807:                     getPhoneFromRequest(request).setVoiceMailNumber(tagNum.first, tagNum.second,
819:                     getPhoneFromRequest(request).setNetworkSelectionModeAutomatic(onCompleted);
829:                     getPhoneFromRequest(request).getAvailableNetworks(onCompleted);
836:                     getPhoneFromRequest(request).getCallForwardingOption(
893:                     getPhoneFromRequest(request).setCallForwardingOption(
915:                     getPhoneFromRequest(request).getCallWaiting(onCompleted);
959:                     getPhoneFromRequest(request).setCallWaiting(isEnable, onCompleted);
1011:                     getPhoneFromRequest(request).selectNetworkManually(selArg.operatorInfo,
1206:                     getPhoneFromRequest(request).getNetworkSelectionMode(onCompleted);
1227:                     getPhoneFromRequest(request).queryCdmaRoamingPreference(onCompleted);
1243:                     getPhoneFromRequest(request).setCdmaRoamingPreference(mode, onCompleted);
1255:                     getPhoneFromRequest(request).setCdmaSubscription(subscriptionMode, onCompleted);
1370:                         mPhoneConfigurationManager.addToPhoneStatusCache(id,
1458:                     getPhoneFromRequest(request).getIccCard().changeIccLockPassword(
1476:                     getPhoneFromRequest(request).getIccCard().setIccLockEnabled(
1690:             return getPhoneFromSubId(request.subId);
2024:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
2099:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
2116:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
2118:                 shutdownRadioUsingPhoneId(i);
2641:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
2781:         return getActivePhoneTypeForSlot(getSlotForDefaultSubscription());
2811:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
2844:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
2875:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3016:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3184:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3244:                     .enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3281:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3307:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3364:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3404:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3429:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3529:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3566:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3600:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3635:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3687:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3769:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3851:         checkModifyPhoneStatePermission(subId, "setRcsProvisioningStatusForCapability");
3915:         checkModifyPhoneStatePermission(subId, "setImsProvisioningStatusForCapability");
4267:                 && !TelephonyPermissions.checkCallingOrSelfReadPhoneStateNoThrow(
4301:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
4326:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
4419:         return mSubscriptionController.getPhoneId(getDefaultSubscription());
4481:         return iccOpenLogicalChannelWithPermission(getPhoneFromSubId(subId), callingPackage, aid,
4494:         return iccOpenLogicalChannelWithPermission(getPhoneFromSlotIdOrThrowException(slotIndex),
4529:         return iccCloseLogicalChannelWithPermission(getPhoneFromSubId(subId), channel);
4536:         return iccCloseLogicalChannelWithPermission(getPhoneFromSlotIdOrThrowException(slotIndex),
4565:         return iccTransmitApduLogicalChannelWithPermission(getPhoneFromSubId(subId), channel, cla,
4579:                 getPhoneFromSlotIdOrThrowException(slotIndex), channel, cla, command, p1, p2, p3,
4618:         return iccTransmitApduBasicChannelWithPermission(getPhoneFromSubId(subId), callingPackage,
4634:                 getPhoneFromSlotIdOrThrowException(slotIndex), callingPackage, cla, command, p1,
4719:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
4757:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, subId, callingPackage,
5131:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5259:                     .enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
5508:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5557:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5602:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5606:             return getPhoneFromSubId(subId).getAllowedNetworkTypes(reason);
5623:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5627:             return getPhoneFromSubId(subId).getEffectiveAllowedNetworkTypes();
5649:             getPhoneFromSubId(subId).setAllowedNetworkTypes(reason, allowedNetworkTypes);
5940:         for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
6004:         enforceReadPrivilegedPermission("getPackagesWithCarrierPrivilegesForAllPhones");
6010:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
6090:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneNumber(
6117:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6140:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6349:                     .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
6399:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6418:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6555:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, getDefaultSubscription(),
6556:                 callingPackage, callingFeatureId, "getSubIdForPhoneAccountHandle")) {
6569:         enforceReadPrivilegedPermission("getPhoneAccountHandleForSubscriptionId, "
6793:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7320:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7472:             TelephonyPermissions.enforeceCallingOrSelfReadPhoneStatePermissionOrCarrierPrivilege(
7517:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
7645:                         slot.getPhoneId(),
7786:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7794:             return mPhoneConfigurationManager.getNumberOfModemsWithSimultaneousDataConnections();
7803:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
7843:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7870:                     .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
8051:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8086:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp,
8111:                 mPhoneConfigurationManager.getStaticPhoneCapability();
8151:             mPhoneConfigurationManager.switchMultiSimConfig(numOfSims);
8191:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8198:             return mPhoneConfigurationManager.isRebootRequiredForModemConfigChange();
8207:         metrics.updateEnabledModemBitmap((1 << TelephonyManager.from(mApp).getPhoneCount()) - 1);
8221:                 if (SubscriptionManager.isValidPhoneId(slotInfos[i].getLogicalSlotIdx())) {
8337:                 SubscriptionManager.getPhoneId(subId), UiccController.APP_FAM_3GPP);
8465:                     ImsPhoneCallTracker imsPhoneCallTracker =
8467:                     imsPhoneCallTracker.setConferenceEventPackageEnabled(isCepEnabled);
8631:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
android.googlesource.com/platform/frameworks/opt/telephony:src/java/com/android/internal/telephony/Phone.java: [ master, ]
133: public abstract class Phone extends Handler implements PhoneInternalInterface {
530:     protected Phone(String name, PhoneNotifier notifier, Context context, CommandsInterface ci,
547:     protected Phone(String name, PhoneNotifier notifier, Context context, CommandsInterface ci,
348:     protected Phone mImsPhone = null;
628:     public void createImsPhone() {
3903:     public Phone getImsPhone() {
4579:     public Phone getDefaultPhone() {
211:     protected static final int EVENT_UPDATE_PHONE_OBJECT            = 42;
314:     protected boolean mIsPhoneInEcmState = false;
345:     protected int mPhoneId;
470:     public String getPhoneName() {
474:     protected void setPhoneName(String name) {
1835:     public void updatePhoneObject(int voiceRadioTech) {
2933:     public abstract int getPhoneType();
4035:     public int getPhoneId() {
4043:     public int getVoicePhoneServiceState() {
123:  * A base implementation for the com.android.internal.telephony.Phone interface.
125:  * Note that implementations of Phone.java are expected to be used
134:     private static final String LOG_TAG = "Phone";
262:      * This method is invoked when the Phone exits Emergency Callback Mode.
312:     // Keep track of whether or not the phone is in Emergency Callback Mode for Phone and
465:      * Returns a string identifier for this phone interface for parties
466:      *  outside the phone app process.
521:      * Constructs a Phone in normal (non-unit test) mode.
532:         this(name, notifier, context, ci, unitTestMode, SubscriptionManager.DEFAULT_PHONE_INDEX,
537:      * Constructs a Phone in normal (non-unit test) mode.
545:      * @param phoneId the phone-id of this phone.
573:         * (i.e. voice) phone calls over the telephony network, and is allowed
601:         if (getPhoneType() == PhoneConstants.PHONE_TYPE_IMS) {
617:         if (getPhoneType() != PhoneConstants.PHONE_TYPE_SIP) {
629:         if (getPhoneType() == PhoneConstants.PHONE_TYPE_SIP) {
633:         synchronized(Phone.lockForRadioTechnologyChange) {
696:         // messages to be handled whether or not the phone is being destroyed
698:         // resources of the phone being destroyed
821:         Phone imsPhone = mImsPhone;
860:      * Gets the context for the phone, as set at initialization time.
916:      * Subclasses of Phone probably want to replace this with a
942:      * Subclasses of Phone probably want to replace this with a
966:      * Subclasses of Phone probably want to replace this with a
978:      * Notify the phone that an SMS has been sent. This will be used determine if the SMS was sent
992:      * Determine if the Phone has recently sent an emergency SMS and is still in the interval of
1033:     protected void migrateFrom(Phone from) {
1046:         // The emergency state of IMS phone will be cleared in ImsPhone#notifySrvccState after
1109:      *   Connection.getCall() == Phone.getRingingCall()
1129:      * Notifies when phone's video capabilities changes <p>
1134:      *  AsyncResult.result = true if phone supports video calling <p>
1273:      * Example: If Phone.dial is called with "*#31#", then the app will
1596:      * For unit tests; don't send notifications to "Phone"
1613:      * Subclasses of Phone probably want to replace this with a
1718:         // no need for regular phone
1722:      * Subclasses of Phone probably want to replace this with a
1734:      * we send out a final ServiceState update when a phone's subId becomes invalid.
1744:      * If this is a simulated phone interface, returns a SimulatedRadioControl.
1758:      * the thread that originally obtained this Phone instance.
1763:                     "com.android.internal.telephony.Phone must be used from within one thread");
1795:      * If the phone has an active call and call waiting occurs,
1796:      * then the phone state is RINGING not OFFHOOK
1805:      * Retrieves the IccFileHandler of the Phone instance
1824:      * Retrieves the Handler of the Phone instance
1831:      * Update the phone object if the voice radio technology has changed
1839:     * Retrieves the ServiceStateTracker of the phone instance.
1847:      * Retrieves the EmergencyNumberTracker of the phone instance.
1869:      * Retrieves the DeviceStateMonitor of the phone instance.
1876:      * Retrieves the DisplayInfoController of the phone instance.
1924:      * Returns the ICC card interface for this phone, or null
1930:         //throw new Exception("getIccCard Shouldn't be called from Phone");
2117:         if (getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA) {
2515:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_OFF}
2516:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_FULL}
2517:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_HCO}
2518:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_VCO}
2529:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_OFF}
2530:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_FULL}
2531:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_HCO}
2532:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_VCO}
2838:     // This property is used to handle phone process crashes, and is the same for CDMA and IMS
2845:      * @return {@code true} if we are in emergency call back mode. This is a period where the phone
2865:      * @return true if this Phone is in an emergency call that caused emergency callback mode to be
2873:      * Set whether or not this Phone has an active emergency call that was placed during emergency
2929:      * Return a numerical identifier for the phone radio interface.
2930:      * @return PHONE_TYPE_XXX as defined above.
2943:     /** sets the voice mail count of the phone and notifies listeners. */
3594:         // Populate the iccid, imei and phone number in the provisioning url.
3603:                     phoneNumber /* Phone number */);
3724:      * Subclasses of Phone probably want to replace this with a
3742:      * Notify registrants if phone is video capable.
3856:         Rlog.e(LOG_TAG, "Error! This function should never be executed, inactive Phone.");
3869:      * Gets the Uicc card corresponding to this phone.
3870:      * @return the UiccCard object corresponding to the phone ID.
3900:      * Return an instance of a IMS phone
4032:      * Returns the phone id.
4044:         Phone imsPhone = mImsPhone;
4118:         Phone imsPhone = mImsPhone;
4137:         Phone imsPhone = mImsPhone;
4151:         Phone imsPhone = mImsPhone;
4175:         Phone imsPhone = mImsPhone;
4185:      * @return the IMS MmTel Registration technology for this Phone, defined in
4189:         Phone imsPhone = mImsPhone;
4199:      * Get the IMS MmTel Registration technology for this Phone, defined in
4203:         Phone imsPhone = mImsPhone;
4212:      * Asynchronously get the IMS MmTel Registration state for this Phone.
4215:         Phone imsPhone = mImsPhone;
4273:      *  Set phone radio capability
4275:      *  @param rc the phone radio capability defined in
4284:      *  Get phone radio access family
4304:      *  Get phone radio capability
4318:      *  @param rc the phone radio capability currently in effect for this phone.
4333:         // When radio capability switch is done, query IMEI value and update it in Phone objects
4357:      * Registers the handler when phone radio  capability is changed.
4368:      * Unregister for notifications when phone radio type and access technology is changed.
4389:      * Determines if video calling is enabled for the phone.
4395:         Phone imsPhone = mImsPhone;
4534:     public static void checkWfcWifiOnlyModeBeforeDial(Phone imsPhone, int phoneId, Context context)
4574:      * This function returns the parent phone of the current phone. It is applicable
4575:      * only for IMS phone (function is overridden by ImsPhone). For others the phone
4613:      * none of the phone is in service, and one of them has the capability to make the emergency
4620:         for (Phone phone : PhoneFactory.getPhones()) {
4621:             if (phone != null) {
4622:                 ServiceStateTracker sst = phone.getServiceStateTracker();
4685:     /** Returns the {@link VoiceCallSessionStats} for this phone ID. */
4690:     /** Sets the {@link VoiceCallSessionStats} mock for this phone ID during unit testing. */
4696:     /** Returns the {@link SmsStats} for this phone ID. */
4701:     /** Sets the {@link SmsStats} mock for this phone ID during unit testing. */
4757:         pw.println("Phone: subId=" + getSubId());
4932:         pw.println("Phone Local Log: ");
53: import android.telephony.PhoneStateListener;
83: import com.android.internal.telephony.imsphone.ImsPhoneCall;
127:  * originally called PhoneFactory to obtain the interface.
437:      * PhoneNotifier is an abstraction for all system-wide
442:     protected PhoneNotifier mNotifier;
479:      * Retrieves Nai for phones. Returns null if Nai is not set.
548:                     boolean unitTestMode, int phoneId,
550:         mPhoneId = phoneId;
587:          * By default old phones won't have the property set but do generate
625:      * Start setup of ImsPhone, which will start trying to connect to the ImsResolver. Will not be
634:             if (mImsPhone == null) {
635:                 mImsPhone = PhoneFactory.makeImsPhone(mNotifier, this);
636:                 CallManager.getInstance().registerPhone(mImsPhone);
637:                 mImsPhone.registerForSilentRedial(
712:                     PhoneConstants.State state = getState();
714:                             && ((state == PhoneConstants.State.RINGING) ||
715:                                     (state == PhoneConstants.State.IDLE))) {
726:                 if (getState() == PhoneConstants.State.RINGING) {
747:                         if (mImsPhone != null) {
749:                             mImsPhone.notifyRedialConnectionChanged(cn);
753:                         if (mImsPhone != null) {
754:                             mImsPhone.notifyRedialConnectionChanged(null);
828:                     if (imsPhone != null) {
829:                         conn = imsPhone.getHandoverConnection();
830:                         migrateFrom(imsPhone);
832:                         Rlog.d(LOG_TAG, "HANDOVER_STARTED: mImsPhone null");
837:                     if (imsPhone != null) {
838:                         imsPhone.notifySrvccState(srvccState);
840:                         Rlog.d(LOG_TAG, "HANDOVER_COMPLETED: mImsPhone null");
893:      * {@link PhoneConstants.State} which can be obtained using the {@link PhoneStateListener}
1063:             // Since CallManager has already registered with both CS and IMS phones,
1802:     public abstract PhoneConstants.State getState();
2000:      * Sets the minimum time in milli-seconds between {@link PhoneStateListener#onCellInfoChanged
2001:      * PhoneStateListener.onCellInfoChanged} will be invoked.
2016:      * available on this interface. Use PhoneStateNotifier or similar instead.
2112:      * available on this interface. Use PhoneStateNotifier or similar instead.
2163:      * interface. Use <code>PhoneStateNotifier</code> or an equivalent.
2755:     public PhoneConstants.DataState getDataConnectionState(String apnType) {
2756:         return PhoneConstants.DataState.DISCONNECTED;
2839:     // phones
2919:         if (mImsPhone != null) {
2920:             isPresent = isVideoCallOrConference(mImsPhone.getForegroundCall()) ||
2921:                     isVideoCallOrConference(mImsPhone.getBackgroundCall()) ||
2922:                     isVideoCallOrConference(mImsPhone.getRingingCall());
3064:      * Retrieves the MIN for CDMA phones.
3080:      *  Retrieves PRL Version for CDMA phones
3596:             String phoneNumber = getLine1Number();
3597:             if (TextUtils.isEmpty(phoneNumber)) {
3598:                 phoneNumber = "0000000000";
3818:      * Retrieves the MSISDN from the UICC. For GSM/UMTS phones, this is equivalent to
3819:      * {@link #getLine1Number()}. For CDMA phones, {@link #getLine1Number()} returns
3820:      * the MDN, so this method is provided to return the MSISDN on CDMA/LTE phones.
3828:      * Retrieves the EF_PNN from the UICC For GSM/UMTS phones.
3837:      * {@link android.telephony.PhoneStateListener} instead.
3840:     public PhoneConstants.DataState getDataConnectionState() {
3855:         // This function should be overridden by class GsmCdmaPhone.
3904:         return mImsPhone;
3979:      * Return if UT capability of ImsPhone is enabled or not
3983:         if (mImsPhone != null) {
3984:             return mImsPhone.isUtEnabled();
4003:         // dialInternal shall be overriden by GsmCdmaPhone
4008:      * This function is for CSFB SS. GsmCdmaPhone overrides this function.
4040:      * Return the service state of mImsPhone if it is STATE_IN_SERVICE
4045:         if (imsPhone != null
4046:                 && imsPhone.getServiceState().getState() == ServiceState.STATE_IN_SERVICE) {
4120:         if (imsPhone != null) {
4121:             isImsRegistered = imsPhone.isImsRegistered();
4139:         if (imsPhone != null) {
4140:             isWifiCallingEnabled = imsPhone.isWifiCallingEnabled();
4153:         if (imsPhone != null) {
4154:             isAvailable = imsPhone.isImsCapabilityAvailable(capability, regTech);
4177:         if (imsPhone != null) {
4178:             isVolteEnabled = imsPhone.isVoiceOverCellularImsEnabled();
4191:         if (imsPhone != null) {
4192:             regTech = imsPhone.getImsRegistrationTech();
4204:         if (imsPhone != null) {
4205:             imsPhone.getImsRegistrationTech(callback);
4216:         if (imsPhone != null) {
4217:             imsPhone.getImsRegistrationState(callback);
4381:         if (mImsPhone == null) {
4385:         return mImsPhone.isImsAvailable();
4396:         if (imsPhone != null) {
4397:             return imsPhone.isVideoEnabled();
4536:         if (imsPhone == null || !imsPhone.isWifiCallingEnabled()) {
4537:             ImsManager imsManager = ImsManager.getInstance(context, phoneId);
4796:         if (mImsPhone != null) {
4798:                 mImsPhone.dump(fd, pw, args);
438:      * state change notification. DefaultPhoneNotifier is
523:      * @param notifier An instance of DefaultPhoneNotifier,
539:      * @param notifier An instance of DefaultPhoneNotifier,
2720:         // This function is added to send the notification to DefaultPhoneNotifier.
2850:         return mIsPhoneInEcmState;
2861:         mIsPhoneInEcmState = isInEcm;
2905:         if (call instanceof ImsPhoneCall) {
2906:             ImsPhoneCall imsPhoneCall = (ImsPhoneCall) call;
2907:             ImsCall imsCall = imsPhoneCall.getImsCall();
2961:                 mPhoneId, UiccController.APP_FAM_3GPP);
3794:      * A fucntion of type getPhoneProp(propType) where propType is an
3874:         return mUiccController.getUiccCard(mPhoneId);
4028:         return SubscriptionController.getInstance().getSubIdUsingPhoneId(mPhoneId);
4036:         return mPhoneId;
4758:         pw.println(" mPhoneId=" + mPhoneId);
4785:         pw.println(" getPhoneName()=" + getPhoneName());
4786:         pw.println(" getPhoneType()=" + getPhoneType());
4945:         Rlog.d(LOG_TAG, "[" + mPhoneId + "] " + s);
4949:         Rlog.i(LOG_TAG, "[" + mPhoneId + "] " + s);
4953:         Rlog.e(LOG_TAG, "[" + mPhoneId + "] " + s);
github.com/apache/dubbo-samples:dubbo-samples-compatible/src/main/java/org/apache/dubbo/samples/basic/api/Phone.java: [ master, ]
23: public class Phone implements Serializable {
46:         return "Phone{" +
github.com/apache/openjpa:openjpa-examples/simple/src/main/java/embeddables/Phone.java: [ trunk, ]
25: public class Phone {
26:     public Phone() {
30:     public Phone(String n, String t) {
android.googlesource.com/platform/external/guice:examples/src/example/xml/Phone.java: [ master, ]
3: public class Phone {
github.com/google/guice:examples/src/example/xml/Phone.java: [ master, ] Duplicate result
github.com/googleapis/google-cloud-php-talent:src/V4beta1/Phone.php: [ master, ]
16: class Phone extends \Google\Protobuf\Internal\Message
14:  * Generated from protobuf message <code>google.cloud.talent.v4beta1.Phone</code>
19:      * The usage of the phone. For example, SCHOOL, WORK, PERSONAL.
25:      * The phone type. For example, LANDLINE, MOBILE, FAX.
27:      * Generated from protobuf field <code>.google.cloud.talent.v4beta1.Phone.PhoneType type = 2;</code>
31:      * Phone number.
32:      * Any phone formats are supported and only exact matches are performed on
33:      * searches. For example, if a phone number in profile is provided in the
34:      * format of "(xxx)xxx-xxxx", in profile searches the same phone format
56:      *           The usage of the phone. For example, SCHOOL, WORK, PERSONAL.
58:      *           The phone type. For example, LANDLINE, MOBILE, FAX.
60:      *           Phone number.
61:      *           Any phone formats are supported and only exact matches are performed on
62:      *           searches. For example, if a phone number in profile is provided in the
63:      *           format of "(xxx)xxx-xxxx", in profile searches the same phone format
77:      * The usage of the phone. For example, SCHOOL, WORK, PERSONAL.
88:      * The usage of the phone. For example, SCHOOL, WORK, PERSONAL.
103:      * The phone type. For example, LANDLINE, MOBILE, FAX.
105:      * Generated from protobuf field <code>.google.cloud.talent.v4beta1.Phone.PhoneType type = 2;</code>
114:      * The phone type. For example, LANDLINE, MOBILE, FAX.
116:      * Generated from protobuf field <code>.google.cloud.talent.v4beta1.Phone.PhoneType type = 2;</code>
122:         GPBUtil::checkEnum($var, \Google\Cloud\Talent\V4beta1\Phone\PhoneType::class);
129:      * Phone number.
130:      * Any phone formats are supported and only exact matches are performed on
131:      * searches. For example, if a phone number in profile is provided in the
132:      * format of "(xxx)xxx-xxxx", in profile searches the same phone format
145:      * Phone number.
146:      * Any phone formats are supported and only exact matches are performed on
147:      * searches. For example, if a phone number in profile is provided in the
148:      * format of "(xxx)xxx-xxxx", in profile searches the same phone format
12:  * Resource that represents a person's telephone number.
github.com/apache/dolphinscheduler:sql/dolphinscheduler_postgre.sql: [ dev, ]
729:   phone varchar(11) DEFAULT NULL ,
875: INSERT INTO t_ds_user(user_name, user_password, user_type, email, phone, tenant_id, state, create_time, update_time)
github.com/apache/dolphinscheduler:sql/create/release-1.2.0_schema/postgresql/dolphinscheduler_ddl.sql: [ dev, ]
627:   phone varchar(11) DEFAULT NULL ,
github.com/google/closure-compiler:contrib/externs/maps/google_maps_api_v3_20.js: [ master, ]
5014: google.maps.TransitAgency.prototype.phone;
6167: google.maps.places.PlaceResult.prototype.formatted_phone_number;
6187: google.maps.places.PlaceResult.prototype.international_phone_number;
github.com/google/closure-compiler:contrib/externs/maps/google_maps_api_v3_45.js: [ master, ]
7573: google.maps.TransitAgency.prototype.phone;
9425: google.maps.places.FindPlaceFromPhoneNumberRequest.prototype.phoneNumber;
9789: google.maps.places.PlaceResult.prototype.formatted_phone_number;
9817: google.maps.places.PlaceResult.prototype.international_phone_number;
9399: google.maps.places.FindPlaceFromPhoneNumberRequest = function() {};
9411: google.maps.places.FindPlaceFromPhoneNumberRequest.prototype.fields;
10146: google.maps.places.PlacesService.prototype.findPlaceFromPhoneNumber = function(
7570:  * The transit agency&#39;s phone number.
9421:  * The phone number of the place to look up. Format must be <a
9783:  * The Place’s phone number, formatted according to the <a
9812:  * The Place’s phone number in international format. International format
10133:  * Retrieves a list of places based on a phone number. In most cases there
9784:  * href="http://en.wikipedia.org/wiki/Local_conventions_for_writing_telephone_numbers">
9396:  * google.maps.places.PlacesService.findPlaceFromPhoneNumber}.
9418: google.maps.places.FindPlaceFromPhoneNumberRequest.prototype.locationBias;
10141:  * @param {!google.maps.places.FindPlaceFromPhoneNumberRequest} request
github.com/google/end-to-end:lib/closure-compiler/contrib/externs/maps/google_maps_api_v3_20.js: [ master, ] Duplicate result
github.com/dart-lang/sdk:docs/newsletter/20171103/big.json: [ master, ]
15:     "phone": "+1 (837) 507-3693",
60:     "phone": "+1 (846) 514-2370",
105:     "phone": "+1 (857) 494-3093",
150:     "phone": "+1 (947) 569-2033",
195:     "phone": "+1 (999) 498-3915",
240:     "phone": "+1 (854) 470-3038",
285:     "phone": "+1 (909) 457-2305",
330:     "phone": "+1 (920) 553-2688",
375:     "phone": "+1 (834) 579-2186",
420:     "phone": "+1 (939) 525-2604",
465:     "phone": "+1 (849) 479-3879",
510:     "phone": "+1 (880) 463-3272",
555:     "phone": "+1 (900) 525-3365",
600:     "phone": "+1 (960) 432-3019",
645:     "phone": "+1 (890) 443-2377",
690:     "phone": "+1 (865) 600-2359",
735:     "phone": "+1 (956) 445-3197",
780:     "phone": "+1 (824) 526-2433",
825:     "phone": "+1 (869) 596-2230",
870:     "phone": "+1 (965) 400-3544",
915:     "phone": "+1 (829) 523-3522",
960:     "phone": "+1 (800) 414-2213",
1005:     "phone": "+1 (965) 477-2144",
1050:     "phone": "+1 (995) 545-3067",
1095:     "phone": "+1 (956) 459-3456",
1140:     "phone": "+1 (940) 518-2078",
1185:     "phone": "+1 (878) 478-2408",
1230:     "phone": "+1 (837) 511-3291",
1275:     "phone": "+1 (858) 487-2467",
1320:     "phone": "+1 (981) 553-2184",
1365:     "phone": "+1 (872) 596-3656",
1410:     "phone": "+1 (966) 543-3136",
1455:     "phone": "+1 (818) 508-2268",
1500:     "phone": "+1 (951) 420-2218",
1545:     "phone": "+1 (844) 555-2715",
1590:     "phone": "+1 (937) 565-2676",
1635:     "phone": "+1 (972) 576-3178",
1680:     "phone": "+1 (917) 450-3471",
1725:     "phone": "+1 (843) 423-3454",
1770:     "phone": "+1 (948) 509-3334",
1815:     "phone": "+1 (831) 416-2264",
1860:     "phone": "+1 (891) 400-3519",
1905:     "phone": "+1 (943) 479-2761",
1950:     "phone": "+1 (906) 480-2565",
1995:     "phone": "+1 (851) 497-3501",
2040:     "phone": "+1 (841) 418-3257",
2085:     "phone": "+1 (926) 512-3937",
2130:     "phone": "+1 (987) 421-2382",
2175:     "phone": "+1 (899) 580-3031",
2220:     "phone": "+1 (960) 427-2889",
2265:     "phone": "+1 (860) 507-2156",
2310:     "phone": "+1 (894) 511-3314",
2355:     "phone": "+1 (926) 591-3806",
2400:     "phone": "+1 (908) 518-2917",
2445:     "phone": "+1 (804) 531-2757",
2490:     "phone": "+1 (923) 584-2675",
2535:     "phone": "+1 (867) 565-3773",
2580:     "phone": "+1 (818) 596-3918",
2625:     "phone": "+1 (948) 499-3495",
2670:     "phone": "+1 (800) 586-3376",
2715:     "phone": "+1 (806) 466-2258",
2760:     "phone": "+1 (898) 448-2185",
2805:     "phone": "+1 (935) 589-2629",
2850:     "phone": "+1 (891) 512-3740",
2895:     "phone": "+1 (981) 551-3815",
2940:     "phone": "+1 (881) 538-3365",
2985:     "phone": "+1 (975) 589-3053",
3030:     "phone": "+1 (902) 562-2128",
3075:     "phone": "+1 (948) 410-2460",
3120:     "phone": "+1 (942) 561-2111",
3165:     "phone": "+1 (843) 425-3098",
3210:     "phone": "+1 (900) 580-3229",
3255:     "phone": "+1 (879) 551-3061",
3300:     "phone": "+1 (814) 582-3071",
3345:     "phone": "+1 (990) 512-2222",
3390:     "phone": "+1 (978) 573-3997",
3435:     "phone": "+1 (894) 433-3996",
3480:     "phone": "+1 (919) 515-3066",
3525:     "phone": "+1 (915) 421-2684",
3570:     "phone": "+1 (925) 529-2747",
3615:     "phone": "+1 (919) 426-2851",
3660:     "phone": "+1 (897) 513-3281",
3705:     "phone": "+1 (850) 539-3379",
3750:     "phone": "+1 (909) 478-2505",
3795:     "phone": "+1 (992) 523-2404",
3840:     "phone": "+1 (876) 463-3788",
3885:     "phone": "+1 (811) 505-2973",
3930:     "phone": "+1 (994) 521-2251",
3975:     "phone": "+1 (820) 448-2105",
4020:     "phone": "+1 (938) 516-3670",
4065:     "phone": "+1 (815) 551-3343",
4110:     "phone": "+1 (855) 469-2689",
4155:     "phone": "+1 (878) 582-3574",
4200:     "phone": "+1 (837) 573-2113",
4245:     "phone": "+1 (988) 541-3936",
4290:     "phone": "+1 (945) 600-2756",
4335:     "phone": "+1 (941) 551-2018",
4380:     "phone": "+1 (826) 564-2855",
4425:     "phone": "+1 (919) 596-3947",
4470:     "phone": "+1 (856) 408-2445",
4515:     "phone": "+1 (880) 472-3026",
4560:     "phone": "+1 (958) 545-2045",
4605:     "phone": "+1 (982) 534-3838",
4650:     "phone": "+1 (874) 433-3388",
4695:     "phone": "+1 (997) 598-3664",
4740:     "phone": "+1 (943) 552-3860",
4785:     "phone": "+1 (823) 536-3787",
4830:     "phone": "+1 (971) 483-3841",
4875:     "phone": "+1 (842) 550-3460",
4920:     "phone": "+1 (816) 457-2084",
4965:     "phone": "+1 (969) 432-2674",
5010:     "phone": "+1 (937) 574-2800",
5055:     "phone": "+1 (862) 584-3454",
5100:     "phone": "+1 (945) 538-2237",
5145:     "phone": "+1 (977) 463-3790",
5190:     "phone": "+1 (948) 511-2897",
5235:     "phone": "+1 (966) 548-3943",
5280:     "phone": "+1 (800) 513-2595",
5325:     "phone": "+1 (910) 515-3339",
5370:     "phone": "+1 (827) 584-3711",
5415:     "phone": "+1 (855) 555-2074",
5460:     "phone": "+1 (902) 494-2637",
5505:     "phone": "+1 (947) 598-3867",
5550:     "phone": "+1 (848) 515-2715",
5595:     "phone": "+1 (883) 424-3837",
5640:     "phone": "+1 (974) 415-3309",
5685:     "phone": "+1 (808) 592-3525",
5730:     "phone": "+1 (932) 446-3346",
5775:     "phone": "+1 (939) 444-3055",
5820:     "phone": "+1 (832) 410-3108",
5865:     "phone": "+1 (961) 557-2724",
5910:     "phone": "+1 (893) 426-3444",
5955:     "phone": "+1 (867) 491-3071",
6000:     "phone": "+1 (809) 510-2641",
6045:     "phone": "+1 (826) 592-3362",
6090:     "phone": "+1 (824) 497-2085",
6135:     "phone": "+1 (863) 543-3535",
6180:     "phone": "+1 (964) 450-3239",
6225:     "phone": "+1 (897) 595-3177",
6270:     "phone": "+1 (944) 451-2580",
6315:     "phone": "+1 (968) 450-3970",
6360:     "phone": "+1 (893) 439-2992",
6405:     "phone": "+1 (824) 548-3309",
6450:     "phone": "+1 (830) 503-3733",
6495:     "phone": "+1 (853) 551-3777",
6540:     "phone": "+1 (838) 587-3155",
6585:     "phone": "+1 (994) 584-3713",
6630:     "phone": "+1 (887) 456-2827",
6675:     "phone": "+1 (881) 585-3898",
6720:     "phone": "+1 (980) 532-3612",
6765:     "phone": "+1 (809) 401-2730",
6810:     "phone": "+1 (887) 567-3628",
6855:     "phone": "+1 (800) 486-2517",
6900:     "phone": "+1 (880) 540-2582",
6945:     "phone": "+1 (811) 444-2511",
6990:     "phone": "+1 (881) 569-3641",
7035:     "phone": "+1 (985) 453-3997",
7080:     "phone": "+1 (807) 542-3950",
7125:     "phone": "+1 (972) 503-2569",
7170:     "phone": "+1 (914) 485-2099",
7215:     "phone": "+1 (999) 440-3045",
7260:     "phone": "+1 (831) 495-3564",
7305:     "phone": "+1 (930) 502-2894",
7350:     "phone": "+1 (986) 487-3994",
7395:     "phone": "+1 (991) 423-2908",
7440:     "phone": "+1 (800) 557-3201",
7485:     "phone": "+1 (923) 569-3362",
7530:     "phone": "+1 (800) 450-3332",
7575:     "phone": "+1 (996) 492-2616",
7620:     "phone": "+1 (973) 501-2510",
7665:     "phone": "+1 (830) 474-3561",
7710:     "phone": "+1 (910) 556-2921",
7755:     "phone": "+1 (821) 581-2332",
7800:     "phone": "+1 (899) 548-2439",
7845:     "phone": "+1 (925) 551-3547",
7890:     "phone": "+1 (844) 552-2562",
7935:     "phone": "+1 (881) 524-2837",
7980:     "phone": "+1 (879) 433-2819",
8025:     "phone": "+1 (885) 412-2056",
8070:     "phone": "+1 (810) 508-2641",
8115:     "phone": "+1 (935) 507-2063",
8160:     "phone": "+1 (815) 477-3954",
8205:     "phone": "+1 (928) 431-3925",
8250:     "phone": "+1 (920) 574-2693",
8295:     "phone": "+1 (867) 418-3502",
8340:     "phone": "+1 (988) 400-3146",
8385:     "phone": "+1 (839) 418-3056",
8430:     "phone": "+1 (874) 505-3221",
8475:     "phone": "+1 (910) 478-3194",
8520:     "phone": "+1 (980) 571-3728",
8565:     "phone": "+1 (813) 495-2329",
8610:     "phone": "+1 (856) 454-3476",
8655:     "phone": "+1 (924) 495-2220",
8700:     "phone": "+1 (824) 597-3676",
8745:     "phone": "+1 (897) 524-2129",
8790:     "phone": "+1 (861) 407-3175",
8835:     "phone": "+1 (922) 534-3554",
8880:     "phone": "+1 (920) 492-2463",
8925:     "phone": "+1 (811) 463-2887",
8970:     "phone": "+1 (890) 494-2947",
9015:     "phone": "+1 (955) 567-3486",
9060:     "phone": "+1 (884) 428-2417",
9105:     "phone": "+1 (883) 538-2435",
9150:     "phone": "+1 (917) 563-3560",
9195:     "phone": "+1 (969) 582-2499",
9240:     "phone": "+1 (920) 418-2624",
9285:     "phone": "+1 (931) 573-2496",
9330:     "phone": "+1 (968) 539-2000",
9375:     "phone": "+1 (801) 452-2159",
9420:     "phone": "+1 (927) 557-3299",
9465:     "phone": "+1 (924) 535-3269",
9510:     "phone": "+1 (957) 477-3087",
9555:     "phone": "+1 (865) 585-3659",
9600:     "phone": "+1 (889) 419-2522",
9645:     "phone": "+1 (885) 476-3326",
9690:     "phone": "+1 (908) 458-3614",
9735:     "phone": "+1 (993) 507-3758",
9780:     "phone": "+1 (911) 508-2308",
9825:     "phone": "+1 (968) 511-2832",
9870:     "phone": "+1 (963) 490-2494",
9915:     "phone": "+1 (946) 425-3567",
9960:     "phone": "+1 (954) 487-3443",
10005:     "phone": "+1 (965) 523-2211",
10050:     "phone": "+1 (983) 474-2966",
10095:     "phone": "+1 (841) 550-3204",
10140:     "phone": "+1 (868) 565-3594",
10185:     "phone": "+1 (811) 403-3705",
10230:     "phone": "+1 (809) 444-3978",
10275:     "phone": "+1 (831) 541-3182",
10320:     "phone": "+1 (855) 493-3667",
10365:     "phone": "+1 (942) 452-2990",
10410:     "phone": "+1 (941) 529-2597",
10455:     "phone": "+1 (972) 493-2362",
10500:     "phone": "+1 (888) 491-2792",
10545:     "phone": "+1 (848) 491-2071",
10590:     "phone": "+1 (858) 550-3038",
10635:     "phone": "+1 (835) 412-3381",
10680:     "phone": "+1 (800) 535-3383",
10725:     "phone": "+1 (985) 594-3323",
10770:     "phone": "+1 (812) 451-2468",
10815:     "phone": "+1 (893) 504-3286",
10860:     "phone": "+1 (892) 466-3931",
10905:     "phone": "+1 (956) 435-3774",
10950:     "phone": "+1 (916) 522-2144",
10995:     "phone": "+1 (943) 532-3928",
11040:     "phone": "+1 (959) 407-3524",
11085:     "phone": "+1 (802) 542-3045",
11130:     "phone": "+1 (804) 551-3651",
11175:     "phone": "+1 (980) 412-2186",
11220:     "phone": "+1 (803) 453-3310",
11265:     "phone": "+1 (877) 548-2895",
11310:     "phone": "+1 (982) 594-3943",
11355:     "phone": "+1 (866) 518-3456",
11400:     "phone": "+1 (850) 463-2269",
11445:     "phone": "+1 (913) 488-3685",
11490:     "phone": "+1 (889) 572-3844",