blob: 93cd991ecaf0fb5a5c36740e029014a320505a51 [file] [log] [blame]
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08001/*
2 * Copyright (C) 2015 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package android.telephony;
18
Hall Liue5b1fda2018-10-22 18:17:44 -070019import android.Manifest;
Jonathan Basserib731c3d2015-05-05 12:00:59 -070020import android.annotation.NonNull;
21import android.annotation.Nullable;
Jeff Sharkeyd86b8fe2017-06-02 17:36:26 -060022import android.annotation.RequiresPermission;
23import android.annotation.SuppressLint;
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080024import android.annotation.SystemApi;
Jeff Sharkeyd86b8fe2017-06-02 17:36:26 -060025import android.annotation.SystemService;
Hall Liue5b1fda2018-10-22 18:17:44 -070026import android.annotation.TestApi;
Artur Satayev2ebb31c2020-01-08 12:24:36 +000027import android.compat.annotation.UnsupportedAppUsage;
tonyzhu6ac54dc2018-11-19 15:00:00 +080028import android.content.ComponentName;
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080029import android.content.Context;
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -070030import android.os.PersistableBundle;
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080031import android.os.RemoteException;
Jeff Sharkey17bebd22017-07-19 21:00:38 -060032import android.service.carrier.CarrierService;
Tyler Gunne4d72b42019-02-25 10:42:45 -080033import android.telecom.TelecomManager;
Brad Ebingerf8c3cd82018-01-22 13:51:52 -080034import android.telephony.ims.ImsReasonInfo;
Brad Ebinger2eed38662020-09-17 14:17:35 -070035import android.telephony.ims.ImsSsData;
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080036
Ta-wei Yen3f9306f2016-04-20 14:46:20 -070037import com.android.internal.telephony.ICarrierConfigLoader;
Sarah China912e112020-01-09 10:43:30 -080038import com.android.telephony.Rlog;
Ta-wei Yen3f9306f2016-04-20 14:46:20 -070039
Malcolm Chen57b574e2020-02-19 15:21:22 -080040import java.util.concurrent.TimeUnit;
41
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080042/**
43 * Provides access to telephony configuration values that are carrier-specific.
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080044 */
Jeff Sharkeyd86b8fe2017-06-02 17:36:26 -060045@SystemService(Context.CARRIER_CONFIG_SERVICE)
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080046public class CarrierConfigManager {
Jonathan Basserif31ac332015-05-27 01:18:46 -070047 private final static String TAG = "CarrierConfigManager";
48
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080049 /**
Amit Mahajan8a4275f2018-01-24 12:54:44 -080050 * Extra included in {@link #ACTION_CARRIER_CONFIG_CHANGED} to indicate the slot index that the
51 * broadcast is for.
52 */
53 public static final String EXTRA_SLOT_INDEX = "android.telephony.extra.SLOT_INDEX";
54
55 /**
Sarah Chin53ae60d2020-04-01 14:05:56 -070056 * Extra included in {@link #ACTION_CARRIER_CONFIG_CHANGED} to indicate whether this is a
57 * rebroadcast on unlock. Defaults to {@code false} if not specified.
58 * @hide
59 */
60 public static final String EXTRA_REBROADCAST_ON_UNLOCK =
61 "android.telephony.extra.REBROADCAST_ON_UNLOCK";
62
63 /**
Amit Mahajan8a4275f2018-01-24 12:54:44 -080064 * Optional extra included in {@link #ACTION_CARRIER_CONFIG_CHANGED} to indicate the
65 * subscription index that the broadcast is for, if a valid one is available.
66 */
67 public static final String EXTRA_SUBSCRIPTION_INDEX =
68 SubscriptionManager.EXTRA_SUBSCRIPTION_INDEX;
69
Brad Ebinger2eed38662020-09-17 14:17:35 -070070 /**
71 * Service class flag if not specify a service class.
72 * Reference: 3GPP TS 27.007 Section 7.4 Facility lock +CLCK
73 * @hide
74 */
75 public static final int SERVICE_CLASS_NONE = ImsSsData.SERVICE_CLASS_NONE;
76
77 /**
78 * Service class flag for voice telephony.
79 * Reference: 3GPP TS 27.007 Section 7.4 Facility lock +CLCK
80 * @hide
81 */
82 public static final int SERVICE_CLASS_VOICE = ImsSsData.SERVICE_CLASS_VOICE;
83
Malcolm Chend1272d12018-02-28 15:20:45 -080084 private final Context mContext;
85
Amit Mahajan8a4275f2018-01-24 12:54:44 -080086 /**
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080087 * @hide
88 */
Malcolm Chend1272d12018-02-28 15:20:45 -080089 public CarrierConfigManager(Context context) {
90 mContext = context;
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080091 }
92
93 /**
Amit Mahajan8a4275f2018-01-24 12:54:44 -080094 * This intent is broadcast by the system when carrier config changes. An int is specified in
95 * {@link #EXTRA_SLOT_INDEX} to indicate the slot index that this is for. An optional int extra
96 * {@link #EXTRA_SUBSCRIPTION_INDEX} is included to indicate the subscription index if a valid
chen xud47a0682018-12-06 15:34:05 -080097 * one is available for the slot index. An optional int extra
98 * {@link TelephonyManager#EXTRA_CARRIER_ID} is included to indicate the carrier id for the
99 * changed carrier configuration. An optional int extra
chen xu45f66212019-03-06 14:43:40 -0800100 * {@link TelephonyManager#EXTRA_SPECIFIC_CARRIER_ID} is included to indicate the precise
chen xud47a0682018-12-06 15:34:05 -0800101 * carrier id for the changed carrier configuration.
102 * @see TelephonyManager#getSimCarrierId()
chen xu45f66212019-03-06 14:43:40 -0800103 * @see TelephonyManager#getSimSpecificCarrierId()
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800104 */
105 public static final String
106 ACTION_CARRIER_CONFIG_CHANGED = "android.telephony.action.CARRIER_CONFIG_CHANGED";
107
Jonathan Basseri08e318e2015-05-29 10:12:23 -0700108 // Below are the keys used in carrier config bundles. To add a new variable, define the key and
109 // give it a default value in sDefaults. If you need to ship a per-network override in the
110 // system image, that can be added in packages/apps/CarrierConfig.
111
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800112 /**
Michele Berionne8ac8bd22018-12-05 11:05:33 -0800113 * Specifies a value that identifies the version of the carrier configuration that is
114 * currently in use. This string is displayed on the UI.
115 * The format of the string is not specified.
Michele Berionne8ac8bd22018-12-05 11:05:33 -0800116 */
117 public static final String KEY_CARRIER_CONFIG_VERSION_STRING =
118 "carrier_config_version_string";
119
120 /**
Jordan Liuc82d1132016-10-03 11:35:33 -0700121 * This flag specifies whether VoLTE availability is based on provisioning. By default this is
122 * false.
123 */
124 public static final String
125 KEY_CARRIER_VOLTE_PROVISIONED_BOOL = "carrier_volte_provisioned_bool";
126
SongFerngWang06057162018-06-28 17:28:22 +0800127 /**
SongFerngWang08972c52019-11-25 22:44:12 +0800128 * Boolean indicating the Supplementary Services(SS) is disable when airplane mode on in the
129 * Call Settings menu.
130 * {@code true}: SS is disable when airplane mode on.
131 * {@code false}: SS is enable when airplane mode on.
132 * The default value for this key is {@code false}
133 */
134 public static final String KEY_DISABLE_SUPPLEMENTARY_SERVICES_IN_AIRPLANE_MODE_BOOL =
135 "disable_supplementary_services_in_airplane_mode_bool";
136
137 /**
SongFerngWang06057162018-06-28 17:28:22 +0800138 * Boolean indicating if the "Call forwarding" item is visible in the Call Settings menu.
139 * true means visible. false means gone.
140 * @hide
141 */
142 public static final String KEY_CALL_FORWARDING_VISIBILITY_BOOL =
143 "call_forwarding_visibility_bool";
144
145 /**
Shu Wang6edfc5a2018-09-13 15:36:30 +0200146 * Boolean indicating if carrier supports call forwarding option "When unreachable".
147 *
148 * {@code true}: Call forwarding option "When unreachable" is supported.
149 * {@code false}: Call forwarding option "When unreachable" is not supported. Option will be
allenwtsu6206afc2020-05-19 21:37:50 +0800150 * removed in the UI.
Shu Wang6edfc5a2018-09-13 15:36:30 +0200151 *
152 * By default this value is true.
153 * @hide
154 */
155 public static final String KEY_CALL_FORWARDING_WHEN_UNREACHABLE_SUPPORTED_BOOL =
156 "call_forwarding_when_unreachable_supported_bool";
157
allenwtsu6206afc2020-05-19 21:37:50 +0800158 /**
159 * Boolean indicating if carrier supports call forwarding option "When unanswered".
160 *
161 * {@code true}: Call forwarding option "When unanswered" is supported.
162 * {@code false}: Call forwarding option "When unanswered" is not supported. Option will be
163 * removed in the UI.
164 *
165 * By default this value is true.
166 * @hide
167 */
168 public static final String KEY_CALL_FORWARDING_WHEN_UNANSWERED_SUPPORTED_BOOL =
169 "call_forwarding_when_unanswered_supported_bool";
170
171 /**
172 * Boolean indicating if carrier supports call forwarding option "When busy".
173 *
174 * {@code true}: Call forwarding option "When busy" is supported.
175 * {@code false}: Call forwarding option "When busy" is not supported. Option will be
176 * removed in the UI.
177 *
178 * By default this value is true.
179 * @hide
180 */
181 public static final String KEY_CALL_FORWARDING_WHEN_BUSY_SUPPORTED_BOOL =
182 "call_forwarding_when_busy_supported_bool";
183
Shu Wang6edfc5a2018-09-13 15:36:30 +0200184 /**
SongFerngWang06057162018-06-28 17:28:22 +0800185 * Boolean indicating if the "Caller ID" item is visible in the Additional Settings menu.
186 * true means visible. false means gone.
187 * @hide
188 */
189 public static final String KEY_ADDITIONAL_SETTINGS_CALLER_ID_VISIBILITY_BOOL =
190 "additional_settings_caller_id_visibility_bool";
191
192 /**
193 * Boolean indicating if the "Call Waiting" item is visible in the Additional Settings menu.
194 * true means visible. false means gone.
195 * @hide
196 */
197 public static final String KEY_ADDITIONAL_SETTINGS_CALL_WAITING_VISIBILITY_BOOL =
198 "additional_settings_call_waiting_visibility_bool";
199
Wenting Xiongd5853682016-08-12 18:28:37 +0800200 /**
201 * Boolean indicating if the "Call barring" item is visible in the Call Settings menu.
Brad Ebinger0819bac2018-08-29 16:08:29 -0700202 * If true, the "Call Barring" menu will be visible. If false, the menu will be gone.
203 *
204 * Disabled by default.
Wenting Xiongd5853682016-08-12 18:28:37 +0800205 */
206 public static final String KEY_CALL_BARRING_VISIBILITY_BOOL =
207 "call_barring_visibility_bool";
208
Jordan Liuc82d1132016-10-03 11:35:33 -0700209 /**
Brad Ebinger0819bac2018-08-29 16:08:29 -0700210 * Flag indicating whether or not changing the call barring password via the "Call Barring"
211 * settings menu is supported. If true, the option will be visible in the "Call
212 * Barring" settings menu. If false, the option will not be visible.
213 *
214 * Enabled by default.
215 */
216 public static final String KEY_CALL_BARRING_SUPPORTS_PASSWORD_CHANGE_BOOL =
217 "call_barring_supports_password_change_bool";
218
219 /**
220 * Flag indicating whether or not deactivating all call barring features via the "Call Barring"
221 * settings menu is supported. If true, the option will be visible in the "Call
222 * Barring" settings menu. If false, the option will not be visible.
223 *
224 * Enabled by default.
225 */
226 public static final String KEY_CALL_BARRING_SUPPORTS_DEACTIVATE_ALL_BOOL =
227 "call_barring_supports_deactivate_all_bool";
228
229 /**
Brad Ebinger2eed38662020-09-17 14:17:35 -0700230 * Specifies the service class for call barring service. Default value is
231 * {@link #SERVICE_CLASS_VOICE}.
232 * The value set as below:
233 * <ul>
234 * <li>0: {@link #SERVICE_CLASS_NONE}</li>
235 * <li>1: {@link #SERVICE_CLASS_VOICE}</li>
236 * </ul>
237 * @hide
238 */
239 public static final String KEY_CALL_BARRING_DEFAULT_SERVICE_CLASS_INT =
240 "call_barring_default_service_class_int";
241
242 /**
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700243 * Flag indicating whether the Phone app should ignore EVENT_SIM_NETWORK_LOCKED
244 * events from the Sim.
245 * If true, this will prevent the IccNetworkDepersonalizationPanel from being shown, and
246 * effectively disable the "Sim network lock" feature.
247 */
248 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700249 KEY_IGNORE_SIM_NETWORK_LOCKED_EVENTS_BOOL = "ignore_sim_network_locked_events_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700250
251 /**
Jordan Liube45b8c2016-11-09 13:23:42 -0800252 * When checking if a given number is the voicemail number, if this flag is true
253 * then in addition to comparing the given number to the voicemail number, we also compare it
254 * to the mdn. If this flag is false, the given number is only compared to the voicemail number.
255 * By default this value is false.
256 */
257 public static final String KEY_MDN_IS_ADDITIONAL_VOICEMAIL_NUMBER_BOOL =
258 "mdn_is_additional_voicemail_number_bool";
259
260 /**
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700261 * Flag indicating whether the Phone app should provide a "Dismiss" button on the SIM network
262 * unlock screen. The default value is true. If set to false, there will be *no way* to dismiss
263 * the SIM network unlock screen if you don't enter the correct unlock code. (One important
264 * consequence: there will be no way to make an Emergency Call if your SIM is network-locked and
265 * you don't know the PIN.)
266 */
267 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700268 KEY_SIM_NETWORK_UNLOCK_ALLOW_DISMISS_BOOL = "sim_network_unlock_allow_dismiss_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700269
Avinash Nalluriceaf7222018-04-21 14:06:06 -0700270 /**
271 * Flag indicating whether or not sending emergency SMS messages over IMS
272 * is supported when in LTE/limited LTE (Emergency only) service mode..
273 *
274 */
275 public static final String
276 KEY_SUPPORT_EMERGENCY_SMS_OVER_IMS_BOOL = "support_emergency_sms_over_ims_bool";
277
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700278 /** Flag indicating if the phone is a world phone */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700279 public static final String KEY_WORLD_PHONE_BOOL = "world_phone_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700280
281 /**
Chris Manton1ba0fa02015-09-01 13:56:46 -0700282 * Flag to require or skip entitlement checks.
283 * If true, entitlement checks will be executed if device has been configured for it,
284 * If false, entitlement checks will be skipped.
Chris Manton1ba0fa02015-09-01 13:56:46 -0700285 */
286 public static final String
287 KEY_REQUIRE_ENTITLEMENT_CHECKS_BOOL = "require_entitlement_checks_bool";
288
289 /**
Jordan Liua5a8b592016-09-12 10:57:27 -0700290 * Flag indicating whether radio is to be restarted on error PDP_FAIL_REGULAR_DEACTIVATION
291 * This is false by default.
Jack Yu3399f362018-08-21 16:57:36 -0700292 *
Jack Yua219efb2018-08-22 17:19:44 -0700293 * @deprecated Use {@link #KEY_RADIO_RESTART_FAILURE_CAUSES_INT_ARRAY} instead
Jordan Liua5a8b592016-09-12 10:57:27 -0700294 */
Jack Yu3399f362018-08-21 16:57:36 -0700295 @Deprecated
296 public static final String KEY_RESTART_RADIO_ON_PDP_FAIL_REGULAR_DEACTIVATION_BOOL =
297 "restart_radio_on_pdp_fail_regular_deactivation_bool";
298
299 /**
300 * A list of failure cause codes that will trigger a modem restart when telephony receiving
301 * one of those during data setup. The cause codes are defined in 3GPP TS 24.008 Annex I and
302 * TS 24.301 Annex B.
303 */
304 public static final String KEY_RADIO_RESTART_FAILURE_CAUSES_INT_ARRAY =
305 "radio_restart_failure_causes_int_array";
Jordan Liua5a8b592016-09-12 10:57:27 -0700306
307 /**
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700308 * If true, enable vibration (haptic feedback) for key presses in the EmergencyDialer activity.
309 * The pattern is set on a per-platform basis using config_virtualKeyVibePattern. To be
310 * consistent with the regular Dialer, this value should agree with the corresponding values
311 * from config.xml under apps/Contacts.
312 */
313 public static final String
Jonathan Basseri1826c232015-06-19 16:04:38 -0700314 KEY_ENABLE_DIALER_KEY_VIBRATION_BOOL = "enable_dialer_key_vibration_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700315
316 /** Flag indicating if dtmf tone type is enabled */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700317 public static final String KEY_DTMF_TYPE_ENABLED_BOOL = "dtmf_type_enabled_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700318
319 /** Flag indicating if auto retry is enabled */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700320 public static final String KEY_AUTO_RETRY_ENABLED_BOOL = "auto_retry_enabled_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700321
322 /**
323 * Determine whether we want to play local DTMF tones in a call, or just let the radio/BP handle
324 * playing of the tones.
325 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700326 public static final String KEY_ALLOW_LOCAL_DTMF_TONES_BOOL = "allow_local_dtmf_tones_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700327
328 /**
Tyler Gunnacdb6862018-01-29 14:30:52 -0800329 * Determines if the carrier requires that a tone be played to the remote party when an app is
330 * recording audio during a call (e.g. using a call recording app).
331 * <p>
332 * Note: This requires the Telephony config_supports_telephony_audio_device overlay to be true
333 * in order to work.
334 * @hide
335 */
336 public static final String KEY_PLAY_CALL_RECORDING_TONE_BOOL = "play_call_recording_tone_bool";
337 /**
Jordan Liu5ac6f5c2016-10-03 12:28:27 -0700338 * Determines if the carrier requires converting the destination number before sending out an
339 * SMS. Certain networks and numbering plans require different formats.
340 */
341 public static final String KEY_SMS_REQUIRES_DESTINATION_NUMBER_CONVERSION_BOOL=
342 "sms_requires_destination_number_conversion_bool";
343
344 /**
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700345 * If true, show an onscreen "Dial" button in the dialer. In practice this is used on all
346 * platforms, even the ones with hard SEND/END keys, but for maximum flexibility it's controlled
347 * by a flag here (which can be overridden on a per-product basis.)
348 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700349 public static final String KEY_SHOW_ONSCREEN_DIAL_BUTTON_BOOL = "show_onscreen_dial_button_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700350
351 /** Determines if device implements a noise suppression device for in call audio. */
352 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700353 KEY_HAS_IN_CALL_NOISE_SUPPRESSION_BOOL = "has_in_call_noise_suppression_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700354
355 /**
356 * Determines if the current device should allow emergency numbers to be logged in the Call Log.
357 * (Some carriers require that emergency calls *not* be logged, presumably to avoid the risk of
358 * accidental redialing from the call log UI. This is a good idea, so the default here is
359 * false.)
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700360 */
361 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700362 KEY_ALLOW_EMERGENCY_NUMBERS_IN_CALL_LOG_BOOL = "allow_emergency_numbers_in_call_log_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700363
Hall Liue6e6ec42018-08-03 18:25:24 -0700364 /**
365 * A string array containing numbers that shouldn't be included in the call log.
Hall Liue6e6ec42018-08-03 18:25:24 -0700366 */
367 public static final String KEY_UNLOGGABLE_NUMBERS_STRING_ARRAY =
368 "unloggable_numbers_string_array";
369
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700370 /** If true, removes the Voice Privacy option from Call Settings */
Jonathan Basseri3360c262015-06-09 15:16:21 -0700371 public static final String KEY_VOICE_PRIVACY_DISABLE_UI_BOOL = "voice_privacy_disable_ui_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700372
373 /** Control whether users can reach the carrier portions of Cellular Network Settings. */
374 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700375 KEY_HIDE_CARRIER_NETWORK_SETTINGS_BOOL = "hide_carrier_network_settings_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700376
Joe LaPenna2b22ae32016-12-07 16:27:24 -0800377 /**
Sarah China912e112020-01-09 10:43:30 -0800378 * Only allow auto selection in Advanced Network Settings when in home network.
Mattias Nilssonef874162017-12-11 13:45:40 +0100379 * Manual selection is allowed when in roaming network.
Mattias Nilssonef874162017-12-11 13:45:40 +0100380 */
Sarah China912e112020-01-09 10:43:30 -0800381 public static final String KEY_ONLY_AUTO_SELECT_IN_HOME_NETWORK_BOOL =
382 "only_auto_select_in_home_network";
Mattias Nilssonef874162017-12-11 13:45:40 +0100383
384 /**
Joe LaPenna2b22ae32016-12-07 16:27:24 -0800385 * Control whether users receive a simplified network settings UI and improved network
386 * selection.
Joe LaPenna2b22ae32016-12-07 16:27:24 -0800387 */
388 public static final String
389 KEY_SIMPLIFIED_NETWORK_SETTINGS_BOOL = "simplified_network_settings_bool";
390
Junda Liue15cca72015-06-17 09:55:57 -0700391 /** Control whether users can reach the SIM lock settings. */
392 public static final String
393 KEY_HIDE_SIM_LOCK_SETTINGS_BOOL = "hide_sim_lock_settings_bool";
394
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700395 /** Control whether users can edit APNs in Settings. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700396 public static final String KEY_APN_EXPAND_BOOL = "apn_expand_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700397
398 /** Control whether users can choose a network operator. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700399 public static final String KEY_OPERATOR_SELECTION_EXPAND_BOOL = "operator_selection_expand_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700400
401 /** Used in Cellular Network Settings for preferred network type. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700402 public static final String KEY_PREFER_2G_BOOL = "prefer_2g_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700403
Junda Liucd115b72015-05-13 14:57:48 -0700404 /** Show cdma network mode choices 1x, 3G, global etc. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700405 public static final String KEY_SHOW_CDMA_CHOICES_BOOL = "show_cdma_choices_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700406
407 /** CDMA activation goes through HFA */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700408 public static final String KEY_USE_HFA_FOR_PROVISIONING_BOOL = "use_hfa_for_provisioning_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700409
410 /**
411 * CDMA activation goes through OTASP.
412 * <p>
413 * TODO: This should be combined with config_use_hfa_for_provisioning and implemented as an enum
414 * (NONE, HFA, OTASP).
415 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700416 public static final String KEY_USE_OTASP_FOR_PROVISIONING_BOOL = "use_otasp_for_provisioning_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700417
418 /** Display carrier settings menu if true */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700419 public static final String KEY_CARRIER_SETTINGS_ENABLE_BOOL = "carrier_settings_enable_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700420
Bin Chen503513d2017-09-01 18:12:53 +0800421 /** Does not display additional call setting for IMS phone based on GSM Phone */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700422 public static final String KEY_ADDITIONAL_CALL_SETTING_BOOL = "additional_call_setting_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700423
424 /** Show APN Settings for some CDMA carriers */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700425 public static final String KEY_SHOW_APN_SETTING_CDMA_BOOL = "show_apn_setting_cdma_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700426
427 /** After a CDMA conference call is merged, the swap button should be displayed. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700428 public static final String KEY_SUPPORT_SWAP_AFTER_MERGE_BOOL = "support_swap_after_merge_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700429
430 /**
manabu, shimoda1de99d12017-10-20 17:16:06 +0900431 * Determine whether user can edit voicemail number in Settings.
432 */
433 public static final String KEY_EDITABLE_VOICEMAIL_NUMBER_SETTING_BOOL =
434 "editable_voicemail_number_setting_bool";
435
436 /**
Jordan Liu4a546382016-09-08 12:45:58 -0700437 * Since the default voicemail number is empty, if a SIM card does not have a voicemail number
438 * available the user cannot use voicemail. This flag allows the user to edit the voicemail
439 * number in such cases, and is false by default.
440 */
441 public static final String KEY_EDITABLE_VOICEMAIL_NUMBER_BOOL= "editable_voicemail_number_bool";
442
443 /**
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700444 * Determine whether the voicemail notification is persistent in the notification bar. If true,
445 * the voicemail notifications cannot be dismissed from the notification bar.
446 */
447 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700448 KEY_VOICEMAIL_NOTIFICATION_PERSISTENT_BOOL = "voicemail_notification_persistent_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700449
450 /** For IMS video over LTE calls, determines whether video pause signalling is supported. */
451 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700452 KEY_SUPPORT_PAUSE_IMS_VIDEO_CALLS_BOOL = "support_pause_ims_video_calls_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700453
454 /**
455 * Disables dialing "*228" (OTASP provisioning) on CDMA carriers where it is not supported or is
456 * potentially harmful by locking the SIM to 3G.
457 */
458 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700459 KEY_DISABLE_CDMA_ACTIVATION_CODE_BOOL = "disable_cdma_activation_code_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700460
Amit Mahajan412e7c82015-10-05 11:05:02 -0700461 /**
Jordan Liu2420a0a2016-10-04 11:46:03 -0700462 * List of RIL radio technologies (See {@link ServiceState} {@code RIL_RADIO_TECHNOLOGY_*}
463 * constants) which support only a single data connection at a time. Some carriers do not
464 * support multiple pdp on UMTS.
465 */
466 public static final String
467 KEY_ONLY_SINGLE_DC_ALLOWED_INT_ARRAY = "only_single_dc_allowed_int_array";
468
469 /**
Chris Mantonca16a792015-06-16 12:06:08 -0700470 * Override the platform's notion of a network operator being considered roaming.
471 * Value is string array of MCCMNCs to be considered roaming for 3GPP RATs.
472 */
473 public static final String
474 KEY_GSM_ROAMING_NETWORKS_STRING_ARRAY = "gsm_roaming_networks_string_array";
475
476 /**
477 * Override the platform's notion of a network operator being considered not roaming.
478 * Value is string array of MCCMNCs to be considered not roaming for 3GPP RATs.
479 */
480 public static final String
481 KEY_GSM_NONROAMING_NETWORKS_STRING_ARRAY = "gsm_nonroaming_networks_string_array";
482
483 /**
Brad Ebinger66978142019-12-05 11:38:15 -0800484 * The package name containing the ImsService that will be bound to the telephony framework to
485 * support both IMS MMTEL and RCS feature functionality instead of the device default
486 * ImsService for this subscription.
487 * @deprecated Use {@link #KEY_CONFIG_IMS_MMTEL_PACKAGE_OVERRIDE_STRING} and
488 * {@link #KEY_CONFIG_IMS_RCS_PACKAGE_OVERRIDE_STRING} instead to configure these values
489 * separately. If any of those values are not empty, they will override this value.
Brad Ebinger024aaf22017-01-23 15:17:50 -0800490 */
491 public static final String KEY_CONFIG_IMS_PACKAGE_OVERRIDE_STRING =
492 "config_ims_package_override_string";
493
494 /**
Brad Ebinger66978142019-12-05 11:38:15 -0800495 * The package name containing the ImsService that will be bound to the telephony framework to
496 * support IMS MMTEL feature functionality instead of the device default ImsService for this
497 * subscription.
498 */
499 public static final String KEY_CONFIG_IMS_MMTEL_PACKAGE_OVERRIDE_STRING =
500 "config_ims_mmtel_package_override_string";
501
502 /**
503 * The package name containing the ImsService that will be bound to the telephony framework to
504 * support IMS RCS feature functionality instead of the device default ImsService for this
505 * subscription.
506 */
507 public static final String KEY_CONFIG_IMS_RCS_PACKAGE_OVERRIDE_STRING =
508 "config_ims_rcs_package_override_string";
509
510 /**
Jeff Sharkey17bebd22017-07-19 21:00:38 -0600511 * Override the package that will manage {@link SubscriptionPlan}
512 * information instead of the {@link CarrierService} that defines this
513 * value.
514 *
515 * @see SubscriptionManager#getSubscriptionPlans(int)
516 * @see SubscriptionManager#setSubscriptionPlans(int, java.util.List)
517 */
518 public static final String KEY_CONFIG_PLANS_PACKAGE_OVERRIDE_STRING =
519 "config_plans_package_override_string";
520
521 /**
Chris Mantonca16a792015-06-16 12:06:08 -0700522 * Override the platform's notion of a network operator being considered roaming.
523 * Value is string array of SIDs to be considered roaming for 3GPP2 RATs.
524 */
525 public static final String
526 KEY_CDMA_ROAMING_NETWORKS_STRING_ARRAY = "cdma_roaming_networks_string_array";
527
528 /**
529 * Override the platform's notion of a network operator being considered non roaming.
530 * Value is string array of SIDs to be considered not roaming for 3GPP2 RATs.
531 */
532 public static final String
533 KEY_CDMA_NONROAMING_NETWORKS_STRING_ARRAY = "cdma_nonroaming_networks_string_array";
534
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700535 /**
Chris Manton63f25b62015-06-24 16:47:49 -0700536 * Override the platform's notion of a network operator being considered non roaming.
537 * If true all networks are considered as home network a.k.a non-roaming. When false,
538 * the 2 pairs of CMDA and GSM roaming/non-roaming arrays are consulted.
539 *
Ricardo Loo Forondaf2a8aea2017-10-26 17:02:31 -0700540 * @see #KEY_GSM_ROAMING_NETWORKS_STRING_ARRAY
541 * @see #KEY_GSM_NONROAMING_NETWORKS_STRING_ARRAY
542 * @see #KEY_CDMA_ROAMING_NETWORKS_STRING_ARRAY
543 * @see #KEY_CDMA_NONROAMING_NETWORKS_STRING_ARRAY
Chris Manton63f25b62015-06-24 16:47:49 -0700544 */
545 public static final String
546 KEY_FORCE_HOME_NETWORK_BOOL = "force_home_network_bool";
547
548 /**
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800549 * Flag specifying whether VoLTE should be available for carrier, independent of carrier
550 * provisioning. If false: hard disabled. If true: then depends on carrier provisioning,
551 * availability, etc.
552 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700553 public static final String KEY_CARRIER_VOLTE_AVAILABLE_BOOL = "carrier_volte_available_bool";
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800554
Junda Liue4786492015-06-15 13:15:28 -0700555 /**
Junda Liue5c7ca72015-06-24 14:41:14 -0700556 * Flag specifying whether video telephony is available for carrier. If false: hard disabled.
557 * If true: then depends on carrier provisioning, availability, etc.
558 */
559 public static final String KEY_CARRIER_VT_AVAILABLE_BOOL = "carrier_vt_available_bool";
560
561 /**
SongFerngWang27b6a582020-04-10 15:07:09 +0800562 * Flag specifying whether to show an alert dialog for 5G disable when the user disables VoLTE.
563 * By default this value is {@code false}.
564 *
565 * @hide
566 */
567 public static final String KEY_VOLTE_5G_LIMITED_ALERT_DIALOG_BOOL =
568 "volte_5g_limited_alert_dialog_bool";
569
570 /**
Tyler Gunn481255d2016-08-16 16:04:48 -0700571 * Flag specifying whether the carrier wants to notify the user when a VT call has been handed
572 * over from WIFI to LTE.
573 * <p>
574 * The handover notification is sent as a
575 * {@link TelephonyManager#EVENT_HANDOVER_VIDEO_FROM_WIFI_TO_LTE}
576 * {@link android.telecom.Connection} event, which an {@link android.telecom.InCallService}
577 * should use to trigger the display of a user-facing message.
578 * <p>
579 * The Connection event is sent to the InCallService only once, the first time it occurs.
580 * @hide
581 */
582 public static final String KEY_NOTIFY_HANDOVER_VIDEO_FROM_WIFI_TO_LTE_BOOL =
583 "notify_handover_video_from_wifi_to_lte_bool";
584
585 /**
Hall Liuef800082019-07-29 16:18:30 -0700586 * Flag specifying whether the carrier supports merging a RTT call with a voice call,
587 * downgrading the call in the process.
588 * @hide
589 */
590 public static final String KEY_ALLOW_MERGING_RTT_CALLS_BOOL =
591 "allow_merging_rtt_calls_bool";
592
593 /**
Tyler Gunn5ce0d3a2017-12-14 14:06:15 -0800594 * Flag specifying whether the carrier wants to notify the user when a VT call has been handed
595 * over from LTE to WIFI.
596 * <p>
597 * The handover notification is sent as a
598 * {@link TelephonyManager#EVENT_HANDOVER_VIDEO_FROM_LTE_TO_WIFI}
599 * {@link android.telecom.Connection} event, which an {@link android.telecom.InCallService}
600 * should use to trigger the display of a user-facing message.
601 * @hide
602 */
603 public static final String KEY_NOTIFY_HANDOVER_VIDEO_FROM_LTE_TO_WIFI_BOOL =
604 "notify_handover_video_from_lte_to_wifi_bool";
605
606 /**
Tyler Gunn86d5c3f2016-08-12 14:14:13 -0700607 * Flag specifying whether the carrier supports downgrading a video call (tx, rx or tx/rx)
608 * directly to an audio call.
609 * @hide
610 */
611 public static final String KEY_SUPPORT_DOWNGRADE_VT_TO_AUDIO_BOOL =
612 "support_downgrade_vt_to_audio_bool";
613
614 /**
Jordan Liu3ff30d22016-09-01 13:25:13 -0700615 * Where there is no preloaded voicemail number on a SIM card, specifies the carrier's default
616 * voicemail number.
617 * When empty string, no default voicemail number is specified.
618 */
619 public static final String KEY_DEFAULT_VM_NUMBER_STRING = "default_vm_number_string";
620
Jack Yu2030cd92016-11-17 09:51:29 -0800621 /**
SongFerngWang310f6d02018-03-23 15:07:05 +0800622 * Where there is no preloaded voicemail number on a SIM card, specifies the carrier's default
623 * voicemail number for roaming network.
624 * When empty string, no default voicemail number is specified for roaming network.
625 * @hide
626 */
627 public static final String KEY_DEFAULT_VM_NUMBER_ROAMING_STRING =
628 "default_vm_number_roaming_string";
629
630 /**
Saki Oomori0dd2dfb2018-09-11 15:44:25 +0900631 * Where there is no preloaded voicemail number on a SIM card, specifies the carrier's default
632 * voicemail number while the device is both roaming and not registered for IMS.
633 * When empty string, no default voicemail number is specified for roaming network and
634 * unregistered state in IMS.
635 */
636 public static final String KEY_DEFAULT_VM_NUMBER_ROAMING_AND_IMS_UNREGISTERED_STRING =
637 "default_vm_number_roaming_and_ims_unregistered_string";
638
639 /**
Cassie4c6f72c2017-10-10 14:33:38 -0700640 * Flag that specifies to use the user's own phone number as the voicemail number when there is
641 * no pre-loaded voicemail number on the SIM card.
642 * <p>
643 * {@link #KEY_DEFAULT_VM_NUMBER_STRING} takes precedence over this flag.
644 * <p>
645 * If false, the system default (*86) will be used instead.
646 */
647 public static final String KEY_CONFIG_TELEPHONY_USE_OWN_NUMBER_FOR_VOICEMAIL_BOOL =
648 "config_telephony_use_own_number_for_voicemail_bool";
649
650 /**
Tyler Gunn9a961f52017-08-17 15:58:47 -0700651 * When {@code true}, changes to the mobile data enabled switch will not cause the VT
652 * registration state to change. That is, turning on or off mobile data will not cause VT to be
653 * enabled or disabled.
654 * When {@code false}, disabling mobile data will cause VT to be de-registered.
Jack Yu2030cd92016-11-17 09:51:29 -0800655 */
656 public static final String KEY_IGNORE_DATA_ENABLED_CHANGED_FOR_VIDEO_CALLS =
657 "ignore_data_enabled_changed_for_video_calls";
Jordan Liu3ff30d22016-09-01 13:25:13 -0700658
659 /**
Tyler Gunn9a961f52017-08-17 15:58:47 -0700660 * Flag indicating whether data used for a video call over LTE is metered or not.
661 * <p>
662 * When {@code true}, if the device hits the data limit or data is disabled during a ViLTE call,
663 * the call will be downgraded to audio-only (or paused if
664 * {@link #KEY_SUPPORT_PAUSE_IMS_VIDEO_CALLS_BOOL} is {@code true}).
665 *
666 * @hide
667 */
668 public static final String KEY_VILTE_DATA_IS_METERED_BOOL = "vilte_data_is_metered_bool";
669
670 /**
Junda Liue4786492015-06-15 13:15:28 -0700671 * Flag specifying whether WFC over IMS should be available for carrier: independent of
672 * carrier provisioning. If false: hard disabled. If true: then depends on carrier
673 * provisioning, availability etc.
674 */
675 public static final String KEY_CARRIER_WFC_IMS_AVAILABLE_BOOL = "carrier_wfc_ims_available_bool";
676
fionaxuc71e8242016-03-08 11:46:55 -0800677 /**
Jordan Liu02ec2a02016-09-09 11:48:48 -0700678 * Specifies a map from dialstrings to replacements for roaming network service numbers which
679 * cannot be replaced on the carrier side.
680 * <p>
681 * Individual entries have the format:
682 * [dialstring to replace]:[replacement]
683 */
684 public static final String KEY_DIAL_STRING_REPLACE_STRING_ARRAY =
685 "dial_string_replace_string_array";
686
687 /**
Tyler Gunn5bbeea02016-03-30 14:50:30 -0700688 * Flag specifying whether WFC over IMS supports the "wifi only" option. If false, the wifi
689 * calling settings will not include an option for "wifi only". If true, the wifi calling
690 * settings will include an option for "wifi only"
691 * <p>
692 * By default, it is assumed that WFC supports "wifi only".
693 */
694 public static final String KEY_CARRIER_WFC_SUPPORTS_WIFI_ONLY_BOOL =
695 "carrier_wfc_supports_wifi_only_bool";
696
697 /**
Meng Wang71b60392018-08-24 15:40:02 -0700698 * Default mode for WFC over IMS on home network:
699 * <ul>
700 * <li>0: Wi-Fi only
701 * <li>1: prefer mobile network
702 * <li>2: prefer Wi-Fi
703 * </ul>
fionaxuc71e8242016-03-08 11:46:55 -0800704 */
705 public static final String KEY_CARRIER_DEFAULT_WFC_IMS_MODE_INT =
706 "carrier_default_wfc_ims_mode_int";
Meng Wang2c25e4a2016-09-19 14:18:05 -0700707
708 /**
Meng Wang71b60392018-08-24 15:40:02 -0700709 * Default mode for WFC over IMS on roaming network.
710 * See {@link #KEY_CARRIER_DEFAULT_WFC_IMS_MODE_INT} for meaning of values.
Meng Wang2c25e4a2016-09-19 14:18:05 -0700711 */
712 public static final String KEY_CARRIER_DEFAULT_WFC_IMS_ROAMING_MODE_INT =
713 "carrier_default_wfc_ims_roaming_mode_int";
714
fionaxuc71e8242016-03-08 11:46:55 -0800715 /**
716 * Default WFC_IMS_enabled: true VoWiFi by default is on
717 * false VoWiFi by default is off
fionaxuc71e8242016-03-08 11:46:55 -0800718 */
719 public static final String KEY_CARRIER_DEFAULT_WFC_IMS_ENABLED_BOOL =
720 "carrier_default_wfc_ims_enabled_bool";
721
722 /**
723 * Default WFC_IMS_roaming_enabled: true VoWiFi roaming by default is on
724 * false VoWiFi roaming by default is off
725 * @hide
726 */
727 public static final String KEY_CARRIER_DEFAULT_WFC_IMS_ROAMING_ENABLED_BOOL =
728 "carrier_default_wfc_ims_roaming_enabled_bool";
729
Tyler Gunnc3e6c932016-07-07 10:11:14 -0700730 /**
731 * Flag indicating whether failed calls due to no service should prompt the user to enable
732 * WIFI calling. When {@code true}, if the user attempts to establish a call when there is no
733 * service available, they are connected to WIFI, and WIFI calling is disabled, a different
734 * call failure message will be used to encourage the user to enable WIFI calling.
735 * @hide
736 */
737 public static final String KEY_CARRIER_PROMOTE_WFC_ON_CALL_FAIL_BOOL =
738 "carrier_promote_wfc_on_call_fail_bool";
739
Brad Ebingerb3f46322019-01-14 13:46:05 -0800740 /**
allenwtsuc2524a42020-01-03 18:18:11 +0800741 * Flag specifying whether provisioning is required for RCS.
742 */
743 public static final String KEY_CARRIER_RCS_PROVISIONING_REQUIRED_BOOL =
744 "carrier_rcs_provisioning_required_bool";
745
746 /**
Brad Ebingerb3f46322019-01-14 13:46:05 -0800747 * Flag specifying whether provisioning is required for VoLTE, Video Telephony, and WiFi
748 * Calling.
749 */
Junda Liue5c7ca72015-06-24 14:41:14 -0700750 public static final String KEY_CARRIER_VOLTE_PROVISIONING_REQUIRED_BOOL
751 = "carrier_volte_provisioning_required_bool";
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800752
Meng Wang05062992017-02-14 21:55:09 -0800753 /**
Brad Ebingerb3f46322019-01-14 13:46:05 -0800754 * Flag indicating whether or not the IMS MmTel UT capability requires carrier provisioning
755 * before it can be set as enabled.
756 *
757 * If true, the UT capability will be set to false for the newly loaded subscription
758 * and will require the carrier provisioning app to set the persistent provisioning result.
759 * If false, the platform will not wait for provisioning status updates for the UT capability
760 * and enable the UT over IMS capability for the subscription when the subscription is loaded.
761 *
762 * The default value for this key is {@code false}.
763 */
764 public static final String KEY_CARRIER_UT_PROVISIONING_REQUIRED_BOOL =
765 "carrier_ut_provisioning_required_bool";
766
767 /**
768 * Flag indicating whether or not the carrier supports Supplementary Services over the UT
769 * interface for this subscription.
770 *
771 * If true, the device will use Supplementary Services over UT when provisioned (see
772 * {@link #KEY_CARRIER_UT_PROVISIONING_REQUIRED_BOOL}). If false, this device will fallback to
773 * circuit switch for supplementary services and will disable this capability for IMS entirely.
774 *
775 * The default value for this key is {@code true}.
776 */
777 public static final String KEY_CARRIER_SUPPORTS_SS_OVER_UT_BOOL =
778 "carrier_supports_ss_over_ut_bool";
779
780 /**
Meng Wang05062992017-02-14 21:55:09 -0800781 * Flag specifying if WFC provisioning depends on VoLTE provisioning.
782 *
783 * {@code false}: default value; honor actual WFC provisioning state.
784 * {@code true}: when VoLTE is not provisioned, treat WFC as not provisioned; when VoLTE is
785 * provisioned, honor actual WFC provisioning state.
786 *
787 * As of now, Verizon is the only carrier enforcing this dependency in their
788 * WFC awareness and activation requirements.
Sarah China912e112020-01-09 10:43:30 -0800789 */
Meng Wang05062992017-02-14 21:55:09 -0800790 public static final String KEY_CARRIER_VOLTE_OVERRIDE_WFC_PROVISIONING_BOOL
791 = "carrier_volte_override_wfc_provisioning_bool";
792
Jack Yufcbda452018-02-01 14:50:53 -0800793 /**
794 * Override the device's configuration for the cellular data service to use for this SIM card.
795 * @hide
796 */
797 public static final String KEY_CARRIER_DATA_SERVICE_WWAN_PACKAGE_OVERRIDE_STRING
798 = "carrier_data_service_wwan_package_override_string";
799
800 /**
801 * Override the device's configuration for the IWLAN data service to use for this SIM card.
802 * @hide
803 */
804 public static final String KEY_CARRIER_DATA_SERVICE_WLAN_PACKAGE_OVERRIDE_STRING
805 = "carrier_data_service_wlan_package_override_string";
806
Yatai Lin6ed1ada2019-04-09 10:24:15 +0800807 /**
808 * Override the device's configuration for the cellular data service class to use
809 * for this SIM card.
810 * @hide
811 */
812 public static final String KEY_CARRIER_DATA_SERVICE_WWAN_CLASS_OVERRIDE_STRING =
813 "carrier_data_service_wwan_class_override_string";
814
815 /**
816 * Override the device's configuration for the IWLAN data service class to use
817 * for this SIM card.
818 * @hide
819 */
820 public static final String KEY_CARRIER_DATA_SERVICE_WLAN_CLASS_OVERRIDE_STRING =
821 "carrier_data_service_wlan_class_override_string";
822
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700823 /** Flag specifying whether VoLTE TTY is supported. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700824 public static final String KEY_CARRIER_VOLTE_TTY_SUPPORTED_BOOL
825 = "carrier_volte_tty_supported_bool";
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800826
827 /**
Junda Liue5c7ca72015-06-24 14:41:14 -0700828 * Flag specifying whether IMS service can be turned off. If false then the service will not be
829 * turned-off completely, but individual features can be disabled.
830 */
831 public static final String KEY_CARRIER_ALLOW_TURNOFF_IMS_BOOL
832 = "carrier_allow_turnoff_ims_bool";
833
834 /**
Pavel Zhamaitsiakb4faf342015-10-16 16:39:00 -0700835 * Flag specifying whether Generic Bootstrapping Architecture capable SIM is required for IMS.
Pavel Zhamaitsiakb4faf342015-10-16 16:39:00 -0700836 */
837 public static final String KEY_CARRIER_IMS_GBA_REQUIRED_BOOL
838 = "carrier_ims_gba_required_bool";
839
840 /**
Tyler Gunnac2aefc2015-07-31 15:34:46 -0700841 * Flag specifying whether IMS instant lettering is available for the carrier. {@code True} if
842 * instant lettering is available for the carrier, {@code false} otherwise.
Tyler Gunnac2aefc2015-07-31 15:34:46 -0700843 */
844 public static final String KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL =
845 "carrier_instant_lettering_available_bool";
846
Etan Cohencd811f02015-08-18 11:11:29 -0700847 /*
848 * Flag specifying whether IMS should be the first phone attempted for E911 even if the
849 * phone is not in service.
Etan Cohencd811f02015-08-18 11:11:29 -0700850 */
851 public static final String KEY_CARRIER_USE_IMS_FIRST_FOR_EMERGENCY_BOOL
852 = "carrier_use_ims_first_for_emergency_bool";
853
Tyler Gunnac2aefc2015-07-31 15:34:46 -0700854 /**
Tyler Gunneb5fcb92015-09-04 13:16:37 -0700855 * When IMS instant lettering is available for a carrier (see
856 * {@link #KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL}), determines the list of characters
857 * which may not be contained in messages. Should be specified as a regular expression suitable
858 * for use with {@link String#matches(String)}.
Tyler Gunneb5fcb92015-09-04 13:16:37 -0700859 */
860 public static final String KEY_CARRIER_INSTANT_LETTERING_INVALID_CHARS_STRING =
861 "carrier_instant_lettering_invalid_chars_string";
862
863 /**
Tyler Gunn14be4cf2015-09-10 13:33:28 -0700864 * When IMS instant lettering is available for a carrier (see
865 * {@link #KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL}), determines a list of characters which
866 * must be escaped with a backslash '\' character. Should be specified as a string containing
867 * the characters to be escaped. For example to escape quote and backslash the string would be
868 * a quote and a backslash.
Tyler Gunn14be4cf2015-09-10 13:33:28 -0700869 */
870 public static final String KEY_CARRIER_INSTANT_LETTERING_ESCAPED_CHARS_STRING =
871 "carrier_instant_lettering_escaped_chars_string";
872
873 /**
Tyler Gunndb3da5c2015-09-21 22:11:30 -0700874 * When IMS instant lettering is available for a carrier (see
875 * {@link #KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL}), determines the character encoding
876 * which will be used when determining the length of messages. Used in the InCall UI to limit
877 * the number of characters the user may type. If empty-string, the instant lettering
878 * message size limit will be enforced on a 1:1 basis. That is, each character will count
879 * towards the messages size limit as a single bye. If a character encoding is specified, the
880 * message size limit will be based on the number of bytes in the message per the specified
881 * encoding.
Tyler Gunndb3da5c2015-09-21 22:11:30 -0700882 */
883 public static final String KEY_CARRIER_INSTANT_LETTERING_ENCODING_STRING =
884 "carrier_instant_lettering_encoding_string";
885
886 /**
887 * When IMS instant lettering is available for a carrier (see
888 * {@link #KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL}), the length limit for messages. Used
889 * in the InCall UI to ensure the user cannot enter more characters than allowed by the carrier.
890 * See also {@link #KEY_CARRIER_INSTANT_LETTERING_ENCODING_STRING} for more information on how
891 * the length of the message is calculated.
Tyler Gunndb3da5c2015-09-21 22:11:30 -0700892 */
893 public static final String KEY_CARRIER_INSTANT_LETTERING_LENGTH_LIMIT_INT =
894 "carrier_instant_lettering_length_limit_int";
895
896 /**
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800897 * If Voice Radio Technology is RIL_RADIO_TECHNOLOGY_LTE:14 or RIL_RADIO_TECHNOLOGY_UNKNOWN:0
898 * this is the value that should be used instead. A configuration value of
899 * RIL_RADIO_TECHNOLOGY_UNKNOWN:0 means there is no replacement value and that the default
900 * assumption for phone type (GSM) should be used.
901 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700902 public static final String KEY_VOLTE_REPLACEMENT_RAT_INT = "volte_replacement_rat_int";
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800903
Junda Liue4786492015-06-15 13:15:28 -0700904 /**
905 * The default sim call manager to use when the default dialer doesn't implement one. A sim call
906 * manager can control and route outgoing and incoming phone calls, even if they're placed
907 * using another connection service (PSTN, for example).
908 */
909 public static final String KEY_DEFAULT_SIM_CALL_MANAGER_STRING = "default_sim_call_manager_string";
910
Jack Yua4f2da32015-07-22 13:36:42 -0700911 /**
912 * The default flag specifying whether ETWS/CMAS test setting is forcibly disabled in
913 * Settings->More->Emergency broadcasts menu even though developer options is turned on.
Jack Yue4238612020-02-18 17:57:41 -0800914 * @deprecated Use {@code com.android.cellbroadcastreceiver.CellBroadcastReceiver} resource
915 * {@code show_test_settings} to control whether to show test alert settings or not.
Jack Yua4f2da32015-07-22 13:36:42 -0700916 */
Chen Xu77e638b2019-11-15 14:59:22 -0800917 @Deprecated
Jack Yua4f2da32015-07-22 13:36:42 -0700918 public static final String KEY_CARRIER_FORCE_DISABLE_ETWS_CMAS_TEST_BOOL =
919 "carrier_force_disable_etws_cmas_test_bool";
920
Jack Yu6af6c342015-09-14 16:18:59 -0700921 /**
Jack Yubcbe4682020-01-10 17:24:58 -0800922 * The default flag specifying whether "Allow alerts" option will be always shown in
923 * emergency alerts settings regardless developer options is turned on or not.
924 *
925 * @deprecated The allow alerts option is always shown now. No longer need a config for that.
Jack Yu6af6c342015-09-14 16:18:59 -0700926 */
Jack Yubcbe4682020-01-10 17:24:58 -0800927 @Deprecated
Jack Yu6af6c342015-09-14 16:18:59 -0700928 public static final String KEY_ALWAYS_SHOW_EMERGENCY_ALERT_ONOFF_BOOL =
929 "always_show_emergency_alert_onoff_bool";
930
Jack Yu090dd722015-12-18 15:16:24 -0800931 /**
Jack Yuc1f0e872016-09-10 00:41:17 -0700932 * The data call retry configuration for different types of APN.
Jack Yu090dd722015-12-18 15:16:24 -0800933 * @hide
934 */
Jack Yuc1f0e872016-09-10 00:41:17 -0700935 public static final String KEY_CARRIER_DATA_CALL_RETRY_CONFIG_STRINGS =
936 "carrier_data_call_retry_config_strings";
Jack Yu090dd722015-12-18 15:16:24 -0800937
938 /**
Jack Yu5523dc52017-08-16 14:26:56 -0700939 * Delay in milliseconds between trying APN from the pool
Jack Yu090dd722015-12-18 15:16:24 -0800940 * @hide
941 */
942 public static final String KEY_CARRIER_DATA_CALL_APN_DELAY_DEFAULT_LONG =
943 "carrier_data_call_apn_delay_default_long";
944
945 /**
Jack Yu5523dc52017-08-16 14:26:56 -0700946 * Faster delay in milliseconds between trying APN from the pool
Jack Yu090dd722015-12-18 15:16:24 -0800947 * @hide
948 */
949 public static final String KEY_CARRIER_DATA_CALL_APN_DELAY_FASTER_LONG =
950 "carrier_data_call_apn_delay_faster_long";
951
Jack Yu66a6be32016-03-30 11:14:39 -0700952 /**
Jack Yu5523dc52017-08-16 14:26:56 -0700953 * Delay in milliseconds for retrying APN after disconnect
954 * @hide
955 */
956 public static final String KEY_CARRIER_DATA_CALL_APN_RETRY_AFTER_DISCONNECT_LONG =
957 "carrier_data_call_apn_retry_after_disconnect_long";
958
959 /**
Jack Yu8a81a212016-06-15 14:26:59 -0700960 * Data call setup permanent failure causes by the carrier
961 */
962 public static final String KEY_CARRIER_DATA_CALL_PERMANENT_FAILURE_STRINGS =
963 "carrier_data_call_permanent_failure_strings";
964
965 /**
Jack Yu66a6be32016-03-30 11:14:39 -0700966 * Default APN types that are metered by the carrier
967 * @hide
968 */
969 public static final String KEY_CARRIER_METERED_APN_TYPES_STRINGS =
970 "carrier_metered_apn_types_strings";
fionaxu28ffb602016-04-17 23:56:42 -0700971 /**
Jack Yu7dc56ee2017-05-20 17:06:33 -0700972 * Default APN types that are roaming-metered by the carrier
fionaxu28ffb602016-04-17 23:56:42 -0700973 * @hide
974 */
975 public static final String KEY_CARRIER_METERED_ROAMING_APN_TYPES_STRINGS =
976 "carrier_metered_roaming_apn_types_strings";
Jack Yu7dc56ee2017-05-20 17:06:33 -0700977
978 /**
Jack Yuac9a7312019-06-28 16:42:37 -0700979 * APN types that are not allowed on cellular
980 * @hide
981 */
982 public static final String KEY_CARRIER_WWAN_DISALLOWED_APN_TYPES_STRING_ARRAY =
983 "carrier_wwan_disallowed_apn_types_string_array";
984
985 /**
986 * APN types that are not allowed on IWLAN
987 * @hide
988 */
989 public static final String KEY_CARRIER_WLAN_DISALLOWED_APN_TYPES_STRING_ARRAY =
990 "carrier_wlan_disallowed_apn_types_string_array";
991 /**
Jack Yu360dc212016-04-08 17:11:25 -0700992 * CDMA carrier ERI (Enhanced Roaming Indicator) file name
993 * @hide
994 */
995 public static final String KEY_CARRIER_ERI_FILE_NAME_STRING =
996 "carrier_eri_file_name_string";
997
Nancy Chen5c86e922015-04-09 13:17:20 -0700998 /* The following 3 fields are related to carrier visual voicemail. */
999
1000 /**
Jonathan Basseri6c1dc312015-06-18 16:05:39 -07001001 * The carrier number mobile outgoing (MO) sms messages are sent to.
Nancy Chen5c86e922015-04-09 13:17:20 -07001002 */
Jonathan Basseri69822f02015-06-04 13:48:08 -07001003 public static final String KEY_VVM_DESTINATION_NUMBER_STRING = "vvm_destination_number_string";
Nancy Chen5c86e922015-04-09 13:17:20 -07001004
1005 /**
Jonathan Basseri6c1dc312015-06-18 16:05:39 -07001006 * The port through which the mobile outgoing (MO) sms messages are sent through.
Nancy Chen5c86e922015-04-09 13:17:20 -07001007 */
Jonathan Basseri69822f02015-06-04 13:48:08 -07001008 public static final String KEY_VVM_PORT_NUMBER_INT = "vvm_port_number_int";
Nancy Chen5c86e922015-04-09 13:17:20 -07001009
1010 /**
Nancy Chencb43f422015-05-27 15:06:58 -07001011 * The type of visual voicemail protocol the carrier adheres to. See {@link TelephonyManager}
1012 * for possible values. For example {@link TelephonyManager#VVM_TYPE_OMTP}.
Nancy Chen5c86e922015-04-09 13:17:20 -07001013 */
Jonathan Basseri69822f02015-06-04 13:48:08 -07001014 public static final String KEY_VVM_TYPE_STRING = "vvm_type_string";
Nancy Chen5c86e922015-04-09 13:17:20 -07001015
Nancy Chen97f5ccd2015-06-04 12:00:25 -07001016 /**
Ta-wei Yen685f53c2015-11-30 18:00:08 -08001017 * Whether cellular data is required to access visual voicemail.
1018 */
Ta-wei Yen153fcd72016-05-17 15:57:20 -07001019 public static final String KEY_VVM_CELLULAR_DATA_REQUIRED_BOOL =
1020 "vvm_cellular_data_required_bool";
Ta-wei Yen685f53c2015-11-30 18:00:08 -08001021
1022 /**
Ta-wei Yenb618d0f2017-01-17 13:52:10 -08001023 * The default OMTP visual voicemail client prefix to use. Defaulted to "//VVM"
1024 */
1025 public static final String KEY_VVM_CLIENT_PREFIX_STRING =
1026 "vvm_client_prefix_string";
1027
1028 /**
1029 * Whether to use SSL to connect to the visual voicemail IMAP server. Defaulted to false.
1030 */
1031 public static final String KEY_VVM_SSL_ENABLED_BOOL = "vvm_ssl_enabled_bool";
1032
1033 /**
1034 * A set of capabilities that should not be used even if it is reported by the visual voicemail
1035 * IMAP CAPABILITY command.
1036 */
1037 public static final String KEY_VVM_DISABLED_CAPABILITIES_STRING_ARRAY =
1038 "vvm_disabled_capabilities_string_array";
1039
1040 /**
1041 * Whether legacy mode should be used when the visual voicemail client is disabled.
1042 *
1043 * <p>Legacy mode is a mode that on the carrier side visual voicemail is still activated, but on
1044 * the client side all network operations are disabled. SMSs are still monitored so a new
1045 * message SYNC SMS will be translated to show a message waiting indicator, like traditional
1046 * voicemails.
1047 *
1048 * <p>This is for carriers that does not support VVM deactivation so voicemail can continue to
1049 * function without the data cost.
1050 */
1051 public static final String KEY_VVM_LEGACY_MODE_ENABLED_BOOL =
1052 "vvm_legacy_mode_enabled_bool";
1053
1054 /**
Ta-wei Yen76193dc2016-01-25 19:04:36 -08001055 * Whether to prefetch audio data on new voicemail arrival, defaulted to true.
1056 */
Ta-wei Yen153fcd72016-05-17 15:57:20 -07001057 public static final String KEY_VVM_PREFETCH_BOOL = "vvm_prefetch_bool";
Ta-wei Yen76193dc2016-01-25 19:04:36 -08001058
1059 /**
Nancy Chen97f5ccd2015-06-04 12:00:25 -07001060 * The package name of the carrier's visual voicemail app to ensure that dialer visual voicemail
1061 * and carrier visual voicemail are not active at the same time.
Ta-wei Yenb618d0f2017-01-17 13:52:10 -08001062 *
1063 * @deprecated use {@link #KEY_CARRIER_VVM_PACKAGE_NAME_STRING_ARRAY}.
Nancy Chen97f5ccd2015-06-04 12:00:25 -07001064 */
Ta-wei Yenb618d0f2017-01-17 13:52:10 -08001065 @Deprecated
Jonathan Basseri69822f02015-06-04 13:48:08 -07001066 public static final String KEY_CARRIER_VVM_PACKAGE_NAME_STRING = "carrier_vvm_package_name_string";
Nancy Chen97f5ccd2015-06-04 12:00:25 -07001067
Amit Mahajan02008b72015-06-11 14:54:20 -07001068 /**
Ta-wei Yenb618d0f2017-01-17 13:52:10 -08001069 * A list of the carrier's visual voicemail app package names to ensure that dialer visual
1070 * voicemail and carrier visual voicemail are not active at the same time.
1071 */
1072 public static final String KEY_CARRIER_VVM_PACKAGE_NAME_STRING_ARRAY =
1073 "carrier_vvm_package_name_string_array";
1074
1075 /**
Meng Wang6b2995a2016-03-14 10:08:41 -07001076 * Flag specifying whether ICCID is showed in SIM Status screen, default to false.
1077 */
1078 public static final String KEY_SHOW_ICCID_IN_SIM_STATUS_BOOL = "show_iccid_in_sim_status_bool";
1079
1080 /**
Jordan Liua59a5eb2017-12-11 16:23:25 -08001081 * Flag specifying whether the {@link android.telephony.SignalStrength} is shown in the SIM
1082 * Status screen. The default value is true.
Patrik Bannura9124ec52017-11-24 12:39:50 +01001083 */
Jordan Liua59a5eb2017-12-11 16:23:25 -08001084 public static final String KEY_SHOW_SIGNAL_STRENGTH_IN_SIM_STATUS_BOOL =
1085 "show_signal_strength_in_sim_status_bool";
Patrik Bannura9124ec52017-11-24 12:39:50 +01001086
1087 /**
Amit Mahajan02008b72015-06-11 14:54:20 -07001088 * Flag specifying whether an additional (client initiated) intent needs to be sent on System
1089 * update
Amit Mahajan02008b72015-06-11 14:54:20 -07001090 */
1091 public static final String KEY_CI_ACTION_ON_SYS_UPDATE_BOOL = "ci_action_on_sys_update_bool";
1092
1093 /**
1094 * Intent to be sent for the additional action on System update
Amit Mahajan02008b72015-06-11 14:54:20 -07001095 */
1096 public static final String KEY_CI_ACTION_ON_SYS_UPDATE_INTENT_STRING =
1097 "ci_action_on_sys_update_intent_string";
1098
1099 /**
1100 * Extra to be included in the intent sent for additional action on System update
Amit Mahajan02008b72015-06-11 14:54:20 -07001101 */
1102 public static final String KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_STRING =
1103 "ci_action_on_sys_update_extra_string";
1104
1105 /**
1106 * Value of extra included in intent sent for additional action on System update
Amit Mahajan02008b72015-06-11 14:54:20 -07001107 */
1108 public static final String KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_VAL_STRING =
1109 "ci_action_on_sys_update_extra_val_string";
1110
Jonathan Basseri019523a2015-06-19 11:07:22 -07001111 /**
Roshan Piusa52c5e22015-08-14 12:58:08 -07001112 * Specifies the amount of gap to be added in millis between postdial DTMF tones. When a
1113 * non-zero value is specified, the UE shall wait for the specified amount of time before it
1114 * sends out successive DTMF tones on the network.
Roshan Pius9f81ce72015-08-12 12:01:42 -07001115 */
Roshan Piusdc364fe2015-09-10 10:28:06 -07001116 public static final String KEY_GSM_DTMF_TONE_DELAY_INT = "gsm_dtmf_tone_delay_int";
1117
1118 /**
1119 * Specifies the amount of gap to be added in millis between DTMF tones. When a non-zero value
1120 * is specified, the UE shall wait for the specified amount of time before it sends out
1121 * successive DTMF tones on the network.
Roshan Piusdc364fe2015-09-10 10:28:06 -07001122 */
Roshan Pius9f81ce72015-08-12 12:01:42 -07001123 public static final String KEY_IMS_DTMF_TONE_DELAY_INT = "ims_dtmf_tone_delay_int";
1124
1125 /**
Roshan Piusa52c5e22015-08-14 12:58:08 -07001126 * Specifies the amount of gap to be added in millis between postdial DTMF tones. When a
1127 * non-zero value is specified, the UE shall wait for the specified amount of time before it
1128 * sends out successive DTMF tones on the network.
Roshan Piusa52c5e22015-08-14 12:58:08 -07001129 */
1130 public static final String KEY_CDMA_DTMF_TONE_DELAY_INT = "cdma_dtmf_tone_delay_int";
1131
1132 /**
Brad Ebinger110856432017-10-12 13:58:55 -07001133 * Some carriers will send call forwarding responses for voicemail in a format that is not 3gpp
1134 * compliant, which causes issues during parsing. This causes the
1135 * {@link com.android.internal.telephony.CallForwardInfo#number} to contain non-numerical
1136 * characters instead of a number.
1137 *
1138 * If true, we will detect the non-numerical characters and replace them with "Voicemail".
1139 * @hide
1140 */
1141 public static final String KEY_CALL_FORWARDING_MAP_NON_NUMBER_TO_VOICEMAIL_BOOL =
1142 "call_forwarding_map_non_number_to_voicemail_bool";
1143
1144 /**
Hall Liu788d01b2019-07-23 18:39:15 -07001145 * When {@code true}, the phone will always tell the IMS stack to keep RTT enabled and
1146 * determine on a per-call basis (based on extras from the dialer app) whether a call should be
1147 * an RTT call or not.
1148 *
1149 * When {@code false}, the old behavior is used, where the toggle in accessibility settings is
1150 * used to set the IMS stack's RTT enabled state.
Hall Liu788d01b2019-07-23 18:39:15 -07001151 */
1152 public static final String KEY_IGNORE_RTT_MODE_SETTING_BOOL =
1153 "ignore_rtt_mode_setting_bool";
1154
Ravi Paluri80aa2142019-12-02 11:57:37 +05301155
1156 /**
1157 * Determines whether adhoc conference calls are supported by a carrier. When {@code true},
1158 * adhoc conference calling is supported, {@code false otherwise}.
Tyler Gunna967af52020-02-10 15:19:07 -08001159 * @hide
Ravi Paluri80aa2142019-12-02 11:57:37 +05301160 */
1161 public static final String KEY_SUPPORT_ADHOC_CONFERENCE_CALLS_BOOL =
1162 "support_adhoc_conference_calls_bool";
1163
Hall Liu788d01b2019-07-23 18:39:15 -07001164 /**
Ravi Paluri404babb2020-01-23 19:02:44 +05301165 * Determines whether conference participants can be added to existing call. When {@code true},
1166 * adding conference participants to existing call is supported, {@code false otherwise}.
Tyler Gunn0c62ef02020-02-11 14:39:43 -08001167 * @hide
Ravi Paluri404babb2020-01-23 19:02:44 +05301168 */
1169 public static final String KEY_SUPPORT_ADD_CONFERENCE_PARTICIPANTS_BOOL =
1170 "support_add_conference_participants_bool";
1171
1172 /**
Sungmin Choi8c651ae2015-08-14 15:55:13 -07001173 * Determines whether conference calls are supported by a carrier. When {@code true},
1174 * conference calling is supported, {@code false otherwise}.
Sungmin Choi8c651ae2015-08-14 15:55:13 -07001175 */
1176 public static final String KEY_SUPPORT_CONFERENCE_CALL_BOOL = "support_conference_call_bool";
1177
1178 /**
Tyler Gunnec5b6e32016-12-01 19:40:30 -08001179 * Determines whether a maximum size limit for IMS conference calls is enforced on the device.
1180 * When {@code true}, IMS conference calls will be limited to at most
1181 * {@link #KEY_IMS_CONFERENCE_SIZE_LIMIT_INT} participants. When {@code false}, no attempt is made
1182 * to limit the number of participants in a conference (the carrier will raise an error when an
1183 * attempt is made to merge too many participants into a conference).
1184 */
1185 public static final String KEY_IS_IMS_CONFERENCE_SIZE_ENFORCED_BOOL =
1186 "is_ims_conference_size_enforced_bool";
1187
1188 /**
1189 * Determines the maximum number of participants the carrier supports for a conference call.
1190 * This number is exclusive of the current device. A conference between 3 devices, for example,
1191 * would have a size limit of 2 participants.
1192 * Enforced when {@link #KEY_IS_IMS_CONFERENCE_SIZE_ENFORCED_BOOL} is {@code true}.
1193 */
1194 public static final String KEY_IMS_CONFERENCE_SIZE_LIMIT_INT = "ims_conference_size_limit_int";
1195
1196 /**
Wei Huang594039c2016-04-22 14:33:55 +08001197 * Determines whether manage IMS conference calls is supported by a carrier. When {@code true},
1198 * manage IMS conference call is supported, {@code false otherwise}.
1199 * @hide
1200 */
1201 public static final String KEY_SUPPORT_MANAGE_IMS_CONFERENCE_CALL_BOOL =
1202 "support_manage_ims_conference_call_bool";
1203
1204 /**
Youming Yed5472f72019-05-21 13:10:48 -07001205 * Determines whether the IMS conference merge process supports and returns its participants
1206 * data. When {@code true}, on merge complete, conference call would have a list of its
1207 * participants returned in XML format, {@code false otherwise}.
Youming Yed5472f72019-05-21 13:10:48 -07001208 */
1209 public static final String KEY_SUPPORT_IMS_CONFERENCE_EVENT_PACKAGE_BOOL =
1210 "support_ims_conference_event_package_bool";
1211
1212 /**
Tyler Gunn60e5f7c2020-04-06 15:07:48 -07001213 * Determines whether processing of conference event package data received on a device other
1214 * than the conference host is supported.
1215 * <p>
1216 * When a device A merges calls B and C into a conference it is considered the conference host
1217 * and B and C are considered the conference peers.
1218 * <p>
1219 * When {@code true}, the conference peer will display the conference state if it receives
1220 * conference event package data from the network. When {@code false}, the conference peer will
1221 * ignore conference event package data received from the network.
1222 * @hide
1223 */
1224 public static final String KEY_SUPPORT_IMS_CONFERENCE_EVENT_PACKAGE_ON_PEER_BOOL =
1225 "support_ims_conference_event_package_on_peer_bool";
1226
1227 /**
Wei Huang237d7752016-03-01 17:02:40 +08001228 * Determines whether High Definition audio property is displayed in the dialer UI.
1229 * If {@code false}, remove the HD audio property from the connection so that HD audio related
1230 * UI is not displayed. If {@code true}, keep HD audio property as it is configured.
Wei Huang237d7752016-03-01 17:02:40 +08001231 */
1232 public static final String KEY_DISPLAY_HD_AUDIO_PROPERTY_BOOL =
1233 "display_hd_audio_property_bool";
1234
1235 /**
Wei Huanga8ad1522016-03-01 15:25:04 +08001236 * Determines whether IMS conference calls are supported by a carrier. When {@code true},
1237 * IMS conference calling is supported, {@code false} otherwise.
1238 * @hide
1239 */
1240 public static final String KEY_SUPPORT_IMS_CONFERENCE_CALL_BOOL =
1241 "support_ims_conference_call_bool";
1242
1243 /**
Tyler Gunn4eb18912020-04-07 19:01:15 -07001244 * Determines whether the device will locally disconnect an IMS conference when the participant
1245 * count drops to zero. When {@code true}, it is assumed the carrier does NOT disconnect a
1246 * conference when the participant count drops to zero and that the device must do this by
1247 * disconnecting the conference locally. When {@code false}, it is assumed that the carrier
1248 * is responsible for disconnecting the conference when there are no longer any participants
1249 * present.
1250 * <p>
1251 * Note: both {@link #KEY_SUPPORT_IMS_CONFERENCE_CALL_BOOL} and
1252 * {@link #KEY_SUPPORT_IMS_CONFERENCE_EVENT_PACKAGE_BOOL} must be true for this configuration to
1253 * have any effect.
1254 * <p>
1255 * Defaults to {@code false}, meaning the carrier network is responsible for disconnecting an
1256 * empty IMS conference.
1257 * @hide
1258 */
1259 public static final String KEY_LOCAL_DISCONNECT_EMPTY_IMS_CONFERENCE_BOOL =
1260 "local_disconnect_empty_ims_conference_bool";
1261
1262 /**
Tyler Gunnee61c622016-04-19 16:17:19 -07001263 * Determines whether video conference calls are supported by a carrier. When {@code true},
1264 * video calls can be merged into conference calls, {@code false} otherwiwse.
1265 * <p>
1266 * Note: even if video conference calls are not supported, audio calls may be merged into a
1267 * conference if {@link #KEY_SUPPORT_CONFERENCE_CALL_BOOL} is {@code true}.
1268 * @hide
1269 */
1270 public static final String KEY_SUPPORT_VIDEO_CONFERENCE_CALL_BOOL =
1271 "support_video_conference_call_bool";
1272
1273 /**
Sungmin Choi8d2826b2015-08-25 23:30:34 -07001274 * Determine whether user can toggle Enhanced 4G LTE Mode in Settings.
Sungmin Choi8d2826b2015-08-25 23:30:34 -07001275 */
1276 public static final String KEY_EDITABLE_ENHANCED_4G_LTE_BOOL = "editable_enhanced_4g_lte_bool";
1277
1278 /**
yinxu34016ae2017-03-14 15:36:17 -07001279 * Determines whether the Enhanced 4G LTE toggle will be shown in the settings. When this
1280 * option is {@code true}, the toggle will be hidden regardless of whether the device and
1281 * carrier supports 4G LTE or not.
1282 */
1283 public static final String KEY_HIDE_ENHANCED_4G_LTE_BOOL = "hide_enhanced_4g_lte_bool";
1284
1285 /**
Brad Ebingerfd880802018-11-08 17:41:54 -08001286 * Sets the default state for the "Enhanced 4G LTE" or "Advanced Calling" mode toggle set by the
1287 * user. When this is {@code true}, this mode by default is on, otherwise if {@code false},
1288 * this mode by default is off.
manabu, shimoda14723e32017-10-06 14:39:01 +09001289 */
1290 public static final String KEY_ENHANCED_4G_LTE_ON_BY_DEFAULT_BOOL =
1291 "enhanced_4g_lte_on_by_default_bool";
1292
1293 /**
Sungmin Choie9d3c112015-08-31 15:32:20 -07001294 * Determine whether IMS apn can be shown.
Sungmin Choie9d3c112015-08-31 15:32:20 -07001295 */
1296 public static final String KEY_HIDE_IMS_APN_BOOL = "hide_ims_apn_bool";
1297
1298 /**
Sungmin Choic03a1da2015-09-08 15:34:23 -07001299 * Determine whether preferred network type can be shown.
Sungmin Choic03a1da2015-09-08 15:34:23 -07001300 */
1301 public static final String KEY_HIDE_PREFERRED_NETWORK_TYPE_BOOL = "hide_preferred_network_type_bool";
1302
1303 /**
Junda Liu85313282017-03-28 13:58:51 -07001304 * String array for package names that need to be enabled for this carrier.
1305 * If user has explicitly disabled some packages in the list, won't re-enable.
1306 * Other carrier specific apps which are not in this list may be disabled for current carrier,
1307 * and only be re-enabled when this config for another carrier includes it.
Meng Wangd5e1af52018-03-23 16:25:03 -07001308 *
1309 * @hide
Junda Liu85313282017-03-28 13:58:51 -07001310 */
1311 public static final String KEY_ENABLE_APPS_STRING_ARRAY = "enable_apps_string_array";
1312
1313 /**
Sarah China912e112020-01-09 10:43:30 -08001314 * Determine whether user can switch Wi-Fi preferred or Cellular preferred
1315 * in calling preference.
Sungmin Choid3b28262015-12-23 14:10:41 +09001316 * Some operators support Wi-Fi Calling only, not VoLTE.
1317 * They don't need "Cellular preferred" option.
Sarah China912e112020-01-09 10:43:30 -08001318 * In this case, set uneditable attribute for preferred preference.
Sungmin Choid3b28262015-12-23 14:10:41 +09001319 */
1320 public static final String KEY_EDITABLE_WFC_MODE_BOOL = "editable_wfc_mode_bool";
1321
Sarah China912e112020-01-09 10:43:30 -08001322 /**
1323 * Flag to indicate if Wi-Fi needs to be disabled in ECBM.
1324 */
1325 public static final String KEY_CONFIG_WIFI_DISABLE_IN_ECBM = "config_wifi_disable_in_ecbm";
Sunil Dutt7c5fda82016-04-05 22:08:57 +05301326
Sungmin Choid3b28262015-12-23 14:10:41 +09001327 /**
Pavel Zhamaitsiak7b7c4fc2016-04-12 14:24:07 -07001328 * List operator-specific error codes and indices of corresponding error strings in
1329 * wfcOperatorErrorAlertMessages and wfcOperatorErrorNotificationMessages.
1330 *
1331 * Example: "REG09|0" specifies error code "REG09" and index "0". This index will be
1332 * used to find alert and notification messages in wfcOperatorErrorAlertMessages and
1333 * wfcOperatorErrorNotificationMessages.
1334 *
1335 * @hide
1336 */
1337 public static final String KEY_WFC_OPERATOR_ERROR_CODES_STRING_ARRAY =
1338 "wfc_operator_error_codes_string_array";
1339
1340 /**
Torbjorn Eklunda765a472018-09-24 17:45:23 +02001341 * Indexes of SPN format strings in wfcSpnFormats.
Torbjorn Eklund57684832018-08-21 16:12:42 +02001342 *
1343 * <p>Available options are:
1344 * <ul>
Torbjorn Eklunda765a472018-09-24 17:45:23 +02001345 * <li> 0: %s</li>
1346 * <li> 1: %s Wi-Fi Calling</li>
1347 * <li> 2: WLAN Call</li>
1348 * <li> 3: %s WLAN Call</li>
1349 * <li> 4: %s Wi-Fi</li>
1350 * <li> 5: WiFi Calling | %s</li>
1351 * <li> 6: %s VoWifi</li>
1352 * <li> 7: Wi-Fi Calling</li>
1353 * <li> 8: Wi-Fi</li>
1354 * <li> 9: WiFi Calling</li>
1355 * <li> 10: VoWifi</li>
Pengquan Meng7f47da02019-05-29 14:56:25 -07001356 * <li> 11: %s WiFi Calling</li>
Pavel Zhamaitsiak7b7c4fc2016-04-12 14:24:07 -07001357 * @hide
1358 */
1359 public static final String KEY_WFC_SPN_FORMAT_IDX_INT = "wfc_spn_format_idx_int";
Torbjorn Eklunda765a472018-09-24 17:45:23 +02001360
1361 /**
1362 * Indexes of data SPN format strings in wfcSpnFormats.
1363 *
1364 * @see KEY_WFC_SPN_FORMAT_IDX_INT for available options.
1365 * @hide
1366 */
Pavel Zhamaitsiak7b7c4fc2016-04-12 14:24:07 -07001367 public static final String KEY_WFC_DATA_SPN_FORMAT_IDX_INT = "wfc_data_spn_format_idx_int";
1368
1369 /**
Torbjorn Eklunda765a472018-09-24 17:45:23 +02001370 * Indexes of SPN format strings in wfcSpnFormats used during flight mode.
1371 *
1372 * Set to -1 to use the value from KEY_WFC_SPN_FORMAT_IDX_INT also in this case.
1373 * @see KEY_WFC_SPN_FORMAT_IDX_INT for other available options.
1374 * @hide
1375 */
1376 public static final String KEY_WFC_FLIGHT_MODE_SPN_FORMAT_IDX_INT =
1377 "wfc_flight_mode_spn_format_idx_int";
1378
1379 /**
Torbjorn Eklund99c11d82018-08-21 16:06:47 +02001380 * Use root locale when reading wfcSpnFormats.
1381 *
1382 * If true, then the root locale will always be used when reading wfcSpnFormats. This means the
1383 * non localized version of wfcSpnFormats will be used.
1384 * @hide
1385 */
1386 public static final String KEY_WFC_SPN_USE_ROOT_LOCALE = "wfc_spn_use_root_locale";
1387
1388 /**
Sarah China912e112020-01-09 10:43:30 -08001389 * The Component Name of the activity that can setup the emergency address for WiFi Calling
Vineeta Srivastavac7d7ab72016-05-14 11:05:28 -07001390 * as per carrier requirement.
Vineeta Srivastavac7d7ab72016-05-14 11:05:28 -07001391 */
1392 public static final String KEY_WFC_EMERGENCY_ADDRESS_CARRIER_APP_STRING =
1393 "wfc_emergency_address_carrier_app_string";
1394
1395 /**
Nathan Harold8366bcb2018-02-28 14:57:54 -08001396 * Unconditionally override the carrier name string using #KEY_CARRIER_NAME_STRING.
1397 *
Nathan Harold178020a2018-04-06 11:27:40 -07001398 * If true, then the carrier name string will be #KEY_CARRIER_NAME_STRING, unconditionally.
Nathan Harold8366bcb2018-02-28 14:57:54 -08001399 *
1400 * <p>If false, then the override will be performed conditionally and the
1401 * #KEY_CARRIER_NAME_STRING will have the lowest-precedence; it will only be used in the event
Nathan Harold178020a2018-04-06 11:27:40 -07001402 * that the name string would otherwise be empty, allowing it to serve as a last-resort. If
1403 * used, this value functions in place of the SPN on any/all ICC records for the corresponding
1404 * subscription.
Sanket Padawe49b20422016-06-01 12:17:23 -07001405 */
1406 public static final String KEY_CARRIER_NAME_OVERRIDE_BOOL = "carrier_name_override_bool";
1407
1408 /**
Nathan Haroldbaaa68d2018-01-15 10:48:00 -08001409 * String to identify carrier name in CarrierConfig app. This string overrides SPN if
1410 * #KEY_CARRIER_NAME_OVERRIDE_BOOL is true; otherwise, it will be used if its value is provided
1411 * and SPN is unavailable
Sanket Padawe49b20422016-06-01 12:17:23 -07001412 */
1413 public static final String KEY_CARRIER_NAME_STRING = "carrier_name_string";
1414
chen xu6b736ee2018-12-02 14:14:15 -08001415 /**
SongFerngWangd1b16442020-06-16 18:39:35 +08001416 * To override wifi calling's carrier name string using ef_pnn from sim card when SPN in empty.
1417 *
1418 * @hide
1419 */
1420 public static final String KEY_WFC_CARRIER_NAME_OVERRIDE_BY_PNN_BOOL =
1421 "wfc_carrier_name_override_by_pnn_bool";
1422
1423 /**
Pengquan Meng057b94f2019-04-17 19:36:58 -07001424 * Override the SPN Display Condition 2 integer bits (lsb). B2, B1 is the last two bits of the
1425 * spn display condition coding.
1426 *
Pengquan Mengb4a53fd2019-04-23 13:55:02 -07001427 * The default value -1 mean this field is not set.
Pengquan Meng057b94f2019-04-17 19:36:58 -07001428 *
1429 * B1 = 0: display of registered PLMN name not required when registered PLMN is either HPLMN
1430 * or a PLMN in the service provider PLMN list (see EF_SPDI).
1431 * B1 = 1: display of registered PLMN name required when registered PLMN is either HPLMN or a
1432 * PLMN in the service provider PLMN list(see EF_SPDI).
1433 * B2 = 0: display of the service provider name is required when registered PLMN is neither
1434 * HPLMN nor a PLMN in the service provider PLMN list(see EF_SPDI).
1435 * B2 = 1: display of the service provider name is not required when registered PLMN is neither
1436 * HPLMN nor a PLMN in the service provider PLMN list(see EF_SPDI).
1437 *
1438 * Reference: 3GPP TS 31.102 v15.2.0 Section 4.2.12 EF_SPN.
1439 * @hide
1440 */
1441 public static final String KEY_SPN_DISPLAY_CONDITION_OVERRIDE_INT =
1442 "spn_display_condition_override_int";
1443
1444 /**
1445 * Override the SPDI - an array of PLMN(MCC + MNC) strings.
1446 *
1447 * Reference: 3GPP TS 31.102 v15.2.0 Section 4.2.66 EF_SPDI.
1448 * @hide
1449 */
1450 public static final String KEY_SPDI_OVERRIDE_STRING_ARRAY = "spdi_override_string_array";
1451
1452 /**
1453 * Override the EHPLMNs - an array of PLMN(MCC + MNC) strings.
1454 *
1455 * To allow provision for multiple HPLMN codes, PLMN codes that are present within this list
1456 * shall replace the HPLMN code derived from the IMSI for PLMN selection purposes.
1457 *
1458 * Reference: 3GPP TS 31.102 v15.2.0 Section 4.2.84 EF_EHPLMN
1459 * Reference: 3GPP TS 23.122 v15.6.0 Section 1.2 Equivalent HPLMN list
1460 * @hide
1461 */
1462 public static final String KEY_EHPLMN_OVERRIDE_STRING_ARRAY = "ehplmn_override_string_array";
1463
1464 /**
1465 * Override the PNN - a string array of comma-separated alpha long and short names:
Pengquan Mengb4a53fd2019-04-23 13:55:02 -07001466 * "alpha_long1,alpha_short1".
Pengquan Meng057b94f2019-04-17 19:36:58 -07001467 *
1468 * Reference: 3GPP TS 31.102 v15.2.0 Section 4.2.58 EF_PNN.
1469 * @hide
1470 */
1471 public static final String KEY_PNN_OVERRIDE_STRING_ARRAY = "pnn_override_string_array";
1472
1473 /**
1474 * A string array of OPL records, each with comma-delimited data fields as follows:
1475 * "plmn1,lactac_start,lactac_end,index".
1476 *
1477 * Reference: 3GPP TS 31.102 v15.2.0 Section 4.2.59 EF_OPL.
1478 * @hide
1479 */
1480 public static final String KEY_OPL_OVERRIDE_STRING_ARRAY = "opl_override_opl_string_array";
1481
1482 /**
1483 * Allow ERI rules to select a carrier name display string when using 3gpp2 access technologies.
Pengquan Mengb4a53fd2019-04-23 13:55:02 -07001484 * If this bit is not set, the carrier name display string will be selected from the carrier
1485 * display name resolver which doesn't apply the ERI rules.
Pengquan Meng057b94f2019-04-17 19:36:58 -07001486 *
1487 * @hide
1488 */
1489 public static final String KEY_ALLOW_ERI_BOOL = "allow_cdma_eri_bool";
1490
1491 /**
1492 * If true, use the carrier display name(SPN and PLMN) from the carrier display name resolver.
1493 *
1494 * @hide
1495 */
1496 public static final String KEY_ENABLE_CARRIER_DISPLAY_NAME_RESOLVER_BOOL =
1497 "enable_carrier_display_name_resolver_bool";
1498
1499 /**
chen xu6b736ee2018-12-02 14:14:15 -08001500 * String to override sim country iso.
1501 * Sim country iso is based on sim MCC which is coarse and doesn't work with dual IMSI SIM where
1502 * a SIM can have multiple MCC from different countries.
1503 * Instead, each sim carrier should have a single country code, apply per carrier based iso
1504 * code as an override. The overridden value can be read from
1505 * {@link TelephonyManager#getSimCountryIso()} and {@link SubscriptionInfo#getCountryIso()}
1506 *
1507 * @hide
1508 */
1509 public static final String KEY_SIM_COUNTRY_ISO_OVERRIDE_STRING =
1510 "sim_country_iso_override_string";
1511
1512 /**
1513 * The Component Name of a carrier-provided CallScreeningService implementation. Telecom will
1514 * bind to {@link android.telecom.CallScreeningService} for ALL incoming calls and provide
1515 * the carrier
1516 * CallScreeningService with the opportunity to allow or block calls.
1517 * <p>
1518 * The String includes the package name/the class name.
1519 * Example:
1520 * <item>com.android.carrier/com.android.carrier.callscreeningserviceimpl</item>
1521 * <p>
1522 * Using {@link ComponentName#flattenToString()} to convert a ComponentName object to String.
1523 * Using {@link ComponentName#unflattenFromString(String)} to convert a String object to a
1524 * ComponentName.
1525 */
tonyzhucd0a63d2018-10-11 14:31:26 +08001526 public static final String KEY_CARRIER_CALL_SCREENING_APP_STRING = "call_screening_app";
1527
1528 /**
Amit Mahajan22e89f42018-06-05 16:27:32 -07001529 * Override the registered PLMN name using #KEY_CDMA_HOME_REGISTERED_PLMN_NAME_STRING.
1530 *
1531 * If true, then the registered PLMN name (only for CDMA/CDMA-LTE and only when not roaming)
1532 * will be #KEY_CDMA_HOME_REGISTERED_PLMN_NAME_STRING. If false, or if phone type is not
1533 * CDMA/CDMA-LTE or if roaming, then #KEY_CDMA_HOME_REGISTERED_PLMN_NAME_STRING will be ignored.
1534 * @hide
1535 */
1536 public static final String KEY_CDMA_HOME_REGISTERED_PLMN_NAME_OVERRIDE_BOOL =
1537 "cdma_home_registered_plmn_name_override_bool";
1538
1539 /**
1540 * String to identify registered PLMN name in CarrierConfig app. This string overrides
1541 * registered PLMN name if #KEY_CDMA_HOME_REGISTERED_PLMN_NAME_OVERRIDE_BOOL is true, phone type
1542 * is CDMA/CDMA-LTE and device is not in roaming state; otherwise, it will be ignored.
1543 * @hide
1544 */
1545 public static final String KEY_CDMA_HOME_REGISTERED_PLMN_NAME_STRING =
1546 "cdma_home_registered_plmn_name_string";
1547
1548 /**
Jonathan Basseri019523a2015-06-19 11:07:22 -07001549 * If this is true, the SIM card (through Customer Service Profile EF file) will be able to
1550 * prevent manual operator selection. If false, this SIM setting will be ignored and manual
1551 * operator selection will always be available. See CPHS4_2.WW6, CPHS B.4.7.1 for more
1552 * information
1553 */
1554 public static final String KEY_CSP_ENABLED_BOOL = "csp_enabled_bool";
1555
Amit Mahajan412e7c82015-10-05 11:05:02 -07001556 /**
1557 * Allow user to add APNs
Amit Mahajan412e7c82015-10-05 11:05:02 -07001558 */
1559 public static final String KEY_ALLOW_ADDING_APNS_BOOL = "allow_adding_apns_bool";
1560
Amit Mahajan0c081482016-01-12 18:25:33 -08001561 /**
Sarah China912e112020-01-09 10:43:30 -08001562 * APN types that user is not allowed to modify.
Amit Mahajand7bb9072016-09-14 18:12:11 -07001563 */
1564 public static final String KEY_READ_ONLY_APN_TYPES_STRING_ARRAY =
1565 "read_only_apn_types_string_array";
1566
1567 /**
Sarah China912e112020-01-09 10:43:30 -08001568 * APN fields that user is not allowed to modify.
Amit Mahajan71e9ea62016-09-20 10:57:47 -07001569 */
1570 public static final String KEY_READ_ONLY_APN_FIELDS_STRING_ARRAY =
1571 "read_only_apn_fields_string_array";
1572
1573 /**
SongFerngWangc87140c2019-08-19 22:51:46 +08001574 * Default value of APN types field if not specified by user when adding/modifying an APN.
SongFerngWangc87140c2019-08-19 22:51:46 +08001575 */
1576 public static final String KEY_APN_SETTINGS_DEFAULT_APN_TYPES_STRING_ARRAY =
1577 "apn_settings_default_apn_types_string_array";
1578
1579 /**
Bonian Chen94ae34a2020-01-17 05:49:54 +08001580 * Configs used for APN setup.
1581 */
1582 public static final class Apn {
1583 /** Prefix of all Apn.KEY_* constants. */
1584 public static final String KEY_PREFIX = "apn.";
1585
1586 /** IPv4 internet protocol */
1587 public static final String PROTOCOL_IPV4 = "IP";
1588 /** IPv6 internet protocol */
1589 public static final String PROTOCOL_IPV6 = "IPV6";
1590 /** IPv4 or IPv6 internet protocol */
1591 public static final String PROTOCOL_IPV4V6 = "IPV4V6";
1592
1593 /**
1594 * Default value of APN protocol field if not specified by user when adding/modifying
1595 * an APN.
1596 *
1597 * Available options are: {@link #PROTOCOL_IPV4}, {@link #PROTOCOL_IPV6},
1598 * {@link #PROTOCOL_IPV4V6}
1599 */
1600 public static final String KEY_SETTINGS_DEFAULT_PROTOCOL_STRING =
1601 KEY_PREFIX + "settings_default_protocol_string";
1602
1603 /**
1604 * Default value of APN roaming protocol field if not specified by user when
1605 * adding/modifying an APN.
1606 *
1607 * Available options are: {@link #PROTOCOL_IPV4}, {@link #PROTOCOL_IPV6},
1608 * {@link #PROTOCOL_IPV4V6}
1609 */
1610 public static final String KEY_SETTINGS_DEFAULT_ROAMING_PROTOCOL_STRING =
1611 KEY_PREFIX + "settings_default_roaming_protocol_string";
1612
1613 private Apn() {}
1614
1615 private static PersistableBundle getDefaults() {
1616 PersistableBundle defaults = new PersistableBundle();
1617 defaults.putString(KEY_SETTINGS_DEFAULT_PROTOCOL_STRING, "");
1618 defaults.putString(KEY_SETTINGS_DEFAULT_ROAMING_PROTOCOL_STRING, "");
1619 return defaults;
1620 }
1621 }
1622
1623 /**
Amit Mahajan0c081482016-01-12 18:25:33 -08001624 * Boolean indicating if intent for emergency call state changes should be broadcast
1625 * @hide
1626 */
1627 public static final String KEY_BROADCAST_EMERGENCY_CALL_STATE_CHANGES_BOOL =
1628 "broadcast_emergency_call_state_changes_bool";
1629
Jack Yubf0fd722016-05-03 11:53:30 -07001630 /**
Sooraj Sasindran6a3d36f2016-10-13 11:36:34 -07001631 * Indicates whether STK LAUNCH_BROWSER command is disabled.
1632 * If {@code true}, then the browser will not be launched
1633 * on UI for the LAUNCH_BROWSER STK command.
1634 * @hide
1635 */
1636 public static final String KEY_STK_DISABLE_LAUNCH_BROWSER_BOOL =
1637 "stk_disable_launch_browser_bool";
1638
Wenting Xiong63364fe2017-02-07 19:12:27 +08001639 /**
Yoshiaki Naka1c5203a62019-02-21 18:40:03 +09001640 * Boolean indicating if the helper text for STK GET INKEY/INPUT commands with the digit only
1641 * mode is displayed on the input screen.
1642 * The helper text is dispayed regardless of the input mode, if {@code false}.
1643 * @hide
1644 */
1645 public static final String KEY_HIDE_DIGITS_HELPER_TEXT_ON_STK_INPUT_SCREEN_BOOL =
1646 "hide_digits_helper_text_on_stk_input_screen_bool";
1647
1648 /**
Sarah China912e112020-01-09 10:43:30 -08001649 * Boolean indicating if show data RAT icon on status bar even when data is disabled.
Wenting Xiong63364fe2017-02-07 19:12:27 +08001650 */
1651 public static final String KEY_ALWAYS_SHOW_DATA_RAT_ICON_BOOL =
1652 "always_show_data_rat_icon_bool";
Sooraj Sasindran6a3d36f2016-10-13 11:36:34 -07001653
Wenting Xiongf21f3cf2016-04-01 15:25:45 +08001654 /**
Sarah China912e112020-01-09 10:43:30 -08001655 * Boolean indicating if default data account should show LTE or 4G icon.
Niklas Lindgrena02964d2018-09-21 14:01:57 +02001656 */
1657 public static final String KEY_SHOW_4G_FOR_LTE_DATA_ICON_BOOL =
1658 "show_4g_for_lte_data_icon_bool";
1659
1660 /**
vagdevi3f2b9a52019-08-09 09:45:14 -07001661 * Boolean indicating if default data account should show 4G icon when in 3G.
vagdevi3f2b9a52019-08-09 09:45:14 -07001662 */
1663 public static final String KEY_SHOW_4G_FOR_3G_DATA_ICON_BOOL =
1664 "show_4g_for_3g_data_icon_bool";
1665
1666 /**
Sarah China912e112020-01-09 10:43:30 -08001667 * Boolean indicating if LTE+ icon should be shown if available.
Niklas Lindgrena02964d2018-09-21 14:01:57 +02001668 */
1669 public static final String KEY_HIDE_LTE_PLUS_DATA_ICON_BOOL =
1670 "hide_lte_plus_data_icon_bool";
1671
1672 /**
Sarah Chinea9d40e2020-08-12 19:38:02 -07001673 * The combined channel bandwidth threshold (non-inclusive) in KHz required to display the
1674 * LTE+ data icon. It is 20000 by default, meaning the LTE+ icon will be shown if the device is
1675 * using carrier aggregation and the combined channel bandwidth is strictly greater than 20 MHz.
1676 * @hide
1677 */
1678 public static final String KEY_LTE_PLUS_THRESHOLD_BANDWIDTH_KHZ_INT =
1679 "lte_plus_threshold_bandwidth_khz_int";
1680
1681 /**
SongFerngWang2d178ea2019-03-21 23:14:20 +08001682 * The string is used to filter redundant string from PLMN Network Name that's supplied by
1683 * specific carrier.
1684 *
1685 * @hide
1686 */
1687 public static final String KEY_OPERATOR_NAME_FILTER_PATTERN_STRING =
1688 "operator_name_filter_pattern_string";
1689
1690 /**
Sarah China912e112020-01-09 10:43:30 -08001691 * The string is used to compare with operator name.
1692 * If it matches the pattern then show specific data icon.
Sarah Chinb800cbd2020-02-19 12:25:36 -08001693 * @hide
SongFerngWang2d178ea2019-03-21 23:14:20 +08001694 */
1695 public static final String KEY_SHOW_CARRIER_DATA_ICON_PATTERN_STRING =
1696 "show_carrier_data_icon_pattern_string";
1697
1698 /**
Wenting Xiongf21f3cf2016-04-01 15:25:45 +08001699 * Boolean to decide whether to show precise call failed cause to user
1700 * @hide
1701 */
1702 public static final String KEY_SHOW_PRECISE_FAILED_CAUSE_BOOL =
1703 "show_precise_failed_cause_bool";
1704
Pengquan Mengcb6aaf02018-11-02 17:40:17 -07001705 /**
Sarah Chin39c87c62020-05-13 23:41:52 -07001706 * Boolean to decide whether NR is enabled.
1707 * @hide
1708 */
1709 public static final String KEY_NR_ENABLED_BOOL = "nr_enabled_bool";
1710
1711 /**
Sarah China912e112020-01-09 10:43:30 -08001712 * Boolean to decide whether LTE is enabled.
Pengquan Mengcb6aaf02018-11-02 17:40:17 -07001713 */
1714 public static final String KEY_LTE_ENABLED_BOOL = "lte_enabled_bool";
1715
1716 /**
1717 * Boolean to decide whether TD-SCDMA is supported.
Pengquan Mengcb6aaf02018-11-02 17:40:17 -07001718 */
1719 public static final String KEY_SUPPORT_TDSCDMA_BOOL = "support_tdscdma_bool";
1720
1721 /**
1722 * A list of mcc/mnc that support TD-SCDMA for device when connect to the roaming network.
Pengquan Mengcb6aaf02018-11-02 17:40:17 -07001723 */
1724 public static final String KEY_SUPPORT_TDSCDMA_ROAMING_NETWORKS_STRING_ARRAY =
1725 "support_tdscdma_roaming_networks_string_array";
1726
1727 /**
1728 * Boolean to decide whether world mode is enabled.
Pengquan Mengcb6aaf02018-11-02 17:40:17 -07001729 */
1730 public static final String KEY_WORLD_MODE_ENABLED_BOOL = "world_mode_enabled_bool";
1731
1732 /**
Pengquan Meng3d4e67c2018-11-07 14:54:21 -08001733 * Flatten {@link android.content.ComponentName} of the carrier's settings activity.
Pengquan Mengcb6aaf02018-11-02 17:40:17 -07001734 */
Pengquan Meng3d4e67c2018-11-07 14:54:21 -08001735 public static final String KEY_CARRIER_SETTINGS_ACTIVITY_COMPONENT_NAME_STRING =
1736 "carrier_settings_activity_component_name_string";
Pengquan Mengcb6aaf02018-11-02 17:40:17 -07001737
Hall Liue5b1fda2018-10-22 18:17:44 -07001738 // These variables are used by the MMS service and exposed through another API,
1739 // SmsManager. The variable names and string values are copied from there.
Jonathan Basseri69822f02015-06-04 13:48:08 -07001740 public static final String KEY_MMS_ALIAS_ENABLED_BOOL = "aliasEnabled";
1741 public static final String KEY_MMS_ALLOW_ATTACH_AUDIO_BOOL = "allowAttachAudio";
1742 public static final String KEY_MMS_APPEND_TRANSACTION_ID_BOOL = "enabledTransID";
1743 public static final String KEY_MMS_GROUP_MMS_ENABLED_BOOL = "enableGroupMms";
1744 public static final String KEY_MMS_MMS_DELIVERY_REPORT_ENABLED_BOOL = "enableMMSDeliveryReports";
1745 public static final String KEY_MMS_MMS_ENABLED_BOOL = "enabledMMS";
1746 public static final String KEY_MMS_MMS_READ_REPORT_ENABLED_BOOL = "enableMMSReadReports";
1747 public static final String KEY_MMS_MULTIPART_SMS_ENABLED_BOOL = "enableMultipartSMS";
1748 public static final String KEY_MMS_NOTIFY_WAP_MMSC_ENABLED_BOOL = "enabledNotifyWapMMSC";
1749 public static final String KEY_MMS_SEND_MULTIPART_SMS_AS_SEPARATE_MESSAGES_BOOL = "sendMultipartSmsAsSeparateMessages";
1750 public static final String KEY_MMS_SHOW_CELL_BROADCAST_APP_LINKS_BOOL = "config_cellBroadcastAppLinks";
1751 public static final String KEY_MMS_SMS_DELIVERY_REPORT_ENABLED_BOOL = "enableSMSDeliveryReports";
1752 public static final String KEY_MMS_SUPPORT_HTTP_CHARSET_HEADER_BOOL = "supportHttpCharsetHeader";
1753 public static final String KEY_MMS_SUPPORT_MMS_CONTENT_DISPOSITION_BOOL = "supportMmsContentDisposition";
1754 public static final String KEY_MMS_ALIAS_MAX_CHARS_INT = "aliasMaxChars";
1755 public static final String KEY_MMS_ALIAS_MIN_CHARS_INT = "aliasMinChars";
1756 public static final String KEY_MMS_HTTP_SOCKET_TIMEOUT_INT = "httpSocketTimeout";
1757 public static final String KEY_MMS_MAX_IMAGE_HEIGHT_INT = "maxImageHeight";
1758 public static final String KEY_MMS_MAX_IMAGE_WIDTH_INT = "maxImageWidth";
1759 public static final String KEY_MMS_MAX_MESSAGE_SIZE_INT = "maxMessageSize";
1760 public static final String KEY_MMS_MESSAGE_TEXT_MAX_SIZE_INT = "maxMessageTextSize";
1761 public static final String KEY_MMS_RECIPIENT_LIMIT_INT = "recipientLimit";
1762 public static final String KEY_MMS_SMS_TO_MMS_TEXT_LENGTH_THRESHOLD_INT = "smsToMmsTextLengthThreshold";
1763 public static final String KEY_MMS_SMS_TO_MMS_TEXT_THRESHOLD_INT = "smsToMmsTextThreshold";
1764 public static final String KEY_MMS_SUBJECT_MAX_LENGTH_INT = "maxSubjectLength";
1765 public static final String KEY_MMS_EMAIL_GATEWAY_NUMBER_STRING = "emailGatewayNumber";
1766 public static final String KEY_MMS_HTTP_PARAMS_STRING = "httpParams";
1767 public static final String KEY_MMS_NAI_SUFFIX_STRING = "naiSuffix";
1768 public static final String KEY_MMS_UA_PROF_TAG_NAME_STRING = "uaProfTagName";
1769 public static final String KEY_MMS_UA_PROF_URL_STRING = "uaProfUrl";
1770 public static final String KEY_MMS_USER_AGENT_STRING = "userAgent";
Sarah Chin58c5b002020-01-15 16:40:08 -08001771 /**
1772 * If true, add "Connection: close" header to MMS HTTP requests so the connection
1773 * is immediately closed (disabling keep-alive).
1774 */
Ye Wen406a41b2016-07-18 14:36:22 -07001775 public static final String KEY_MMS_CLOSE_CONNECTION_BOOL = "mmsCloseConnection";
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08001776
Tyler Gunn387ce2f2015-08-28 14:14:11 -07001777 /**
chen xud040f2d2018-11-10 10:54:45 -08001778 * The flatten {@link android.content.ComponentName componentName} of the activity that can
1779 * setup the device and activate with the network per carrier requirements.
1780 *
1781 * e.g, com.google.android.carrierPackageName/.CarrierActivityName
Stuart Scott9abc2732016-05-11 15:42:01 -07001782 * @hide
1783 */
chen xud040f2d2018-11-10 10:54:45 -08001784 @SystemApi
Hall Liue5b1fda2018-10-22 18:17:44 -07001785 public static final String KEY_CARRIER_SETUP_APP_STRING = "carrier_setup_app_string";
Stuart Scott9abc2732016-05-11 15:42:01 -07001786
1787 /**
fionaxua21a87b2016-12-13 17:15:11 -08001788 * Defines carrier-specific actions which act upon
fionaxuabeba602017-02-23 18:06:52 -08001789 * com.android.internal.telephony.CARRIER_SIGNAL_REDIRECTED, used for customization of the
Sarah China912e112020-01-09 10:43:30 -08001790 * default carrier app.
fionaxua21a87b2016-12-13 17:15:11 -08001791 * Format: "CARRIER_ACTION_IDX, ..."
1792 * Where {@code CARRIER_ACTION_IDX} is an integer defined in
Sarah China912e112020-01-09 10:43:30 -08001793 * com.android.carrierdefaultapp.CarrierActionUtils
fionaxua21a87b2016-12-13 17:15:11 -08001794 * Example:
Sarah China912e112020-01-09 10:43:30 -08001795 * com.android.carrierdefaultapp.CarrierActionUtils#CARRIER_ACTION_DISABLE_METERED_APNS
1796 * disables metered APNs
fionaxua21a87b2016-12-13 17:15:11 -08001797 */
Sarah China912e112020-01-09 10:43:30 -08001798 @SuppressLint("IntentName")
fionaxua21a87b2016-12-13 17:15:11 -08001799 public static final String KEY_CARRIER_DEFAULT_ACTIONS_ON_REDIRECTION_STRING_ARRAY =
1800 "carrier_default_actions_on_redirection_string_array";
1801
1802 /**
Sarah China912e112020-01-09 10:43:30 -08001803 * Defines carrier-specific actions which act upon CARRIER_SIGNAL_REQUEST_NETWORK_FAILED
fionaxua21a87b2016-12-13 17:15:11 -08001804 * and configured signal args:
Sarah China912e112020-01-09 10:43:30 -08001805 * android.telephony.TelephonyManager#EXTRA_APN_TYPE,
1806 * android.telephony.TelephonyManager#EXTRA_ERROR_CODE
fionaxua21a87b2016-12-13 17:15:11 -08001807 * used for customization of the default carrier app
1808 * Format:
1809 * {
1810 * "APN_1, ERROR_CODE_1 : CARRIER_ACTION_IDX_1, CARRIER_ACTION_IDX_2...",
1811 * "APN_1, ERROR_CODE_2 : CARRIER_ACTION_IDX_1 "
1812 * }
1813 * Where {@code APN_1} is a string defined in
Sarah China912e112020-01-09 10:43:30 -08001814 * com.android.internal.telephony.PhoneConstants
fionaxua21a87b2016-12-13 17:15:11 -08001815 * Example: "default"
1816 *
Sarah China912e112020-01-09 10:43:30 -08001817 * {@code ERROR_CODE_1} is an integer defined in android.telephony.DataFailCause
fionaxua21a87b2016-12-13 17:15:11 -08001818 * Example:
Sarah China912e112020-01-09 10:43:30 -08001819 * android.telephony.DataFailCause#MISSING_UNKNOWN_APN
fionaxua21a87b2016-12-13 17:15:11 -08001820 *
1821 * {@code CARRIER_ACTION_IDX_1} is an integer defined in
Sarah China912e112020-01-09 10:43:30 -08001822 * com.android.carrierdefaultapp.CarrierActionUtils
fionaxua21a87b2016-12-13 17:15:11 -08001823 * Example:
Sarah China912e112020-01-09 10:43:30 -08001824 * com.android.carrierdefaultapp.CarrierActionUtils#CARRIER_ACTION_DISABLE_METERED_APNS
1825 * disables metered APNs
fionaxua21a87b2016-12-13 17:15:11 -08001826 */
Sarah China912e112020-01-09 10:43:30 -08001827 @SuppressLint("IntentName")
fionaxua21a87b2016-12-13 17:15:11 -08001828 public static final String KEY_CARRIER_DEFAULT_ACTIONS_ON_DCFAILURE_STRING_ARRAY =
1829 "carrier_default_actions_on_dcfailure_string_array";
1830
1831 /**
Sarah China912e112020-01-09 10:43:30 -08001832 * Defines carrier-specific actions which act upon CARRIER_SIGNAL_RESET,
1833 * used for customization of the default carrier app.
fionaxu77f466d2017-04-26 16:05:25 -07001834 * Format: "CARRIER_ACTION_IDX, ..."
1835 * Where {@code CARRIER_ACTION_IDX} is an integer defined in
Sarah China912e112020-01-09 10:43:30 -08001836 * com.android.carrierdefaultapp.CarrierActionUtils
fionaxu77f466d2017-04-26 16:05:25 -07001837 * Example:
Sarah China912e112020-01-09 10:43:30 -08001838 * com.android.carrierdefaultapp.CarrierActionUtils#CARRIER_ACTION_CANCEL_ALL_NOTIFICATIONS
1839 * clears all notifications on reset
fionaxu77f466d2017-04-26 16:05:25 -07001840 */
Sarah China912e112020-01-09 10:43:30 -08001841 @SuppressLint("IntentName")
fionaxu77f466d2017-04-26 16:05:25 -07001842 public static final String KEY_CARRIER_DEFAULT_ACTIONS_ON_RESET =
1843 "carrier_default_actions_on_reset_string_array";
fionaxud60a9d02017-05-23 14:55:27 -07001844
1845 /**
1846 * Defines carrier-specific actions which act upon
1847 * com.android.internal.telephony.CARRIER_SIGNAL_DEFAULT_NETWORK_AVAILABLE,
Sarah China912e112020-01-09 10:43:30 -08001848 * used for customization of the default carrier app.
fionaxud60a9d02017-05-23 14:55:27 -07001849 * Format:
1850 * {
1851 * "true : CARRIER_ACTION_IDX_1",
1852 * "false: CARRIER_ACTION_IDX_2"
1853 * }
1854 * Where {@code true} is a boolean indicates default network available/unavailable
1855 * Where {@code CARRIER_ACTION_IDX} is an integer defined in
Sarah China912e112020-01-09 10:43:30 -08001856 * com.android.carrierdefaultapp.CarrierActionUtils CarrierActionUtils
fionaxud60a9d02017-05-23 14:55:27 -07001857 * Example:
Sarah China912e112020-01-09 10:43:30 -08001858 * com.android.carrierdefaultapp.CarrierActionUtils#CARRIER_ACTION_ENABLE_DEFAULT_URL_HANDLER
1859 * enables the app as the default URL handler
fionaxud60a9d02017-05-23 14:55:27 -07001860 */
Sarah China912e112020-01-09 10:43:30 -08001861 @SuppressLint("IntentName")
fionaxud60a9d02017-05-23 14:55:27 -07001862 public static final String KEY_CARRIER_DEFAULT_ACTIONS_ON_DEFAULT_NETWORK_AVAILABLE =
1863 "carrier_default_actions_on_default_network_available_string_array";
Sarah China912e112020-01-09 10:43:30 -08001864
fionaxu77f466d2017-04-26 16:05:25 -07001865 /**
Sarah China912e112020-01-09 10:43:30 -08001866 * Defines a list of acceptable redirection url for default carrier app.
fionaxua21a87b2016-12-13 17:15:11 -08001867 */
1868 public static final String KEY_CARRIER_DEFAULT_REDIRECTION_URL_STRING_ARRAY =
1869 "carrier_default_redirection_url_string_array";
1870
1871 /**
fionaxu41ca9372016-11-17 16:46:30 -08001872 * Each config includes the componentName of the carrier app, followed by a list of interesting
1873 * signals(declared in the manifest) which could wake up the app.
1874 * @see com.android.internal.telephony.TelephonyIntents
1875 * Example:
1876 * <item>com.google.android.carrierAPK/.CarrierSignalReceiverA:
fionaxuabeba602017-02-23 18:06:52 -08001877 * com.android.internal.telephony.CARRIER_SIGNAL_REDIRECTED,
1878 * com.android.internal.telephony.CARRIER_SIGNAL_PCO_VALUE
fionaxu41ca9372016-11-17 16:46:30 -08001879 * </item>
1880 * <item>com.google.android.carrierAPK/.CarrierSignalReceiverB:
fionaxuabeba602017-02-23 18:06:52 -08001881 * com.android.internal.telephony.CARRIER_SIGNAL_PCO_VALUE
fionaxu41ca9372016-11-17 16:46:30 -08001882 * </item>
1883 * @hide
1884 */
1885 public static final String KEY_CARRIER_APP_WAKE_SIGNAL_CONFIG_STRING_ARRAY =
1886 "carrier_app_wake_signal_config";
1887
1888 /**
1889 * Each config includes the componentName of the carrier app, followed by a list of interesting
1890 * signals for the app during run-time. The list of signals(intents) are targeting on run-time
1891 * broadcast receivers only, aiming to avoid unnecessary wake-ups and should not be declared in
1892 * the app's manifest.
1893 * @see com.android.internal.telephony.TelephonyIntents
1894 * Example:
1895 * <item>com.google.android.carrierAPK/.CarrierSignalReceiverA:
fionaxuabeba602017-02-23 18:06:52 -08001896 * com.android.internal.telephony.CARRIER_SIGNAL_REQUEST_NETWORK_FAILED,
1897 * com.android.internal.telephony.CARRIER_SIGNAL_PCO_VALUE
fionaxu41ca9372016-11-17 16:46:30 -08001898 * </item>
1899 * <item>com.google.android.carrierAPK/.CarrierSignalReceiverB:
fionaxuabeba602017-02-23 18:06:52 -08001900 * com.android.internal.telephony.CARRIER_SIGNAL_REQUEST_NETWORK_FAILED
fionaxu41ca9372016-11-17 16:46:30 -08001901 * </item>
1902 * @hide
1903 */
1904 public static final String KEY_CARRIER_APP_NO_WAKE_SIGNAL_CONFIG_STRING_ARRAY =
1905 "carrier_app_no_wake_signal_config";
1906
1907 /**
Qingxi Li38fbddc2019-03-14 13:26:03 -07001908 * Determines whether the carrier app needed to be involved when users try to finish setting up
1909 * the SIM card to get network service.
Qingxi Li38fbddc2019-03-14 13:26:03 -07001910 */
1911 public static final String KEY_CARRIER_APP_REQUIRED_DURING_SIM_SETUP_BOOL =
1912 "carrier_app_required_during_setup_bool";
1913
1914 /**
fionaxu7834be22017-06-22 18:14:23 -07001915 * Default value for {@link Settings.Global#DATA_ROAMING}
1916 * @hide
1917 */
1918 public static final String KEY_CARRIER_DEFAULT_DATA_ROAMING_ENABLED_BOOL =
1919 "carrier_default_data_roaming_enabled_bool";
1920
1921 /**
Tyler Gunn387ce2f2015-08-28 14:14:11 -07001922 * Determines whether the carrier supports making non-emergency phone calls while the phone is
1923 * in emergency callback mode. Default value is {@code true}, meaning that non-emergency calls
1924 * are allowed in emergency callback mode.
Tyler Gunn387ce2f2015-08-28 14:14:11 -07001925 */
1926 public static final String KEY_ALLOW_NON_EMERGENCY_CALLS_IN_ECM_BOOL =
Tyler Gunn6ef57c32015-08-31 13:15:27 -07001927 "allow_non_emergency_calls_in_ecm_bool";
Tyler Gunn387ce2f2015-08-28 14:14:11 -07001928
Tyler Gunn1cee4772015-12-04 21:03:30 -08001929 /**
Brad Ebinger5eeb79d2019-03-15 13:50:34 -07001930 * Time that the telephony framework stays in "emergency SMS mode" after an emergency SMS is
1931 * sent to the network. This is used by carriers to configure the time
1932 * {@link TelephonyManager#isInEmergencySmsMode()} will be true after an emergency SMS is sent.
1933 * This is used by GNSS to override user location permissions so that the carrier network can
1934 * get the user's location for emergency services.
1935 *
1936 * The default is 0, which means that this feature is disabled. The maximum value for this timer
1937 * is 300000 mS (5 minutes).
1938 *
1939 * @hide
1940 */
1941 public static final String KEY_EMERGENCY_SMS_MODE_TIMER_MS_INT =
1942 "emergency_sms_mode_timer_ms_int";
1943
1944 /**
Tyler Gunnabfdaea2015-05-28 15:09:10 -07001945 * Flag indicating whether to allow carrier video calls to emergency numbers.
1946 * When {@code true}, video calls to emergency numbers will be allowed. When {@code false},
1947 * video calls to emergency numbers will be initiated as audio-only calls instead.
Tyler Gunnabfdaea2015-05-28 15:09:10 -07001948 */
Tyler Gunnf0836192016-03-15 20:33:13 -07001949 public static final String KEY_ALLOW_EMERGENCY_VIDEO_CALLS_BOOL =
1950 "allow_emergency_video_calls_bool";
Tyler Gunn3e122f72016-01-11 19:25:00 -08001951
1952 /**
Brad Ebinger62713872019-11-18 18:43:35 -08001953 * Flag indicating whether or not an ongoing call will be held when an outgoing emergency call
1954 * is placed. If true, ongoing calls will be put on hold when an emergency call is placed. If
1955 * false, placing an emergency call will trigger the disconnect of all ongoing calls before
1956 * the emergency call is placed.
1957 */
1958 public static final String KEY_ALLOW_HOLD_CALL_DURING_EMERGENCY_BOOL =
1959 "allow_hold_call_during_emergency_bool";
1960
1961 /**
James.cf Linc8a345a2019-09-20 18:04:06 +08001962 * Flag indicating whether the carrier supports RCS presence indication for
1963 * User Capability Exchange (UCE). When presence is supported, the device should use the
Tyler Gunn3e122f72016-01-11 19:25:00 -08001964 * {@link android.provider.ContactsContract.Data#CARRIER_PRESENCE} bit mask and set the
1965 * {@link android.provider.ContactsContract.Data#CARRIER_PRESENCE_VT_CAPABLE} bit to indicate
1966 * whether each contact supports video calling. The UI is made aware that presence is enabled
1967 * via {@link android.telecom.PhoneAccount#CAPABILITY_VIDEO_CALLING_RELIES_ON_PRESENCE}
1968 * and can choose to hide or show the video calling icon based on whether a contact supports
1969 * video.
Tyler Gunn3e122f72016-01-11 19:25:00 -08001970 */
Tyler Gunn3e122f72016-01-11 19:25:00 -08001971 public static final String KEY_USE_RCS_PRESENCE_BOOL = "use_rcs_presence_bool";
1972
Abhijith Shastryd48935872016-02-04 17:28:03 -08001973 /**
James.cf Linc8a345a2019-09-20 18:04:06 +08001974 * Flag indicating whether the carrier supports RCS SIP OPTIONS indication for
1975 * User Capability Exchange (UCE).
1976 */
1977 public static final String KEY_USE_RCS_SIP_OPTIONS_BOOL = "use_rcs_sip_options_bool";
1978
1979 /**
Abhijith Shastryd48935872016-02-04 17:28:03 -08001980 * The duration in seconds that platform call and message blocking is disabled after the user
Tyler Gunn48c570b2018-03-09 02:33:22 +00001981 * contacts emergency services. Platform considers values for below cases:
1982 * 1) 0 <= VALUE <= 604800(one week): the value will be used as the duration directly.
1983 * 2) VALUE > 604800(one week): will use the default value as duration instead.
1984 * 3) VALUE < 0: block will be disabled forever until user re-eanble block manually,
1985 * the suggested value to disable forever is -1.
1986 * See {@code android.provider.BlockedNumberContract#notifyEmergencyContact(Context)}
1987 * See {@code android.provider.BlockedNumberContract#isBlocked(Context, String)}.
Abhijith Shastryd48935872016-02-04 17:28:03 -08001988 */
1989 public static final String KEY_DURATION_BLOCKING_DISABLED_AFTER_EMERGENCY_INT =
1990 "duration_blocking_disabled_after_emergency_int";
1991
qingxi247e7f42016-06-03 15:24:33 -07001992 /**
Tyler Gunn48c570b2018-03-09 02:33:22 +00001993 * Determines whether to enable enhanced call blocking feature on the device.
Sarah China912e112020-01-09 10:43:30 -08001994 * android.provider.BlockedNumberContract.SystemContract#ENHANCED_SETTING_KEY_BLOCK_UNREGISTERED
1995 * android.provider.BlockedNumberContract.SystemContract#ENHANCED_SETTING_KEY_BLOCK_PRIVATE
1996 * android.provider.BlockedNumberContract.SystemContract#ENHANCED_SETTING_KEY_BLOCK_PAYPHONE
1997 * android.provider.BlockedNumberContract.SystemContract#ENHANCED_SETTING_KEY_BLOCK_UNKNOWN
Tyler Gunn48c570b2018-03-09 02:33:22 +00001998 *
1999 * <p>
2000 * 1. For Single SIM(SS) device, it can be customized in both carrier_config_mccmnc.xml
2001 * and vendor.xml.
2002 * <p>
2003 * 2. For Dual SIM(DS) device, it should be customized in vendor.xml, since call blocking
2004 * function is used regardless of SIM.
2005 * <p>
2006 * If {@code true} enable enhanced call blocking feature on the device, {@code false} otherwise.
Tyler Gunn48c570b2018-03-09 02:33:22 +00002007 */
2008 public static final String KEY_SUPPORT_ENHANCED_CALL_BLOCKING_BOOL =
2009 "support_enhanced_call_blocking_bool";
2010
2011 /**
Jordan Liue1663562016-09-07 12:01:24 -07002012 * For carriers which require an empty flash to be sent before sending the normal 3-way calling
2013 * flash, the duration in milliseconds of the empty flash to send. When {@code 0}, no empty
2014 * flash is sent.
2015 */
2016 public static final String KEY_CDMA_3WAYCALL_FLASH_DELAY_INT = "cdma_3waycall_flash_delay_int";
2017
Jordan Liue1663562016-09-07 12:01:24 -07002018 /**
Jeff Davidsonaf1d3202017-10-25 12:51:43 -07002019 * The CDMA roaming mode (aka CDMA system select).
2020 *
2021 * <p>The value should be one of the CDMA_ROAMING_MODE_ constants in {@link TelephonyManager}.
2022 * Values other than {@link TelephonyManager#CDMA_ROAMING_MODE_RADIO_DEFAULT} (which is the
2023 * default) will take precedence over user selection.
2024 *
2025 * @see TelephonyManager#CDMA_ROAMING_MODE_RADIO_DEFAULT
2026 * @see TelephonyManager#CDMA_ROAMING_MODE_HOME
2027 * @see TelephonyManager#CDMA_ROAMING_MODE_AFFILIATED
2028 * @see TelephonyManager#CDMA_ROAMING_MODE_ANY
qingxi247e7f42016-06-03 15:24:33 -07002029 */
2030 public static final String KEY_CDMA_ROAMING_MODE_INT = "cdma_roaming_mode_int";
Jeff Davidsonaf1d3202017-10-25 12:51:43 -07002031
Josh Hou0e9ea952019-12-03 21:00:44 +08002032 /**
2033 * Determines whether 1X voice calls is supported for some CDMA carriers.
2034 * Default value is true.
2035 * @hide
2036 */
2037 @SystemApi
2038 public static final String KEY_SUPPORT_CDMA_1X_VOICE_CALLS_BOOL =
2039 "support_cdma_1x_voice_calls_bool";
Jeff Davidsonaf1d3202017-10-25 12:51:43 -07002040
Wileen Chiu5e8e3082016-07-15 10:00:09 -07002041 /**
2042 * Boolean indicating if support is provided for directly dialing FDN number from FDN list.
2043 * If false, this feature is not supported.
2044 * @hide
2045 */
2046 public static final String KEY_SUPPORT_DIRECT_FDN_DIALING_BOOL =
2047 "support_direct_fdn_dialing_bool";
qingxi247e7f42016-06-03 15:24:33 -07002048
Robert Greenwalt60551b62016-06-09 16:28:40 -07002049 /**
rongmei.libcadc902019-10-16 18:41:48 +08002050 * Int indicating the max number length for FDN
2051 * @hide
2052 */
2053 public static final String KEY_FDN_NUMBER_LENGTH_LIMIT_INT =
2054 "fdn_number_length_limit_int";
2055
2056 /**
Junda Liu276f4d62016-07-14 13:55:03 -07002057 * Report IMEI as device id even if it's a CDMA/LTE phone.
2058 *
2059 * @hide
2060 */
2061 public static final String KEY_FORCE_IMEI_BOOL = "force_imei_bool";
2062
2063 /**
Robert Greenwalt60551b62016-06-09 16:28:40 -07002064 * The families of Radio Access Technologies that will get clustered and ratcheted,
2065 * ie, we will report transitions up within the family, but not down until we change
2066 * cells. This prevents flapping between base technologies and higher techs that are
2067 * granted on demand within the cell.
2068 * @hide
2069 */
2070 public static final String KEY_RATCHET_RAT_FAMILIES =
2071 "ratchet_rat_families";
2072
Tyler Gunn4b6614e2016-06-22 10:35:13 -07002073 /**
2074 * Flag indicating whether some telephony logic will treat a call which was formerly a video
2075 * call as if it is still a video call. When {@code true}:
2076 * <p>
2077 * Logic which will automatically drop a video call which takes place over WIFI when a
2078 * voice call is answered (see {@link #KEY_DROP_VIDEO_CALL_WHEN_ANSWERING_AUDIO_CALL_BOOL}.
2079 * <p>
2080 * Logic which determines whether the user can use TTY calling.
2081 */
2082 public static final String KEY_TREAT_DOWNGRADED_VIDEO_CALLS_AS_VIDEO_CALLS_BOOL =
2083 "treat_downgraded_video_calls_as_video_calls_bool";
2084
2085 /**
2086 * When {@code true}, if the user is in an ongoing video call over WIFI and answers an incoming
2087 * audio call, the video call will be disconnected before the audio call is answered. This is
2088 * in contrast to the usual expected behavior where a foreground video call would be put into
2089 * the background and held when an incoming audio call is answered.
2090 */
2091 public static final String KEY_DROP_VIDEO_CALL_WHEN_ANSWERING_AUDIO_CALL_BOOL =
2092 "drop_video_call_when_answering_audio_call_bool";
2093
Tyler Gunn7d633d32016-06-24 07:30:10 -07002094 /**
2095 * Flag indicating whether the carrier supports merging wifi calls when VoWIFI is disabled.
2096 * This can happen in the case of a carrier which allows offloading video calls to WIFI
2097 * separately of whether voice over wifi is enabled. In such a scenario when two video calls
2098 * are downgraded to voice, they remain over wifi. However, if VoWIFI is disabled, these calls
2099 * cannot be merged.
2100 */
2101 public static final String KEY_ALLOW_MERGE_WIFI_CALLS_WHEN_VOWIFI_OFF_BOOL =
2102 "allow_merge_wifi_calls_when_vowifi_off_bool";
2103
Hall Liu10208662016-06-15 17:55:00 -07002104 /**
Brad Ebingerc8601012016-07-19 14:09:23 -07002105 * Flag indicating whether the carrier supports the Hold command while in an IMS call.
Tyler Gunnd81c4262016-08-03 10:53:52 -07002106 * <p>
2107 * The device configuration value {@code config_device_respects_hold_carrier_config} ultimately
2108 * controls whether this carrier configuration option is used. Where
2109 * {@code config_device_respects_hold_carrier_config} is false, the value of the
2110 * {@link #KEY_ALLOW_HOLD_IN_IMS_CALL_BOOL} carrier configuration option is ignored.
Brad Ebingerc8601012016-07-19 14:09:23 -07002111 * @hide
2112 */
2113 public static final String KEY_ALLOW_HOLD_IN_IMS_CALL_BOOL = "allow_hold_in_ims_call";
2114
Pooja Jaind34698d2017-12-28 14:15:31 +05302115 /**
2116 * Flag indicating whether the carrier supports call deflection for an incoming IMS call.
Pooja Jaind34698d2017-12-28 14:15:31 +05302117 */
2118 public static final String KEY_CARRIER_ALLOW_DEFLECT_IMS_CALL_BOOL =
2119 "carrier_allow_deflect_ims_call_bool";
Tyler Gunn30889422017-11-28 09:04:31 -08002120
2121 /**
Ravi Palurif4b38e72020-02-05 12:35:41 +05302122 * Flag indicating whether the carrier supports explicit call transfer for an IMS call.
2123 * @hide
2124 */
2125 public static final String KEY_CARRIER_ALLOW_TRANSFER_IMS_CALL_BOOL =
2126 "carrier_allow_transfer_ims_call_bool";
2127
2128 /**
Tyler Gunn30889422017-11-28 09:04:31 -08002129 * Flag indicating whether the carrier always wants to play an "on-hold" tone when a call has
2130 * been remotely held.
2131 * <p>
2132 * When {@code true}, if the IMS stack indicates that the call session has been held, a signal
2133 * will be sent from Telephony to play an audible "on-hold" tone played to the user.
2134 * When {@code false}, a hold tone will only be played if the audio session becomes inactive.
2135 * @hide
2136 */
2137 public static final String KEY_ALWAYS_PLAY_REMOTE_HOLD_TONE_BOOL =
2138 "always_play_remote_hold_tone_bool";
2139
Brad Ebingerc8601012016-07-19 14:09:23 -07002140 /**
Hall Liuf31f3852018-07-25 18:48:55 -07002141 * When true, the Telephony stack will automatically turn off airplane mode and retry a wifi
2142 * emergency call over the cell network if the initial attempt at dialing was met with a SIP 308
2143 * error.
2144 * @hide
2145 */
2146 public static final String KEY_AUTO_RETRY_FAILED_WIFI_EMERGENCY_CALL =
2147 "auto_retry_failed_wifi_emergency_call";
2148
2149 /**
Hall Liu41027002016-07-06 16:32:43 -07002150 * When true, indicates that adding a call is disabled when there is an ongoing video call
2151 * or when there is an ongoing call on wifi which was downgraded from video and VoWifi is
2152 * turned off.
Hall Liu10208662016-06-15 17:55:00 -07002153 */
2154 public static final String KEY_ALLOW_ADD_CALL_DURING_VIDEO_CALL_BOOL =
2155 "allow_add_call_during_video_call";
2156
Tyler Gunnc96b5e02016-07-07 22:53:57 -07002157 /**
Tyler Gunnbe363242020-02-12 13:50:46 -08002158 * When {@code true}, indicates that video calls can be put on hold in order to swap to another
2159 * call (e.g. a new outgoing call).
2160 * When {@code false}, indicates that video calls will be disconnected when swapping to another
2161 * call.
2162 * <p>
2163 * This is {@code true} by default.
Ravi Paluri0fe55412019-12-10 16:53:14 +05302164 */
Tyler Gunnbe363242020-02-12 13:50:46 -08002165 public static final String KEY_ALLOW_HOLD_VIDEO_CALL_BOOL =
2166 "allow_hold_video_call_bool";
Ravi Paluri0fe55412019-12-10 16:53:14 +05302167
2168 /**
Hall Liu7c3c28b2016-07-19 11:18:49 -07002169 * When true, indicates that the HD audio icon in the in-call screen should not be shown for
2170 * VoWifi calls.
2171 * @hide
2172 */
2173 public static final String KEY_WIFI_CALLS_CAN_BE_HD_AUDIO = "wifi_calls_can_be_hd_audio";
2174
2175 /**
2176 * When true, indicates that the HD audio icon in the in-call screen should not be shown for
2177 * video calls.
2178 * @hide
2179 */
2180 public static final String KEY_VIDEO_CALLS_CAN_BE_HD_AUDIO = "video_calls_can_be_hd_audio";
2181
2182 /**
Alex Khlivnuikabdd37c2017-11-29 12:18:05 +09002183 * When true, indicates that the HD audio icon in the in-call screen should be shown for
2184 * GSM/CDMA calls.
2185 * @hide
2186 */
2187 public static final String KEY_GSM_CDMA_CALLS_CAN_BE_HD_AUDIO =
2188 "gsm_cdma_calls_can_be_hd_audio";
2189
2190 /**
Ta-wei Yen9d20d982017-06-02 11:07:07 -07002191 * Whether system apps are allowed to use fallback if carrier video call is not available.
2192 * Defaults to {@code true}.
Ta-wei Yen9d20d982017-06-02 11:07:07 -07002193 */
2194 public static final String KEY_ALLOW_VIDEO_CALLING_FALLBACK_BOOL =
2195 "allow_video_calling_fallback_bool";
2196
2197 /**
Brad Ebingerf8c3cd82018-01-22 13:51:52 -08002198 * Defines operator-specific {@link ImsReasonInfo} mappings.
Tyler Gunnc96b5e02016-07-07 22:53:57 -07002199 *
2200 * Format: "ORIGINAL_CODE|MESSAGE|NEW_CODE"
2201 * Where {@code ORIGINAL_CODE} corresponds to a {@link ImsReasonInfo#getCode()} code,
2202 * {@code MESSAGE} corresponds to an expected {@link ImsReasonInfo#getExtraMessage()} string,
2203 * and {@code NEW_CODE} is the new {@code ImsReasonInfo#CODE_*} which this combination of
2204 * original code and message shall be remapped to.
2205 *
Tyler Gunne0714692017-01-30 09:52:55 -08002206 * Note: If {@code *} is specified for the original code, any ImsReasonInfo with the matching
2207 * {@code MESSAGE} will be remapped to {@code NEW_CODE}.
2208 *
Tyler Gunnc96b5e02016-07-07 22:53:57 -07002209 * Example: "501|call completion elsewhere|1014"
2210 * When the {@link ImsReasonInfo#getCode()} is {@link ImsReasonInfo#CODE_USER_TERMINATED} and
2211 * the {@link ImsReasonInfo#getExtraMessage()} is {@code "call completion elsewhere"},
2212 * {@link ImsReasonInfo#CODE_ANSWERED_ELSEWHERE} shall be used as the {@link ImsReasonInfo}
2213 * code instead.
2214 * @hide
2215 */
2216 public static final String KEY_IMS_REASONINFO_MAPPING_STRING_ARRAY =
2217 "ims_reasoninfo_mapping_string_array";
2218
Meng Wang542e2622016-08-03 10:18:36 -07002219 /**
2220 * When {@code false}, use default title for Enhanced 4G LTE Mode settings.
2221 * When {@code true}, use the variant.
2222 * @hide
clownshen6400b932018-08-16 16:54:16 +08002223 * @deprecated use {@link #KEY_ENHANCED_4G_LTE_TITLE_VARIANT_INT}.
Meng Wang542e2622016-08-03 10:18:36 -07002224 */
clownshen6400b932018-08-16 16:54:16 +08002225 @Deprecated
Meng Wang542e2622016-08-03 10:18:36 -07002226 public static final String KEY_ENHANCED_4G_LTE_TITLE_VARIANT_BOOL =
2227 "enhanced_4g_lte_title_variant_bool";
2228
Tyler Gunn0f20d932016-08-09 15:56:43 -07002229 /**
Sarah China912e112020-01-09 10:43:30 -08002230 * The index indicates the carrier specified title string of Enhanced 4G LTE Mode settings.
clownshen6400b932018-08-16 16:54:16 +08002231 * Default value is 0, which indicates the default title string.
clownshen6400b932018-08-16 16:54:16 +08002232 */
2233 public static final String KEY_ENHANCED_4G_LTE_TITLE_VARIANT_INT =
2234 "enhanced_4g_lte_title_variant_int";
2235
2236 /**
Tyler Gunn0f20d932016-08-09 15:56:43 -07002237 * Indicates whether the carrier wants to notify the user when handover of an LTE video call to
2238 * WIFI fails.
2239 * <p>
2240 * When {@code true}, if a video call starts on LTE and the modem reports a failure to handover
2241 * the call to WIFI or if no handover success is reported within 60 seconds of call initiation,
2242 * the {@link android.telephony.TelephonyManager#EVENT_HANDOVER_TO_WIFI_FAILED} event is raised
2243 * on the connection.
2244 * @hide
2245 */
2246 public static final String KEY_NOTIFY_VT_HANDOVER_TO_WIFI_FAILURE_BOOL =
2247 "notify_vt_handover_to_wifi_failure_bool";
2248
Brad Ebinger9b63ad1a2016-08-15 11:28:26 -07002249 /**
2250 * A upper case list of CNAP names that are unhelpful to the user for distinguising calls and
2251 * should be filtered out of the CNAP information. This includes CNAP names such as "WIRELESS
2252 * CALLER" or "UNKNOWN NAME". By default, if there are no filtered names for this carrier, null
2253 * is returned.
2254 * @hide
2255 */
Jordan Liu1ca2e31d2016-12-01 11:39:30 -08002256 public static final String KEY_FILTERED_CNAP_NAMES_STRING_ARRAY = "filtered_cnap_names_string_array";
Brad Ebinger9b63ad1a2016-08-15 11:28:26 -07002257
Abhijith Shastry2215c9b2016-08-24 15:17:39 -07002258 /**
2259 * The RCS configuration server URL. This URL is used to initiate RCS provisioning.
2260 */
2261 public static final String KEY_RCS_CONFIG_SERVER_URL_STRING = "rcs_config_server_url_string";
2262
Meng Wang587a5f9c72016-09-28 21:06:55 -07002263 /**
Meng Wang2c25e4a2016-09-19 14:18:05 -07002264 * Determine whether user can change Wi-Fi Calling preference in roaming.
Hiroto Taruida081212019-02-14 14:37:09 +09002265 * {@code false} - roaming preference cannot be changed by user independently. If
2266 * {@link #KEY_USE_WFC_HOME_NETWORK_MODE_IN_ROAMING_NETWORK_BOOL} is false,
2267 * {@link #KEY_CARRIER_DEFAULT_WFC_IMS_ROAMING_MODE_INT} is used as the default
2268 * value. If {@link #KEY_USE_WFC_HOME_NETWORK_MODE_IN_ROAMING_NETWORK_BOOL} is
2269 * true, roaming preference is the same as home preference and
2270 * {@link #KEY_CARRIER_DEFAULT_WFC_IMS_MODE_INT} is used as the default value.
2271 * {@code true} - roaming preference can be changed by user independently if
2272 * {@link #KEY_USE_WFC_HOME_NETWORK_MODE_IN_ROAMING_NETWORK_BOOL} is false. If
2273 * {@link #KEY_USE_WFC_HOME_NETWORK_MODE_IN_ROAMING_NETWORK_BOOL} is true, this
2274 * configuration is ignored and roaming preference cannot be changed.
Meng Wang2c25e4a2016-09-19 14:18:05 -07002275 */
2276 public static final String KEY_EDITABLE_WFC_ROAMING_MODE_BOOL =
2277 "editable_wfc_roaming_mode_bool";
2278
Amit Mahajan22e89f42018-06-05 16:27:32 -07002279 /**
Sarah China912e112020-01-09 10:43:30 -08002280 * Flag specifying whether to show blocking pay phone option in blocked numbers screen.
2281 * Only show the option if payphone call presentation is present in the carrier's region.
Youming Ye9592a422019-03-20 17:53:44 -07002282 */
2283 public static final java.lang.String KEY_SHOW_BLOCKING_PAY_PHONE_OPTION_BOOL =
2284 "show_blocking_pay_phone_option_bool";
2285
2286 /**
Hiroto Taruida081212019-02-14 14:37:09 +09002287 * Flag specifying whether the carrier will use the WFC home network mode in roaming network.
2288 * {@code false} - roaming preference can be selected separately from the home preference.
2289 * {@code true} - roaming preference is the same as home preference and
2290 * {@link #KEY_CARRIER_DEFAULT_WFC_IMS_MODE_INT} is used as the default value.
Hiroto Taruida081212019-02-14 14:37:09 +09002291 */
2292 public static final String KEY_USE_WFC_HOME_NETWORK_MODE_IN_ROAMING_NETWORK_BOOL =
2293 "use_wfc_home_network_mode_in_roaming_network_bool";
2294
2295 /**
Ecco Park1074c882019-03-21 12:58:09 -07002296 * Flag specifying whether the carrier is allowed to use metered network to download a
2297 * certificate of Carrier-WiFi.
2298 * {@code false} - default value.
2299 *
2300 * @hide
2301 */
2302 public static final String KEY_ALLOW_METERED_NETWORK_FOR_CERT_DOWNLOAD_BOOL =
2303 "allow_metered_network_for_cert_download_bool";
2304
2305 /**
pkanwarffd45832016-12-11 17:45:50 -08002306 * Time delay (in ms) after which we show the notification to switch the preferred
2307 * network.
2308 * @hide
2309 */
2310 public static final String KEY_PREF_NETWORK_NOTIFICATION_DELAY_INT =
2311 "network_notification_delay_int";
2312
Brad Ebinger17acc152016-12-09 13:18:30 -08002313 /**
pkanwar68e3de72017-08-13 12:18:19 -07002314 * Time delay (in ms) after which we show the notification for emergency calls,
2315 * while the device is registered over WFC. Default value is -1, which indicates
2316 * that this notification is not pertinent for a particular carrier. We've added a delay
2317 * to prevent false positives.
pkanwar68e3de72017-08-13 12:18:19 -07002318 */
2319 public static final String KEY_EMERGENCY_NOTIFICATION_DELAY_INT =
2320 "emergency_notification_delay_int";
2321
2322 /**
Tyler Gunn02212db2017-06-05 11:26:46 -07002323 * When {@code true}, the carrier allows the user of the
2324 * {@link TelephonyManager#sendUssdRequest(String, TelephonyManager.UssdResponseCallback,
2325 * Handler)} API to perform USSD requests. {@code True} by default.
2326 * @hide
2327 */
2328 public static final String KEY_ALLOW_USSD_REQUESTS_VIA_TELEPHONY_MANAGER_BOOL =
2329 "allow_ussd_requests_via_telephony_manager_bool";
2330
2331 /**
Brad Ebinger17acc152016-12-09 13:18:30 -08002332 * Indicates whether the carrier supports 3gpp call forwarding MMI codes while roaming. If
2333 * false, the user will be notified that call forwarding is not available when the MMI code
2334 * fails.
2335 */
2336 public static final String KEY_SUPPORT_3GPP_CALL_FORWARDING_WHILE_ROAMING_BOOL =
2337 "support_3gpp_call_forwarding_while_roaming_bool";
2338
Junda Liuf1adc1d2016-12-16 16:45:10 -08002339 /**
Qiong Liu48fe53f2017-10-16 17:04:30 +08002340 * Boolean indicating whether to display voicemail number as default call forwarding number in
2341 * call forwarding settings.
2342 * If true, display vm number when cf number is null.
2343 * If false, display the cf number from network.
2344 * By default this value is false.
2345 * @hide
2346 */
2347 public static final String KEY_DISPLAY_VOICEMAIL_NUMBER_AS_DEFAULT_CALL_FORWARDING_NUMBER_BOOL =
2348 "display_voicemail_number_as_default_call_forwarding_number";
2349
2350 /**
Tyler Gunn662ae092017-02-16 16:21:14 -08002351 * When {@code true}, the user will be notified when they attempt to place an international call
2352 * when the call is placed using wifi calling.
2353 * @hide
2354 */
2355 public static final String KEY_NOTIFY_INTERNATIONAL_CALL_ON_WFC_BOOL =
2356 "notify_international_call_on_wfc_bool";
2357
2358 /**
taiki tsutsumi2ee96822018-07-02 17:15:42 +09002359 * Flag to hide Preset APN details. If true, user cannot enter ApnEditor view of Preset APN,
2360 * and cannot view details of the APN. If false, user can enter ApnEditor view of Preset APN.
2361 * Default value is false.
2362 */
2363 public static final String KEY_HIDE_PRESET_APN_DETAILS_BOOL = "hide_preset_apn_details_bool";
2364
2365 /**
Masaho Nishikawa4c7511c2017-12-18 14:33:38 +09002366 * Flag specifying whether to show an alert dialog for video call charges.
2367 * By default this value is {@code false}.
Masaho Nishikawa4c7511c2017-12-18 14:33:38 +09002368 */
2369 public static final String KEY_SHOW_VIDEO_CALL_CHARGES_ALERT_DIALOG_BOOL =
2370 "show_video_call_charges_alert_dialog_bool";
2371
2372 /**
Brad Ebinger9ab43212016-12-12 14:57:37 -08002373 * An array containing custom call forwarding number prefixes that will be blocked while the
2374 * device is reporting that it is roaming. By default, there are no custom call
2375 * forwarding prefixes and none of these numbers will be filtered. If one or more entries are
2376 * present, the system will not complete the call and display an error message.
2377 *
2378 * To display a message to the user when call forwarding fails for 3gpp MMI codes while roaming,
2379 * use the {@link #KEY_SUPPORT_3GPP_CALL_FORWARDING_WHILE_ROAMING_BOOL} option instead.
2380 */
2381 public static final String KEY_CALL_FORWARDING_BLOCKS_WHILE_ROAMING_STRING_ARRAY =
2382 "call_forwarding_blocks_while_roaming_string_array";
2383
Ammar Aijazi11b44982017-01-17 17:32:15 -08002384 /**
Josh Hou7d4f7792020-05-28 23:32:37 +08002385 * Call forwarding number prefixes defined by {@link
2386 * #KEY_CALL_FORWARDING_BLOCKS_WHILE_ROAMING_STRING_ARRAY} which will be allowed while the
2387 * device is reporting that it is roaming and IMS is registered over LTE or Wi-Fi.
2388 * By default this value is {@code true}.
2389 * @hide
2390 */
2391 public static final String KEY_SUPPORT_IMS_CALL_FORWARDING_WHILE_ROAMING_BOOL =
2392 "support_ims_call_forwarding_while_roaming_bool";
2393
2394 /**
Ammar Aijazi11b44982017-01-17 17:32:15 -08002395 * The day of the month (1-31) on which the data cycle rolls over.
2396 * <p>
Jeff Sharkey17bebd22017-07-19 21:00:38 -06002397 * If the current month does not have this day, the cycle will roll over at
2398 * the start of the next month.
Ammar Aijazi11b44982017-01-17 17:32:15 -08002399 * <p>
Jeff Sharkey17bebd22017-07-19 21:00:38 -06002400 * This setting may be still overridden by explicit user choice. By default,
Shuo Qian3d182902019-12-16 11:14:08 -08002401 * {@link #DATA_CYCLE_USE_PLATFORM_DEFAULT} will be used.
Ammar Aijazi11b44982017-01-17 17:32:15 -08002402 */
2403 public static final String KEY_MONTHLY_DATA_CYCLE_DAY_INT =
2404 "monthly_data_cycle_day_int";
2405
2406 /**
2407 * When {@link #KEY_MONTHLY_DATA_CYCLE_DAY_INT}, {@link #KEY_DATA_LIMIT_THRESHOLD_BYTES_LONG},
2408 * or {@link #KEY_DATA_WARNING_THRESHOLD_BYTES_LONG} are set to this value, the platform default
2409 * value will be used for that key.
Ammar Aijazi11b44982017-01-17 17:32:15 -08002410 */
2411 public static final int DATA_CYCLE_USE_PLATFORM_DEFAULT = -1;
2412
2413 /**
2414 * Flag indicating that a data cycle threshold should be disabled.
2415 * <p>
2416 * If {@link #KEY_DATA_WARNING_THRESHOLD_BYTES_LONG} is set to this value, the platform's
2417 * default data warning, if one exists, will be disabled. A user selected data warning will not
2418 * be overridden.
2419 * <p>
2420 * If {@link #KEY_DATA_LIMIT_THRESHOLD_BYTES_LONG} is set to this value, the platform's
2421 * default data limit, if one exists, will be disabled. A user selected data limit will not be
2422 * overridden.
2423 */
2424 public static final int DATA_CYCLE_THRESHOLD_DISABLED = -2;
2425
2426 /**
2427 * Controls the data usage warning.
2428 * <p>
2429 * If the user uses more than this amount of data in their billing cycle, as defined by
2430 * {@link #KEY_MONTHLY_DATA_CYCLE_DAY_INT}, the user will be alerted about the usage.
2431 * If the value is set to {@link #DATA_CYCLE_THRESHOLD_DISABLED}, the data usage warning will
2432 * be disabled.
2433 * <p>
Shuo Qian3d182902019-12-16 11:14:08 -08002434 * This setting may be overridden by explicit user choice. By default,
2435 * {@link #DATA_CYCLE_USE_PLATFORM_DEFAULT} will be used.
Ammar Aijazi11b44982017-01-17 17:32:15 -08002436 */
2437 public static final String KEY_DATA_WARNING_THRESHOLD_BYTES_LONG =
2438 "data_warning_threshold_bytes_long";
2439
2440 /**
Jeff Sharkey0a5570d2018-04-10 12:38:29 -06002441 * Controls if the device should automatically notify the user as they reach
2442 * their cellular data warning. When set to {@code false} the carrier is
Shuo Qian3d182902019-12-16 11:14:08 -08002443 * expected to have implemented their own notification mechanism. {@code true} by default.
Jeff Sharkey0a5570d2018-04-10 12:38:29 -06002444 */
2445 public static final String KEY_DATA_WARNING_NOTIFICATION_BOOL =
2446 "data_warning_notification_bool";
2447
2448 /**
chen xu00511062019-07-02 16:32:07 -07002449 * Controls if the device should automatically warn the user that sim voice & data function
2450 * might be limited due to dual sim scenario. When set to {@true} display the notification,
2451 * {@code false} otherwise.
2452 * @hide
2453 */
2454 public static final String KEY_LIMITED_SIM_FUNCTION_NOTIFICATION_FOR_DSDS_BOOL =
2455 "limited_sim_function_notification_for_dsds_bool";
2456
2457 /**
Ammar Aijazi11b44982017-01-17 17:32:15 -08002458 * Controls the cellular data limit.
2459 * <p>
2460 * If the user uses more than this amount of data in their billing cycle, as defined by
2461 * {@link #KEY_MONTHLY_DATA_CYCLE_DAY_INT}, cellular data will be turned off by the user's
2462 * phone. If the value is set to {@link #DATA_CYCLE_THRESHOLD_DISABLED}, the data limit will be
2463 * disabled.
2464 * <p>
Shuo Qian3d182902019-12-16 11:14:08 -08002465 * This setting may be overridden by explicit user choice. By default,
2466 * {@link #DATA_CYCLE_USE_PLATFORM_DEFAULT} will be used.
Ammar Aijazi11b44982017-01-17 17:32:15 -08002467 */
2468 public static final String KEY_DATA_LIMIT_THRESHOLD_BYTES_LONG =
2469 "data_limit_threshold_bytes_long";
2470
Sooraj Sasindran1b7bec52017-03-08 23:43:17 -08002471 /**
Jeff Sharkey0a5570d2018-04-10 12:38:29 -06002472 * Controls if the device should automatically notify the user as they reach
2473 * their cellular data limit. When set to {@code false} the carrier is
Shuo Qian3d182902019-12-16 11:14:08 -08002474 * expected to have implemented their own notification mechanism. {@code true} by default.
Jeff Sharkey0a5570d2018-04-10 12:38:29 -06002475 */
2476 public static final String KEY_DATA_LIMIT_NOTIFICATION_BOOL =
2477 "data_limit_notification_bool";
2478
2479 /**
2480 * Controls if the device should automatically notify the user when rapid
2481 * cellular data usage is observed. When set to {@code false} the carrier is
Shuo Qian3d182902019-12-16 11:14:08 -08002482 * expected to have implemented their own notification mechanism. {@code true} by default.
Jeff Sharkey0a5570d2018-04-10 12:38:29 -06002483 */
2484 public static final String KEY_DATA_RAPID_NOTIFICATION_BOOL =
2485 "data_rapid_notification_bool";
2486
2487 /**
Sooraj Sasindran1b7bec52017-03-08 23:43:17 -08002488 * Offset to be reduced from rsrp threshold while calculating signal strength level.
2489 * @hide
2490 */
2491 public static final String KEY_LTE_EARFCNS_RSRP_BOOST_INT = "lte_earfcns_rsrp_boost_int";
2492
2493 /**
2494 * List of EARFCN (E-UTRA Absolute Radio Frequency Channel Number,
2495 * Reference: 3GPP TS 36.104 5.4.3) inclusive ranges on which lte_rsrp_boost_int
2496 * will be applied. Format of the String array is expected to be {"erafcn1_start-earfcn1_end",
2497 * "earfcn2_start-earfcn2_end" ... }
2498 * @hide
2499 */
2500 public static final String KEY_BOOSTED_LTE_EARFCNS_STRING_ARRAY =
2501 "boosted_lte_earfcns_string_array";
2502
Sanket Padawedb688bb2017-03-28 15:26:13 -07002503 /**
Wenting Xiongcb35e992017-10-18 15:05:49 +09002504 * Determine whether to use only RSRP for the number of LTE signal bars.
2505 * @hide
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09002506 *
2507 * @deprecated use {@link #KEY_PARAMETERS_USED_FOR_LTE_SIGNAL_BAR_INT}.
Wenting Xiongcb35e992017-10-18 15:05:49 +09002508 */
Nathan Haroldf23153f2018-11-19 18:09:40 -08002509 // FIXME: this key and related keys must not be exposed without a consistent philosophy for
2510 // all RATs.
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09002511 @Deprecated
Wenting Xiongcb35e992017-10-18 15:05:49 +09002512 public static final String KEY_USE_ONLY_RSRP_FOR_LTE_SIGNAL_BAR_BOOL =
2513 "use_only_rsrp_for_lte_signal_bar_bool";
2514
2515 /**
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09002516 * Bit-field integer to determine whether to use Reference Signal Received Power (RSRP),
2517 * Reference Signal Received Quality (RSRQ), or/and Reference Signal Signal to Noise Ratio
2518 * (RSSNR) for the number of LTE signal bars and signal criteria reporting enabling.
2519 *
2520 * <p> If a measure is not set, signal criteria reporting from modem will not be triggered and
2521 * not be used for calculating signal level. If multiple measures are set bit, the parameter
2522 * whose value is smallest is used to indicate the signal level.
Shuo Qiane3efafd2020-03-03 19:51:13 -08002523 * <UL>
2524 * <LI>RSRP = 1 << 0</LI>
2525 * <LI>RSRQ = 1 << 1</LI>
2526 * <LI>RSSNR = 1 << 2</LI>
2527 * </UL>
2528 * <p> The value of this key must be bitwise OR of {@link CellSignalStrengthLte#USE_RSRP},
2529 * {@link CellSignalStrengthLte#USE_RSRQ}, {@link CellSignalStrengthLte#USE_RSSNR}.
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09002530 *
Shuo Qiane3efafd2020-03-03 19:51:13 -08002531 * <p> For example, if both RSRP and RSRQ are used, the value of key is 3 (1 << 0 | 1 << 1).
2532 * If the key is invalid or not configured, a default value (RSRP = 1 << 0) will apply.
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09002533 *
2534 * @hide
2535 */
2536 public static final String KEY_PARAMETERS_USED_FOR_LTE_SIGNAL_BAR_INT =
2537 "parameters_used_for_lte_signal_bar_int";
2538
2539 /**
Shuo Qian8c1e8732019-10-24 11:12:50 -07002540 * List of 4 customized 5G SS reference signal received power (SSRSRP) thresholds.
Shuo Qiane3efafd2020-03-03 19:51:13 -08002541 * <p>
Shuo Qian8c1e8732019-10-24 11:12:50 -07002542 * Reference: 3GPP TS 38.215
Shuo Qiane3efafd2020-03-03 19:51:13 -08002543 * <p>
Shuo Qian8c1e8732019-10-24 11:12:50 -07002544 * 4 threshold integers must be within the boundaries [-140 dB, -44 dB], and the levels are:
Shuo Qiane3efafd2020-03-03 19:51:13 -08002545 * <UL>
2546 * <LI>"NONE: [-140, threshold1]"</LI>
2547 * <LI>"POOR: (threshold1, threshold2]"</LI>
2548 * <LI>"MODERATE: (threshold2, threshold3]"</LI>
2549 * <LI>"GOOD: (threshold3, threshold4]"</LI>
2550 * <LI>"EXCELLENT: (threshold4, -44]"</LI>
2551 * </UL>
2552 * <p>
Shuo Qian8c1e8732019-10-24 11:12:50 -07002553 * This key is considered invalid if the format is violated. If the key is invalid or
2554 * not configured, a default value set will apply.
2555 */
2556 public static final String KEY_5G_NR_SSRSRP_THRESHOLDS_INT_ARRAY =
2557 "5g_nr_ssrsrp_thresholds_int_array";
2558
2559 /**
2560 * List of 4 customized 5G SS reference signal received quality (SSRSRQ) thresholds.
Shuo Qiane3efafd2020-03-03 19:51:13 -08002561 * <p>
Shuo Qian26e679e2020-07-01 11:48:52 -07002562 * Reference: 3GPP TS 38.215; 3GPP TS 38.133 section 10
Shuo Qiane3efafd2020-03-03 19:51:13 -08002563 * <p>
Shuo Qian26e679e2020-07-01 11:48:52 -07002564 * 4 threshold integers must be within the boundaries [-43 dB, 20 dB], and the levels are:
Shuo Qiane3efafd2020-03-03 19:51:13 -08002565 * <UL>
Shuo Qian26e679e2020-07-01 11:48:52 -07002566 * <LI>"NONE: [-43, threshold1]"</LI>
Shuo Qiane3efafd2020-03-03 19:51:13 -08002567 * <LI>"POOR: (threshold1, threshold2]"</LI>
2568 * <LI>"MODERATE: (threshold2, threshold3]"</LI>
2569 * <LI>"GOOD: (threshold3, threshold4]"</LI>
Shuo Qian26e679e2020-07-01 11:48:52 -07002570 * <LI>"EXCELLENT: (threshold4, 20]"</LI>
Shuo Qiane3efafd2020-03-03 19:51:13 -08002571 * </UL>
2572 * <p>
Shuo Qian8c1e8732019-10-24 11:12:50 -07002573 * This key is considered invalid if the format is violated. If the key is invalid or
2574 * not configured, a default value set will apply.
2575 */
2576 public static final String KEY_5G_NR_SSRSRQ_THRESHOLDS_INT_ARRAY =
2577 "5g_nr_ssrsrq_thresholds_int_array";
2578
2579 /**
2580 * List of 4 customized 5G SS signal-to-noise and interference ratio (SSSINR) thresholds.
Shuo Qiane3efafd2020-03-03 19:51:13 -08002581 * <p>
Shuo Qian8c1e8732019-10-24 11:12:50 -07002582 * Reference: 3GPP TS 38.215,
2583 * 3GPP TS 38.133 10.1.16.1
Shuo Qiane3efafd2020-03-03 19:51:13 -08002584 * <p>
Shuo Qian8c1e8732019-10-24 11:12:50 -07002585 * 4 threshold integers must be within the boundaries [-23 dB, 40 dB], and the levels are:
Shuo Qiane3efafd2020-03-03 19:51:13 -08002586 * <UL>
2587 * <LI>"NONE: [-23, threshold1]"</LI>
2588 * <LI>"POOR: (threshold1, threshold2]"</LI>
2589 * <LI>"MODERATE: (threshold2, threshold3]"</LI>
2590 * <LI>"GOOD: (threshold3, threshold4]"</LI>
2591 * <LI>"EXCELLENT: (threshold4, 40]"</LI>
2592 * </UL>
2593 * <p>
Shuo Qian8c1e8732019-10-24 11:12:50 -07002594 * This key is considered invalid if the format is violated. If the key is invalid or
2595 * not configured, a default value set will apply.
2596 */
2597 public static final String KEY_5G_NR_SSSINR_THRESHOLDS_INT_ARRAY =
2598 "5g_nr_sssinr_thresholds_int_array";
2599
2600 /**
2601 * Bit-field integer to determine whether to use SS reference signal received power (SSRSRP),
2602 * SS reference signal received quality (SSRSRQ), or/and SS signal-to-noise and interference
Shuo Qian7d7b2f12019-11-23 19:09:36 -08002603 * ratio (SSSINR) for the number of 5G NR signal bars and signal criteria reporting enabling.
2604 *
2605 * <p> If a measure is not set, signal criteria reporting from modem will not be triggered and
2606 * not be used for calculating signal level. If multiple measures are set bit, the parameter
2607 * whose value is smallest is used to indicate the signal level.
Shuo Qiane3efafd2020-03-03 19:51:13 -08002608 * <UL>
2609 * <LI>SSRSRP = 1 << 0</LI>
2610 * <LI>SSRSRQ = 1 << 1</LI>
2611 * <LI>SSSINR = 1 << 2</LI>
2612 * </UL>
Shuo Qian7d7b2f12019-11-23 19:09:36 -08002613 * The value of this key must be bitwise OR of {@link CellSignalStrengthNr#USE_SSRSRP},
2614 * {@link CellSignalStrengthNr#USE_SSRSRQ}, {@link CellSignalStrengthNr#USE_SSSINR}.
2615 *
Shuo Qiane3efafd2020-03-03 19:51:13 -08002616 * <p> For example, if both SSRSRP and SSSINR are used, the value of key is 5 (1 << 0 | 1 << 2).
Shuo Qian7d7b2f12019-11-23 19:09:36 -08002617 * If the key is invalid or not configured, a default value (SSRSRP = 1 << 0) will apply.
2618 *
Shuo Qiane3efafd2020-03-03 19:51:13 -08002619 * <p> Reference: 3GPP TS 38.215,
2620 * 3GPP TS 38.133 10.1.16.1
Shuo Qian7d7b2f12019-11-23 19:09:36 -08002621 *
2622 * @hide
Shuo Qian8c1e8732019-10-24 11:12:50 -07002623 */
2624 public static final String KEY_PARAMETERS_USE_FOR_5G_NR_SIGNAL_BAR_INT =
2625 "parameters_use_for_5g_nr_signal_bar_int";
2626
2627 /**
SongFerngWang68c58a52020-04-13 18:13:04 +08002628 * There are two signal strengths, NR and LTE signal strength, during NR (non-standalone).
2629 * Boolean indicating whether to use LTE signal strength as primary during NR (non-standalone).
2630 * By default this value is true.
2631 *
2632 * @hide
2633 */
2634 public static final String KEY_SIGNAL_STRENGTH_NR_NSA_USE_LTE_AS_PRIMARY_BOOL =
2635 "signal_strength_nr_nsa_use_lte_as_primary_bool";
2636
2637 /**
Sarah Chin5023ffd2020-02-07 10:33:06 -08002638 * String array of default bandwidth values per network type.
2639 * The entries should be of form "network_name:downstream,upstream", with values in Kbps.
2640 * @hide
2641 */
2642 public static final String KEY_BANDWIDTH_STRING_ARRAY = "bandwidth_string_array";
2643
2644 /**
2645 * For NR (non-standalone), whether to use the LTE value instead of NR value as the default for
2646 * upstream bandwidth. Downstream bandwidth will still use the NR value as the default.
2647 * @hide
2648 */
2649 public static final String KEY_BANDWIDTH_NR_NSA_USE_LTE_VALUE_FOR_UPSTREAM_BOOL =
2650 "bandwidth_nr_nsa_use_lte_value_for_upstream_bool";
2651
2652 /**
Sanket Padawedb688bb2017-03-28 15:26:13 -07002653 * Key identifying if voice call barring notification is required to be shown to the user.
2654 * @hide
2655 */
Mathew Inwood323d08f2018-08-16 11:30:29 +01002656 @UnsupportedAppUsage
Sanket Padawedb688bb2017-03-28 15:26:13 -07002657 public static final String KEY_DISABLE_VOICE_BARRING_NOTIFICATION_BOOL =
2658 "disable_voice_barring_notification_bool";
2659
pkanwar232573f2017-05-31 13:10:03 -07002660 /**
fionaxu1c6027c2017-06-01 18:52:17 -07002661 * List of operators considered non-roaming which won't show roaming icon.
2662 * <p>
2663 * Can use mcc or mcc+mnc as item. For example, 302 or 21407.
2664 * If operators, 21404 and 21407, make roaming agreements, users of 21404 should not see
2665 * the roaming icon as using 21407 network.
2666 * @hide
2667 */
2668 public static final String KEY_NON_ROAMING_OPERATOR_STRING_ARRAY =
2669 "non_roaming_operator_string_array";
2670
2671 /**
2672 * List of operators considered roaming with the roaming icon.
2673 * <p>
2674 * Can use mcc or mcc+mnc as item. For example, 302 or 21407.
2675 * If operators, 21404 and 21407, make roaming agreements, users of 21404 should see
2676 * the roaming icon as using 21407 network.
2677 * <p>
2678 * A match on this supersedes a match on {@link #KEY_NON_ROAMING_OPERATOR_STRING_ARRAY}.
2679 * @hide
2680 */
2681 public static final String KEY_ROAMING_OPERATOR_STRING_ARRAY =
2682 "roaming_operator_string_array";
2683
pkanwar766f4612017-05-31 13:10:03 -07002684 /**
2685 * URL from which the proto containing the public key of the Carrier used for
2686 * IMSI encryption will be downloaded.
2687 * @hide
2688 */
2689 public static final String IMSI_KEY_DOWNLOAD_URL_STRING = "imsi_key_download_url_string";
2690
2691 /**
pkanwarbecc8692017-07-04 16:04:44 -07002692 * Identifies if the key is available for WLAN or EPDG or both. The value is a bitmask.
2693 * 0 indicates that neither EPDG or WLAN is enabled.
Sarah China912e112020-01-09 10:43:30 -08002694 * 1 indicates that key type TelephonyManager#KEY_TYPE_EPDG is enabled.
2695 * 2 indicates that key type TelephonyManager#KEY_TYPE_WLAN is enabled.
pkanwarbecc8692017-07-04 16:04:44 -07002696 * 3 indicates that both are enabled.
pkanwar766f4612017-05-31 13:10:03 -07002697 */
pkanwarbecc8692017-07-04 16:04:44 -07002698 public static final String IMSI_KEY_AVAILABILITY_INT = "imsi_key_availability_int";
2699
Naveen Kallaabd28422017-07-11 20:03:58 -07002700 /**
2701 * Key identifying if the CDMA Caller ID presentation and suppression MMI codes
2702 * should be converted to 3GPP CLIR codes when a multimode (CDMA+UMTS+LTE) device is roaming
2703 * on a 3GPP network. Specifically *67<number> will be converted to #31#<number> and
2704 * *82<number> will be converted to *31#<number> before dialing a call when this key is
2705 * set TRUE and device is roaming on a 3GPP network.
2706 * @hide
2707 */
2708 public static final String KEY_CONVERT_CDMA_CALLER_ID_MMI_CODES_WHILE_ROAMING_ON_3GPP_BOOL =
2709 "convert_cdma_caller_id_mmi_codes_while_roaming_on_3gpp_bool";
2710
Ping Sune0e3cbd2016-03-02 19:09:27 +08002711 /**
2712 * Flag specifying whether IMS registration state menu is shown in Status Info setting,
2713 * default to false.
Ping Sune0e3cbd2016-03-02 19:09:27 +08002714 */
2715 public static final String KEY_SHOW_IMS_REGISTRATION_STATUS_BOOL =
2716 "show_ims_registration_status_bool";
2717
Omata Shou9766b182017-08-22 17:17:55 +09002718 /**
Hall Liu47ed6202017-11-20 16:25:39 -08002719 * Flag indicating whether the carrier supports RTT over IMS.
2720 */
2721 public static final String KEY_RTT_SUPPORTED_BOOL = "rtt_supported_bool";
2722
2723 /**
Tyler Gunne4d72b42019-02-25 10:42:45 -08002724 * Boolean flag indicating whether the carrier supports TTY.
2725 * <p>
2726 * Note that {@link #KEY_CARRIER_VOLTE_TTY_SUPPORTED_BOOL} controls availability of TTY over
2727 * VoLTE; if {@link #KEY_TTY_SUPPORTED_BOOL} is disabled, then
2728 * {@link #KEY_CARRIER_VOLTE_TTY_SUPPORTED_BOOL} is also implicitly disabled.
2729 * <p>
2730 * {@link TelecomManager#isTtySupported()} should be used to determine if a device supports TTY,
2731 * and this carrier config key should be used to see if the current carrier supports it.
2732 */
2733 public static final String KEY_TTY_SUPPORTED_BOOL = "tty_supported_bool";
2734
2735 /**
Hall Liu86fec032018-10-09 16:33:45 -07002736 * Indicates if the carrier supports auto-upgrading a call to RTT when receiving a call from a
2737 * RTT-supported device.
2738 * @hide
2739 */
2740 public static final String KEY_RTT_AUTO_UPGRADE_BOOL = "rtt_auto_upgrade_bool";
2741
2742 /**
2743 * Indicates if the carrier supports RTT during a video call.
2744 * @hide
2745 */
2746 public static final String KEY_RTT_SUPPORTED_FOR_VT_BOOL = "rtt_supported_for_vt_bool";
2747
2748 /**
2749 * Indicates if the carrier supports upgrading a voice call to an RTT call during the call.
2750 * @hide
2751 */
2752 public static final String KEY_RTT_UPGRADE_SUPPORTED_BOOL = "rtt_upgrade_supported_bool";
2753
2754 /**
2755 * Indicates if the carrier supports downgrading a RTT call to a voice call during the call.
2756 * @hide
2757 */
2758 public static final String KEY_RTT_DOWNGRADE_SUPPORTED_BOOL = "rtt_downgrade_supported_bool";
2759
2760 /**
Hall Liu3a23d7e2019-07-29 17:30:12 -07002761 * Indicates if the TTY HCO and VCO options should be hidden in the accessibility menu
2762 * if the device is capable of RTT.
2763 * @hide
2764 */
2765 public static final String KEY_HIDE_TTY_HCO_VCO_WITH_RTT_BOOL = "hide_tty_hco_vco_with_rtt";
2766
2767 /**
Omata Shou9766b182017-08-22 17:17:55 +09002768 * The flag to disable the popup dialog which warns the user of data charges.
Omata Shou9766b182017-08-22 17:17:55 +09002769 */
2770 public static final String KEY_DISABLE_CHARGE_INDICATION_BOOL =
2771 "disable_charge_indication_bool";
2772
DongYuchen439f16d2017-02-16 18:22:36 +08002773 /**
2774 * Boolean indicating whether to skip the call forwarding (CF) fail-to-disable dialog.
2775 * The logic used to determine whether we succeeded in disabling is carrier specific,
2776 * so the dialog may not always be accurate.
2777 * {@code false} - show CF fail-to-disable dialog.
2778 * {@code true} - skip showing CF fail-to-disable dialog.
2779 *
2780 * @hide
2781 */
2782 public static final String KEY_SKIP_CF_FAIL_TO_DISABLE_DIALOG_BOOL =
2783 "skip_cf_fail_to_disable_dialog_bool";
2784
Kazuya Ohshiro990af172017-09-27 16:02:55 +09002785 /**
manabu, shimoda6ce31382017-12-25 18:38:47 +09002786 * Flag specifying whether operator supports including no reply condition timer option on
2787 * CFNRy (3GPP TS 24.082 3: Call Forwarding on No Reply) in the call forwarding settings UI.
2788 * {@code true} - include no reply condition timer option on CFNRy
2789 * {@code false} - don't include no reply condition timer option on CFNRy
2790 *
2791 * @hide
2792 */
2793 public static final String KEY_SUPPORT_NO_REPLY_TIMER_FOR_CFNRY_BOOL =
2794 "support_no_reply_timer_for_cfnry_bool";
2795
2796 /**
Kazuya Ohshiro990af172017-09-27 16:02:55 +09002797 * List of the FAC (feature access codes) to dial as a normal call.
2798 * @hide
2799 */
2800 public static final String KEY_FEATURE_ACCESS_CODES_STRING_ARRAY =
2801 "feature_access_codes_string_array";
2802
Kazuya Ohshirob8981ba2017-10-27 16:26:15 +09002803 /**
2804 * Determines if the carrier wants to identify high definition calls in the call log.
2805 * @hide
2806 */
2807 public static final String KEY_IDENTIFY_HIGH_DEFINITION_CALLS_IN_CALL_LOG_BOOL =
2808 "identify_high_definition_calls_in_call_log_bool";
2809
Masaho Nishikawa40184352017-11-01 20:33:36 +09002810 /**
2811 * Flag specifying whether to use the {@link ServiceState} roaming status, which can be
2812 * affected by other carrier configs (e.g.
2813 * {@link #KEY_GSM_NONROAMING_NETWORKS_STRING_ARRAY}), when setting the SPN display.
2814 * <p>
2815 * If {@code true}, the SPN display uses {@link ServiceState#getRoaming}.
2816 * If {@code false} the SPN display checks if the current MCC/MNC is different from the
2817 * SIM card's MCC/MNC.
2818 *
2819 * @see KEY_GSM_ROAMING_NETWORKS_STRING_ARRAY
2820 * @see KEY_GSM_NONROAMING_NETWORKS_STRING_ARRAY
2821 * @see KEY_NON_ROAMING_OPERATOR_STRING_ARRAY
2822 * @see KEY_ROAMING_OPERATOR_STRING_ARRAY
2823 * @see KEY_FORCE_HOME_NETWORK_BOOL
2824 *
2825 * @hide
2826 */
2827 public static final String KEY_SPN_DISPLAY_RULE_USE_ROAMING_FROM_SERVICE_STATE_BOOL =
2828 "spn_display_rule_use_roaming_from_service_state_bool";
2829
yinxu0d56f3c2017-11-29 15:02:05 -08002830 /**
2831 * Determines whether any carrier has been identified and its specific config has been applied,
2832 * default to false.
yinxu0d56f3c2017-11-29 15:02:05 -08002833 */
2834 public static final String KEY_CARRIER_CONFIG_APPLIED_BOOL = "carrier_config_applied_bool";
2835
pkanwar1e96fae2018-01-03 18:41:18 -08002836 /**
2837 * Determines whether we should show a warning asking the user to check with their carrier
Sarah China912e112020-01-09 10:43:30 -08002838 * on pricing when the user enabled data roaming,
pkanwar1e96fae2018-01-03 18:41:18 -08002839 * default to false.
pkanwar1e96fae2018-01-03 18:41:18 -08002840 */
2841 public static final String KEY_CHECK_PRICING_WITH_CARRIER_FOR_DATA_ROAMING_BOOL =
2842 "check_pricing_with_carrier_data_roaming_bool";
2843
Jordan Liub5fbb912019-07-23 15:52:08 -07002844 /**
2845 * Determines whether we should show a notification when the phone established a data
2846 * connection in roaming network, to warn users about possible roaming charges.
2847 * @hide
2848 */
2849 public static final String KEY_SHOW_DATA_CONNECTED_ROAMING_NOTIFICATION_BOOL =
2850 "show_data_connected_roaming_notification";
2851
Kitta Koutarou911f56c2017-12-01 19:19:49 +09002852 /**
Jordan Liu407b4792018-02-26 15:50:21 -08002853 * A list of 4 LTE RSRP thresholds above which a signal level is considered POOR,
2854 * MODERATE, GOOD, or EXCELLENT, to be used in SignalStrength reporting.
2855 *
2856 * Note that the min and max thresholds are fixed at -140 and -44, as explained in
2857 * TS 136.133 9.1.4 - RSRP Measurement Report Mapping.
2858 * <p>
2859 * See SignalStrength#MAX_LTE_RSRP and SignalStrength#MIN_LTE_RSRP. Any signal level outside
2860 * these boundaries is considered invalid.
Kitta Koutarou911f56c2017-12-01 19:19:49 +09002861 * @hide
2862 */
2863 public static final String KEY_LTE_RSRP_THRESHOLDS_INT_ARRAY =
2864 "lte_rsrp_thresholds_int_array";
2865
Malcolm Chenec102212018-01-29 15:10:46 -08002866 /**
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09002867 * A list of 4 customized LTE Reference Signal Received Quality (RSRQ) thresholds.
2868 *
2869 * Reference: TS 136.133 v12.6.0 section 9.1.7 - RSRQ Measurement Report Mapping.
2870 *
2871 * 4 threshold integers must be within the boundaries [-34 dB, 3 dB], and the levels are:
2872 * "NONE: [-34, threshold1)"
2873 * "POOR: [threshold1, threshold2)"
2874 * "MODERATE: [threshold2, threshold3)"
2875 * "GOOD: [threshold3, threshold4)"
2876 * "EXCELLENT: [threshold4, 3]"
2877 *
2878 * This key is considered invalid if the format is violated. If the key is invalid or
2879 * not configured, a default value set will apply.
2880 */
2881 public static final String KEY_LTE_RSRQ_THRESHOLDS_INT_ARRAY =
2882 "lte_rsrq_thresholds_int_array";
2883
2884 /**
2885 * A list of 4 customized LTE Reference Signal Signal to Noise Ratio (RSSNR) thresholds.
2886 *
Shuo Qian6775b772020-06-11 10:32:17 -07002887 * 4 threshold integers must be within the boundaries [-20 dB, 30 dB], and the levels are:
2888 * "NONE: [-20, threshold1)"
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09002889 * "POOR: [threshold1, threshold2)"
2890 * "MODERATE: [threshold2, threshold3)"
2891 * "GOOD: [threshold3, threshold4)"
Shuo Qian6775b772020-06-11 10:32:17 -07002892 * "EXCELLENT: [threshold4, 30]"
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09002893 *
2894 * This key is considered invalid if the format is violated. If the key is invalid or
2895 * not configured, a default value set will apply.
2896 */
2897 public static final String KEY_LTE_RSSNR_THRESHOLDS_INT_ARRAY =
2898 "lte_rssnr_thresholds_int_array";
2899
2900 /**
Malcolm Chenec102212018-01-29 15:10:46 -08002901 * Decides when clients try to bind to iwlan network service, which package name will
2902 * the binding intent go to.
2903 * @hide
2904 */
Jack Yu4d21a402018-08-27 16:59:05 -07002905 public static final String KEY_CARRIER_NETWORK_SERVICE_WLAN_PACKAGE_OVERRIDE_STRING =
2906 "carrier_network_service_wlan_package_override_string";
Malcolm Chenec102212018-01-29 15:10:46 -08002907
2908 /**
Yatai Lin6ed1ada2019-04-09 10:24:15 +08002909 * Decides when clients try to bind to iwlan network service, which class name will
2910 * the binding intent go to.
2911 * @hide
2912 */
2913 public static final String KEY_CARRIER_NETWORK_SERVICE_WLAN_CLASS_OVERRIDE_STRING =
2914 "carrier_network_service_wlan_class_override_string";
2915
2916 /**
Malcolm Chenec102212018-01-29 15:10:46 -08002917 * Decides when clients try to bind to wwan (cellular) network service, which package name will
2918 * the binding intent go to.
2919 * @hide
2920 */
Jack Yu4d21a402018-08-27 16:59:05 -07002921 public static final String KEY_CARRIER_NETWORK_SERVICE_WWAN_PACKAGE_OVERRIDE_STRING =
2922 "carrier_network_service_wwan_package_override_string";
Malcolm Chenec102212018-01-29 15:10:46 -08002923
Tomita, Ryounosuke Xd41feee2017-12-13 18:46:12 +09002924 /**
Yatai Lin6ed1ada2019-04-09 10:24:15 +08002925 * Decides when clients try to bind to wwan (cellular) network service, which class name will
2926 * the binding intent go to.
2927 * @hide
2928 */
2929 public static final String KEY_CARRIER_NETWORK_SERVICE_WWAN_CLASS_OVERRIDE_STRING =
2930 "carrier_network_service_wwan_class_override_string";
2931
2932 /**
Jack Yu4d21a402018-08-27 16:59:05 -07002933 * The package name of qualified networks service that telephony binds to.
2934 *
2935 * @hide
2936 */
2937 public static final String KEY_CARRIER_QUALIFIED_NETWORKS_SERVICE_PACKAGE_OVERRIDE_STRING =
2938 "carrier_qualified_networks_service_package_override_string";
Yatai Lin6ed1ada2019-04-09 10:24:15 +08002939
2940 /**
2941 * The class name of qualified networks service that telephony binds to.
2942 *
2943 * @hide
2944 */
2945 public static final String KEY_CARRIER_QUALIFIED_NETWORKS_SERVICE_CLASS_OVERRIDE_STRING =
2946 "carrier_qualified_networks_service_class_override_string";
Jack Yu4d21a402018-08-27 16:59:05 -07002947 /**
Tomita, Ryounosuke Xd41feee2017-12-13 18:46:12 +09002948 * A list of 4 LTE RSCP thresholds above which a signal level is considered POOR,
2949 * MODERATE, GOOD, or EXCELLENT, to be used in SignalStrength reporting.
2950 *
2951 * Note that the min and max thresholds are fixed at -120 and -24, as set in 3GPP TS 27.007
2952 * section 8.69.
2953 * <p>
2954 * See SignalStrength#MAX_WCDMA_RSCP and SignalStrength#MIN_WDCMA_RSCP. Any signal level outside
2955 * these boundaries is considered invalid.
2956 * @hide
2957 */
2958 public static final String KEY_WCDMA_RSCP_THRESHOLDS_INT_ARRAY =
2959 "wcdma_rscp_thresholds_int_array";
2960
2961 /**
2962 * The default measurement to use for signal strength reporting. If this is not specified, the
2963 * RSSI is used.
2964 * <p>
2965 * e.g.) To use RSCP by default, set the value to "rscp". The signal strength level will
2966 * then be determined by #KEY_WCDMA_RSCP_THRESHOLDS_INT_ARRAY
2967 * <p>
Nathan Harold549c3ba2019-01-03 10:30:31 -08002968 * Currently this supports the value "rscp" and "rssi".
Tomita, Ryounosuke Xd41feee2017-12-13 18:46:12 +09002969 * @hide
2970 */
Nathan Haroldf23153f2018-11-19 18:09:40 -08002971 // FIXME: this key and related keys must not be exposed without a consistent philosophy for
2972 // all RATs.
Tomita, Ryounosuke Xd41feee2017-12-13 18:46:12 +09002973 public static final String KEY_WCDMA_DEFAULT_SIGNAL_STRENGTH_MEASUREMENT_STRING =
2974 "wcdma_default_signal_strength_measurement_string";
2975
Malcolm Chenb56234f2018-04-16 15:20:38 -07002976 /**
2977 * When a partial sms / mms message stay in raw table for too long without being completed,
2978 * we expire them and delete them from the raw table. This carrier config defines the
2979 * expiration time.
2980 * @hide
2981 */
2982 public static final String KEY_UNDELIVERED_SMS_MESSAGE_EXPIRATION_TIME =
2983 "undelivered_sms_message_expiration_time";
2984
sqianea8970c2018-06-06 22:54:04 -07002985 /**
sqian4be071a2019-03-18 14:10:53 -07002986 * Specifies a carrier-defined {@link android.telecom.CallRedirectionService} which Telecom
2987 * will bind to for outgoing calls. An empty string indicates that no carrier-defined
2988 * {@link android.telecom.CallRedirectionService} is specified.
sqianea8970c2018-06-06 22:54:04 -07002989 */
2990 public static final String KEY_CALL_REDIRECTION_SERVICE_COMPONENT_NAME_STRING =
2991 "call_redirection_service_component_name_string";
Sarah China912e112020-01-09 10:43:30 -08002992
Mengjun Lengc9356222018-08-28 11:05:34 +08002993 /**
2994 * Support for the original string display of CDMA MO call.
2995 * By default, it is disabled.
2996 * @hide
2997 */
2998 public static final String KEY_CONFIG_SHOW_ORIG_DIAL_STRING_FOR_CDMA_BOOL =
2999 "config_show_orig_dial_string_for_cdma";
sqianea8970c2018-06-06 22:54:04 -07003000
Kikkawa Shohei638d11e2018-09-21 17:06:07 +09003001 /**
3002 * Flag specifying whether to show notification(call blocking disabled) when Enhanced Call
3003 * Blocking(KEY_SUPPORT_ENHANCED_CALL_BLOCKING_BOOL) is enabled and making emergency call.
3004 * When true, notification is shown always.
3005 * When false, notification is shown only when any setting of "Enhanced Blocked number" is
3006 * enabled.
3007 */
3008 public static final String KEY_SHOW_CALL_BLOCKING_DISABLED_NOTIFICATION_ALWAYS_BOOL =
3009 "show_call_blocking_disabled_notification_always_bool";
3010
SongFerngWang165d2d22018-07-09 21:10:26 +08003011 /**
3012 * Some carriers only support SS over UT via INTERNET PDN.
3013 * When mobile data is OFF or data roaming OFF during roaming,
3014 * UI should block the call forwarding operation and notify the user
3015 * that the function only works if data is available.
3016 * @hide
3017 */
3018 public static final String KEY_CALL_FORWARDING_OVER_UT_WARNING_BOOL =
3019 "call_forwarding_over_ut_warning_bool";
3020
3021 /**
3022 * Some carriers only support SS over UT via INTERNET PDN.
3023 * When mobile data is OFF or data roaming OFF during roaming,
3024 * UI should block the call barring operation and notify the user
3025 * that the function only works if data is available.
3026 * @hide
3027 */
3028 public static final String KEY_CALL_BARRING_OVER_UT_WARNING_BOOL =
3029 "call_barring_over_ut_warning_bool";
3030
3031 /**
3032 * Some carriers only support SS over UT via INTERNET PDN.
3033 * When mobile data is OFF or data roaming OFF during roaming,
3034 * UI should block the caller id operation and notify the user
3035 * that the function only works if data is available.
3036 * @hide
3037 */
3038 public static final String KEY_CALLER_ID_OVER_UT_WARNING_BOOL =
3039 "caller_id_over_ut_warning_bool";
3040
3041 /**
3042 * Some carriers only support SS over UT via INTERNET PDN.
3043 * When mobile data is OFF or data roaming OFF during roaming,
3044 * UI should block the call waiting operation and notify the user
3045 * that the function only works if data is available.
3046 * @hide
3047 */
3048 public static final String KEY_CALL_WAITING_OVER_UT_WARNING_BOOL =
3049 "call_waiting_over_ut_warning_bool";
3050
Youming Ye568455f2018-10-24 14:54:39 -07003051 /**
3052 * Flag indicating whether to support "Network default" option in Caller ID settings for Calling
3053 * Line Identification Restriction (CLIR).
3054 */
3055 public static final String KEY_SUPPORT_CLIR_NETWORK_DEFAULT_BOOL =
3056 "support_clir_network_default_bool";
3057
Chuck Liao3bad37e2018-10-30 11:39:56 +08003058 /**
3059 * Determines whether the carrier want to support emergency dialer shortcut.
3060 * @hide
3061 */
3062 public static final String KEY_SUPPORT_EMERGENCY_DIALER_SHORTCUT_BOOL =
3063 "support_emergency_dialer_shortcut_bool";
3064
SongFerngWangc64d9702018-10-24 11:37:13 +08003065 /**
3066 * Call forwarding uses USSD command without SS command.
3067 * When {@code true}, the call forwarding query/set by ussd command and UI only display Call
3068 * Forwarding when unanswered.
3069 * When {@code false}, don't use USSD to query/set call forwarding.
3070 * @hide
3071 */
3072 public static final String KEY_USE_CALL_FORWARDING_USSD_BOOL = "use_call_forwarding_ussd_bool";
3073
3074 /**
3075 * This flag specifies whether to support for the caller id set command by ussd.
3076 * When {@code true}, device shall sync caller id ussd result to ss command.
3077 * When {@code false}, caller id don't support ussd command.
3078 * @hide
3079 */
3080 public static final String KEY_USE_CALLER_ID_USSD_BOOL = "use_caller_id_ussd_bool";
3081
3082 /**
3083 * Specifies the service class for call waiting service.
3084 * Default value is
3085 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_VOICE}.
3086 * <p>
3087 * See 27.007 +CCFC or +CLCK.
3088 * The value set as below:
3089 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_NONE}
3090 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_VOICE}
3091 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_DATA}
3092 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_FAX}
3093 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_SMS}
3094 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_DATA_SYNC}
3095 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_DATA_ASYNC}
3096 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_PACKET}
3097 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_PAD}
3098 * {@link com.android.internal.telephony.CommandsInterface#SERVICE_CLASS_MAX}
3099 * @hide
3100 */
3101 public static final String KEY_CALL_WAITING_SERVICE_CLASS_INT =
3102 "call_waiting_service_class_int";
3103
Pengquan Mengdfb39562018-12-05 16:26:42 -08003104 /**
Sarah China912e112020-01-09 10:43:30 -08003105 * This configuration allows the system UI to display different 5G icons for different 5G
3106 * scenarios.
Pengquan Mengdfb39562018-12-05 16:26:42 -08003107 *
SongFerngWang52dada72019-08-14 16:59:29 +08003108 * There are five 5G scenarios:
Pengquan Mengdfb39562018-12-05 16:26:42 -08003109 * 1. connected_mmwave: device currently connected to 5G cell as the secondary cell and using
3110 * millimeter wave.
3111 * 2. connected: device currently connected to 5G cell as the secondary cell but not using
3112 * millimeter wave.
SongFerngWang52dada72019-08-14 16:59:29 +08003113 * 3. not_restricted_rrc_idle: device camped on a network that has 5G capability(not necessary
3114 * to connect a 5G cell as a secondary cell) and the use of 5G is not restricted and RRC
3115 * currently in IDLE state.
3116 * 4. not_restricted_rrc_con: device camped on a network that has 5G capability(not necessary
3117 * to connect a 5G cell as a secondary cell) and the use of 5G is not restricted and RRC
3118 * currently in CONNECTED state.
3119 * 5. restricted: device camped on a network that has 5G capability(not necessary to connect a
Pengquan Mengdfb39562018-12-05 16:26:42 -08003120 * 5G cell as a secondary cell) but the use of 5G is restricted.
3121 *
3122 * The configured string contains multiple key-value pairs separated by comma. For each pair,
Sarah China912e112020-01-09 10:43:30 -08003123 * the key and value are separated by a colon. The key corresponds to a 5G status above and
Pengquan Mengdfb39562018-12-05 16:26:42 -08003124 * the value is the icon name. Use "None" as the icon name if no icon should be shown in a
SongFerngWang52dada72019-08-14 16:59:29 +08003125 * specific 5G scenario. If the scenario is "None", config can skip this key and value.
Pengquan Mengdfb39562018-12-05 16:26:42 -08003126 *
SongFerngWangb532af62019-08-20 22:32:16 +08003127 * Icon name options: "5G_Plus", "5G".
3128 *
SongFerngWang52dada72019-08-14 16:59:29 +08003129 * Here is an example:
Sarah China912e112020-01-09 10:43:30 -08003130 * UE wants to display 5G_Plus icon for scenario#1, and 5G icon for scenario#2; otherwise not
SongFerngWang52dada72019-08-14 16:59:29 +08003131 * define.
SongFerngWangb532af62019-08-20 22:32:16 +08003132 * The configuration is: "connected_mmwave:5G_Plus,connected:5G"
Sarah Chinb800cbd2020-02-19 12:25:36 -08003133 * @hide
Pengquan Mengdfb39562018-12-05 16:26:42 -08003134 */
Sarah Chinb800cbd2020-02-19 12:25:36 -08003135 public static final String KEY_5G_ICON_CONFIGURATION_STRING = "5g_icon_configuration_string";
Pengquan Mengdfb39562018-12-05 16:26:42 -08003136
Sooraj Sasindran873252f2018-12-11 10:35:16 -08003137 /**
Sarah Chin46941d62020-04-20 21:11:40 -07003138 * This configuration allows the system UI to determine how long to continue to display 5G icons
3139 * when the device switches between different 5G scenarios.
3140 *
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07003141 * There are seven 5G scenarios:
Sarah Chin46941d62020-04-20 21:11:40 -07003142 * 1. connected_mmwave: device currently connected to 5G cell as the secondary cell and using
3143 * millimeter wave.
3144 * 2. connected: device currently connected to 5G cell as the secondary cell but not using
3145 * millimeter wave.
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07003146 * 3. not_restricted_rrc_idle: device camped on a network that has 5G capability (not necessary
Sarah Chin46941d62020-04-20 21:11:40 -07003147 * to connect a 5G cell as a secondary cell) and the use of 5G is not restricted and RRC
3148 * currently in IDLE state.
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07003149 * 4. not_restricted_rrc_con: device camped on a network that has 5G capability (not necessary
Sarah Chin46941d62020-04-20 21:11:40 -07003150 * to connect a 5G cell as a secondary cell) and the use of 5G is not restricted and RRC
3151 * currently in CONNECTED state.
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07003152 * 5. restricted: device camped on a network that has 5G capability (not necessary to connect a
Sarah Chin46941d62020-04-20 21:11:40 -07003153 * 5G cell as a secondary cell) but the use of 5G is restricted.
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07003154 * 6. legacy: device is not camped on a network that has 5G capability
3155 * 7. any: any of the above scenarios
Sarah Chin46941d62020-04-20 21:11:40 -07003156 *
3157 * The configured string contains various timer rules separated by a semicolon.
3158 * Each rule will have three items: prior 5G scenario, current 5G scenario, and grace period
3159 * in seconds before changing the icon. When the 5G state changes from the prior to the current
3160 * 5G scenario, the system UI will continue to show the icon for the prior 5G scenario (defined
3161 * in {@link #KEY_5G_ICON_CONFIGURATION_STRING}) for the amount of time specified by the grace
3162 * period. If the prior 5G scenario is reestablished, the timer will reset and start again if
3163 * the UE changes 5G scenarios again. Defined states (5G scenarios #1-5) take precedence over
3164 * 'any' (5G scenario #6), and unspecified transitions have a default grace period of 0.
3165 * The order of rules in the configuration determines the priority (the first applicable timer
3166 * rule will be used).
3167 *
3168 * Here is an example: "connected_mmwave,connected,30;connected_mmwave,any,10;connected,any,10"
3169 * This configuration defines 3 timers:
3170 * 1. When UE goes from 'connected_mmwave' to 'connected', system UI will continue to display
3171 * the 5G icon for 'connected_mmwave' for 30 seconds.
3172 * 2. When UE goes from 'connected_mmwave' to any other state (except for connected, since
3173 * rule 1 would be used instead), system UI will continue to display the 5G icon for
3174 * 'connected_mmwave' for 10 seconds.
3175 * 3. When UE goes from 'connected' to any other state, system UI will continue to display the
3176 * 5G icon for 'connected' for 10 seconds.
3177 *
3178 * @hide
3179 */
3180 public static final String KEY_5G_ICON_DISPLAY_GRACE_PERIOD_STRING =
3181 "5g_icon_display_grace_period_string";
3182
3183 /**
3184 * This configuration extends {@link #KEY_5G_ICON_DISPLAY_GRACE_PERIOD_STRING} to allow the
3185 * system UI to continue displaying 5G icons after the initial timer expires.
3186 *
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07003187 * There are seven 5G scenarios:
Sarah Chin46941d62020-04-20 21:11:40 -07003188 * 1. connected_mmwave: device currently connected to 5G cell as the secondary cell and using
3189 * millimeter wave.
3190 * 2. connected: device currently connected to 5G cell as the secondary cell but not using
3191 * millimeter wave.
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07003192 * 3. not_restricted_rrc_idle: device camped on a network that has 5G capability (not necessary
Sarah Chin46941d62020-04-20 21:11:40 -07003193 * to connect a 5G cell as a secondary cell) and the use of 5G is not restricted and RRC
3194 * currently in IDLE state.
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07003195 * 4. not_restricted_rrc_con: device camped on a network that has 5G capability (not necessary
Sarah Chin46941d62020-04-20 21:11:40 -07003196 * to connect a 5G cell as a secondary cell) and the use of 5G is not restricted and RRC
3197 * currently in CONNECTED state.
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07003198 * 5. restricted: device camped on a network that has 5G capability (not necessary to connect a
Sarah Chin46941d62020-04-20 21:11:40 -07003199 * 5G cell as a secondary cell) but the use of 5G is restricted.
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07003200 * 6. legacy: device is not camped on a network that has 5G capability
3201 * 7. any: any of the above scenarios
Sarah Chin46941d62020-04-20 21:11:40 -07003202 *
3203 * The configured string contains various timer rules separated by a semicolon.
3204 * Each rule will have three items: primary 5G scenario, secondary 5G scenario, and
3205 * grace period in seconds before changing the icon. When the timer for the primary 5G timer
3206 * expires, the system UI will continue to show the icon for the primary 5G scenario (defined
3207 * in {@link #KEY_5G_ICON_CONFIGURATION_STRING}) for the amount of time specified by the grace
3208 * period. If the primary 5G scenario is reestablished, the timers will reset and the system UI
3209 * will continue to display the icon for the primary 5G scenario without interruption. If the
3210 * secondary 5G scenario is lost, the timer will reset and the icon will reflect the true state.
3211 * Defined states (5G scenarios #1-5) take precedence over 'any' (5G scenario #6), and
3212 * unspecified transitions have a default grace period of 0. The order of rules in the
3213 * configuration determines the priority (the first applicable timer rule will be used).
3214 *
3215 * Here is an example: "connected,not_restricted_rrc_idle,30"
3216 * This configuration defines a secondary timer that extends the primary 'connected' timer.
3217 * When the primary 'connected' timer expires while the UE is in the 'not_restricted_rrc_idle'
3218 * 5G state, system UI will continue to display the 5G icon for 'connected' for 30 seconds.
3219 * If the 5G state returns to 'connected', the timer will be reset without change to the icon,
3220 * and if the 5G state changes to neither 'connected' not 'not_restricted_rrc_idle', the icon
3221 * will change to reflect the true state.
3222 *
3223 * @hide
3224 */
3225 public static final String KEY_5G_ICON_DISPLAY_SECONDARY_GRACE_PERIOD_STRING =
3226 "5g_icon_display_secondary_grace_period_string";
3227
3228 /**
SongFerngWang3a3af2f2020-07-07 18:10:00 +08003229 * Whether device reset all of NR timers when device camped on a network that haven't 5G
3230 * capability and RRC currently in IDLE state.
3231 *
3232 * The default value is false;
3233 *
3234 * @hide
3235 */
3236 public static final String KEY_NR_TIMERS_RESET_IF_NON_ENDC_AND_RRC_IDLE_BOOL =
3237 "nr_timers_reset_if_non_endc_and_rrc_idle_bool";
3238
3239 /**
Sarah Chine0b991e2020-02-04 12:08:45 -08003240 * Controls time in milliseconds until DcTracker reevaluates 5G connection state.
Sarah Chinb800cbd2020-02-19 12:25:36 -08003241 * @hide
Sarah Chine0b991e2020-02-04 12:08:45 -08003242 */
Sarah Chine2642ad2020-03-19 21:13:02 -07003243 public static final String KEY_5G_WATCHDOG_TIME_MS_LONG = "5g_watchdog_time_ms_long";
Sarah Chine0b991e2020-02-04 12:08:45 -08003244
3245 /**
3246 * Whether NR (non-standalone) should be unmetered for all frequencies.
3247 * If either {@link #KEY_UNMETERED_NR_NSA_MMWAVE_BOOL} or
3248 * {@link #KEY_UNMETERED_NR_NSA_SUB6_BOOL} are true, then this value will be ignored.
3249 * @hide
3250 */
3251 public static final String KEY_UNMETERED_NR_NSA_BOOL = "unmetered_nr_nsa_bool";
3252
3253 /**
3254 * Whether NR (non-standalone) frequencies above 6GHz (millimeter wave) should be unmetered.
3255 * If this is true, then the value for {@link #KEY_UNMETERED_NR_NSA_BOOL} will be ignored.
3256 * @hide
3257 */
3258 public static final String KEY_UNMETERED_NR_NSA_MMWAVE_BOOL = "unmetered_nr_nsa_mmwave_bool";
3259
3260 /**
3261 * Whether NR (non-standalone) frequencies below 6GHz (sub6) should be unmetered.
3262 * If this is true, then the value for {@link #KEY_UNMETERED_NR_NSA_BOOL} will be ignored.
3263 * @hide
3264 */
3265 public static final String KEY_UNMETERED_NR_NSA_SUB6_BOOL = "unmetered_nr_nsa_sub6_bool";
3266
3267 /**
Sarah Chindc310312020-04-01 10:59:34 -07003268 * Whether NR (non-standalone) should be unmetered when the device is roaming.
3269 * If false, then the values for {@link #KEY_UNMETERED_NR_NSA_BOOL},
3270 * {@link #KEY_UNMETERED_NR_NSA_MMWAVE_BOOL}, {@link #KEY_UNMETERED_NR_NSA_SUB6_BOOL},
3271 * and unmetered {@link SubscriptionPlan} will be ignored.
3272 * @hide
3273 */
3274 public static final String KEY_UNMETERED_NR_NSA_WHEN_ROAMING_BOOL =
3275 "unmetered_nr_nsa_when_roaming_bool";
3276
3277 /**
Sarah Chin5956f302020-04-09 10:33:28 -07003278 * Whether NR (standalone) should be unmetered for all frequencies.
3279 * If either {@link #KEY_UNMETERED_NR_SA_MMWAVE_BOOL} or
3280 * {@link #KEY_UNMETERED_NR_SA_SUB6_BOOL} are true, then this value will be ignored.
3281 * @hide
3282 */
3283 public static final String KEY_UNMETERED_NR_SA_BOOL = "unmetered_nr_sa_bool";
3284
3285 /**
3286 * Whether NR (standalone) frequencies above 6GHz (millimeter wave) should be unmetered.
3287 * If this is true, then the value for {@link #KEY_UNMETERED_NR_SA_BOOL} will be ignored.
3288 * @hide
3289 */
3290 public static final String KEY_UNMETERED_NR_SA_MMWAVE_BOOL = "unmetered_nr_sa_mmwave_bool";
3291
3292 /**
3293 * Whether NR (standalone) frequencies below 6GHz (sub6) should be unmetered.
3294 * If this is true, then the value for {@link #KEY_UNMETERED_NR_SA_BOOL} will be ignored.
3295 * @hide
3296 */
3297 public static final String KEY_UNMETERED_NR_SA_SUB6_BOOL = "unmetered_nr_sa_sub6_bool";
3298
3299 /**
Sukanya Rajkhowa6de48e42018-08-20 16:35:36 +08003300 * Support ASCII 7-BIT encoding for long SMS. This carrier config is used to enable
3301 * this feature.
3302 * @hide
3303 */
3304 public static final String KEY_ASCII_7_BIT_SUPPORT_FOR_LONG_MESSAGE_BOOL =
3305 "ascii_7_bit_support_for_long_message_bool";
3306
3307 /**
Nishizawa Nobuhiro7feb6322020-01-30 18:01:36 +09003308 * Controls whether to show wifi calling icon in statusbar when wifi calling is available.
3309 * @hide
3310 */
3311 public static final String KEY_SHOW_WIFI_CALLING_ICON_IN_STATUS_BAR_BOOL =
3312 "show_wifi_calling_icon_in_status_bar_bool";
3313
3314 /**
Sooraj Sasindran73710f82019-01-09 11:09:22 -08003315 * Controls RSRP threshold at which OpportunisticNetworkService will decide whether
Sooraj Sasindran873252f2018-12-11 10:35:16 -08003316 * the opportunistic network is good enough for internet data.
3317 */
3318 public static final String KEY_OPPORTUNISTIC_NETWORK_ENTRY_THRESHOLD_RSRP_INT =
3319 "opportunistic_network_entry_threshold_rsrp_int";
3320
3321 /**
Sooraj Sasindran73710f82019-01-09 11:09:22 -08003322 * Controls RSSNR threshold at which OpportunisticNetworkService will decide whether
Sooraj Sasindran873252f2018-12-11 10:35:16 -08003323 * the opportunistic network is good enough for internet data.
3324 */
3325 public static final String KEY_OPPORTUNISTIC_NETWORK_ENTRY_THRESHOLD_RSSNR_INT =
3326 "opportunistic_network_entry_threshold_rssnr_int";
3327
3328 /**
Sooraj Sasindran73710f82019-01-09 11:09:22 -08003329 * Controls RSRP threshold below which OpportunisticNetworkService will decide whether
Sooraj Sasindran873252f2018-12-11 10:35:16 -08003330 * the opportunistic network available is not good enough for internet data.
3331 */
3332 public static final String KEY_OPPORTUNISTIC_NETWORK_EXIT_THRESHOLD_RSRP_INT =
3333 "opportunistic_network_exit_threshold_rsrp_int";
3334
3335 /**
Sooraj Sasindran73710f82019-01-09 11:09:22 -08003336 * Controls RSSNR threshold below which OpportunisticNetworkService will decide whether
Sooraj Sasindran873252f2018-12-11 10:35:16 -08003337 * the opportunistic network available is not good enough for internet data.
3338 */
3339 public static final String KEY_OPPORTUNISTIC_NETWORK_EXIT_THRESHOLD_RSSNR_INT =
3340 "opportunistic_network_exit_threshold_rssnr_int";
3341
Meng Wang19b214d2018-11-07 12:14:39 -08003342 /**
Sooraj Sasindran73710f82019-01-09 11:09:22 -08003343 * Controls bandwidth threshold in Kbps at which OpportunisticNetworkService will decide whether
3344 * the opportunistic network is good enough for internet data.
3345 */
3346 public static final String KEY_OPPORTUNISTIC_NETWORK_ENTRY_THRESHOLD_BANDWIDTH_INT =
3347 "opportunistic_network_entry_threshold_bandwidth_int";
3348
3349 /**
3350 * Controls hysteresis time in milli seconds for which OpportunisticNetworkService
3351 * will wait before attaching to a network.
3352 */
3353 public static final String KEY_OPPORTUNISTIC_NETWORK_ENTRY_OR_EXIT_HYSTERESIS_TIME_LONG =
3354 "opportunistic_network_entry_or_exit_hysteresis_time_long";
3355
3356 /**
3357 * Controls hysteresis time in milli seconds for which OpportunisticNetworkService
Sooraj Sasindran9f80e4b2019-08-01 13:52:32 -07003358 * will wait before switching data to an opportunistic network.
Sooraj Sasindran73710f82019-01-09 11:09:22 -08003359 */
3360 public static final String KEY_OPPORTUNISTIC_NETWORK_DATA_SWITCH_HYSTERESIS_TIME_LONG =
3361 "opportunistic_network_data_switch_hysteresis_time_long";
3362
3363 /**
Sooraj Sasindran9f80e4b2019-08-01 13:52:32 -07003364 * Controls hysteresis time in milli seconds for which OpportunisticNetworkService
3365 * will wait before switching data from opportunistic network to primary network.
Sooraj Sasindran9f80e4b2019-08-01 13:52:32 -07003366 */
3367 public static final String KEY_OPPORTUNISTIC_NETWORK_DATA_SWITCH_EXIT_HYSTERESIS_TIME_LONG =
3368 "opportunistic_network_data_switch_exit_hysteresis_time_long";
3369
3370 /**
Sooraj Sasindran75c09602019-09-13 10:40:32 -07003371 * Controls whether to do ping test before switching data to opportunistic network.
3372 * This carrier config is used to disable this feature.
Sooraj Sasindran75c09602019-09-13 10:40:32 -07003373 */
3374 public static final String KEY_PING_TEST_BEFORE_DATA_SWITCH_BOOL =
3375 "ping_test_before_data_switch_bool";
3376
3377 /**
Sooraj Sasindran8c04a5a2019-11-04 13:07:23 -08003378 * Controls whether to switch data to primary from opportunistic subscription
3379 * if primary is out of service. This control only affects system or 1st party app
3380 * initiated data switch, but will not override data switch initiated by privileged carrier apps
3381 * This carrier config is used to disable this feature.
Sooraj Sasindran8c04a5a2019-11-04 13:07:23 -08003382 */
3383 public static final String KEY_SWITCH_DATA_TO_PRIMARY_IF_PRIMARY_IS_OOS_BOOL =
3384 "switch_data_to_primary_if_primary_is_oos_bool";
3385
3386 /**
Sooraj Sasindran74891f22019-11-19 10:23:22 -08003387 * Controls the ping pong determination of opportunistic network.
3388 * If opportunistic network is determined as out of service or below
3389 * #KEY_OPPORTUNISTIC_NETWORK_EXIT_THRESHOLD_RSRP_INT or
3390 * #KEY_OPPORTUNISTIC_NETWORK_EXIT_THRESHOLD_RSSNR_INT within
3391 * #KEY_OPPORTUNISTIC_NETWORK_PING_PONG_TIME_LONG of switching to opportunistic network,
3392 * it will be determined as ping pong situation by system app or 1st party app.
Sooraj Sasindran74891f22019-11-19 10:23:22 -08003393 */
3394 public static final String KEY_OPPORTUNISTIC_NETWORK_PING_PONG_TIME_LONG =
3395 "opportunistic_network_ping_pong_time_long";
3396 /**
Sooraj Sasindran8c04a5a2019-11-04 13:07:23 -08003397 * Controls back off time in milli seconds for switching back to
3398 * opportunistic subscription. This time will be added to
3399 * {@link CarrierConfigManager#KEY_OPPORTUNISTIC_NETWORK_DATA_SWITCH_HYSTERESIS_TIME_LONG} to
Sooraj Sasindran74891f22019-11-19 10:23:22 -08003400 * determine hysteresis time if there is ping pong situation
Sooraj Sasindran8c04a5a2019-11-04 13:07:23 -08003401 * (determined by system app or 1st party app) between primary and opportunistic
Sooraj Sasindran74891f22019-11-19 10:23:22 -08003402 * subscription. Ping ping situation is defined in
3403 * #KEY_OPPORTUNISTIC_NETWORK_PING_PONG_TIME_LONG.
3404 * If ping pong situation continuous #KEY_OPPORTUNISTIC_NETWORK_BACKOFF_TIME_LONG
3405 * will be added to previously determined hysteresis time.
Sooraj Sasindran8c04a5a2019-11-04 13:07:23 -08003406 */
3407 public static final String KEY_OPPORTUNISTIC_NETWORK_BACKOFF_TIME_LONG =
3408 "opportunistic_network_backoff_time_long";
Sarah Chin92860a702019-08-19 18:08:21 -07003409
3410 /**
Sooraj Sasindran74891f22019-11-19 10:23:22 -08003411 * Controls the max back off time in milli seconds for switching back to
3412 * opportunistic subscription.
3413 * This time will be the max hysteresis that can be determined irrespective of there is
3414 * continuous ping pong situation or not as described in
3415 * #KEY_OPPORTUNISTIC_NETWORK_PING_PONG_TIME_LONG and
3416 * #KEY_OPPORTUNISTIC_NETWORK_BACKOFF_TIME_LONG.
Sooraj Sasindran74891f22019-11-19 10:23:22 -08003417 */
3418 public static final String KEY_OPPORTUNISTIC_NETWORK_MAX_BACKOFF_TIME_LONG =
3419 "opportunistic_network_max_backoff_time_long";
3420
3421 /**
sqian69f48c52019-02-15 16:19:36 -08003422 * Indicates zero or more emergency number prefix(es), because some carrier requires
3423 * if users dial an emergency number address with a specific prefix, the combination of the
3424 * prefix and the address is also a valid emergency number to dial. For example, an emergency
3425 * number prefix is 318, and the emergency number is 911. Both 318911 and 911 can be dialed by
3426 * users for emergency call. An empty array of string indicates that current carrier does not
3427 * have this requirement.
3428 */
3429 public static final String KEY_EMERGENCY_NUMBER_PREFIX_STRING_ARRAY =
3430 "emergency_number_prefix_string_array";
3431
3432 /**
Bonian Chen612e6a92019-03-26 01:49:39 +08003433 * Smart forwarding config. Smart forwarding is a feature to configure call forwarding to a
3434 * different SIM in the device when one SIM is not reachable. The config here specifies a smart
3435 * forwarding component that will launch UI for changing the configuration. An empty string
3436 * indicates that no smart forwarding component is specified.
3437 *
3438 * Currently, only one non-empty configuration of smart forwarding component within system will
3439 * be used when multiple SIMs are inserted.
3440 *
3441 * Empty string by default.
3442 *
3443 * @hide
3444 */
3445 public static final String KEY_SMART_FORWARDING_CONFIG_COMPONENT_NAME_STRING =
3446 "smart_forwarding_config_component_name_string";
3447
3448 /**
Malcolm Chen50ba9632019-02-26 16:49:56 -08003449 * Indicates when a carrier has a primary subscription and an opportunistic subscription active,
3450 * and when Internet data is switched to opportunistic network, whether to still show
3451 * signal bar of primary network. By default it will be false, meaning whenever data
3452 * is going over opportunistic network, signal bar will reflect signal strength and rat
3453 * icon of that network.
Malcolm Chen50ba9632019-02-26 16:49:56 -08003454 */
3455 public static final String KEY_ALWAYS_SHOW_PRIMARY_SIGNAL_BAR_IN_OPPORTUNISTIC_NETWORK_BOOLEAN =
3456 "always_show_primary_signal_bar_in_opportunistic_network_boolean";
3457
3458 /**
Malcolm Chen58f8d0f2019-10-31 15:06:19 -07003459 * Upon data switching between subscriptions within a carrier group, if switch depends on
3460 * validation result, this value defines customized value of how long we wait for validation
3461 * success before we fail and revoke the switch.
3462 * Time out is in milliseconds.
Malcolm Chen58f8d0f2019-10-31 15:06:19 -07003463 */
3464 public static final String KEY_DATA_SWITCH_VALIDATION_TIMEOUT_LONG =
3465 "data_switch_validation_timeout_long";
3466
3467 /**
Hai Shalom0a5b2072019-12-26 16:17:00 -08003468 * Specifies whether the system should prefix the EAP method to the anonymous identity.
3469 * The following prefix will be added if this key is set to TRUE:
3470 * EAP-AKA: "0"
3471 * EAP-SIM: "1"
3472 * EAP-AKA_PRIME: "6"
Hai Shalom0a5b2072019-12-26 16:17:00 -08003473 */
3474 public static final String ENABLE_EAP_METHOD_PREFIX_BOOL = "enable_eap_method_prefix_bool";
3475
3476 /**
Shuo Qian6fe660e2019-12-17 13:07:33 -08003477 * GPS configs. See the GNSS HAL documentation for more details.
Meng Wang19b214d2018-11-07 12:14:39 -08003478 */
3479 public static final class Gps {
Shuo Qian6fe660e2019-12-17 13:07:33 -08003480 private Gps() {}
3481
Meng Wang19b214d2018-11-07 12:14:39 -08003482 /** Prefix of all Gps.KEY_* constants. */
3483 public static final String KEY_PREFIX = "gps.";
3484
3485 /**
Brad Ebingerc9654c12019-05-30 16:31:57 -07003486 * Location information during (and after) an emergency call is only provided over control
3487 * plane signaling from the network.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003488 * @hide
Brad Ebingerc9654c12019-05-30 16:31:57 -07003489 */
3490 public static final int SUPL_EMERGENCY_MODE_TYPE_CP_ONLY = 0;
3491
3492 /**
3493 * Location information during (and after) an emergency call is provided over the data
3494 * plane and serviced by the framework GNSS service, but if it fails, the carrier also
3495 * supports control plane backup signaling.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003496 * @hide
Brad Ebingerc9654c12019-05-30 16:31:57 -07003497 */
3498 public static final int SUPL_EMERGENCY_MODE_TYPE_CP_FALLBACK = 1;
3499
3500 /**
3501 * Location information during (and after) an emergency call is provided over the data plane
3502 * and serviced by the framework GNSS service only. There is no backup signalling over the
3503 * control plane if it fails.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003504 * @hide
Brad Ebingerc9654c12019-05-30 16:31:57 -07003505 */
3506 public static final int SUPL_EMERGENCY_MODE_TYPE_DP_ONLY = 2;
3507
3508
3509 /**
Meng Wang19b214d2018-11-07 12:14:39 -08003510 * Determine whether current lpp_mode used for E-911 needs to be kept persistently.
3511 * {@code false} - not keeping the lpp_mode means using default configuration of gps.conf
3512 * when sim is not presented.
3513 * {@code true} - current lpp_profile of carrier will be kepted persistently
3514 * even after sim is removed. This is default.
3515 */
3516 public static final String KEY_PERSIST_LPP_MODE_BOOL = KEY_PREFIX + "persist_lpp_mode_bool";
3517
3518 /**
3519 * SUPL server host for SET Initiated & non-ES Network-Initiated SUPL requests.
3520 * Default to supl.google.com
Shuo Qian6fe660e2019-12-17 13:07:33 -08003521 * @hide
Meng Wang19b214d2018-11-07 12:14:39 -08003522 */
3523 public static final String KEY_SUPL_HOST_STRING = KEY_PREFIX + "supl_host";
3524
Shuo Qian6fe660e2019-12-17 13:07:33 -08003525 /**
3526 * SUPL server port. Default to 7275.
3527 * @hide
3528 */
Meng Wang19b214d2018-11-07 12:14:39 -08003529 public static final String KEY_SUPL_PORT_STRING = KEY_PREFIX + "supl_port";
3530
3531 /**
3532 * The SUPL version requested by Carrier. This is a bit mask
3533 * with bits 0:7 representing a service indicator field, bits 8:15
3534 * representing the minor version and bits 16:23 representing the
3535 * major version. Default to 0x20000.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003536 * @hide
Meng Wang19b214d2018-11-07 12:14:39 -08003537 */
3538 public static final String KEY_SUPL_VER_STRING = KEY_PREFIX + "supl_ver";
3539
3540 /**
3541 * SUPL_MODE configuration bit mask
3542 * 1 - Mobile Station Based. This is default.
3543 * 2 - Mobile Station Assisted.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003544 * @hide
Meng Wang19b214d2018-11-07 12:14:39 -08003545 */
3546 public static final String KEY_SUPL_MODE_STRING = KEY_PREFIX + "supl_mode";
3547
3548 /**
3549 * Whether to limit responses to SUPL ES mode requests only during user emergency sessions
3550 * (e.g. E911), and SUPL non-ES requests to only outside of non user emergency sessions.
3551 * 0 - no.
3552 * 1 - yes. This is default.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003553 * @hide
Meng Wang19b214d2018-11-07 12:14:39 -08003554 */
Meng Wang19b214d2018-11-07 12:14:39 -08003555 public static final String KEY_SUPL_ES_STRING = KEY_PREFIX + "supl_es";
3556
3557 /**
3558 * LTE Positioning Profile settings bit mask.
3559 * 0 - Radio Resource Location Protocol in user plane and control plane. This is default.
3560 * 1 - Enable LTE Positioning Protocol in user plane.
3561 * 2 - Enable LTE Positioning Protocol in control plane.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003562 * @hide
Meng Wang19b214d2018-11-07 12:14:39 -08003563 */
3564 public static final String KEY_LPP_PROFILE_STRING = KEY_PREFIX + "lpp_profile";
3565
3566 /**
3567 * Determine whether to use emergency PDN for emergency SUPL.
3568 * 0 - no.
3569 * 1 - yes. This is default.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003570 * @hide
Meng Wang19b214d2018-11-07 12:14:39 -08003571 */
3572 public static final String KEY_USE_EMERGENCY_PDN_FOR_EMERGENCY_SUPL_STRING =
3573 KEY_PREFIX + "use_emergency_pdn_for_emergency_supl";
3574
3575 /**
3576 * A_GLONASS_POS_PROTOCOL_SELECT bit mask.
3577 * 0 - Don't use A-GLONASS. This is default.
3578 * 1 - Use A-GLONASS in Radio Resource Control(RRC) control-plane.
3579 * 2 - Use A-GLONASS in Radio Resource Location user-plane.
3580 * 4 - Use A-GLONASS in LTE Positioning Protocol User plane.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003581 * @hide
Meng Wang19b214d2018-11-07 12:14:39 -08003582 */
3583 public static final String KEY_A_GLONASS_POS_PROTOCOL_SELECT_STRING =
3584 KEY_PREFIX + "a_glonass_pos_protocol_select";
3585
3586 /**
3587 * GPS_LOCK configuration bit mask to specify GPS device behavior toward other services,
3588 * when Location Settings are off.
3589 * "0" - No lock.
3590 * "1" - Lock Mobile Originated GPS functionalities.
3591 * "2" - Lock Network initiated GPS functionalities.
3592 * "3" - Lock both. This is default.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003593 * @hide
Meng Wang19b214d2018-11-07 12:14:39 -08003594 */
3595 public static final String KEY_GPS_LOCK_STRING = KEY_PREFIX + "gps_lock";
3596
3597 /**
Anil Admal0177f902019-01-17 14:23:37 -08003598 * Control Plane / SUPL NI emergency extension time in seconds. Default to "0".
Shuo Qian6fe660e2019-12-17 13:07:33 -08003599 * @hide
Meng Wang19b214d2018-11-07 12:14:39 -08003600 */
Anil Admalbefd4832019-05-09 19:58:13 -07003601 public static final String KEY_ES_EXTENSION_SEC_STRING = KEY_PREFIX + "es_extension_sec";
Meng Wang19b214d2018-11-07 12:14:39 -08003602
Anil Admal0177f902019-01-17 14:23:37 -08003603 /**
3604 * Space separated list of Android package names of proxy applications representing
3605 * the non-framework entities requesting location directly from GNSS without involving
3606 * the framework, as managed by IGnssVisibilityControl.hal. For example,
3607 * "com.example.mdt com.example.ims".
Shuo Qian6fe660e2019-12-17 13:07:33 -08003608 * @hide
Anil Admal0177f902019-01-17 14:23:37 -08003609 */
Anil Admalbefd4832019-05-09 19:58:13 -07003610 public static final String KEY_NFW_PROXY_APPS_STRING = KEY_PREFIX + "nfw_proxy_apps";
3611
Brad Ebingerc9654c12019-05-30 16:31:57 -07003612 /**
3613 * Determines whether or not SUPL ES mode supports a control-plane mechanism to get a user's
3614 * location in the event that data plane SUPL fails or is otherwise unavailable.
3615 * <p>
3616 * An integer value determines the support type of this carrier. If this carrier only
3617 * supports data plane SUPL ES, then the value will be
3618 * {@link #SUPL_EMERGENCY_MODE_TYPE_DP_ONLY}. If the carrier supports control plane fallback
3619 * for emergency SUPL, the value will be {@link #SUPL_EMERGENCY_MODE_TYPE_CP_FALLBACK}.
3620 * If the carrier does not support data plane SUPL using the framework, the value will be
3621 * {@link #SUPL_EMERGENCY_MODE_TYPE_CP_ONLY}.
3622 * <p>
3623 * The default value for this configuration is {@link #SUPL_EMERGENCY_MODE_TYPE_CP_ONLY}.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003624 * @hide
Brad Ebingerc9654c12019-05-30 16:31:57 -07003625 */
3626 public static final String KEY_ES_SUPL_CONTROL_PLANE_SUPPORT_INT = KEY_PREFIX
3627 + "es_supl_control_plane_support_int";
3628
Brad Ebinger82dc2792019-12-09 16:09:57 -08003629 /**
3630 * A list of roaming PLMNs where SUPL ES mode does not support a control-plane mechanism to
3631 * get a user's location in the event that data plane SUPL fails or is otherwise
3632 * unavailable.
3633 * <p>
3634 * A string array of PLMNs that do not support a control-plane mechanism for getting a
3635 * user's location for SUPL ES.
Shuo Qian6fe660e2019-12-17 13:07:33 -08003636 * @hide
Brad Ebinger82dc2792019-12-09 16:09:57 -08003637 */
3638 public static final String KEY_ES_SUPL_DATA_PLANE_ONLY_ROAMING_PLMN_STRING_ARRAY =
3639 KEY_PREFIX + "es_supl_data_plane_only_roaming_plmn_string_array";
3640
Meng Wang19b214d2018-11-07 12:14:39 -08003641 private static PersistableBundle getDefaults() {
3642 PersistableBundle defaults = new PersistableBundle();
3643 defaults.putBoolean(KEY_PERSIST_LPP_MODE_BOOL, true);
3644 defaults.putString(KEY_SUPL_HOST_STRING, "supl.google.com");
3645 defaults.putString(KEY_SUPL_PORT_STRING, "7275");
3646 defaults.putString(KEY_SUPL_VER_STRING, "0x20000");
3647 defaults.putString(KEY_SUPL_MODE_STRING, "1");
3648 defaults.putString(KEY_SUPL_ES_STRING, "1");
joethhuang851befb2019-07-25 16:33:09 +08003649 defaults.putString(KEY_LPP_PROFILE_STRING, "2");
Meng Wang19b214d2018-11-07 12:14:39 -08003650 defaults.putString(KEY_USE_EMERGENCY_PDN_FOR_EMERGENCY_SUPL_STRING, "1");
3651 defaults.putString(KEY_A_GLONASS_POS_PROTOCOL_SELECT_STRING, "0");
3652 defaults.putString(KEY_GPS_LOCK_STRING, "3");
Anil Admalbefd4832019-05-09 19:58:13 -07003653 defaults.putString(KEY_ES_EXTENSION_SEC_STRING, "0");
3654 defaults.putString(KEY_NFW_PROXY_APPS_STRING, "");
Brad Ebingerc9654c12019-05-30 16:31:57 -07003655 defaults.putInt(KEY_ES_SUPL_CONTROL_PLANE_SUPPORT_INT,
3656 SUPL_EMERGENCY_MODE_TYPE_CP_ONLY);
Brad Ebinger82dc2792019-12-09 16:09:57 -08003657 defaults.putStringArray(KEY_ES_SUPL_DATA_PLANE_ONLY_ROAMING_PLMN_STRING_ARRAY, null);
Meng Wang19b214d2018-11-07 12:14:39 -08003658 return defaults;
3659 }
3660 }
3661
chen xueb07e4e2019-02-08 17:40:33 -08003662 /**
3663 * An int array containing CDMA enhanced roaming indicator values for Home (non-roaming) network.
3664 * The default values come from 3GPP2 C.R1001 table 8.1-1.
3665 * Enhanced Roaming Indicator Number Assignments
3666 *
3667 * @hide
3668 */
3669 public static final String KEY_CDMA_ENHANCED_ROAMING_INDICATOR_FOR_HOME_NETWORK_INT_ARRAY =
3670 "cdma_enhanced_roaming_indicator_for_home_network_int_array";
3671
mavishsu00111212019-03-06 13:12:23 +08003672 /**
Minoru Sakuma7f3a9d02017-10-25 15:52:31 +09003673 * Determines whether wifi calling location privacy policy is shown.
Minoru Sakuma7f3a9d02017-10-25 15:52:31 +09003674 */
3675 public static final String KEY_SHOW_WFC_LOCATION_PRIVACY_POLICY_BOOL =
3676 "show_wfc_location_privacy_policy_bool";
3677
3678 /**
mavishsu00111212019-03-06 13:12:23 +08003679 * Indicates use 3GPP application to replace 3GPP2 application even if it's a CDMA/CDMA-LTE
3680 * phone, becasue some carriers's CSIM application is present but not supported.
3681 * @hide
3682 */
3683 public static final String KEY_USE_USIM_BOOL = "use_usim_bool";
3684
Seongho Kim93f78f52018-11-13 15:08:34 +09003685 /**
3686 * Determines whether the carrier wants to cancel the cs reject notification automatically
3687 * when the voice registration state changes.
3688 * If true, the notification will be automatically removed
3689 * when the voice registration state changes.
3690 * If false, the notification will persist until the user dismisses it,
3691 * the SIM is removed, or the device is rebooted.
3692 * @hide
3693 */
3694 public static final String KEY_AUTO_CANCEL_CS_REJECT_NOTIFICATION =
3695 "carrier_auto_cancel_cs_notification";
3696
Nathan Harold773b0822019-03-12 15:51:42 -07003697 /**
3698 * Passing this value as {@link KEY_SUBSCRIPTION_GROUP_UUID_STRING} will remove the
3699 * subscription from a group instead of adding it to a group.
3700 *
3701 * TODO: Expose in a future release.
3702 *
3703 * @hide
3704 */
3705 public static final String REMOVE_GROUP_UUID_STRING = "00000000-0000-0000-0000-000000000000";
3706
3707 /**
3708 * The UUID of a Group of related subscriptions in which to place the current subscription.
3709 *
3710 * A grouped subscription will behave for billing purposes and other UI purposes as though it
3711 * is a transparent extension of other subscriptions in the group.
3712 *
3713 * <p>If set to {@link #REMOVE_GROUP_UUID_STRING}, then the subscription will be removed from
3714 * its current group.
3715 *
3716 * TODO: unhide this key.
3717 *
3718 * @hide
3719 */
3720 public static final String KEY_SUBSCRIPTION_GROUP_UUID_STRING =
Nathan Haroldbbb89682019-04-11 16:33:26 -07003721 "subscription_group_uuid_string";
Nathan Harold773b0822019-03-12 15:51:42 -07003722
3723 /**
Malcolm Chen46e16492020-02-04 19:01:25 -08003724 * Data switch validation minimal gap time, in milliseconds.
3725 *
3726 * Which means, if the same subscription on the same network (based on MCC+MNC+TAC+subId)
3727 * was recently validated (within this time gap), and Telephony receives a request to switch to
3728 * it again, Telephony will skip the validation part and switch to it as soon as connection
3729 * is setup, as if it's already validated.
3730 *
3731 * If the network was validated within the gap but the latest validation result is false, the
3732 * validation will not be skipped.
3733 *
3734 * If not set or set to 0, validation will never be skipped.
3735 * The max acceptable value of this config is 24 hours.
3736 *
3737 * @hide
3738 */
3739 public static final String KEY_DATA_SWITCH_VALIDATION_MIN_GAP_LONG =
Malcolm Chen9859e172020-02-27 17:11:43 -08003740 "data_switch_validation_min_gap_long";
Malcolm Chen46e16492020-02-04 19:01:25 -08003741
3742 /**
Nathan Harold773b0822019-03-12 15:51:42 -07003743 * A boolean property indicating whether this subscription should be managed as an opportunistic
3744 * subscription.
3745 *
3746 * If true, then this subscription will be selected based on available coverage and will not be
3747 * available for a user in settings menus for selecting macro network providers. If unset,
3748 * defaults to “false”.
3749 *
3750 * TODO: unhide this key.
3751 *
3752 * @hide
3753 */
3754 public static final String KEY_IS_OPPORTUNISTIC_SUBSCRIPTION_BOOL =
Nathan Haroldbbb89682019-04-11 16:33:26 -07003755 "is_opportunistic_subscription_bool";
Nathan Harold773b0822019-03-12 15:51:42 -07003756
andychoub80dbce2019-04-09 14:50:31 +08003757 /**
Dheeraj Shetty054700a2019-05-23 18:22:05 -07003758 * Configs used by the IMS stack.
3759 */
3760 public static final class Ims {
3761 /** Prefix of all Ims.KEY_* constants. */
3762 public static final String KEY_PREFIX = "ims.";
3763
Jimmy Chen7e47f392019-12-03 09:49:10 +08003764 /**
3765 * Delay in milliseconds to turn off wifi when IMS is registered over wifi.
3766 */
Jimmy Chen8c3cfcd2020-02-26 09:34:46 +08003767 public static final String KEY_WIFI_OFF_DEFERRING_TIME_MILLIS_INT =
3768 KEY_PREFIX + "wifi_off_deferring_time_millis_int";
Dheeraj Shetty054700a2019-05-23 18:22:05 -07003769
3770 private Ims() {}
3771
3772 private static PersistableBundle getDefaults() {
3773 PersistableBundle defaults = new PersistableBundle();
radhika1599ce02020-03-03 11:47:14 -08003774 defaults.putInt(KEY_WIFI_OFF_DEFERRING_TIME_MILLIS_INT, 4000);
Dheeraj Shetty054700a2019-05-23 18:22:05 -07003775 return defaults;
3776 }
3777 }
3778
3779 /**
andychoub80dbce2019-04-09 14:50:31 +08003780 * A list of 4 GSM RSSI thresholds above which a signal level is considered POOR,
3781 * MODERATE, GOOD, or EXCELLENT, to be used in SignalStrength reporting.
3782 *
3783 * Note that the min and max thresholds are fixed at -113 and -51, as set in 3GPP TS 27.007
3784 * section 8.5.
3785 * <p>
3786 * See CellSignalStrengthGsm#GSM_RSSI_MAX and CellSignalStrengthGsm#GSM_RSSI_MIN. Any signal
3787 * level outside these boundaries is considered invalid.
3788 * @hide
3789 */
3790 public static final String KEY_GSM_RSSI_THRESHOLDS_INT_ARRAY =
3791 "gsm_rssi_thresholds_int_array";
Nathan Harold773b0822019-03-12 15:51:42 -07003792
andychoudcc0dd22019-05-08 23:24:08 +08003793 /**
3794 * Determines whether Wireless Priority Service call is supported over IMS.
3795 *
3796 * See Wireless Priority Service from https://www.fcc.gov/general/wireless-priority-service-wps
3797 * @hide
3798 */
3799 public static final String KEY_SUPPORT_WPS_OVER_IMS_BOOL =
3800 "support_wps_over_ims_bool";
3801
Nazanin Bakhshi9ed96bd2019-08-02 16:43:44 -07003802 /**
James.cf Lin8da1b072020-02-27 18:37:17 +08003803 * The two digital number pattern of MMI code which is defined by carrier.
3804 * If the dial number matches this pattern, it will be dialed out normally not USSD.
3805 *
3806 * @hide
3807 */
3808 public static final String KEY_MMI_TWO_DIGIT_NUMBER_PATTERN_STRING_ARRAY =
3809 "mmi_two_digit_number_pattern_string_array";
3810
3811 /**
Sarah China912e112020-01-09 10:43:30 -08003812 * Holds the list of carrier certificate hashes.
3813 * Note that each carrier has its own certificates.
Nazanin Bakhshi9ed96bd2019-08-02 16:43:44 -07003814 */
3815 public static final String KEY_CARRIER_CERTIFICATE_STRING_ARRAY =
3816 "carrier_certificate_string_array";
3817
Saki Oomori63bb8562018-08-22 16:07:07 +09003818 /**
3819 * DisconnectCause array to play busy tone. Value should be array of
3820 * {@link android.telephony.DisconnectCause}.
3821 */
3822 public static final String KEY_DISCONNECT_CAUSE_PLAY_BUSYTONE_INT_ARRAY =
3823 "disconnect_cause_play_busytone_int_array";
3824
Hideki Ishiide2688e2018-09-27 17:26:21 +09003825 /**
3826 * Flag specifying whether to prevent sending CLIR activation("*31#") and deactivation("#31#")
3827 * code only without dialing number.
3828 * When {@code true}, these are prevented, {@code false} otherwise.
3829 */
3830 public static final String KEY_PREVENT_CLIR_ACTIVATION_AND_DEACTIVATION_CODE_BOOL =
3831 "prevent_clir_activation_and_deactivation_code_bool";
3832
Dheeraj Shetty81a4f4e2020-01-15 16:30:18 -08003833 /**
Shinsuke Ishioka5ee45892018-08-30 13:33:30 +09003834 * Flag specifying whether to show forwarded number on call-in-progress screen.
3835 * When true, forwarded number is shown.
3836 * When false, forwarded number is not shown.
3837 */
3838 public static final String KEY_SHOW_FORWARDED_NUMBER_BOOL =
3839 "show_forwarded_number_bool";
3840
Jack Yu1e1ff942019-12-23 15:19:56 -08003841 /**
3842 * The list of originating address of missed incoming call SMS. If the SMS has originator
3843 * matched, the SMS will be treated as special SMS for notifying missed incoming call to the
3844 * user.
3845 *
3846 * @hide
3847 */
3848 public static final String KEY_MISSED_INCOMING_CALL_SMS_ORIGINATOR_STRING_ARRAY =
3849 "missed_incoming_call_sms_originator_string_array";
3850
Daniel Bright14ad8422020-03-24 14:53:59 -07003851
3852 /**
3853 * String array of Apn Type configurations.
3854 * The entries should be of form "APN_TYPE_NAME:priority".
3855 * priority is an integer that is sorted from highest to lowest.
3856 * example: cbs:5
3857 *
3858 * @hide
3859 */
3860 public static final String KEY_APN_PRIORITY_STRING_ARRAY = "apn_priority_string_array";
3861
Jack Yu1e1ff942019-12-23 15:19:56 -08003862 /**
3863 * The patterns of missed incoming call sms. This is the regular expression used for
3864 * matching the missed incoming call's date, time, and caller id. The pattern should match
3865 * fields for at least month, day, hour, and minute. Year is optional although it is encouraged.
3866 *
3867 * An usable pattern should look like this:
3868 * ^(?<month>0[1-9]|1[012])\/(?<day>0[1-9]|1[0-9]|2[0-9]|3[0-1]) (?<hour>[0-1][0-9]|2[0-3]):
3869 * (?<minute>[0-5][0-9])\s*(?<callerId>[0-9]+)\s*$
3870 *
3871 * @hide
3872 */
3873 public static final String KEY_MISSED_INCOMING_CALL_SMS_PATTERN_STRING_ARRAY =
3874 "missed_incoming_call_sms_pattern_string_array";
3875
Jack Yudb897af2020-06-24 12:43:31 -07003876 /**
3877 * Indicating whether DUN APN should be disabled when the device is roaming. In that case,
3878 * the default APN (i.e. internet) will be used for tethering.
3879 *
Amit Mahajan4f59bdd2020-09-18 15:17:28 -07003880 * This config is only available when using Preset APN(not user edited) as Preferred APN.
3881 *
Jack Yudb897af2020-06-24 12:43:31 -07003882 * @hide
3883 */
Amit Mahajan4f59bdd2020-09-18 15:17:28 -07003884 public static final String KEY_DISABLE_DUN_APN_WHILE_ROAMING_WITH_PRESET_APN_BOOL =
3885 "disable_dun_apn_while_roaming_with_preset_apn_bool";
3886
3887 /**
3888 * Where there is no preferred APN, specifies the carrier's default preferred APN.
3889 * Specifies the {@link android.provider.Telephony.Carriers.APN} of the default preferred apn.
3890 *
3891 * This config is only available with Preset APN(not user edited).
3892 *
3893 * @hide
3894 */
3895 public static final String KEY_DEFAULT_PREFERRED_APN_NAME_STRING =
3896 "default_preferred_apn_name_string";
Jack Yudb897af2020-06-24 12:43:31 -07003897
Sarah Chindc7260a2020-08-06 17:37:40 -07003898 /**
3899 * For Android 11, provide a temporary solution for OEMs to use the lower of the two MTU values
3900 * for IPv4 and IPv6 if both are sent.
3901 * TODO: remove in later release
3902 *
3903 * @hide
3904 */
3905 public static final String KEY_USE_LOWER_MTU_VALUE_IF_BOTH_RECEIVED =
3906 "use_lower_mtu_value_if_both_received";
3907
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08003908 /** The default value for every variable. */
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -07003909 private final static PersistableBundle sDefaults;
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08003910
3911 static {
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -07003912 sDefaults = new PersistableBundle();
Michele Berionne8ac8bd22018-12-05 11:05:33 -08003913 sDefaults.putString(KEY_CARRIER_CONFIG_VERSION_STRING, "");
Brad Ebingerc8601012016-07-19 14:09:23 -07003914 sDefaults.putBoolean(KEY_ALLOW_HOLD_IN_IMS_CALL_BOOL, true);
Pooja Jaind34698d2017-12-28 14:15:31 +05303915 sDefaults.putBoolean(KEY_CARRIER_ALLOW_DEFLECT_IMS_CALL_BOOL, false);
Ravi Palurif4b38e72020-02-05 12:35:41 +05303916 sDefaults.putBoolean(KEY_CARRIER_ALLOW_TRANSFER_IMS_CALL_BOOL, false);
Tyler Gunn30889422017-11-28 09:04:31 -08003917 sDefaults.putBoolean(KEY_ALWAYS_PLAY_REMOTE_HOLD_TONE_BOOL, false);
Hall Liuf31f3852018-07-25 18:48:55 -07003918 sDefaults.putBoolean(KEY_AUTO_RETRY_FAILED_WIFI_EMERGENCY_CALL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -07003919 sDefaults.putBoolean(KEY_ADDITIONAL_CALL_SETTING_BOOL, true);
3920 sDefaults.putBoolean(KEY_ALLOW_EMERGENCY_NUMBERS_IN_CALL_LOG_BOOL, false);
Hall Liue6e6ec42018-08-03 18:25:24 -07003921 sDefaults.putStringArray(KEY_UNLOGGABLE_NUMBERS_STRING_ARRAY, null);
Jonathan Basseri69822f02015-06-04 13:48:08 -07003922 sDefaults.putBoolean(KEY_ALLOW_LOCAL_DTMF_TONES_BOOL, true);
Tyler Gunnacdb6862018-01-29 14:30:52 -08003923 sDefaults.putBoolean(KEY_PLAY_CALL_RECORDING_TONE_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -07003924 sDefaults.putBoolean(KEY_APN_EXPAND_BOOL, true);
3925 sDefaults.putBoolean(KEY_AUTO_RETRY_ENABLED_BOOL, false);
3926 sDefaults.putBoolean(KEY_CARRIER_SETTINGS_ENABLE_BOOL, false);
3927 sDefaults.putBoolean(KEY_CARRIER_VOLTE_AVAILABLE_BOOL, false);
Junda Liue5c7ca72015-06-24 14:41:14 -07003928 sDefaults.putBoolean(KEY_CARRIER_VT_AVAILABLE_BOOL, false);
SongFerngWang27b6a582020-04-10 15:07:09 +08003929 sDefaults.putBoolean(KEY_VOLTE_5G_LIMITED_ALERT_DIALOG_BOOL, false);
Tyler Gunn481255d2016-08-16 16:04:48 -07003930 sDefaults.putBoolean(KEY_NOTIFY_HANDOVER_VIDEO_FROM_WIFI_TO_LTE_BOOL, false);
Hall Liuef800082019-07-29 16:18:30 -07003931 sDefaults.putBoolean(KEY_ALLOW_MERGING_RTT_CALLS_BOOL, false);
Tyler Gunn5ce0d3a2017-12-14 14:06:15 -08003932 sDefaults.putBoolean(KEY_NOTIFY_HANDOVER_VIDEO_FROM_LTE_TO_WIFI_BOOL, false);
Tyler Gunn86d5c3f2016-08-12 14:14:13 -07003933 sDefaults.putBoolean(KEY_SUPPORT_DOWNGRADE_VT_TO_AUDIO_BOOL, true);
Jordan Liu3ff30d22016-09-01 13:25:13 -07003934 sDefaults.putString(KEY_DEFAULT_VM_NUMBER_STRING, "");
SongFerngWang310f6d02018-03-23 15:07:05 +08003935 sDefaults.putString(KEY_DEFAULT_VM_NUMBER_ROAMING_STRING, "");
Saki Oomori0dd2dfb2018-09-11 15:44:25 +09003936 sDefaults.putString(KEY_DEFAULT_VM_NUMBER_ROAMING_AND_IMS_UNREGISTERED_STRING, "");
Cassie4c6f72c2017-10-10 14:33:38 -07003937 sDefaults.putBoolean(KEY_CONFIG_TELEPHONY_USE_OWN_NUMBER_FOR_VOICEMAIL_BOOL, false);
Tyler Gunn9a961f52017-08-17 15:58:47 -07003938 sDefaults.putBoolean(KEY_IGNORE_DATA_ENABLED_CHANGED_FOR_VIDEO_CALLS, true);
3939 sDefaults.putBoolean(KEY_VILTE_DATA_IS_METERED_BOOL, true);
Junda Liue4786492015-06-15 13:15:28 -07003940 sDefaults.putBoolean(KEY_CARRIER_WFC_IMS_AVAILABLE_BOOL, false);
fionaxudcf5c2b2016-05-12 13:40:05 -07003941 sDefaults.putBoolean(KEY_CARRIER_WFC_SUPPORTS_WIFI_ONLY_BOOL, false);
fionaxuc71e8242016-03-08 11:46:55 -08003942 sDefaults.putBoolean(KEY_CARRIER_DEFAULT_WFC_IMS_ENABLED_BOOL, false);
3943 sDefaults.putBoolean(KEY_CARRIER_DEFAULT_WFC_IMS_ROAMING_ENABLED_BOOL, false);
Tyler Gunnc3e6c932016-07-07 10:11:14 -07003944 sDefaults.putBoolean(KEY_CARRIER_PROMOTE_WFC_ON_CALL_FAIL_BOOL, false);
fionaxuc71e8242016-03-08 11:46:55 -08003945 sDefaults.putInt(KEY_CARRIER_DEFAULT_WFC_IMS_MODE_INT, 2);
Meng Wang2c25e4a2016-09-19 14:18:05 -07003946 sDefaults.putInt(KEY_CARRIER_DEFAULT_WFC_IMS_ROAMING_MODE_INT, 2);
Jack Yua4f2da32015-07-22 13:36:42 -07003947 sDefaults.putBoolean(KEY_CARRIER_FORCE_DISABLE_ETWS_CMAS_TEST_BOOL, false);
allenwtsuc2524a42020-01-03 18:18:11 +08003948 sDefaults.putBoolean(KEY_CARRIER_RCS_PROVISIONING_REQUIRED_BOOL, true);
Junda Liue5c7ca72015-06-24 14:41:14 -07003949 sDefaults.putBoolean(KEY_CARRIER_VOLTE_PROVISIONING_REQUIRED_BOOL, false);
Brad Ebingerb3f46322019-01-14 13:46:05 -08003950 sDefaults.putBoolean(KEY_CARRIER_UT_PROVISIONING_REQUIRED_BOOL, false);
Brad Ebingerbb9446d2019-03-27 09:46:56 -07003951 sDefaults.putBoolean(KEY_CARRIER_SUPPORTS_SS_OVER_UT_BOOL, false);
Meng Wang05062992017-02-14 21:55:09 -08003952 sDefaults.putBoolean(KEY_CARRIER_VOLTE_OVERRIDE_WFC_PROVISIONING_BOOL, false);
Pankaj Kanwar9a7abe62018-03-21 20:20:06 +00003953 sDefaults.putBoolean(KEY_CARRIER_VOLTE_TTY_SUPPORTED_BOOL, true);
Junda Liue5c7ca72015-06-24 14:41:14 -07003954 sDefaults.putBoolean(KEY_CARRIER_ALLOW_TURNOFF_IMS_BOOL, true);
Pavel Zhamaitsiakb4faf342015-10-16 16:39:00 -07003955 sDefaults.putBoolean(KEY_CARRIER_IMS_GBA_REQUIRED_BOOL, false);
Tyler Gunnac2aefc2015-07-31 15:34:46 -07003956 sDefaults.putBoolean(KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL, false);
Etan Cohencd811f02015-08-18 11:11:29 -07003957 sDefaults.putBoolean(KEY_CARRIER_USE_IMS_FIRST_FOR_EMERGENCY_BOOL, true);
Malcolm Chenec102212018-01-29 15:10:46 -08003958 sDefaults.putString(KEY_CARRIER_NETWORK_SERVICE_WWAN_PACKAGE_OVERRIDE_STRING, "");
3959 sDefaults.putString(KEY_CARRIER_NETWORK_SERVICE_WLAN_PACKAGE_OVERRIDE_STRING, "");
Jack Yu4d21a402018-08-27 16:59:05 -07003960 sDefaults.putString(KEY_CARRIER_QUALIFIED_NETWORKS_SERVICE_PACKAGE_OVERRIDE_STRING, "");
Jack Yufcbda452018-02-01 14:50:53 -08003961 sDefaults.putString(KEY_CARRIER_DATA_SERVICE_WWAN_PACKAGE_OVERRIDE_STRING, "");
3962 sDefaults.putString(KEY_CARRIER_DATA_SERVICE_WLAN_PACKAGE_OVERRIDE_STRING, "");
Tyler Gunneb5fcb92015-09-04 13:16:37 -07003963 sDefaults.putString(KEY_CARRIER_INSTANT_LETTERING_INVALID_CHARS_STRING, "");
Tyler Gunn14be4cf2015-09-10 13:33:28 -07003964 sDefaults.putString(KEY_CARRIER_INSTANT_LETTERING_ESCAPED_CHARS_STRING, "");
Tyler Gunndb3da5c2015-09-21 22:11:30 -07003965 sDefaults.putString(KEY_CARRIER_INSTANT_LETTERING_ENCODING_STRING, "");
3966 sDefaults.putInt(KEY_CARRIER_INSTANT_LETTERING_LENGTH_LIMIT_INT, 64);
Jonathan Basseri69822f02015-06-04 13:48:08 -07003967 sDefaults.putBoolean(KEY_DISABLE_CDMA_ACTIVATION_CODE_BOOL, false);
3968 sDefaults.putBoolean(KEY_DTMF_TYPE_ENABLED_BOOL, false);
3969 sDefaults.putBoolean(KEY_ENABLE_DIALER_KEY_VIBRATION_BOOL, true);
3970 sDefaults.putBoolean(KEY_HAS_IN_CALL_NOISE_SUPPRESSION_BOOL, false);
3971 sDefaults.putBoolean(KEY_HIDE_CARRIER_NETWORK_SETTINGS_BOOL, false);
Mattias Nilssonef874162017-12-11 13:45:40 +01003972 sDefaults.putBoolean(KEY_ONLY_AUTO_SELECT_IN_HOME_NETWORK_BOOL, false);
Joe LaPenna2b22ae32016-12-07 16:27:24 -08003973 sDefaults.putBoolean(KEY_SIMPLIFIED_NETWORK_SETTINGS_BOOL, false);
Junda Liue15cca72015-06-17 09:55:57 -07003974 sDefaults.putBoolean(KEY_HIDE_SIM_LOCK_SETTINGS_BOOL, false);
Jordan Liuc82d1132016-10-03 11:35:33 -07003975
3976 sDefaults.putBoolean(KEY_CARRIER_VOLTE_PROVISIONED_BOOL, false);
Wenting Xiongd5853682016-08-12 18:28:37 +08003977 sDefaults.putBoolean(KEY_CALL_BARRING_VISIBILITY_BOOL, false);
Brad Ebinger0819bac2018-08-29 16:08:29 -07003978 sDefaults.putBoolean(KEY_CALL_BARRING_SUPPORTS_PASSWORD_CHANGE_BOOL, true);
3979 sDefaults.putBoolean(KEY_CALL_BARRING_SUPPORTS_DEACTIVATE_ALL_BOOL, true);
Brad Ebinger2eed38662020-09-17 14:17:35 -07003980 sDefaults.putInt(KEY_CALL_BARRING_DEFAULT_SERVICE_CLASS_INT, SERVICE_CLASS_VOICE);
SongFerngWang06057162018-06-28 17:28:22 +08003981 sDefaults.putBoolean(KEY_CALL_FORWARDING_VISIBILITY_BOOL, true);
Shu Wang6edfc5a2018-09-13 15:36:30 +02003982 sDefaults.putBoolean(KEY_CALL_FORWARDING_WHEN_UNREACHABLE_SUPPORTED_BOOL, true);
allenwtsu6206afc2020-05-19 21:37:50 +08003983 sDefaults.putBoolean(KEY_CALL_FORWARDING_WHEN_UNANSWERED_SUPPORTED_BOOL, true);
3984 sDefaults.putBoolean(KEY_CALL_FORWARDING_WHEN_BUSY_SUPPORTED_BOOL, true);
SongFerngWang06057162018-06-28 17:28:22 +08003985 sDefaults.putBoolean(KEY_ADDITIONAL_SETTINGS_CALLER_ID_VISIBILITY_BOOL, true);
3986 sDefaults.putBoolean(KEY_ADDITIONAL_SETTINGS_CALL_WAITING_VISIBILITY_BOOL, true);
SongFerngWang08972c52019-11-25 22:44:12 +08003987 sDefaults.putBoolean(KEY_DISABLE_SUPPLEMENTARY_SERVICES_IN_AIRPLANE_MODE_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -07003988 sDefaults.putBoolean(KEY_IGNORE_SIM_NETWORK_LOCKED_EVENTS_BOOL, false);
Jordan Liube45b8c2016-11-09 13:23:42 -08003989 sDefaults.putBoolean(KEY_MDN_IS_ADDITIONAL_VOICEMAIL_NUMBER_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -07003990 sDefaults.putBoolean(KEY_OPERATOR_SELECTION_EXPAND_BOOL, true);
3991 sDefaults.putBoolean(KEY_PREFER_2G_BOOL, true);
3992 sDefaults.putBoolean(KEY_SHOW_APN_SETTING_CDMA_BOOL, false);
3993 sDefaults.putBoolean(KEY_SHOW_CDMA_CHOICES_BOOL, false);
Jordan Liu5ac6f5c2016-10-03 12:28:27 -07003994 sDefaults.putBoolean(KEY_SMS_REQUIRES_DESTINATION_NUMBER_CONVERSION_BOOL, false);
Avinash Nalluriceaf7222018-04-21 14:06:06 -07003995 sDefaults.putBoolean(KEY_SUPPORT_EMERGENCY_SMS_OVER_IMS_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -07003996 sDefaults.putBoolean(KEY_SHOW_ONSCREEN_DIAL_BUTTON_BOOL, true);
3997 sDefaults.putBoolean(KEY_SIM_NETWORK_UNLOCK_ALLOW_DISMISS_BOOL, true);
Omkar Kolangade2e8f8fe2015-12-22 21:07:04 +05303998 sDefaults.putBoolean(KEY_SUPPORT_PAUSE_IMS_VIDEO_CALLS_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -07003999 sDefaults.putBoolean(KEY_SUPPORT_SWAP_AFTER_MERGE_BOOL, true);
4000 sDefaults.putBoolean(KEY_USE_HFA_FOR_PROVISIONING_BOOL, false);
manabu, shimoda1de99d12017-10-20 17:16:06 +09004001 sDefaults.putBoolean(KEY_EDITABLE_VOICEMAIL_NUMBER_SETTING_BOOL, true);
Jordan Liu4a546382016-09-08 12:45:58 -07004002 sDefaults.putBoolean(KEY_EDITABLE_VOICEMAIL_NUMBER_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -07004003 sDefaults.putBoolean(KEY_USE_OTASP_FOR_PROVISIONING_BOOL, false);
4004 sDefaults.putBoolean(KEY_VOICEMAIL_NOTIFICATION_PERSISTENT_BOOL, false);
Jonathan Basseri3360c262015-06-09 15:16:21 -07004005 sDefaults.putBoolean(KEY_VOICE_PRIVACY_DISABLE_UI_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -07004006 sDefaults.putBoolean(KEY_WORLD_PHONE_BOOL, false);
Chris Manton1ba0fa02015-09-01 13:56:46 -07004007 sDefaults.putBoolean(KEY_REQUIRE_ENTITLEMENT_CHECKS_BOOL, true);
Jordan Liua5a8b592016-09-12 10:57:27 -07004008 sDefaults.putBoolean(KEY_RESTART_RADIO_ON_PDP_FAIL_REGULAR_DEACTIVATION_BOOL, false);
Jack Yu3399f362018-08-21 16:57:36 -07004009 sDefaults.putIntArray(KEY_RADIO_RESTART_FAILURE_CAUSES_INT_ARRAY, new int[]{});
Jonathan Basseri69822f02015-06-04 13:48:08 -07004010 sDefaults.putInt(KEY_VOLTE_REPLACEMENT_RAT_INT, 0);
Junda Liue4786492015-06-15 13:15:28 -07004011 sDefaults.putString(KEY_DEFAULT_SIM_CALL_MANAGER_STRING, "");
Jonathan Basseri69822f02015-06-04 13:48:08 -07004012 sDefaults.putString(KEY_VVM_DESTINATION_NUMBER_STRING, "");
4013 sDefaults.putInt(KEY_VVM_PORT_NUMBER_INT, 0);
4014 sDefaults.putString(KEY_VVM_TYPE_STRING, "");
Ta-wei Yen3f9306f2016-04-20 14:46:20 -07004015 sDefaults.putBoolean(KEY_VVM_CELLULAR_DATA_REQUIRED_BOOL, false);
Ta-wei Yenb618d0f2017-01-17 13:52:10 -08004016 sDefaults.putString(KEY_VVM_CLIENT_PREFIX_STRING,"//VVM");
4017 sDefaults.putBoolean(KEY_VVM_SSL_ENABLED_BOOL,false);
4018 sDefaults.putStringArray(KEY_VVM_DISABLED_CAPABILITIES_STRING_ARRAY, null);
4019 sDefaults.putBoolean(KEY_VVM_LEGACY_MODE_ENABLED_BOOL,false);
Ta-wei Yen3f9306f2016-04-20 14:46:20 -07004020 sDefaults.putBoolean(KEY_VVM_PREFETCH_BOOL, true);
Jonathan Basseri69822f02015-06-04 13:48:08 -07004021 sDefaults.putString(KEY_CARRIER_VVM_PACKAGE_NAME_STRING, "");
Ta-wei Yenb618d0f2017-01-17 13:52:10 -08004022 sDefaults.putStringArray(KEY_CARRIER_VVM_PACKAGE_NAME_STRING_ARRAY, null);
Meng Wang6b2995a2016-03-14 10:08:41 -07004023 sDefaults.putBoolean(KEY_SHOW_ICCID_IN_SIM_STATUS_BOOL, false);
Jordan Liua59a5eb2017-12-11 16:23:25 -08004024 sDefaults.putBoolean(KEY_SHOW_SIGNAL_STRENGTH_IN_SIM_STATUS_BOOL, true);
Amit Mahajan02008b72015-06-11 14:54:20 -07004025 sDefaults.putBoolean(KEY_CI_ACTION_ON_SYS_UPDATE_BOOL, false);
4026 sDefaults.putString(KEY_CI_ACTION_ON_SYS_UPDATE_INTENT_STRING, "");
4027 sDefaults.putString(KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_STRING, "");
4028 sDefaults.putString(KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_VAL_STRING, "");
Jonathan Basseri019523a2015-06-19 11:07:22 -07004029 sDefaults.putBoolean(KEY_CSP_ENABLED_BOOL, false);
Amit Mahajan412e7c82015-10-05 11:05:02 -07004030 sDefaults.putBoolean(KEY_ALLOW_ADDING_APNS_BOOL, true);
Amit Mahajan94222f42017-05-17 15:36:30 -07004031 sDefaults.putStringArray(KEY_READ_ONLY_APN_TYPES_STRING_ARRAY, new String[] {"dun"});
Amit Mahajan71e9ea62016-09-20 10:57:47 -07004032 sDefaults.putStringArray(KEY_READ_ONLY_APN_FIELDS_STRING_ARRAY, null);
SongFerngWangc87140c2019-08-19 22:51:46 +08004033 sDefaults.putStringArray(KEY_APN_SETTINGS_DEFAULT_APN_TYPES_STRING_ARRAY, null);
Bonian Chen94ae34a2020-01-17 05:49:54 +08004034 sDefaults.putAll(Apn.getDefaults());
4035
Amit Mahajan0c081482016-01-12 18:25:33 -08004036 sDefaults.putBoolean(KEY_BROADCAST_EMERGENCY_CALL_STATE_CHANGES_BOOL, false);
Jack Yu6af6c342015-09-14 16:18:59 -07004037 sDefaults.putBoolean(KEY_ALWAYS_SHOW_EMERGENCY_ALERT_ONOFF_BOOL, false);
Jack Yuc1f0e872016-09-10 00:41:17 -07004038 sDefaults.putStringArray(KEY_CARRIER_DATA_CALL_RETRY_CONFIG_STRINGS, new String[]{
4039 "default:default_randomization=2000,5000,10000,20000,40000,80000:5000,160000:5000,"
4040 + "320000:5000,640000:5000,1280000:5000,1800000:5000",
4041 "mms:default_randomization=2000,5000,10000,20000,40000,80000:5000,160000:5000,"
4042 + "320000:5000,640000:5000,1280000:5000,1800000:5000",
4043 "others:max_retries=3, 5000, 5000, 5000"});
Jack Yu090dd722015-12-18 15:16:24 -08004044 sDefaults.putLong(KEY_CARRIER_DATA_CALL_APN_DELAY_DEFAULT_LONG, 20000);
4045 sDefaults.putLong(KEY_CARRIER_DATA_CALL_APN_DELAY_FASTER_LONG, 3000);
Jack Yu5523dc52017-08-16 14:26:56 -07004046 sDefaults.putLong(KEY_CARRIER_DATA_CALL_APN_RETRY_AFTER_DISCONNECT_LONG, 10000);
Jack Yu360dc212016-04-08 17:11:25 -07004047 sDefaults.putString(KEY_CARRIER_ERI_FILE_NAME_STRING, "eri.xml");
Abhijith Shastryd48935872016-02-04 17:28:03 -08004048 sDefaults.putInt(KEY_DURATION_BLOCKING_DISABLED_AFTER_EMERGENCY_INT, 7200);
Jack Yu66a6be32016-03-30 11:14:39 -07004049 sDefaults.putStringArray(KEY_CARRIER_METERED_APN_TYPES_STRINGS,
4050 new String[]{"default", "mms", "dun", "supl"});
fionaxu28ffb602016-04-17 23:56:42 -07004051 sDefaults.putStringArray(KEY_CARRIER_METERED_ROAMING_APN_TYPES_STRINGS,
4052 new String[]{"default", "mms", "dun", "supl"});
Jack Yuac9a7312019-06-28 16:42:37 -07004053 sDefaults.putStringArray(KEY_CARRIER_WWAN_DISALLOWED_APN_TYPES_STRING_ARRAY,
4054 new String[]{""});
4055 sDefaults.putStringArray(KEY_CARRIER_WLAN_DISALLOWED_APN_TYPES_STRING_ARRAY,
4056 new String[]{""});
Jordan Liu2420a0a2016-10-04 11:46:03 -07004057 sDefaults.putIntArray(KEY_ONLY_SINGLE_DC_ALLOWED_INT_ARRAY,
4058 new int[]{
4059 4, /* IS95A */
4060 5, /* IS95B */
4061 6, /* 1xRTT */
4062 7, /* EVDO_0 */
4063 8, /* EVDO_A */
4064 12 /* EVDO_B */
4065 });
Chris Mantonca16a792015-06-16 12:06:08 -07004066 sDefaults.putStringArray(KEY_GSM_ROAMING_NETWORKS_STRING_ARRAY, null);
4067 sDefaults.putStringArray(KEY_GSM_NONROAMING_NETWORKS_STRING_ARRAY, null);
Brad Ebinger024aaf22017-01-23 15:17:50 -08004068 sDefaults.putString(KEY_CONFIG_IMS_PACKAGE_OVERRIDE_STRING, null);
Brad Ebinger66978142019-12-05 11:38:15 -08004069 sDefaults.putString(KEY_CONFIG_IMS_MMTEL_PACKAGE_OVERRIDE_STRING, null);
4070 sDefaults.putString(KEY_CONFIG_IMS_RCS_PACKAGE_OVERRIDE_STRING, null);
Chris Mantonca16a792015-06-16 12:06:08 -07004071 sDefaults.putStringArray(KEY_CDMA_ROAMING_NETWORKS_STRING_ARRAY, null);
4072 sDefaults.putStringArray(KEY_CDMA_NONROAMING_NETWORKS_STRING_ARRAY, null);
Jordan Liu02ec2a02016-09-09 11:48:48 -07004073 sDefaults.putStringArray(KEY_DIAL_STRING_REPLACE_STRING_ARRAY, null);
Chris Manton63f25b62015-06-24 16:47:49 -07004074 sDefaults.putBoolean(KEY_FORCE_HOME_NETWORK_BOOL, false);
Roshan Piusdc364fe2015-09-10 10:28:06 -07004075 sDefaults.putInt(KEY_GSM_DTMF_TONE_DELAY_INT, 0);
Roshan Pius9f81ce72015-08-12 12:01:42 -07004076 sDefaults.putInt(KEY_IMS_DTMF_TONE_DELAY_INT, 0);
Roshan Piusa52c5e22015-08-14 12:58:08 -07004077 sDefaults.putInt(KEY_CDMA_DTMF_TONE_DELAY_INT, 100);
Brad Ebinger110856432017-10-12 13:58:55 -07004078 sDefaults.putBoolean(KEY_CALL_FORWARDING_MAP_NON_NUMBER_TO_VOICEMAIL_BOOL, false);
Hall Liud18e5b42019-12-11 17:35:33 -08004079 sDefaults.putBoolean(KEY_IGNORE_RTT_MODE_SETTING_BOOL, true);
Jordan Liue1663562016-09-07 12:01:24 -07004080 sDefaults.putInt(KEY_CDMA_3WAYCALL_FLASH_DELAY_INT , 0);
Ravi Paluri80aa2142019-12-02 11:57:37 +05304081 sDefaults.putBoolean(KEY_SUPPORT_ADHOC_CONFERENCE_CALLS_BOOL, false);
Ravi Paluri404babb2020-01-23 19:02:44 +05304082 sDefaults.putBoolean(KEY_SUPPORT_ADD_CONFERENCE_PARTICIPANTS_BOOL, false);
Sungmin Choi8c651ae2015-08-14 15:55:13 -07004083 sDefaults.putBoolean(KEY_SUPPORT_CONFERENCE_CALL_BOOL, true);
Wei Huanga8ad1522016-03-01 15:25:04 +08004084 sDefaults.putBoolean(KEY_SUPPORT_IMS_CONFERENCE_CALL_BOOL, true);
Tyler Gunn4eb18912020-04-07 19:01:15 -07004085 sDefaults.putBoolean(KEY_LOCAL_DISCONNECT_EMPTY_IMS_CONFERENCE_BOOL, false);
Wei Huang594039c2016-04-22 14:33:55 +08004086 sDefaults.putBoolean(KEY_SUPPORT_MANAGE_IMS_CONFERENCE_CALL_BOOL, true);
Youming Yed5472f72019-05-21 13:10:48 -07004087 sDefaults.putBoolean(KEY_SUPPORT_IMS_CONFERENCE_EVENT_PACKAGE_BOOL, true);
Tyler Gunn60e5f7c2020-04-06 15:07:48 -07004088 sDefaults.putBoolean(KEY_SUPPORT_IMS_CONFERENCE_EVENT_PACKAGE_ON_PEER_BOOL, true);
Tyler Gunnee61c622016-04-19 16:17:19 -07004089 sDefaults.putBoolean(KEY_SUPPORT_VIDEO_CONFERENCE_CALL_BOOL, false);
Tyler Gunnec5b6e32016-12-01 19:40:30 -08004090 sDefaults.putBoolean(KEY_IS_IMS_CONFERENCE_SIZE_ENFORCED_BOOL, false);
4091 sDefaults.putInt(KEY_IMS_CONFERENCE_SIZE_LIMIT_INT, 5);
Wei Huang237d7752016-03-01 17:02:40 +08004092 sDefaults.putBoolean(KEY_DISPLAY_HD_AUDIO_PROPERTY_BOOL, true);
Sungmin Choi8d2826b2015-08-25 23:30:34 -07004093 sDefaults.putBoolean(KEY_EDITABLE_ENHANCED_4G_LTE_BOOL, true);
yinxu34016ae2017-03-14 15:36:17 -07004094 sDefaults.putBoolean(KEY_HIDE_ENHANCED_4G_LTE_BOOL, false);
manabu, shimoda14723e32017-10-06 14:39:01 +09004095 sDefaults.putBoolean(KEY_ENHANCED_4G_LTE_ON_BY_DEFAULT_BOOL, true);
Sungmin Choie9d3c112015-08-31 15:32:20 -07004096 sDefaults.putBoolean(KEY_HIDE_IMS_APN_BOOL, false);
Sungmin Choic03a1da2015-09-08 15:34:23 -07004097 sDefaults.putBoolean(KEY_HIDE_PREFERRED_NETWORK_TYPE_BOOL, false);
Tyler Gunnf0836192016-03-15 20:33:13 -07004098 sDefaults.putBoolean(KEY_ALLOW_EMERGENCY_VIDEO_CALLS_BOOL, false);
Junda Liu85313282017-03-28 13:58:51 -07004099 sDefaults.putStringArray(KEY_ENABLE_APPS_STRING_ARRAY, null);
Sungmin Choid3b28262015-12-23 14:10:41 +09004100 sDefaults.putBoolean(KEY_EDITABLE_WFC_MODE_BOOL, true);
Pavel Zhamaitsiak7b7c4fc2016-04-12 14:24:07 -07004101 sDefaults.putStringArray(KEY_WFC_OPERATOR_ERROR_CODES_STRING_ARRAY, null);
4102 sDefaults.putInt(KEY_WFC_SPN_FORMAT_IDX_INT, 0);
4103 sDefaults.putInt(KEY_WFC_DATA_SPN_FORMAT_IDX_INT, 0);
Torbjorn Eklunda765a472018-09-24 17:45:23 +02004104 sDefaults.putInt(KEY_WFC_FLIGHT_MODE_SPN_FORMAT_IDX_INT, -1);
Torbjorn Eklund99c11d82018-08-21 16:06:47 +02004105 sDefaults.putBoolean(KEY_WFC_SPN_USE_ROOT_LOCALE, false);
Vineeta Srivastavac7d7ab72016-05-14 11:05:28 -07004106 sDefaults.putString(KEY_WFC_EMERGENCY_ADDRESS_CARRIER_APP_STRING, "");
Sunil Dutt7c5fda82016-04-05 22:08:57 +05304107 sDefaults.putBoolean(KEY_CONFIG_WIFI_DISABLE_IN_ECBM, false);
Sanket Padawe49b20422016-06-01 12:17:23 -07004108 sDefaults.putBoolean(KEY_CARRIER_NAME_OVERRIDE_BOOL, false);
4109 sDefaults.putString(KEY_CARRIER_NAME_STRING, "");
SongFerngWangd1b16442020-06-16 18:39:35 +08004110 sDefaults.putBoolean(KEY_WFC_CARRIER_NAME_OVERRIDE_BY_PNN_BOOL, false);
Pengquan Meng057b94f2019-04-17 19:36:58 -07004111 sDefaults.putInt(KEY_SPN_DISPLAY_CONDITION_OVERRIDE_INT, -1);
4112 sDefaults.putStringArray(KEY_SPDI_OVERRIDE_STRING_ARRAY, null);
4113 sDefaults.putStringArray(KEY_PNN_OVERRIDE_STRING_ARRAY, null);
4114 sDefaults.putStringArray(KEY_OPL_OVERRIDE_STRING_ARRAY, null);
4115 sDefaults.putStringArray(KEY_EHPLMN_OVERRIDE_STRING_ARRAY, null);
4116 sDefaults.putBoolean(KEY_ALLOW_ERI_BOOL, false);
4117 sDefaults.putBoolean(KEY_ENABLE_CARRIER_DISPLAY_NAME_RESOLVER_BOOL, false);
chen xu6b736ee2018-12-02 14:14:15 -08004118 sDefaults.putString(KEY_SIM_COUNTRY_ISO_OVERRIDE_STRING, "");
tonyzhucd0a63d2018-10-11 14:31:26 +08004119 sDefaults.putString(KEY_CARRIER_CALL_SCREENING_APP_STRING, "");
sqian4be071a2019-03-18 14:10:53 -07004120 sDefaults.putString(KEY_CALL_REDIRECTION_SERVICE_COMPONENT_NAME_STRING, null);
Amit Mahajan22e89f42018-06-05 16:27:32 -07004121 sDefaults.putBoolean(KEY_CDMA_HOME_REGISTERED_PLMN_NAME_OVERRIDE_BOOL, false);
4122 sDefaults.putString(KEY_CDMA_HOME_REGISTERED_PLMN_NAME_STRING, "");
Wileen Chiu5e8e3082016-07-15 10:00:09 -07004123 sDefaults.putBoolean(KEY_SUPPORT_DIRECT_FDN_DIALING_BOOL, false);
rongmei.libcadc902019-10-16 18:41:48 +08004124 sDefaults.putInt(KEY_FDN_NUMBER_LENGTH_LIMIT_INT, 20);
fionaxu7834be22017-06-22 18:14:23 -07004125 sDefaults.putBoolean(KEY_CARRIER_DEFAULT_DATA_ROAMING_ENABLED_BOOL, false);
DongYuchen439f16d2017-02-16 18:22:36 +08004126 sDefaults.putBoolean(KEY_SKIP_CF_FAIL_TO_DISABLE_DIALOG_BOOL, false);
Tyler Gunn212c1572018-09-12 17:50:49 -07004127 sDefaults.putBoolean(KEY_SUPPORT_ENHANCED_CALL_BLOCKING_BOOL, true);
Chris Mantonca16a792015-06-16 12:06:08 -07004128
Jonathan Basserif31ac332015-05-27 01:18:46 -07004129 // MMS defaults
Jonathan Basseri69822f02015-06-04 13:48:08 -07004130 sDefaults.putBoolean(KEY_MMS_ALIAS_ENABLED_BOOL, false);
4131 sDefaults.putBoolean(KEY_MMS_ALLOW_ATTACH_AUDIO_BOOL, true);
4132 sDefaults.putBoolean(KEY_MMS_APPEND_TRANSACTION_ID_BOOL, false);
4133 sDefaults.putBoolean(KEY_MMS_GROUP_MMS_ENABLED_BOOL, true);
4134 sDefaults.putBoolean(KEY_MMS_MMS_DELIVERY_REPORT_ENABLED_BOOL, false);
4135 sDefaults.putBoolean(KEY_MMS_MMS_ENABLED_BOOL, true);
4136 sDefaults.putBoolean(KEY_MMS_MMS_READ_REPORT_ENABLED_BOOL, false);
4137 sDefaults.putBoolean(KEY_MMS_MULTIPART_SMS_ENABLED_BOOL, true);
4138 sDefaults.putBoolean(KEY_MMS_NOTIFY_WAP_MMSC_ENABLED_BOOL, false);
4139 sDefaults.putBoolean(KEY_MMS_SEND_MULTIPART_SMS_AS_SEPARATE_MESSAGES_BOOL, false);
4140 sDefaults.putBoolean(KEY_MMS_SHOW_CELL_BROADCAST_APP_LINKS_BOOL, true);
4141 sDefaults.putBoolean(KEY_MMS_SMS_DELIVERY_REPORT_ENABLED_BOOL, true);
4142 sDefaults.putBoolean(KEY_MMS_SUPPORT_HTTP_CHARSET_HEADER_BOOL, false);
4143 sDefaults.putBoolean(KEY_MMS_SUPPORT_MMS_CONTENT_DISPOSITION_BOOL, true);
Ye Wen406a41b2016-07-18 14:36:22 -07004144 sDefaults.putBoolean(KEY_MMS_CLOSE_CONNECTION_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -07004145 sDefaults.putInt(KEY_MMS_ALIAS_MAX_CHARS_INT, 48);
4146 sDefaults.putInt(KEY_MMS_ALIAS_MIN_CHARS_INT, 2);
4147 sDefaults.putInt(KEY_MMS_HTTP_SOCKET_TIMEOUT_INT, 60 * 1000);
4148 sDefaults.putInt(KEY_MMS_MAX_IMAGE_HEIGHT_INT, 480);
4149 sDefaults.putInt(KEY_MMS_MAX_IMAGE_WIDTH_INT, 640);
4150 sDefaults.putInt(KEY_MMS_MAX_MESSAGE_SIZE_INT, 300 * 1024);
4151 sDefaults.putInt(KEY_MMS_MESSAGE_TEXT_MAX_SIZE_INT, -1);
4152 sDefaults.putInt(KEY_MMS_RECIPIENT_LIMIT_INT, Integer.MAX_VALUE);
4153 sDefaults.putInt(KEY_MMS_SMS_TO_MMS_TEXT_LENGTH_THRESHOLD_INT, -1);
4154 sDefaults.putInt(KEY_MMS_SMS_TO_MMS_TEXT_THRESHOLD_INT, -1);
4155 sDefaults.putInt(KEY_MMS_SUBJECT_MAX_LENGTH_INT, 40);
4156 sDefaults.putString(KEY_MMS_EMAIL_GATEWAY_NUMBER_STRING, "");
4157 sDefaults.putString(KEY_MMS_HTTP_PARAMS_STRING, "");
4158 sDefaults.putString(KEY_MMS_NAI_SUFFIX_STRING, "");
4159 sDefaults.putString(KEY_MMS_UA_PROF_TAG_NAME_STRING, "x-wap-profile");
4160 sDefaults.putString(KEY_MMS_UA_PROF_URL_STRING, "");
4161 sDefaults.putString(KEY_MMS_USER_AGENT_STRING, "");
Tyler Gunn387ce2f2015-08-28 14:14:11 -07004162 sDefaults.putBoolean(KEY_ALLOW_NON_EMERGENCY_CALLS_IN_ECM_BOOL, true);
Brad Ebinger5eeb79d2019-03-15 13:50:34 -07004163 sDefaults.putInt(KEY_EMERGENCY_SMS_MODE_TIMER_MS_INT, 0);
Brad Ebinger62713872019-11-18 18:43:35 -08004164 sDefaults.putBoolean(KEY_ALLOW_HOLD_CALL_DURING_EMERGENCY_BOOL, true);
Tyler Gunn3e122f72016-01-11 19:25:00 -08004165 sDefaults.putBoolean(KEY_USE_RCS_PRESENCE_BOOL, false);
James.cf Linc8a345a2019-09-20 18:04:06 +08004166 sDefaults.putBoolean(KEY_USE_RCS_SIP_OPTIONS_BOOL, false);
Junda Liu276f4d62016-07-14 13:55:03 -07004167 sDefaults.putBoolean(KEY_FORCE_IMEI_BOOL, false);
Jeff Davidsonaf1d3202017-10-25 12:51:43 -07004168 sDefaults.putInt(
4169 KEY_CDMA_ROAMING_MODE_INT, TelephonyManager.CDMA_ROAMING_MODE_RADIO_DEFAULT);
Josh Hou0e9ea952019-12-03 21:00:44 +08004170 sDefaults.putBoolean(KEY_SUPPORT_CDMA_1X_VOICE_CALLS_BOOL, true);
Abhijith Shastry2215c9b2016-08-24 15:17:39 -07004171 sDefaults.putString(KEY_RCS_CONFIG_SERVER_URL_STRING, "");
fionaxub5592dc2016-04-08 13:19:31 -07004172
fionaxu1bf6ec22016-05-23 16:33:16 -07004173 // Carrier Signalling Receivers
Stuart Scott9abc2732016-05-11 15:42:01 -07004174 sDefaults.putString(KEY_CARRIER_SETUP_APP_STRING, "");
fionaxub537d742017-09-06 12:07:14 -07004175 sDefaults.putStringArray(KEY_CARRIER_APP_WAKE_SIGNAL_CONFIG_STRING_ARRAY,
4176 new String[]{
4177 "com.android.carrierdefaultapp/.CarrierDefaultBroadcastReceiver:"
4178 + "com.android.internal.telephony.CARRIER_SIGNAL_RESET"
4179 });
fionaxu41ca9372016-11-17 16:46:30 -08004180 sDefaults.putStringArray(KEY_CARRIER_APP_NO_WAKE_SIGNAL_CONFIG_STRING_ARRAY, null);
Qingxi Li38fbddc2019-03-14 13:26:03 -07004181 sDefaults.putBoolean(KEY_CARRIER_APP_REQUIRED_DURING_SIM_SETUP_BOOL, false);
fionaxu41ca9372016-11-17 16:46:30 -08004182
Robert Greenwalt60551b62016-06-09 16:28:40 -07004183
fionaxua21a87b2016-12-13 17:15:11 -08004184 // Default carrier app configurations
4185 sDefaults.putStringArray(KEY_CARRIER_DEFAULT_ACTIONS_ON_REDIRECTION_STRING_ARRAY,
4186 new String[]{
fionaxud60a9d02017-05-23 14:55:27 -07004187 "9, 4, 1"
4188 //9: CARRIER_ACTION_REGISTER_NETWORK_AVAIL
fionaxua21a87b2016-12-13 17:15:11 -08004189 //4: CARRIER_ACTION_DISABLE_METERED_APNS
4190 //1: CARRIER_ACTION_SHOW_PORTAL_NOTIFICATION
4191 });
fionaxu77f466d2017-04-26 16:05:25 -07004192 sDefaults.putStringArray(KEY_CARRIER_DEFAULT_ACTIONS_ON_RESET, new String[]{
fionaxud60a9d02017-05-23 14:55:27 -07004193 "6, 8"
4194 //6: CARRIER_ACTION_CANCEL_ALL_NOTIFICATIONS
4195 //8: CARRIER_ACTION_DISABLE_DEFAULT_URL_HANDLER
4196 });
fionaxu79d77bb2017-07-19 11:11:54 -07004197 sDefaults.putStringArray(KEY_CARRIER_DEFAULT_ACTIONS_ON_DEFAULT_NETWORK_AVAILABLE, new String[] {
4198 String.valueOf(false) + ": 7", //7: CARRIER_ACTION_ENABLE_DEFAULT_URL_HANDLER
4199 String.valueOf(true) + ": 8" //8: CARRIER_ACTION_DISABLE_DEFAULT_URL_HANDLER
fionaxu77f466d2017-04-26 16:05:25 -07004200 });
fionaxua21a87b2016-12-13 17:15:11 -08004201 sDefaults.putStringArray(KEY_CARRIER_DEFAULT_REDIRECTION_URL_STRING_ARRAY, null);
4202
Ammar Aijazi11b44982017-01-17 17:32:15 -08004203 sDefaults.putInt(KEY_MONTHLY_DATA_CYCLE_DAY_INT, DATA_CYCLE_USE_PLATFORM_DEFAULT);
4204 sDefaults.putLong(KEY_DATA_WARNING_THRESHOLD_BYTES_LONG, DATA_CYCLE_USE_PLATFORM_DEFAULT);
Jeff Sharkey0a5570d2018-04-10 12:38:29 -06004205 sDefaults.putBoolean(KEY_DATA_WARNING_NOTIFICATION_BOOL, true);
chen xu00511062019-07-02 16:32:07 -07004206 sDefaults.putBoolean(KEY_LIMITED_SIM_FUNCTION_NOTIFICATION_FOR_DSDS_BOOL, false);
Ammar Aijazi11b44982017-01-17 17:32:15 -08004207 sDefaults.putLong(KEY_DATA_LIMIT_THRESHOLD_BYTES_LONG, DATA_CYCLE_USE_PLATFORM_DEFAULT);
Jeff Sharkey0a5570d2018-04-10 12:38:29 -06004208 sDefaults.putBoolean(KEY_DATA_LIMIT_NOTIFICATION_BOOL, true);
4209 sDefaults.putBoolean(KEY_DATA_RAPID_NOTIFICATION_BOOL, true);
Ammar Aijazi11b44982017-01-17 17:32:15 -08004210
Ajay Nambi7965fa42015-05-14 18:48:33 -07004211 // Rat families: {GPRS, EDGE}, {EVDO, EVDO_A, EVDO_B}, {UMTS, HSPA, HSDPA, HSUPA, HSPAP},
4212 // {LTE, LTE_CA}
Robert Greenwalt60551b62016-06-09 16:28:40 -07004213 // Order is important - lowest precidence first
4214 sDefaults.putStringArray(KEY_RATCHET_RAT_FAMILIES,
Ajay Nambi7965fa42015-05-14 18:48:33 -07004215 new String[]{"1,2","7,8,12","3,11,9,10,15","14,19"});
Tyler Gunn7d633d32016-06-24 07:30:10 -07004216 sDefaults.putBoolean(KEY_TREAT_DOWNGRADED_VIDEO_CALLS_AS_VIDEO_CALLS_BOOL, false);
4217 sDefaults.putBoolean(KEY_DROP_VIDEO_CALL_WHEN_ANSWERING_AUDIO_CALL_BOOL, false);
4218 sDefaults.putBoolean(KEY_ALLOW_MERGE_WIFI_CALLS_WHEN_VOWIFI_OFF_BOOL, true);
Hall Liu10208662016-06-15 17:55:00 -07004219 sDefaults.putBoolean(KEY_ALLOW_ADD_CALL_DURING_VIDEO_CALL_BOOL, true);
Tyler Gunnbe363242020-02-12 13:50:46 -08004220 sDefaults.putBoolean(KEY_ALLOW_HOLD_VIDEO_CALL_BOOL, true);
Hall Liu7c3c28b2016-07-19 11:18:49 -07004221 sDefaults.putBoolean(KEY_WIFI_CALLS_CAN_BE_HD_AUDIO, true);
4222 sDefaults.putBoolean(KEY_VIDEO_CALLS_CAN_BE_HD_AUDIO, true);
Alex Khlivnuikabdd37c2017-11-29 12:18:05 +09004223 sDefaults.putBoolean(KEY_GSM_CDMA_CALLS_CAN_BE_HD_AUDIO, false);
Ta-wei Yen9d20d982017-06-02 11:07:07 -07004224 sDefaults.putBoolean(KEY_ALLOW_VIDEO_CALLING_FALLBACK_BOOL, true);
Tyler Gunnc96b5e02016-07-07 22:53:57 -07004225
4226 sDefaults.putStringArray(KEY_IMS_REASONINFO_MAPPING_STRING_ARRAY, null);
Meng Wang542e2622016-08-03 10:18:36 -07004227 sDefaults.putBoolean(KEY_ENHANCED_4G_LTE_TITLE_VARIANT_BOOL, false);
clownshen6400b932018-08-16 16:54:16 +08004228 sDefaults.putInt(KEY_ENHANCED_4G_LTE_TITLE_VARIANT_INT, 0);
Tyler Gunn0f20d932016-08-09 15:56:43 -07004229 sDefaults.putBoolean(KEY_NOTIFY_VT_HANDOVER_TO_WIFI_FAILURE_BOOL, false);
Jordan Liu1ca2e31d2016-12-01 11:39:30 -08004230 sDefaults.putStringArray(KEY_FILTERED_CNAP_NAMES_STRING_ARRAY, null);
Meng Wang2c25e4a2016-09-19 14:18:05 -07004231 sDefaults.putBoolean(KEY_EDITABLE_WFC_ROAMING_MODE_BOOL, false);
Youming Ye9592a422019-03-20 17:53:44 -07004232 sDefaults.putBoolean(KEY_SHOW_BLOCKING_PAY_PHONE_OPTION_BOOL, false);
Hiroto Taruida081212019-02-14 14:37:09 +09004233 sDefaults.putBoolean(KEY_USE_WFC_HOME_NETWORK_MODE_IN_ROAMING_NETWORK_BOOL, false);
Sooraj Sasindran6a3d36f2016-10-13 11:36:34 -07004234 sDefaults.putBoolean(KEY_STK_DISABLE_LAUNCH_BROWSER_BOOL, false);
Ecco Park1074c882019-03-21 12:58:09 -07004235 sDefaults.putBoolean(KEY_ALLOW_METERED_NETWORK_FOR_CERT_DOWNLOAD_BOOL, false);
Yoshiaki Naka1c5203a62019-02-21 18:40:03 +09004236 sDefaults.putBoolean(KEY_HIDE_DIGITS_HELPER_TEXT_ON_STK_INPUT_SCREEN_BOOL, true);
pkanwarffd45832016-12-11 17:45:50 -08004237 sDefaults.putInt(KEY_PREF_NETWORK_NOTIFICATION_DELAY_INT, -1);
pkanwar68e3de72017-08-13 12:18:19 -07004238 sDefaults.putInt(KEY_EMERGENCY_NOTIFICATION_DELAY_INT, -1);
Tyler Gunn02212db2017-06-05 11:26:46 -07004239 sDefaults.putBoolean(KEY_ALLOW_USSD_REQUESTS_VIA_TELEPHONY_MANAGER_BOOL, true);
Brad Ebinger17acc152016-12-09 13:18:30 -08004240 sDefaults.putBoolean(KEY_SUPPORT_3GPP_CALL_FORWARDING_WHILE_ROAMING_BOOL, true);
Qiong Liu48fe53f2017-10-16 17:04:30 +08004241 sDefaults.putBoolean(KEY_DISPLAY_VOICEMAIL_NUMBER_AS_DEFAULT_CALL_FORWARDING_NUMBER_BOOL,
4242 false);
Tyler Gunn662ae092017-02-16 16:21:14 -08004243 sDefaults.putBoolean(KEY_NOTIFY_INTERNATIONAL_CALL_ON_WFC_BOOL, false);
taiki tsutsumi2ee96822018-07-02 17:15:42 +09004244 sDefaults.putBoolean(KEY_HIDE_PRESET_APN_DETAILS_BOOL, false);
Masaho Nishikawa4c7511c2017-12-18 14:33:38 +09004245 sDefaults.putBoolean(KEY_SHOW_VIDEO_CALL_CHARGES_ALERT_DIALOG_BOOL, false);
Brad Ebinger9ab43212016-12-12 14:57:37 -08004246 sDefaults.putStringArray(KEY_CALL_FORWARDING_BLOCKS_WHILE_ROAMING_STRING_ARRAY,
4247 null);
Josh Hou7d4f7792020-05-28 23:32:37 +08004248 sDefaults.putBoolean(KEY_SUPPORT_IMS_CALL_FORWARDING_WHILE_ROAMING_BOOL, true);
Sooraj Sasindran1b7bec52017-03-08 23:43:17 -08004249 sDefaults.putInt(KEY_LTE_EARFCNS_RSRP_BOOST_INT, 0);
4250 sDefaults.putStringArray(KEY_BOOSTED_LTE_EARFCNS_STRING_ARRAY, null);
Wenting Xiongcb35e992017-10-18 15:05:49 +09004251 sDefaults.putBoolean(KEY_USE_ONLY_RSRP_FOR_LTE_SIGNAL_BAR_BOOL, false);
Sanket Padawedb688bb2017-03-28 15:26:13 -07004252 sDefaults.putBoolean(KEY_DISABLE_VOICE_BARRING_NOTIFICATION_BOOL, false);
pkanwarbecc8692017-07-04 16:04:44 -07004253 sDefaults.putInt(IMSI_KEY_AVAILABILITY_INT, 0);
pkanwar232573f2017-05-31 13:10:03 -07004254 sDefaults.putString(IMSI_KEY_DOWNLOAD_URL_STRING, null);
Naveen Kallaabd28422017-07-11 20:03:58 -07004255 sDefaults.putBoolean(KEY_CONVERT_CDMA_CALLER_ID_MMI_CODES_WHILE_ROAMING_ON_3GPP_BOOL,
4256 false);
Naveen Kalla7e15c582017-07-13 20:43:21 -07004257 sDefaults.putStringArray(KEY_NON_ROAMING_OPERATOR_STRING_ARRAY, null);
fionaxu1c6027c2017-06-01 18:52:17 -07004258 sDefaults.putStringArray(KEY_ROAMING_OPERATOR_STRING_ARRAY, null);
Ping Sune0e3cbd2016-03-02 19:09:27 +08004259 sDefaults.putBoolean(KEY_SHOW_IMS_REGISTRATION_STATUS_BOOL, false);
Hall Liu47ed6202017-11-20 16:25:39 -08004260 sDefaults.putBoolean(KEY_RTT_SUPPORTED_BOOL, false);
Tyler Gunne4d72b42019-02-25 10:42:45 -08004261 sDefaults.putBoolean(KEY_TTY_SUPPORTED_BOOL, true);
Hall Liu3a23d7e2019-07-29 17:30:12 -07004262 sDefaults.putBoolean(KEY_HIDE_TTY_HCO_VCO_WITH_RTT_BOOL, false);
Omata Shou9766b182017-08-22 17:17:55 +09004263 sDefaults.putBoolean(KEY_DISABLE_CHARGE_INDICATION_BOOL, false);
manabu, shimoda6ce31382017-12-25 18:38:47 +09004264 sDefaults.putBoolean(KEY_SUPPORT_NO_REPLY_TIMER_FOR_CFNRY_BOOL, true);
Kazuya Ohshiro990af172017-09-27 16:02:55 +09004265 sDefaults.putStringArray(KEY_FEATURE_ACCESS_CODES_STRING_ARRAY, null);
Kazuya Ohshirob8981ba2017-10-27 16:26:15 +09004266 sDefaults.putBoolean(KEY_IDENTIFY_HIGH_DEFINITION_CALLS_IN_CALL_LOG_BOOL, false);
Wenting Xiongf21f3cf2016-04-01 15:25:45 +08004267 sDefaults.putBoolean(KEY_SHOW_PRECISE_FAILED_CAUSE_BOOL, false);
Masaho Nishikawa40184352017-11-01 20:33:36 +09004268 sDefaults.putBoolean(KEY_SPN_DISPLAY_RULE_USE_ROAMING_FROM_SERVICE_STATE_BOOL, false);
Wenting Xiong63364fe2017-02-07 19:12:27 +08004269 sDefaults.putBoolean(KEY_ALWAYS_SHOW_DATA_RAT_ICON_BOOL, false);
Pengquan Mengcdb6c682018-10-24 15:43:44 -07004270 sDefaults.putBoolean(KEY_SHOW_4G_FOR_LTE_DATA_ICON_BOOL, false);
vagdevi3f2b9a52019-08-09 09:45:14 -07004271 sDefaults.putBoolean(KEY_SHOW_4G_FOR_3G_DATA_ICON_BOOL, false);
SongFerngWang2d178ea2019-03-21 23:14:20 +08004272 sDefaults.putString(KEY_OPERATOR_NAME_FILTER_PATTERN_STRING, "");
4273 sDefaults.putString(KEY_SHOW_CARRIER_DATA_ICON_PATTERN_STRING, "");
Hall Liu1ce5e662018-10-31 18:17:38 -07004274 sDefaults.putBoolean(KEY_HIDE_LTE_PLUS_DATA_ICON_BOOL, true);
Sarah Chinea9d40e2020-08-12 19:38:02 -07004275 sDefaults.putInt(KEY_LTE_PLUS_THRESHOLD_BANDWIDTH_KHZ_INT, 20000);
Sarah Chin39c87c62020-05-13 23:41:52 -07004276 sDefaults.putBoolean(KEY_NR_ENABLED_BOOL, true);
Pengquan Mengcb6aaf02018-11-02 17:40:17 -07004277 sDefaults.putBoolean(KEY_LTE_ENABLED_BOOL, true);
4278 sDefaults.putBoolean(KEY_SUPPORT_TDSCDMA_BOOL, false);
4279 sDefaults.putStringArray(KEY_SUPPORT_TDSCDMA_ROAMING_NETWORKS_STRING_ARRAY, null);
4280 sDefaults.putBoolean(KEY_WORLD_MODE_ENABLED_BOOL, false);
Pengquan Meng3d4e67c2018-11-07 14:54:21 -08004281 sDefaults.putString(KEY_CARRIER_SETTINGS_ACTIVITY_COMPONENT_NAME_STRING, "");
yinxu0d56f3c2017-11-29 15:02:05 -08004282 sDefaults.putBoolean(KEY_CARRIER_CONFIG_APPLIED_BOOL, false);
pkanwar1e96fae2018-01-03 18:41:18 -08004283 sDefaults.putBoolean(KEY_CHECK_PRICING_WITH_CARRIER_FOR_DATA_ROAMING_BOOL, false);
Jordan Liub5fbb912019-07-23 15:52:08 -07004284 sDefaults.putBoolean(KEY_SHOW_DATA_CONNECTED_ROAMING_NOTIFICATION_BOOL, false);
Kitta Koutarou911f56c2017-12-01 19:19:49 +09004285 sDefaults.putIntArray(KEY_LTE_RSRP_THRESHOLDS_INT_ARRAY,
4286 new int[] {
Kitta Koutarou911f56c2017-12-01 19:19:49 +09004287 -128, /* SIGNAL_STRENGTH_POOR */
4288 -118, /* SIGNAL_STRENGTH_MODERATE */
4289 -108, /* SIGNAL_STRENGTH_GOOD */
4290 -98, /* SIGNAL_STRENGTH_GREAT */
Kitta Koutarou911f56c2017-12-01 19:19:49 +09004291 });
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09004292 sDefaults.putIntArray(KEY_LTE_RSRQ_THRESHOLDS_INT_ARRAY,
4293 new int[] {
Shuo Qian66c51cd2020-05-01 00:38:02 -07004294 -20, /* SIGNAL_STRENGTH_POOR */
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09004295 -17, /* SIGNAL_STRENGTH_MODERATE */
4296 -14, /* SIGNAL_STRENGTH_GOOD */
Shuo Qian66c51cd2020-05-01 00:38:02 -07004297 -11 /* SIGNAL_STRENGTH_GREAT */
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09004298 });
4299 sDefaults.putIntArray(KEY_LTE_RSSNR_THRESHOLDS_INT_ARRAY,
4300 new int[] {
Shuo Qian6775b772020-06-11 10:32:17 -07004301 -3, /* SIGNAL_STRENGTH_POOR */
4302 1, /* SIGNAL_STRENGTH_MODERATE */
4303 5, /* SIGNAL_STRENGTH_GOOD */
4304 13 /* SIGNAL_STRENGTH_GREAT */
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09004305 });
Tomita, Ryounosuke Xd41feee2017-12-13 18:46:12 +09004306 sDefaults.putIntArray(KEY_WCDMA_RSCP_THRESHOLDS_INT_ARRAY,
4307 new int[] {
4308 -115, /* SIGNAL_STRENGTH_POOR */
4309 -105, /* SIGNAL_STRENGTH_MODERATE */
4310 -95, /* SIGNAL_STRENGTH_GOOD */
4311 -85 /* SIGNAL_STRENGTH_GREAT */
4312 });
Shuo Qian7d7b2f12019-11-23 19:09:36 -08004313 sDefaults.putIntArray(KEY_5G_NR_SSRSRP_THRESHOLDS_INT_ARRAY,
4314 // Boundaries: [-140 dB, -44 dB]
4315 new int[] {
sqian9db66a62020-01-23 15:42:51 -08004316 -110, /* SIGNAL_STRENGTH_POOR */
4317 -90, /* SIGNAL_STRENGTH_MODERATE */
4318 -80, /* SIGNAL_STRENGTH_GOOD */
4319 -65, /* SIGNAL_STRENGTH_GREAT */
Shuo Qian7d7b2f12019-11-23 19:09:36 -08004320 });
4321 sDefaults.putIntArray(KEY_5G_NR_SSRSRQ_THRESHOLDS_INT_ARRAY,
Shuo Qian26e679e2020-07-01 11:48:52 -07004322 // Boundaries: [-43 dB, 20 dB]
Shuo Qian7d7b2f12019-11-23 19:09:36 -08004323 new int[] {
Shuo Qian26e679e2020-07-01 11:48:52 -07004324 -31, /* SIGNAL_STRENGTH_POOR */
4325 -19, /* SIGNAL_STRENGTH_MODERATE */
4326 -7, /* SIGNAL_STRENGTH_GOOD */
4327 6 /* SIGNAL_STRENGTH_GREAT */
Shuo Qian7d7b2f12019-11-23 19:09:36 -08004328 });
4329 sDefaults.putIntArray(KEY_5G_NR_SSSINR_THRESHOLDS_INT_ARRAY,
4330 // Boundaries: [-23 dB, 40 dB]
4331 new int[] {
sqian9db66a62020-01-23 15:42:51 -08004332 -5, /* SIGNAL_STRENGTH_POOR */
4333 5, /* SIGNAL_STRENGTH_MODERATE */
4334 15, /* SIGNAL_STRENGTH_GOOD */
4335 30 /* SIGNAL_STRENGTH_GREAT */
Shuo Qian7d7b2f12019-11-23 19:09:36 -08004336 });
4337 sDefaults.putInt(KEY_PARAMETERS_USE_FOR_5G_NR_SIGNAL_BAR_INT,
4338 CellSignalStrengthNr.USE_SSRSRP);
SongFerngWang68c58a52020-04-13 18:13:04 +08004339 sDefaults.putBoolean(KEY_SIGNAL_STRENGTH_NR_NSA_USE_LTE_AS_PRIMARY_BOOL, true);
Sarah Chin5023ffd2020-02-07 10:33:06 -08004340 sDefaults.putStringArray(KEY_BANDWIDTH_STRING_ARRAY, new String[]{
4341 "GPRS:24,24", "EDGE:70,18", "UMTS:115,115", "CDMA-IS95A:14,14", "CDMA-IS95B:14,14",
4342 "1xRTT:30,30", "EvDo-rev.0:750,48", "EvDo-rev.A:950,550", "HSDPA:4300,620",
Sarah Chin4ab6a9e2020-04-29 11:23:02 -07004343 "HSUPA:4300,1800", "HSPA:4300,1800", "EvDo-rev.B:1500,550", "eHRPD:750,48",
Sarah Chin69634212020-06-04 11:29:18 -07004344 "HSPAP:13000,3400", "TD-SCDMA:115,115", "LTE:30000,15000", "NR_NSA:47000,18000",
4345 "NR_NSA_MMWAVE:145000,60000", "NR_SA:145000,60000"});
Sarah Chin5023ffd2020-02-07 10:33:06 -08004346 sDefaults.putBoolean(KEY_BANDWIDTH_NR_NSA_USE_LTE_VALUE_FOR_UPSTREAM_BOOL, false);
Nathan Harold549c3ba2019-01-03 10:30:31 -08004347 sDefaults.putString(KEY_WCDMA_DEFAULT_SIGNAL_STRENGTH_MEASUREMENT_STRING, "rssi");
Mengjun Lengc9356222018-08-28 11:05:34 +08004348 sDefaults.putBoolean(KEY_CONFIG_SHOW_ORIG_DIAL_STRING_FOR_CDMA_BOOL, false);
Kikkawa Shohei638d11e2018-09-21 17:06:07 +09004349 sDefaults.putBoolean(KEY_SHOW_CALL_BLOCKING_DISABLED_NOTIFICATION_ALWAYS_BOOL, false);
SongFerngWang165d2d22018-07-09 21:10:26 +08004350 sDefaults.putBoolean(KEY_CALL_FORWARDING_OVER_UT_WARNING_BOOL, false);
4351 sDefaults.putBoolean(KEY_CALL_BARRING_OVER_UT_WARNING_BOOL, false);
4352 sDefaults.putBoolean(KEY_CALLER_ID_OVER_UT_WARNING_BOOL, false);
4353 sDefaults.putBoolean(KEY_CALL_WAITING_OVER_UT_WARNING_BOOL, false);
Youming Ye568455f2018-10-24 14:54:39 -07004354 sDefaults.putBoolean(KEY_SUPPORT_CLIR_NETWORK_DEFAULT_BOOL, true);
Chuck Liao3bad37e2018-10-30 11:39:56 +08004355 sDefaults.putBoolean(KEY_SUPPORT_EMERGENCY_DIALER_SHORTCUT_BOOL, true);
SongFerngWangc64d9702018-10-24 11:37:13 +08004356 sDefaults.putBoolean(KEY_USE_CALL_FORWARDING_USSD_BOOL, false);
4357 sDefaults.putBoolean(KEY_USE_CALLER_ID_USSD_BOOL, false);
4358 sDefaults.putInt(KEY_CALL_WAITING_SERVICE_CLASS_INT, 1 /* SERVICE_CLASS_VOICE */);
Pengquan Mengdfb39562018-12-05 16:26:42 -08004359 sDefaults.putString(KEY_5G_ICON_CONFIGURATION_STRING,
SongFerngWang56e1a312020-03-10 13:08:31 +08004360 "connected_mmwave:5G,connected:5G,not_restricted_rrc_idle:5G,"
4361 + "not_restricted_rrc_con:5G");
Sarah Chin46941d62020-04-20 21:11:40 -07004362 sDefaults.putString(KEY_5G_ICON_DISPLAY_GRACE_PERIOD_STRING, "");
4363 sDefaults.putString(KEY_5G_ICON_DISPLAY_SECONDARY_GRACE_PERIOD_STRING, "");
SongFerngWang3a3af2f2020-07-07 18:10:00 +08004364 sDefaults.putBoolean(KEY_NR_TIMERS_RESET_IF_NON_ENDC_AND_RRC_IDLE_BOOL, false);
Sarah Chine0b991e2020-02-04 12:08:45 -08004365 /* Default value is 1 hour. */
4366 sDefaults.putLong(KEY_5G_WATCHDOG_TIME_MS_LONG, 3600000);
4367 sDefaults.putBoolean(KEY_UNMETERED_NR_NSA_BOOL, false);
4368 sDefaults.putBoolean(KEY_UNMETERED_NR_NSA_MMWAVE_BOOL, false);
4369 sDefaults.putBoolean(KEY_UNMETERED_NR_NSA_SUB6_BOOL, false);
Sarah Chindc310312020-04-01 10:59:34 -07004370 sDefaults.putBoolean(KEY_UNMETERED_NR_NSA_WHEN_ROAMING_BOOL, false);
Sarah Chin5956f302020-04-09 10:33:28 -07004371 sDefaults.putBoolean(KEY_UNMETERED_NR_SA_BOOL, false);
4372 sDefaults.putBoolean(KEY_UNMETERED_NR_SA_MMWAVE_BOOL, false);
4373 sDefaults.putBoolean(KEY_UNMETERED_NR_SA_SUB6_BOOL, false);
Sukanya Rajkhowa6de48e42018-08-20 16:35:36 +08004374 sDefaults.putBoolean(KEY_ASCII_7_BIT_SUPPORT_FOR_LONG_MESSAGE_BOOL, false);
Nishizawa Nobuhiro7feb6322020-01-30 18:01:36 +09004375 sDefaults.putBoolean(KEY_SHOW_WIFI_CALLING_ICON_IN_STATUS_BAR_BOOL, false);
Sooraj Sasindran6633c572019-03-29 23:14:23 +00004376 /* Default value is minimum RSRP level needed for SIGNAL_STRENGTH_GOOD */
4377 sDefaults.putInt(KEY_OPPORTUNISTIC_NETWORK_ENTRY_THRESHOLD_RSRP_INT, -108);
Sooraj Sasindran873252f2018-12-11 10:35:16 -08004378 /* Default value is minimum RSRP level needed for SIGNAL_STRENGTH_MODERATE */
Sooraj Sasindran6633c572019-03-29 23:14:23 +00004379 sDefaults.putInt(KEY_OPPORTUNISTIC_NETWORK_EXIT_THRESHOLD_RSRP_INT, -118);
4380 /* Default value is minimum RSSNR level needed for SIGNAL_STRENGTH_GOOD */
4381 sDefaults.putInt(KEY_OPPORTUNISTIC_NETWORK_ENTRY_THRESHOLD_RSSNR_INT, 45);
Sooraj Sasindran873252f2018-12-11 10:35:16 -08004382 /* Default value is minimum RSSNR level needed for SIGNAL_STRENGTH_MODERATE */
Sooraj Sasindran6633c572019-03-29 23:14:23 +00004383 sDefaults.putInt(KEY_OPPORTUNISTIC_NETWORK_EXIT_THRESHOLD_RSSNR_INT, 10);
Sooraj Sasindran73710f82019-01-09 11:09:22 -08004384 /* Default value is 1024 kbps */
4385 sDefaults.putInt(KEY_OPPORTUNISTIC_NETWORK_ENTRY_THRESHOLD_BANDWIDTH_INT, 1024);
4386 /* Default value is 10 seconds */
Sooraj Sasindran5f7ca3a2019-02-20 19:51:06 -08004387 sDefaults.putLong(KEY_OPPORTUNISTIC_NETWORK_ENTRY_OR_EXIT_HYSTERESIS_TIME_LONG, 10000);
Sooraj Sasindran73710f82019-01-09 11:09:22 -08004388 /* Default value is 10 seconds. */
Sooraj Sasindran5f7ca3a2019-02-20 19:51:06 -08004389 sDefaults.putLong(KEY_OPPORTUNISTIC_NETWORK_DATA_SWITCH_HYSTERESIS_TIME_LONG, 10000);
Sooraj Sasindran9f80e4b2019-08-01 13:52:32 -07004390 /* Default value is 3 seconds. */
4391 sDefaults.putLong(KEY_OPPORTUNISTIC_NETWORK_DATA_SWITCH_EXIT_HYSTERESIS_TIME_LONG, 3000);
Sooraj Sasindran75c09602019-09-13 10:40:32 -07004392 sDefaults.putBoolean(KEY_PING_TEST_BEFORE_DATA_SWITCH_BOOL, true);
Sooraj Sasindran8c04a5a2019-11-04 13:07:23 -08004393 sDefaults.putBoolean(KEY_SWITCH_DATA_TO_PRIMARY_IF_PRIMARY_IS_OOS_BOOL, true);
Sooraj Sasindran74891f22019-11-19 10:23:22 -08004394 /* Default value is 60 seconds. */
4395 sDefaults.putLong(KEY_OPPORTUNISTIC_NETWORK_PING_PONG_TIME_LONG, 60000);
Sooraj Sasindran8c04a5a2019-11-04 13:07:23 -08004396 /* Default value is 10 seconds. */
4397 sDefaults.putLong(KEY_OPPORTUNISTIC_NETWORK_BACKOFF_TIME_LONG, 10000);
Sooraj Sasindran74891f22019-11-19 10:23:22 -08004398 /* Default value is 60 seconds. */
4399 sDefaults.putLong(KEY_OPPORTUNISTIC_NETWORK_MAX_BACKOFF_TIME_LONG, 60000);
Meng Wang19b214d2018-11-07 12:14:39 -08004400 sDefaults.putAll(Gps.getDefaults());
chen xueb07e4e2019-02-08 17:40:33 -08004401 sDefaults.putIntArray(KEY_CDMA_ENHANCED_ROAMING_INDICATOR_FOR_HOME_NETWORK_INT_ARRAY,
4402 new int[] {
4403 1 /* Roaming Indicator Off */
4404 });
sqian69f48c52019-02-15 16:19:36 -08004405 sDefaults.putStringArray(KEY_EMERGENCY_NUMBER_PREFIX_STRING_ARRAY, new String[0]);
mavishsu00111212019-03-06 13:12:23 +08004406 sDefaults.putBoolean(KEY_USE_USIM_BOOL, false);
Hall Liuf30b5ac2019-04-30 07:45:00 -07004407 sDefaults.putBoolean(KEY_SHOW_WFC_LOCATION_PRIVACY_POLICY_BOOL, false);
James.cf Lin8f05cb62019-08-07 15:41:45 +08004408 sDefaults.putBoolean(KEY_AUTO_CANCEL_CS_REJECT_NOTIFICATION, true);
Bonian Chen612e6a92019-03-26 01:49:39 +08004409 sDefaults.putString(KEY_SMART_FORWARDING_CONFIG_COMPONENT_NAME_STRING, "");
Malcolm Chen50ba9632019-02-26 16:49:56 -08004410 sDefaults.putBoolean(KEY_ALWAYS_SHOW_PRIMARY_SIGNAL_BAR_IN_OPPORTUNISTIC_NETWORK_BOOLEAN,
4411 false);
Nathan Harold773b0822019-03-12 15:51:42 -07004412 sDefaults.putString(KEY_SUBSCRIPTION_GROUP_UUID_STRING, "");
4413 sDefaults.putBoolean(KEY_IS_OPPORTUNISTIC_SUBSCRIPTION_BOOL, false);
andychoub80dbce2019-04-09 14:50:31 +08004414 sDefaults.putIntArray(KEY_GSM_RSSI_THRESHOLDS_INT_ARRAY,
4415 new int[] {
4416 -107, /* SIGNAL_STRENGTH_POOR */
4417 -103, /* SIGNAL_STRENGTH_MODERATE */
4418 -97, /* SIGNAL_STRENGTH_GOOD */
4419 -89, /* SIGNAL_STRENGTH_GREAT */
4420 });
andychoudcc0dd22019-05-08 23:24:08 +08004421 sDefaults.putBoolean(KEY_SUPPORT_WPS_OVER_IMS_BOOL, true);
Dheeraj Shetty054700a2019-05-23 18:22:05 -07004422 sDefaults.putAll(Ims.getDefaults());
Nazanin0c3a6b72020-08-18 14:45:22 -07004423 sDefaults.putStringArray(KEY_CARRIER_CERTIFICATE_STRING_ARRAY, new String[0]);
Saki Oomori63bb8562018-08-22 16:07:07 +09004424 sDefaults.putIntArray(KEY_DISCONNECT_CAUSE_PLAY_BUSYTONE_INT_ARRAY,
4425 new int[] {4 /* BUSY */});
Hideki Ishiide2688e2018-09-27 17:26:21 +09004426 sDefaults.putBoolean(KEY_PREVENT_CLIR_ACTIVATION_AND_DEACTIVATION_CODE_BOOL, false);
Malcolm Chen58f8d0f2019-10-31 15:06:19 -07004427 sDefaults.putLong(KEY_DATA_SWITCH_VALIDATION_TIMEOUT_LONG, 2000);
James.cf Lin8da1b072020-02-27 18:37:17 +08004428 sDefaults.putStringArray(KEY_MMI_TWO_DIGIT_NUMBER_PATTERN_STRING_ARRAY, new String[0]);
Tomita, Ryounosuke Xbe117202018-09-11 14:06:40 +09004429 sDefaults.putInt(KEY_PARAMETERS_USED_FOR_LTE_SIGNAL_BAR_INT,
SongFerngWang680c9862020-02-04 21:29:47 +08004430 CellSignalStrengthLte.USE_RSRP);
lesle14a0902019-12-12 17:16:30 +08004431 // Default wifi configurations.
4432 sDefaults.putAll(Wifi.getDefaults());
Hai Shalom0a5b2072019-12-26 16:17:00 -08004433 sDefaults.putBoolean(ENABLE_EAP_METHOD_PREFIX_BOOL, false);
Shinsuke Ishioka5ee45892018-08-30 13:33:30 +09004434 sDefaults.putBoolean(KEY_SHOW_FORWARDED_NUMBER_BOOL, false);
Malcolm Chen57b574e2020-02-19 15:21:22 -08004435 sDefaults.putLong(KEY_DATA_SWITCH_VALIDATION_MIN_GAP_LONG, TimeUnit.DAYS.toMillis(1));
Jack Yu1e1ff942019-12-23 15:19:56 -08004436 sDefaults.putStringArray(KEY_MISSED_INCOMING_CALL_SMS_ORIGINATOR_STRING_ARRAY,
4437 new String[0]);
Daniel Bright14ad8422020-03-24 14:53:59 -07004438 sDefaults.putStringArray(KEY_APN_PRIORITY_STRING_ARRAY, new String[] {
4439 "default:0", "mms:2", "supl:2", "dun:2", "hipri:3", "fota:2",
4440 "ims:2", "cbs:2", "ia:2", "emergency:2", "mcx:3", "xcap:3"
4441 });
Jack Yu1e1ff942019-12-23 15:19:56 -08004442 sDefaults.putStringArray(KEY_MISSED_INCOMING_CALL_SMS_PATTERN_STRING_ARRAY, new String[0]);
Amit Mahajan4f59bdd2020-09-18 15:17:28 -07004443 sDefaults.putBoolean(KEY_DISABLE_DUN_APN_WHILE_ROAMING_WITH_PRESET_APN_BOOL, false);
4444 sDefaults.putString(KEY_DEFAULT_PREFERRED_APN_NAME_STRING, "");
Sarah Chindc7260a2020-08-06 17:37:40 -07004445 sDefaults.putBoolean(KEY_USE_LOWER_MTU_VALUE_IF_BOTH_RECEIVED, false);
lesle14a0902019-12-12 17:16:30 +08004446 }
4447
4448 /**
4449 * Wi-Fi configs used in WiFi Module.
4450 *
4451 * @hide
4452 */
4453 @SystemApi
4454 public static final class Wifi {
4455 /** Prefix of all Wifi.KEY_* constants. */
4456 public static final String KEY_PREFIX = "wifi.";
4457 /**
lesl565176c2020-02-24 18:53:06 +08004458 * It contains the maximum client count definition that the carrier sets.
4459 * The default is 0, which means that the carrier hasn't set a requirement.
lesle14a0902019-12-12 17:16:30 +08004460 */
4461 public static final String KEY_HOTSPOT_MAX_CLIENT_COUNT =
4462 KEY_PREFIX + "hotspot_maximum_client_count";
4463
4464 private static PersistableBundle getDefaults() {
4465 PersistableBundle defaults = new PersistableBundle();
4466 defaults.putInt(KEY_HOTSPOT_MAX_CLIENT_COUNT, 0);
4467 return defaults;
4468 }
4469
4470 private Wifi() {}
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004471 }
4472
4473 /**
4474 * Gets the configuration values for a particular subscription, which is associated with a
4475 * specific SIM card. If an invalid subId is used, the returned config will contain default
yinxu349b6442018-03-16 10:16:53 -07004476 * values. After using this method to get the configuration bundle,
4477 * {@link #isConfigForIdentifiedCarrier(PersistableBundle)} should be called to confirm whether
4478 * any carrier specific configuration has been applied.
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004479 *
Junda Liufbd740c2015-06-18 16:29:35 -07004480 * <p>Requires Permission:
4481 * {@link android.Manifest.permission#READ_PHONE_STATE READ_PHONE_STATE}
4482 *
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004483 * @param subId the subscription ID, normally obtained from {@link SubscriptionManager}.
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -07004484 * @return A {@link PersistableBundle} containing the config for the given subId, or default
4485 * values for an invalid subId.
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004486 */
Jonathan Basserib731c3d2015-05-05 12:00:59 -07004487 @Nullable
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -07004488 public PersistableBundle getConfigForSubId(int subId) {
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004489 try {
Chenjie Luo90bc39d2015-12-03 12:24:12 -08004490 ICarrierConfigLoader loader = getICarrierConfigLoader();
4491 if (loader == null) {
4492 Rlog.w(TAG, "Error getting config for subId " + subId
4493 + " ICarrierConfigLoader is null");
4494 return null;
4495 }
Philip P. Moltmann33692f72019-10-03 11:56:11 -07004496 return loader.getConfigForSubIdWithFeature(subId, mContext.getOpPackageName(),
Philip P. Moltmann12ac3f42020-03-05 15:01:29 -08004497 mContext.getAttributionTag());
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004498 } catch (RemoteException ex) {
Chenjie Luo90bc39d2015-12-03 12:24:12 -08004499 Rlog.e(TAG, "Error getting config for subId " + subId + ": "
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004500 + ex.toString());
4501 }
4502 return null;
4503 }
4504
4505 /**
Hall Liue5b1fda2018-10-22 18:17:44 -07004506 * Overrides the carrier config of the provided subscription ID with the provided values.
4507 *
Brad Ebingera298e672019-04-15 17:10:26 -07004508 * Any further queries to carrier config from any process will return the overridden values
4509 * after this method returns. The overrides are effective for the lifetime of the phone process
4510 * until the user passes in {@code null} for {@code overrideValues}. This removes all previous
4511 * overrides and sets the carrier config back to production values.
Hall Liue5b1fda2018-10-22 18:17:44 -07004512 *
4513 * May throw an {@link IllegalArgumentException} if {@code overrideValues} contains invalid
4514 * values for the specified config keys.
4515 *
Brad Ebingercf297462019-04-25 10:59:08 -07004516 * NOTE: This API is meant for testing purposes only.
Brad Ebingera298e672019-04-15 17:10:26 -07004517 *
Hall Liue5b1fda2018-10-22 18:17:44 -07004518 * @param subscriptionId The subscription ID for which the override should be done.
Brad Ebingera298e672019-04-15 17:10:26 -07004519 * @param overrideValues Key-value pairs of the values that are to be overridden. If set to
4520 * {@code null}, this will remove all previous overrides and set the
4521 * carrier configuration back to production values.
Hall Liue5b1fda2018-10-22 18:17:44 -07004522 * @hide
4523 */
4524 @RequiresPermission(Manifest.permission.MODIFY_PHONE_STATE)
4525 @SystemApi
4526 @TestApi
4527 public void overrideConfig(int subscriptionId, @Nullable PersistableBundle overrideValues) {
Torbjorn Eklund4af3ae92019-02-13 16:42:16 +01004528 overrideConfig(subscriptionId, overrideValues, false);
4529 }
4530
4531 /**
4532 * Overrides the carrier config of the provided subscription ID with the provided values.
4533 *
4534 * Any further queries to carrier config from any process will return the overridden values
4535 * after this method returns. The overrides are effective until the user passes in {@code null}
4536 * for {@code overrideValues}. This removes all previous overrides and sets the carrier config
4537 * back to production values.
4538 *
4539 * The overrides is stored persistently and will survive a reboot if {@code persistent} is true.
4540 *
4541 * May throw an {@link IllegalArgumentException} if {@code overrideValues} contains invalid
4542 * values for the specified config keys.
4543 *
4544 * NOTE: This API is meant for testing purposes only.
4545 *
4546 * @param subscriptionId The subscription ID for which the override should be done.
4547 * @param overrideValues Key-value pairs of the values that are to be overridden. If set to
4548 * {@code null}, this will remove all previous overrides and set the
4549 * carrier configuration back to production values.
4550 * @param persistent Determines whether the override should be persistent.
4551 * @hide
4552 */
4553 @RequiresPermission(Manifest.permission.MODIFY_PHONE_STATE)
4554 public void overrideConfig(int subscriptionId, @Nullable PersistableBundle overrideValues,
4555 boolean persistent) {
Hall Liue5b1fda2018-10-22 18:17:44 -07004556 try {
4557 ICarrierConfigLoader loader = getICarrierConfigLoader();
4558 if (loader == null) {
4559 Rlog.w(TAG, "Error setting config for subId " + subscriptionId
4560 + " ICarrierConfigLoader is null");
4561 return;
4562 }
Torbjorn Eklund4af3ae92019-02-13 16:42:16 +01004563 loader.overrideConfig(subscriptionId, overrideValues, persistent);
Hall Liue5b1fda2018-10-22 18:17:44 -07004564 } catch (RemoteException ex) {
4565 Rlog.e(TAG, "Error setting config for subId " + subscriptionId + ": "
4566 + ex.toString());
4567 }
4568 }
4569
4570 /**
yinxu349b6442018-03-16 10:16:53 -07004571 * Gets the configuration values for the default subscription. After using this method to get
4572 * the configuration bundle, {@link #isConfigForIdentifiedCarrier(PersistableBundle)} should be
4573 * called to confirm whether any carrier specific configuration has been applied.
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004574 *
Junda Liufbd740c2015-06-18 16:29:35 -07004575 * <p>Requires Permission:
4576 * {@link android.Manifest.permission#READ_PHONE_STATE READ_PHONE_STATE}
4577 *
Derek Tan818822a2016-05-25 18:37:05 +00004578 * @see #getConfigForSubId
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004579 */
Jonathan Basserib731c3d2015-05-05 12:00:59 -07004580 @Nullable
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -07004581 public PersistableBundle getConfig() {
Derek Tan818822a2016-05-25 18:37:05 +00004582 return getConfigForSubId(SubscriptionManager.getDefaultSubscriptionId());
Shishir Agrawal3bf26b52016-02-17 15:52:09 -08004583 }
4584
4585 /**
yinxu0d56f3c2017-11-29 15:02:05 -08004586 * Determines whether a configuration {@link PersistableBundle} obtained from
4587 * {@link #getConfig()} or {@link #getConfigForSubId(int)} corresponds to an identified carrier.
4588 * <p>
4589 * When an app receives the {@link CarrierConfigManager#ACTION_CARRIER_CONFIG_CHANGED}
4590 * broadcast which informs it that the carrier configuration has changed, it is possible
4591 * that another reload of the carrier configuration has begun since the intent was sent.
4592 * In this case, the carrier configuration the app fetches (e.g. via {@link #getConfig()})
4593 * may not represent the configuration for the current carrier. It should be noted that it
4594 * does not necessarily mean the configuration belongs to current carrier when this function
4595 * return true because it may belong to another previous identified carrier. Users should
4596 * always call {@link #getConfig()} or {@link #getConfigForSubId(int)} after receiving the
4597 * broadcast {@link #ACTION_CARRIER_CONFIG_CHANGED}.
4598 * </p>
4599 * <p>
4600 * After using {@link #getConfig()} or {@link #getConfigForSubId(int)} an app should always
4601 * use this method to confirm whether any carrier specific configuration has been applied.
yinxu349b6442018-03-16 10:16:53 -07004602 * Especially when an app misses the broadcast {@link #ACTION_CARRIER_CONFIG_CHANGED} but it
4603 * still needs to get the current configuration, it must use this method to verify whether the
4604 * configuration is default or carrier overridden.
yinxu0d56f3c2017-11-29 15:02:05 -08004605 * </p>
4606 *
4607 * @param bundle the configuration bundle to be checked.
4608 * @return boolean true if any carrier specific configuration bundle has been applied, false
4609 * otherwise or the bundle is null.
4610 */
4611 public static boolean isConfigForIdentifiedCarrier(PersistableBundle bundle) {
4612 return bundle != null && bundle.getBoolean(KEY_CARRIER_CONFIG_APPLIED_BOOL);
4613 }
4614
4615 /**
Shishir Agrawal3bf26b52016-02-17 15:52:09 -08004616 * Calling this method triggers telephony services to fetch the current carrier configuration.
4617 * <p>
4618 * Normally this does not need to be called because the platform reloads config on its own.
4619 * This should be called by a carrier service app if it wants to update config at an arbitrary
4620 * moment.
4621 * </p>
4622 * <p>Requires that the calling app has carrier privileges.
Shishir Agrawal3bf26b52016-02-17 15:52:09 -08004623 * <p>
4624 * This method returns before the reload has completed, and
4625 * {@link android.service.carrier.CarrierService#onLoadConfig} will be called from an
4626 * arbitrary thread.
4627 * </p>
Ricardo Loo Forondaf2a8aea2017-10-26 17:02:31 -07004628 * @see TelephonyManager#hasCarrierPrivileges
Shishir Agrawal3bf26b52016-02-17 15:52:09 -08004629 */
4630 public void notifyConfigChangedForSubId(int subId) {
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004631 try {
Chenjie Luo90bc39d2015-12-03 12:24:12 -08004632 ICarrierConfigLoader loader = getICarrierConfigLoader();
4633 if (loader == null) {
4634 Rlog.w(TAG, "Error reloading config for subId=" + subId
4635 + " ICarrierConfigLoader is null");
4636 return;
4637 }
4638 loader.notifyConfigChangedForSubId(subId);
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004639 } catch (RemoteException ex) {
4640 Rlog.e(TAG, "Error reloading config for subId=" + subId + ": " + ex.toString());
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004641 }
4642 }
4643
4644 /**
4645 * Request the carrier config loader to update the cofig for phoneId.
Jonathan Basseri9b56ad82015-04-27 14:14:38 -07004646 * <p>
4647 * Depending on simState, the config may be cleared or loaded from config app. This is only used
4648 * by SubscriptionInfoUpdater.
4649 * </p>
Nancy Chen9e4cd832015-05-22 17:29:43 -07004650 *
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004651 * @hide
4652 */
4653 @SystemApi
Jeff Sharkeyd86b8fe2017-06-02 17:36:26 -06004654 @RequiresPermission(android.Manifest.permission.MODIFY_PHONE_STATE)
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004655 public void updateConfigForPhoneId(int phoneId, String simState) {
4656 try {
Chenjie Luo90bc39d2015-12-03 12:24:12 -08004657 ICarrierConfigLoader loader = getICarrierConfigLoader();
4658 if (loader == null) {
4659 Rlog.w(TAG, "Error updating config for phoneId=" + phoneId
4660 + " ICarrierConfigLoader is null");
4661 return;
4662 }
4663 loader.updateConfigForPhoneId(phoneId, simState);
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004664 } catch (RemoteException ex) {
4665 Rlog.e(TAG, "Error updating config for phoneId=" + phoneId + ": " + ex.toString());
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004666 }
4667 }
4668
Shuo Qianec428aa2019-12-19 15:09:43 -08004669 /**
4670 * Gets the package name for a default carrier service.
4671 * @return the package name for a default carrier service; empty string if not available.
4672 *
4673 * @hide
4674 */
4675 @NonNull
4676 @SystemApi
4677 @RequiresPermission(android.Manifest.permission.READ_PRIVILEGED_PHONE_STATE)
Jeff Sharkey17bebd22017-07-19 21:00:38 -06004678 public String getDefaultCarrierServicePackageName() {
4679 try {
Shuo Qianec428aa2019-12-19 15:09:43 -08004680 ICarrierConfigLoader loader = getICarrierConfigLoader();
4681 if (loader == null) {
4682 Rlog.w(TAG, "getDefaultCarrierServicePackageName ICarrierConfigLoader is null");
4683 return "";
4684 }
4685 return loader.getDefaultCarrierServicePackageName();
4686 } catch (RemoteException ex) {
4687 Rlog.e(TAG, "getDefaultCarrierServicePackageName ICarrierConfigLoader is null"
4688 + ex.toString());
Jeff Sharkey17bebd22017-07-19 21:00:38 -06004689 }
Shuo Qianec428aa2019-12-19 15:09:43 -08004690 return "";
Jeff Sharkey17bebd22017-07-19 21:00:38 -06004691 }
4692
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004693 /**
Jonathan Basseri98927182015-04-23 23:34:15 -07004694 * Returns a new bundle with the default value for every supported configuration variable.
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004695 *
4696 * @hide
4697 */
Jonathan Basserib731c3d2015-05-05 12:00:59 -07004698 @NonNull
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004699 @SystemApi
Jeff Sharkeyd86b8fe2017-06-02 17:36:26 -06004700 @SuppressLint("Doclava125")
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -07004701 public static PersistableBundle getDefaultConfig() {
4702 return new PersistableBundle(sDefaults);
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004703 }
4704
4705 /** @hide */
Chenjie Luo90bc39d2015-12-03 12:24:12 -08004706 @Nullable
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004707 private ICarrierConfigLoader getICarrierConfigLoader() {
Peter Wangd9eebca2019-12-30 16:14:01 -08004708 return ICarrierConfigLoader.Stub.asInterface(
4709 TelephonyFrameworkInitializer
4710 .getTelephonyServiceManager()
4711 .getCarrierConfigServiceRegisterer()
4712 .get());
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004713 }
Dheeraj Shetty054700a2019-05-23 18:22:05 -07004714
4715 /**
4716 * Gets the configuration values for a component using its prefix.
4717 *
4718 * <p>Requires Permission:
4719 * {@link android.Manifest.permission#READ_PHONE_STATE READ_PHONE_STATE}
4720 *
4721 * @param prefix prefix of the component.
4722 * @param subId the subscription ID, normally obtained from {@link SubscriptionManager}.
4723 *
4724 * @see #getConfigForSubId
4725 */
4726 @Nullable
Aurimas Liutikas4d1699d2019-08-28 13:01:05 -07004727 public PersistableBundle getConfigByComponentForSubId(@NonNull String prefix, int subId) {
Dheeraj Shetty054700a2019-05-23 18:22:05 -07004728 PersistableBundle configs = getConfigForSubId(subId);
4729
4730 if (configs == null) {
4731 return null;
4732 }
4733
4734 PersistableBundle ret = new PersistableBundle();
4735 for (String configKey : configs.keySet()) {
4736 if (configKey.startsWith(prefix)) {
4737 addConfig(configKey, configs.get(configKey), ret);
4738 }
4739 }
4740
4741 return ret;
4742 }
4743
4744 private void addConfig(String key, Object value, PersistableBundle configs) {
4745 if (value instanceof String) {
4746 configs.putString(key, (String) value);
4747 }
4748
4749 if (value instanceof String[]) {
4750 configs.putStringArray(key, (String[]) value);
4751 }
4752
4753 if (value instanceof Integer) {
4754 configs.putInt(key, (Integer) value);
4755 }
4756
4757 if (value instanceof Long) {
4758 configs.putLong(key, (Long) value);
4759 }
4760
4761 if (value instanceof Double) {
4762 configs.putDouble(key, (Double) value);
4763 }
4764
4765 if (value instanceof Boolean) {
4766 configs.putBoolean(key, (Boolean) value);
4767 }
4768
4769 if (value instanceof int[]) {
4770 configs.putIntArray(key, (int[]) value);
4771 }
4772
4773 if (value instanceof double[]) {
4774 configs.putDoubleArray(key, (double[]) value);
4775 }
4776
4777 if (value instanceof boolean[]) {
4778 configs.putBooleanArray(key, (boolean[]) value);
4779 }
4780
4781 if (value instanceof long[]) {
4782 configs.putLongArray(key, (long[]) value);
4783 }
4784 }
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08004785}