blob: a1316a98fd4601a0f59c1b52200ce3b2001ef07a [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
Jonathan Basserib731c3d2015-05-05 12:00:59 -070019import android.annotation.NonNull;
20import android.annotation.Nullable;
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080021import android.annotation.SystemApi;
22import android.content.Context;
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -070023import android.os.PersistableBundle;
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080024import android.os.RemoteException;
25import android.os.ServiceManager;
26
Ta-wei Yen3f9306f2016-04-20 14:46:20 -070027import com.android.internal.telephony.ICarrierConfigLoader;
28
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080029/**
30 * Provides access to telephony configuration values that are carrier-specific.
31 * <p>
32 * Users should obtain an instance of this class by calling
33 * {@code mContext.getSystemService(Context.CARRIER_CONFIG_SERVICE);}
34 * </p>
35 *
36 * @see Context#getSystemService
37 * @see Context#CARRIER_CONFIG_SERVICE
38 */
39public class CarrierConfigManager {
Jonathan Basserif31ac332015-05-27 01:18:46 -070040 private final static String TAG = "CarrierConfigManager";
41
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080042 /**
43 * @hide
44 */
45 public CarrierConfigManager() {
46 }
47
48 /**
49 * This intent is broadcast by the system when carrier config changes.
50 */
51 public static final String
52 ACTION_CARRIER_CONFIG_CHANGED = "android.telephony.action.CARRIER_CONFIG_CHANGED";
53
Jonathan Basseri08e318e2015-05-29 10:12:23 -070054 // Below are the keys used in carrier config bundles. To add a new variable, define the key and
55 // give it a default value in sDefaults. If you need to ship a per-network override in the
56 // system image, that can be added in packages/apps/CarrierConfig.
57
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -080058 /**
Jonathan Basseri9b56ad82015-04-27 14:14:38 -070059 * Flag indicating whether the Phone app should ignore EVENT_SIM_NETWORK_LOCKED
60 * events from the Sim.
61 * If true, this will prevent the IccNetworkDepersonalizationPanel from being shown, and
62 * effectively disable the "Sim network lock" feature.
63 */
64 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -070065 KEY_IGNORE_SIM_NETWORK_LOCKED_EVENTS_BOOL = "ignore_sim_network_locked_events_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -070066
67 /**
68 * Flag indicating whether the Phone app should provide a "Dismiss" button on the SIM network
69 * unlock screen. The default value is true. If set to false, there will be *no way* to dismiss
70 * the SIM network unlock screen if you don't enter the correct unlock code. (One important
71 * consequence: there will be no way to make an Emergency Call if your SIM is network-locked and
72 * you don't know the PIN.)
73 */
74 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -070075 KEY_SIM_NETWORK_UNLOCK_ALLOW_DISMISS_BOOL = "sim_network_unlock_allow_dismiss_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -070076
77 /** Flag indicating if the phone is a world phone */
Jonathan Basseri69822f02015-06-04 13:48:08 -070078 public static final String KEY_WORLD_PHONE_BOOL = "world_phone_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -070079
80 /**
Chris Manton1ba0fa02015-09-01 13:56:46 -070081 * Flag to require or skip entitlement checks.
82 * If true, entitlement checks will be executed if device has been configured for it,
83 * If false, entitlement checks will be skipped.
Chris Manton1ba0fa02015-09-01 13:56:46 -070084 */
85 public static final String
86 KEY_REQUIRE_ENTITLEMENT_CHECKS_BOOL = "require_entitlement_checks_bool";
87
88 /**
Jordan Liu12bc4ea2016-09-12 10:57:27 -070089 * Flag indicating whether radio is to be restarted on error PDP_FAIL_REGULAR_DEACTIVATION
90 * This is false by default.
91 * @hide
92 */
93 public static final String
94 KEY_RESTART_RADIO_ON_PDP_FAIL_REGULAR_DEACTIVATION_BOOL =
95 "restart_radio_on_pdp_fail_regular_deactivation_bool";
96
97 /**
Jonathan Basseri9b56ad82015-04-27 14:14:38 -070098 * If true, enable vibration (haptic feedback) for key presses in the EmergencyDialer activity.
99 * The pattern is set on a per-platform basis using config_virtualKeyVibePattern. To be
100 * consistent with the regular Dialer, this value should agree with the corresponding values
101 * from config.xml under apps/Contacts.
102 */
103 public static final String
Jonathan Basseri1826c232015-06-19 16:04:38 -0700104 KEY_ENABLE_DIALER_KEY_VIBRATION_BOOL = "enable_dialer_key_vibration_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700105
106 /** Flag indicating if dtmf tone type is enabled */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700107 public static final String KEY_DTMF_TYPE_ENABLED_BOOL = "dtmf_type_enabled_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700108
109 /** Flag indicating if auto retry is enabled */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700110 public static final String KEY_AUTO_RETRY_ENABLED_BOOL = "auto_retry_enabled_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700111
112 /**
113 * Determine whether we want to play local DTMF tones in a call, or just let the radio/BP handle
114 * playing of the tones.
115 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700116 public static final String KEY_ALLOW_LOCAL_DTMF_TONES_BOOL = "allow_local_dtmf_tones_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700117
118 /**
119 * If true, show an onscreen "Dial" button in the dialer. In practice this is used on all
120 * platforms, even the ones with hard SEND/END keys, but for maximum flexibility it's controlled
121 * by a flag here (which can be overridden on a per-product basis.)
122 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700123 public static final String KEY_SHOW_ONSCREEN_DIAL_BUTTON_BOOL = "show_onscreen_dial_button_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700124
125 /** Determines if device implements a noise suppression device for in call audio. */
126 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700127 KEY_HAS_IN_CALL_NOISE_SUPPRESSION_BOOL = "has_in_call_noise_suppression_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700128
129 /**
130 * Determines if the current device should allow emergency numbers to be logged in the Call Log.
131 * (Some carriers require that emergency calls *not* be logged, presumably to avoid the risk of
132 * accidental redialing from the call log UI. This is a good idea, so the default here is
133 * false.)
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700134 */
135 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700136 KEY_ALLOW_EMERGENCY_NUMBERS_IN_CALL_LOG_BOOL = "allow_emergency_numbers_in_call_log_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700137
138 /** If true, removes the Voice Privacy option from Call Settings */
Jonathan Basseri3360c262015-06-09 15:16:21 -0700139 public static final String KEY_VOICE_PRIVACY_DISABLE_UI_BOOL = "voice_privacy_disable_ui_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700140
141 /** Control whether users can reach the carrier portions of Cellular Network Settings. */
142 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700143 KEY_HIDE_CARRIER_NETWORK_SETTINGS_BOOL = "hide_carrier_network_settings_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700144
Junda Liue15cca72015-06-17 09:55:57 -0700145 /** Control whether users can reach the SIM lock settings. */
146 public static final String
147 KEY_HIDE_SIM_LOCK_SETTINGS_BOOL = "hide_sim_lock_settings_bool";
148
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700149 /** Control whether users can edit APNs in Settings. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700150 public static final String KEY_APN_EXPAND_BOOL = "apn_expand_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700151
152 /** Control whether users can choose a network operator. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700153 public static final String KEY_OPERATOR_SELECTION_EXPAND_BOOL = "operator_selection_expand_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700154
155 /** Used in Cellular Network Settings for preferred network type. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700156 public static final String KEY_PREFER_2G_BOOL = "prefer_2g_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700157
Junda Liucd115b72015-05-13 14:57:48 -0700158 /** Show cdma network mode choices 1x, 3G, global etc. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700159 public static final String KEY_SHOW_CDMA_CHOICES_BOOL = "show_cdma_choices_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700160
161 /** CDMA activation goes through HFA */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700162 public static final String KEY_USE_HFA_FOR_PROVISIONING_BOOL = "use_hfa_for_provisioning_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700163
164 /**
165 * CDMA activation goes through OTASP.
166 * <p>
167 * TODO: This should be combined with config_use_hfa_for_provisioning and implemented as an enum
168 * (NONE, HFA, OTASP).
169 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700170 public static final String KEY_USE_OTASP_FOR_PROVISIONING_BOOL = "use_otasp_for_provisioning_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700171
172 /** Display carrier settings menu if true */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700173 public static final String KEY_CARRIER_SETTINGS_ENABLE_BOOL = "carrier_settings_enable_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700174
175 /** Does not display additional call seting for IMS phone based on GSM Phone */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700176 public static final String KEY_ADDITIONAL_CALL_SETTING_BOOL = "additional_call_setting_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700177
178 /** Show APN Settings for some CDMA carriers */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700179 public static final String KEY_SHOW_APN_SETTING_CDMA_BOOL = "show_apn_setting_cdma_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700180
181 /** After a CDMA conference call is merged, the swap button should be displayed. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700182 public static final String KEY_SUPPORT_SWAP_AFTER_MERGE_BOOL = "support_swap_after_merge_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700183
184 /**
Jordan Liu3643dd12016-09-08 12:45:58 -0700185 * Since the default voicemail number is empty, if a SIM card does not have a voicemail number
186 * available the user cannot use voicemail. This flag allows the user to edit the voicemail
187 * number in such cases, and is false by default.
188 * @hide
189 */
190 public static final String KEY_EDITABLE_VOICEMAIL_NUMBER_BOOL= "editable_voicemail_number_bool";
191
192 /**
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700193 * Determine whether the voicemail notification is persistent in the notification bar. If true,
194 * the voicemail notifications cannot be dismissed from the notification bar.
195 */
196 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700197 KEY_VOICEMAIL_NOTIFICATION_PERSISTENT_BOOL = "voicemail_notification_persistent_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700198
199 /** For IMS video over LTE calls, determines whether video pause signalling is supported. */
200 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700201 KEY_SUPPORT_PAUSE_IMS_VIDEO_CALLS_BOOL = "support_pause_ims_video_calls_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700202
203 /**
204 * Disables dialing "*228" (OTASP provisioning) on CDMA carriers where it is not supported or is
205 * potentially harmful by locking the SIM to 3G.
206 */
207 public static final String
Jonathan Basseri69822f02015-06-04 13:48:08 -0700208 KEY_DISABLE_CDMA_ACTIVATION_CODE_BOOL = "disable_cdma_activation_code_bool";
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700209
Amit Mahajan412e7c82015-10-05 11:05:02 -0700210 /**
Jordan Liud109a6b2016-10-04 11:46:03 -0700211 * List of RIL radio technologies (See {@link ServiceState} {@code RIL_RADIO_TECHNOLOGY_*}
212 * constants) which support only a single data connection at a time. Some carriers do not
213 * support multiple pdp on UMTS.
214 */
215 public static final String
216 KEY_ONLY_SINGLE_DC_ALLOWED_INT_ARRAY = "only_single_dc_allowed_int_array";
217
218 /**
Chris Mantonca16a792015-06-16 12:06:08 -0700219 * Override the platform's notion of a network operator being considered roaming.
220 * Value is string array of MCCMNCs to be considered roaming for 3GPP RATs.
221 */
222 public static final String
223 KEY_GSM_ROAMING_NETWORKS_STRING_ARRAY = "gsm_roaming_networks_string_array";
224
225 /**
226 * Override the platform's notion of a network operator being considered not roaming.
227 * Value is string array of MCCMNCs to be considered not roaming for 3GPP RATs.
228 */
229 public static final String
230 KEY_GSM_NONROAMING_NETWORKS_STRING_ARRAY = "gsm_nonroaming_networks_string_array";
231
232 /**
233 * Override the platform's notion of a network operator being considered roaming.
234 * Value is string array of SIDs to be considered roaming for 3GPP2 RATs.
235 */
236 public static final String
237 KEY_CDMA_ROAMING_NETWORKS_STRING_ARRAY = "cdma_roaming_networks_string_array";
238
239 /**
240 * Override the platform's notion of a network operator being considered non roaming.
241 * Value is string array of SIDs to be considered not roaming for 3GPP2 RATs.
242 */
243 public static final String
244 KEY_CDMA_NONROAMING_NETWORKS_STRING_ARRAY = "cdma_nonroaming_networks_string_array";
245
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700246 /**
Chris Manton63f25b62015-06-24 16:47:49 -0700247 * Override the platform's notion of a network operator being considered non roaming.
248 * If true all networks are considered as home network a.k.a non-roaming. When false,
249 * the 2 pairs of CMDA and GSM roaming/non-roaming arrays are consulted.
250 *
251 * @see KEY_GSM_ROAMING_NETWORKS_STRING_ARRAY
252 * @see KEY_GSM_NONROAMING_NETWORKS_STRING_ARRAY
253 * @see KEY_CDMA_ROAMING_NETWORKS_STRING_ARRAY
254 * @see KEY_CDMA_NONROAMING_NETWORKS_STRING_ARRAY
255 */
256 public static final String
257 KEY_FORCE_HOME_NETWORK_BOOL = "force_home_network_bool";
258
259 /**
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800260 * Flag specifying whether VoLTE should be available for carrier, independent of carrier
261 * provisioning. If false: hard disabled. If true: then depends on carrier provisioning,
262 * availability, etc.
263 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700264 public static final String KEY_CARRIER_VOLTE_AVAILABLE_BOOL = "carrier_volte_available_bool";
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800265
Junda Liue4786492015-06-15 13:15:28 -0700266 /**
Junda Liue5c7ca72015-06-24 14:41:14 -0700267 * Flag specifying whether video telephony is available for carrier. If false: hard disabled.
268 * If true: then depends on carrier provisioning, availability, etc.
269 */
270 public static final String KEY_CARRIER_VT_AVAILABLE_BOOL = "carrier_vt_available_bool";
271
272 /**
Jordan Liuf2456cb2016-09-01 13:25:13 -0700273 * Where there is no preloaded voicemail number on a SIM card, specifies the carrier's default
274 * voicemail number.
275 * When empty string, no default voicemail number is specified.
276 * @hide
277 */
278 public static final String KEY_DEFAULT_VM_NUMBER_STRING = "default_vm_number_string";
279
280
281 /**
Junda Liue4786492015-06-15 13:15:28 -0700282 * Flag specifying whether WFC over IMS should be available for carrier: independent of
283 * carrier provisioning. If false: hard disabled. If true: then depends on carrier
284 * provisioning, availability etc.
285 */
286 public static final String KEY_CARRIER_WFC_IMS_AVAILABLE_BOOL = "carrier_wfc_ims_available_bool";
287
fionaxuc71e8242016-03-08 11:46:55 -0800288 /**
Jordan Liu705cbc72016-09-09 11:48:48 -0700289 * Specifies a map from dialstrings to replacements for roaming network service numbers which
290 * cannot be replaced on the carrier side.
291 * <p>
292 * Individual entries have the format:
293 * [dialstring to replace]:[replacement]
294 * @hide
295 */
296 public static final String KEY_DIAL_STRING_REPLACE_STRING_ARRAY =
297 "dial_string_replace_string_array";
298
299 /**
Tyler Gunn5bbeea02016-03-30 14:50:30 -0700300 * Flag specifying whether WFC over IMS supports the "wifi only" option. If false, the wifi
301 * calling settings will not include an option for "wifi only". If true, the wifi calling
302 * settings will include an option for "wifi only"
303 * <p>
304 * By default, it is assumed that WFC supports "wifi only".
305 */
306 public static final String KEY_CARRIER_WFC_SUPPORTS_WIFI_ONLY_BOOL =
307 "carrier_wfc_supports_wifi_only_bool";
308
309 /**
fionaxuc71e8242016-03-08 11:46:55 -0800310 * Default WFC_IMS_mode 0: WIFI_ONLY
311 * 1: CELLULAR_PREFERRED
312 * 2: WIFI_PREFERRED
313 * @hide
314 */
315 public static final String KEY_CARRIER_DEFAULT_WFC_IMS_MODE_INT =
316 "carrier_default_wfc_ims_mode_int";
317 /**
318 * Default WFC_IMS_enabled: true VoWiFi by default is on
319 * false VoWiFi by default is off
320 * @hide
321 */
322 public static final String KEY_CARRIER_DEFAULT_WFC_IMS_ENABLED_BOOL =
323 "carrier_default_wfc_ims_enabled_bool";
324
325 /**
326 * Default WFC_IMS_roaming_enabled: true VoWiFi roaming by default is on
327 * false VoWiFi roaming by default is off
328 * @hide
329 */
330 public static final String KEY_CARRIER_DEFAULT_WFC_IMS_ROAMING_ENABLED_BOOL =
331 "carrier_default_wfc_ims_roaming_enabled_bool";
332
Junda Liue5c7ca72015-06-24 14:41:14 -0700333 /** Flag specifying whether provisioning is required for VOLTE. */
334 public static final String KEY_CARRIER_VOLTE_PROVISIONING_REQUIRED_BOOL
335 = "carrier_volte_provisioning_required_bool";
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800336
Jonathan Basseri9b56ad82015-04-27 14:14:38 -0700337 /** Flag specifying whether VoLTE TTY is supported. */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700338 public static final String KEY_CARRIER_VOLTE_TTY_SUPPORTED_BOOL
339 = "carrier_volte_tty_supported_bool";
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800340
341 /**
Junda Liue5c7ca72015-06-24 14:41:14 -0700342 * Flag specifying whether IMS service can be turned off. If false then the service will not be
343 * turned-off completely, but individual features can be disabled.
344 */
345 public static final String KEY_CARRIER_ALLOW_TURNOFF_IMS_BOOL
346 = "carrier_allow_turnoff_ims_bool";
347
348 /**
Pavel Zhamaitsiakb4faf342015-10-16 16:39:00 -0700349 * Flag specifying whether Generic Bootstrapping Architecture capable SIM is required for IMS.
Pavel Zhamaitsiakb4faf342015-10-16 16:39:00 -0700350 */
351 public static final String KEY_CARRIER_IMS_GBA_REQUIRED_BOOL
352 = "carrier_ims_gba_required_bool";
353
354 /**
Tyler Gunnac2aefc2015-07-31 15:34:46 -0700355 * Flag specifying whether IMS instant lettering is available for the carrier. {@code True} if
356 * instant lettering is available for the carrier, {@code false} otherwise.
Tyler Gunnac2aefc2015-07-31 15:34:46 -0700357 */
358 public static final String KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL =
359 "carrier_instant_lettering_available_bool";
360
Etan Cohencd811f02015-08-18 11:11:29 -0700361 /*
362 * Flag specifying whether IMS should be the first phone attempted for E911 even if the
363 * phone is not in service.
Etan Cohencd811f02015-08-18 11:11:29 -0700364 */
365 public static final String KEY_CARRIER_USE_IMS_FIRST_FOR_EMERGENCY_BOOL
366 = "carrier_use_ims_first_for_emergency_bool";
367
Tyler Gunnac2aefc2015-07-31 15:34:46 -0700368 /**
Tyler Gunneb5fcb92015-09-04 13:16:37 -0700369 * When IMS instant lettering is available for a carrier (see
370 * {@link #KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL}), determines the list of characters
371 * which may not be contained in messages. Should be specified as a regular expression suitable
372 * for use with {@link String#matches(String)}.
Tyler Gunneb5fcb92015-09-04 13:16:37 -0700373 */
374 public static final String KEY_CARRIER_INSTANT_LETTERING_INVALID_CHARS_STRING =
375 "carrier_instant_lettering_invalid_chars_string";
376
377 /**
Tyler Gunn14be4cf2015-09-10 13:33:28 -0700378 * When IMS instant lettering is available for a carrier (see
379 * {@link #KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL}), determines a list of characters which
380 * must be escaped with a backslash '\' character. Should be specified as a string containing
381 * the characters to be escaped. For example to escape quote and backslash the string would be
382 * a quote and a backslash.
Tyler Gunn14be4cf2015-09-10 13:33:28 -0700383 */
384 public static final String KEY_CARRIER_INSTANT_LETTERING_ESCAPED_CHARS_STRING =
385 "carrier_instant_lettering_escaped_chars_string";
386
387 /**
Tyler Gunndb3da5c2015-09-21 22:11:30 -0700388 * When IMS instant lettering is available for a carrier (see
389 * {@link #KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL}), determines the character encoding
390 * which will be used when determining the length of messages. Used in the InCall UI to limit
391 * the number of characters the user may type. If empty-string, the instant lettering
392 * message size limit will be enforced on a 1:1 basis. That is, each character will count
393 * towards the messages size limit as a single bye. If a character encoding is specified, the
394 * message size limit will be based on the number of bytes in the message per the specified
395 * encoding.
Tyler Gunndb3da5c2015-09-21 22:11:30 -0700396 */
397 public static final String KEY_CARRIER_INSTANT_LETTERING_ENCODING_STRING =
398 "carrier_instant_lettering_encoding_string";
399
400 /**
401 * When IMS instant lettering is available for a carrier (see
402 * {@link #KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL}), the length limit for messages. Used
403 * in the InCall UI to ensure the user cannot enter more characters than allowed by the carrier.
404 * See also {@link #KEY_CARRIER_INSTANT_LETTERING_ENCODING_STRING} for more information on how
405 * the length of the message is calculated.
Tyler Gunndb3da5c2015-09-21 22:11:30 -0700406 */
407 public static final String KEY_CARRIER_INSTANT_LETTERING_LENGTH_LIMIT_INT =
408 "carrier_instant_lettering_length_limit_int";
409
410 /**
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800411 * If Voice Radio Technology is RIL_RADIO_TECHNOLOGY_LTE:14 or RIL_RADIO_TECHNOLOGY_UNKNOWN:0
412 * this is the value that should be used instead. A configuration value of
413 * RIL_RADIO_TECHNOLOGY_UNKNOWN:0 means there is no replacement value and that the default
414 * assumption for phone type (GSM) should be used.
415 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700416 public static final String KEY_VOLTE_REPLACEMENT_RAT_INT = "volte_replacement_rat_int";
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800417
Junda Liue4786492015-06-15 13:15:28 -0700418 /**
419 * The default sim call manager to use when the default dialer doesn't implement one. A sim call
420 * manager can control and route outgoing and incoming phone calls, even if they're placed
421 * using another connection service (PSTN, for example).
422 */
423 public static final String KEY_DEFAULT_SIM_CALL_MANAGER_STRING = "default_sim_call_manager_string";
424
Jack Yua4f2da32015-07-22 13:36:42 -0700425 /**
426 * The default flag specifying whether ETWS/CMAS test setting is forcibly disabled in
427 * Settings->More->Emergency broadcasts menu even though developer options is turned on.
Jack Yua4f2da32015-07-22 13:36:42 -0700428 */
429 public static final String KEY_CARRIER_FORCE_DISABLE_ETWS_CMAS_TEST_BOOL =
430 "carrier_force_disable_etws_cmas_test_bool";
431
Jack Yu6af6c342015-09-14 16:18:59 -0700432 /**
433 * The default flag specifying whether "Turn on Notifications" option will be always shown in
434 * Settings->More->Emergency broadcasts menu regardless developer options is turned on or not.
Jack Yu6af6c342015-09-14 16:18:59 -0700435 */
436 public static final String KEY_ALWAYS_SHOW_EMERGENCY_ALERT_ONOFF_BOOL =
437 "always_show_emergency_alert_onoff_bool";
438
Jack Yu090dd722015-12-18 15:16:24 -0800439 /**
440 * The data call APN retry configuration for default type APN.
441 * @hide
442 */
443 public static final String KEY_CARRIER_DATA_CALL_RETRY_CONFIG_DEFAULT_STRING =
444 "carrier_data_call_retry_config_default_string";
445
446 /**
447 * The data call APN retry configuration for other type APNs.
448 * @hide
449 */
450 public static final String KEY_CARRIER_DATA_CALL_RETRY_CONFIG_OTHERS_STRING =
451 "carrier_data_call_retry_config_others_string";
452
453 /**
454 * Delay between trying APN from the pool
455 * @hide
456 */
457 public static final String KEY_CARRIER_DATA_CALL_APN_DELAY_DEFAULT_LONG =
458 "carrier_data_call_apn_delay_default_long";
459
460 /**
461 * Faster delay between trying APN from the pool
462 * @hide
463 */
464 public static final String KEY_CARRIER_DATA_CALL_APN_DELAY_FASTER_LONG =
465 "carrier_data_call_apn_delay_faster_long";
466
Jack Yu66a6be32016-03-30 11:14:39 -0700467 /**
468 * Default APN types that are metered by the carrier
469 * @hide
470 */
471 public static final String KEY_CARRIER_METERED_APN_TYPES_STRINGS =
472 "carrier_metered_apn_types_strings";
fionaxu28ffb602016-04-17 23:56:42 -0700473 /**
474 * Default APN types that are roamig-metered by the carrier
475 * @hide
476 */
477 public static final String KEY_CARRIER_METERED_ROAMING_APN_TYPES_STRINGS =
478 "carrier_metered_roaming_apn_types_strings";
Jack Yu360dc212016-04-08 17:11:25 -0700479 /**
480 * CDMA carrier ERI (Enhanced Roaming Indicator) file name
481 * @hide
482 */
483 public static final String KEY_CARRIER_ERI_FILE_NAME_STRING =
484 "carrier_eri_file_name_string";
485
Nancy Chen5c86e922015-04-09 13:17:20 -0700486 /* The following 3 fields are related to carrier visual voicemail. */
487
488 /**
Jonathan Basseri6c1dc312015-06-18 16:05:39 -0700489 * The carrier number mobile outgoing (MO) sms messages are sent to.
Nancy Chen5c86e922015-04-09 13:17:20 -0700490 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700491 public static final String KEY_VVM_DESTINATION_NUMBER_STRING = "vvm_destination_number_string";
Nancy Chen5c86e922015-04-09 13:17:20 -0700492
493 /**
Jonathan Basseri6c1dc312015-06-18 16:05:39 -0700494 * The port through which the mobile outgoing (MO) sms messages are sent through.
Nancy Chen5c86e922015-04-09 13:17:20 -0700495 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700496 public static final String KEY_VVM_PORT_NUMBER_INT = "vvm_port_number_int";
Nancy Chen5c86e922015-04-09 13:17:20 -0700497
498 /**
Nancy Chencb43f422015-05-27 15:06:58 -0700499 * The type of visual voicemail protocol the carrier adheres to. See {@link TelephonyManager}
500 * for possible values. For example {@link TelephonyManager#VVM_TYPE_OMTP}.
Nancy Chen5c86e922015-04-09 13:17:20 -0700501 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700502 public static final String KEY_VVM_TYPE_STRING = "vvm_type_string";
Nancy Chen5c86e922015-04-09 13:17:20 -0700503
Nancy Chen97f5ccd2015-06-04 12:00:25 -0700504 /**
Ta-wei Yen685f53c2015-11-30 18:00:08 -0800505 * Whether cellular data is required to access visual voicemail.
506 */
Ta-wei Yen153fcd72016-05-17 15:57:20 -0700507 public static final String KEY_VVM_CELLULAR_DATA_REQUIRED_BOOL =
508 "vvm_cellular_data_required_bool";
Ta-wei Yen685f53c2015-11-30 18:00:08 -0800509
510 /**
Ta-wei Yen76193dc2016-01-25 19:04:36 -0800511 * Whether to prefetch audio data on new voicemail arrival, defaulted to true.
512 */
Ta-wei Yen153fcd72016-05-17 15:57:20 -0700513 public static final String KEY_VVM_PREFETCH_BOOL = "vvm_prefetch_bool";
Ta-wei Yen76193dc2016-01-25 19:04:36 -0800514
515 /**
Nancy Chen97f5ccd2015-06-04 12:00:25 -0700516 * The package name of the carrier's visual voicemail app to ensure that dialer visual voicemail
517 * and carrier visual voicemail are not active at the same time.
Nancy Chen97f5ccd2015-06-04 12:00:25 -0700518 */
Jonathan Basseri69822f02015-06-04 13:48:08 -0700519 public static final String KEY_CARRIER_VVM_PACKAGE_NAME_STRING = "carrier_vvm_package_name_string";
Nancy Chen97f5ccd2015-06-04 12:00:25 -0700520
Amit Mahajan02008b72015-06-11 14:54:20 -0700521 /**
Meng Wang6b2995a2016-03-14 10:08:41 -0700522 * Flag specifying whether ICCID is showed in SIM Status screen, default to false.
523 */
524 public static final String KEY_SHOW_ICCID_IN_SIM_STATUS_BOOL = "show_iccid_in_sim_status_bool";
525
526 /**
Amit Mahajan02008b72015-06-11 14:54:20 -0700527 * Flag specifying whether an additional (client initiated) intent needs to be sent on System
528 * update
Amit Mahajan02008b72015-06-11 14:54:20 -0700529 */
530 public static final String KEY_CI_ACTION_ON_SYS_UPDATE_BOOL = "ci_action_on_sys_update_bool";
531
532 /**
533 * Intent to be sent for the additional action on System update
Amit Mahajan02008b72015-06-11 14:54:20 -0700534 */
535 public static final String KEY_CI_ACTION_ON_SYS_UPDATE_INTENT_STRING =
536 "ci_action_on_sys_update_intent_string";
537
538 /**
539 * Extra to be included in the intent sent for additional action on System update
Amit Mahajan02008b72015-06-11 14:54:20 -0700540 */
541 public static final String KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_STRING =
542 "ci_action_on_sys_update_extra_string";
543
544 /**
545 * Value of extra included in intent sent for additional action on System update
Amit Mahajan02008b72015-06-11 14:54:20 -0700546 */
547 public static final String KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_VAL_STRING =
548 "ci_action_on_sys_update_extra_val_string";
549
Jonathan Basseri019523a2015-06-19 11:07:22 -0700550 /**
Roshan Piusa52c5e22015-08-14 12:58:08 -0700551 * Specifies the amount of gap to be added in millis between postdial DTMF tones. When a
552 * non-zero value is specified, the UE shall wait for the specified amount of time before it
553 * sends out successive DTMF tones on the network.
Roshan Pius9f81ce72015-08-12 12:01:42 -0700554 */
Roshan Piusdc364fe2015-09-10 10:28:06 -0700555 public static final String KEY_GSM_DTMF_TONE_DELAY_INT = "gsm_dtmf_tone_delay_int";
556
557 /**
558 * Specifies the amount of gap to be added in millis between DTMF tones. When a non-zero value
559 * is specified, the UE shall wait for the specified amount of time before it sends out
560 * successive DTMF tones on the network.
Roshan Piusdc364fe2015-09-10 10:28:06 -0700561 */
Roshan Pius9f81ce72015-08-12 12:01:42 -0700562 public static final String KEY_IMS_DTMF_TONE_DELAY_INT = "ims_dtmf_tone_delay_int";
563
564 /**
Roshan Piusa52c5e22015-08-14 12:58:08 -0700565 * Specifies the amount of gap to be added in millis between postdial DTMF tones. When a
566 * non-zero value is specified, the UE shall wait for the specified amount of time before it
567 * sends out successive DTMF tones on the network.
Roshan Piusa52c5e22015-08-14 12:58:08 -0700568 */
569 public static final String KEY_CDMA_DTMF_TONE_DELAY_INT = "cdma_dtmf_tone_delay_int";
570
571 /**
Sungmin Choi8c651ae2015-08-14 15:55:13 -0700572 * Determines whether conference calls are supported by a carrier. When {@code true},
573 * conference calling is supported, {@code false otherwise}.
Sungmin Choi8c651ae2015-08-14 15:55:13 -0700574 */
575 public static final String KEY_SUPPORT_CONFERENCE_CALL_BOOL = "support_conference_call_bool";
576
577 /**
Sungmin Choi8d2826b2015-08-25 23:30:34 -0700578 * Determine whether user can toggle Enhanced 4G LTE Mode in Settings.
Sungmin Choi8d2826b2015-08-25 23:30:34 -0700579 */
580 public static final String KEY_EDITABLE_ENHANCED_4G_LTE_BOOL = "editable_enhanced_4g_lte_bool";
581
582 /**
Sungmin Choie9d3c112015-08-31 15:32:20 -0700583 * Determine whether IMS apn can be shown.
Sungmin Choie9d3c112015-08-31 15:32:20 -0700584 */
585 public static final String KEY_HIDE_IMS_APN_BOOL = "hide_ims_apn_bool";
586
587 /**
Sungmin Choic03a1da2015-09-08 15:34:23 -0700588 * Determine whether preferred network type can be shown.
Sungmin Choic03a1da2015-09-08 15:34:23 -0700589 */
590 public static final String KEY_HIDE_PREFERRED_NETWORK_TYPE_BOOL = "hide_preferred_network_type_bool";
591
592 /**
Sungmin Choid3b28262015-12-23 14:10:41 +0900593 * Determine whether user can switch Wi-Fi preferred or Cellular preferred in calling preference.
594 * Some operators support Wi-Fi Calling only, not VoLTE.
595 * They don't need "Cellular preferred" option.
596 * In this case, set uneditalbe attribute for preferred preference.
597 * @hide
598 */
599 public static final String KEY_EDITABLE_WFC_MODE_BOOL = "editable_wfc_mode_bool";
600
Sunil Dutt7c5fda82016-04-05 22:08:57 +0530601 /**
602 * Flag to indicate if Wi-Fi needs to be disabled in ECBM
603 * @hide
604 **/
605 public static final String
606 KEY_CONFIG_WIFI_DISABLE_IN_ECBM = "config_wifi_disable_in_ecbm";
607
Sungmin Choid3b28262015-12-23 14:10:41 +0900608 /**
Pavel Zhamaitsiak7b7c4fc2016-04-12 14:24:07 -0700609 * List operator-specific error codes and indices of corresponding error strings in
610 * wfcOperatorErrorAlertMessages and wfcOperatorErrorNotificationMessages.
611 *
612 * Example: "REG09|0" specifies error code "REG09" and index "0". This index will be
613 * used to find alert and notification messages in wfcOperatorErrorAlertMessages and
614 * wfcOperatorErrorNotificationMessages.
615 *
616 * @hide
617 */
618 public static final String KEY_WFC_OPERATOR_ERROR_CODES_STRING_ARRAY =
619 "wfc_operator_error_codes_string_array";
620
621 /**
622 * Indexes of SPN format strings in wfcSpnFormats and wfcDataSpnFormats.
623 * @hide
624 */
625 public static final String KEY_WFC_SPN_FORMAT_IDX_INT = "wfc_spn_format_idx_int";
626 /** @hide */
627 public static final String KEY_WFC_DATA_SPN_FORMAT_IDX_INT = "wfc_data_spn_format_idx_int";
628
629 /**
Sanket Padawe49b20422016-06-01 12:17:23 -0700630 * Boolean to decide whether to use #KEY_CARRIER_NAME_STRING from CarrierConfig app.
631 * @hide
632 */
633 public static final String KEY_CARRIER_NAME_OVERRIDE_BOOL = "carrier_name_override_bool";
634
635 /**
636 * String to identify carrier name in CarrierConfig app. This string is used only if
637 * #KEY_CARRIER_NAME_OVERRIDE_BOOL is true
638 * @hide
639 */
640 public static final String KEY_CARRIER_NAME_STRING = "carrier_name_string";
641
642
643 /**
Jonathan Basseri019523a2015-06-19 11:07:22 -0700644 * If this is true, the SIM card (through Customer Service Profile EF file) will be able to
645 * prevent manual operator selection. If false, this SIM setting will be ignored and manual
646 * operator selection will always be available. See CPHS4_2.WW6, CPHS B.4.7.1 for more
647 * information
648 */
649 public static final String KEY_CSP_ENABLED_BOOL = "csp_enabled_bool";
650
Amit Mahajan412e7c82015-10-05 11:05:02 -0700651 /**
652 * Allow user to add APNs
Amit Mahajan412e7c82015-10-05 11:05:02 -0700653 */
654 public static final String KEY_ALLOW_ADDING_APNS_BOOL = "allow_adding_apns_bool";
655
Amit Mahajan0c081482016-01-12 18:25:33 -0800656 /**
657 * Boolean indicating if intent for emergency call state changes should be broadcast
658 * @hide
659 */
660 public static final String KEY_BROADCAST_EMERGENCY_CALL_STATE_CHANGES_BOOL =
661 "broadcast_emergency_call_state_changes_bool";
662
Jonathan Basserif31ac332015-05-27 01:18:46 -0700663 // These variables are used by the MMS service and exposed through another API, {@link
664 // SmsManager}. The variable names and string values are copied from there.
Jonathan Basseri69822f02015-06-04 13:48:08 -0700665 public static final String KEY_MMS_ALIAS_ENABLED_BOOL = "aliasEnabled";
666 public static final String KEY_MMS_ALLOW_ATTACH_AUDIO_BOOL = "allowAttachAudio";
667 public static final String KEY_MMS_APPEND_TRANSACTION_ID_BOOL = "enabledTransID";
668 public static final String KEY_MMS_GROUP_MMS_ENABLED_BOOL = "enableGroupMms";
669 public static final String KEY_MMS_MMS_DELIVERY_REPORT_ENABLED_BOOL = "enableMMSDeliveryReports";
670 public static final String KEY_MMS_MMS_ENABLED_BOOL = "enabledMMS";
671 public static final String KEY_MMS_MMS_READ_REPORT_ENABLED_BOOL = "enableMMSReadReports";
672 public static final String KEY_MMS_MULTIPART_SMS_ENABLED_BOOL = "enableMultipartSMS";
673 public static final String KEY_MMS_NOTIFY_WAP_MMSC_ENABLED_BOOL = "enabledNotifyWapMMSC";
674 public static final String KEY_MMS_SEND_MULTIPART_SMS_AS_SEPARATE_MESSAGES_BOOL = "sendMultipartSmsAsSeparateMessages";
675 public static final String KEY_MMS_SHOW_CELL_BROADCAST_APP_LINKS_BOOL = "config_cellBroadcastAppLinks";
676 public static final String KEY_MMS_SMS_DELIVERY_REPORT_ENABLED_BOOL = "enableSMSDeliveryReports";
677 public static final String KEY_MMS_SUPPORT_HTTP_CHARSET_HEADER_BOOL = "supportHttpCharsetHeader";
678 public static final String KEY_MMS_SUPPORT_MMS_CONTENT_DISPOSITION_BOOL = "supportMmsContentDisposition";
679 public static final String KEY_MMS_ALIAS_MAX_CHARS_INT = "aliasMaxChars";
680 public static final String KEY_MMS_ALIAS_MIN_CHARS_INT = "aliasMinChars";
681 public static final String KEY_MMS_HTTP_SOCKET_TIMEOUT_INT = "httpSocketTimeout";
682 public static final String KEY_MMS_MAX_IMAGE_HEIGHT_INT = "maxImageHeight";
683 public static final String KEY_MMS_MAX_IMAGE_WIDTH_INT = "maxImageWidth";
684 public static final String KEY_MMS_MAX_MESSAGE_SIZE_INT = "maxMessageSize";
685 public static final String KEY_MMS_MESSAGE_TEXT_MAX_SIZE_INT = "maxMessageTextSize";
686 public static final String KEY_MMS_RECIPIENT_LIMIT_INT = "recipientLimit";
687 public static final String KEY_MMS_SMS_TO_MMS_TEXT_LENGTH_THRESHOLD_INT = "smsToMmsTextLengthThreshold";
688 public static final String KEY_MMS_SMS_TO_MMS_TEXT_THRESHOLD_INT = "smsToMmsTextThreshold";
689 public static final String KEY_MMS_SUBJECT_MAX_LENGTH_INT = "maxSubjectLength";
690 public static final String KEY_MMS_EMAIL_GATEWAY_NUMBER_STRING = "emailGatewayNumber";
691 public static final String KEY_MMS_HTTP_PARAMS_STRING = "httpParams";
692 public static final String KEY_MMS_NAI_SUFFIX_STRING = "naiSuffix";
693 public static final String KEY_MMS_UA_PROF_TAG_NAME_STRING = "uaProfTagName";
694 public static final String KEY_MMS_UA_PROF_URL_STRING = "uaProfUrl";
695 public static final String KEY_MMS_USER_AGENT_STRING = "userAgent";
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800696
Tyler Gunn387ce2f2015-08-28 14:14:11 -0700697 /**
fionaxub5592dc2016-04-08 13:19:31 -0700698 * If carriers require differentiate un-provisioned status: cold sim or out of credit sim
699 * a package name and activity name can be provided to launch a supported carrier application
700 * that check the sim provisioning status
701 * The first element is the package name and the second element is the activity name
702 * of the provisioning app
703 * example:
704 * <item>com.google.android.carrierPackageName</item>
705 * <item>com.google.android.carrierPackageName.CarrierActivityName</item>
706 * @hide
707 */
708 public static final String KEY_SIM_PROVISIONING_STATUS_DETECTION_CARRIER_APP_STRING_ARRAY =
709 "sim_state_detection_carrier_app_string_array";
710
711 /**
Tyler Gunn387ce2f2015-08-28 14:14:11 -0700712 * Determines whether the carrier supports making non-emergency phone calls while the phone is
713 * in emergency callback mode. Default value is {@code true}, meaning that non-emergency calls
714 * are allowed in emergency callback mode.
Tyler Gunn387ce2f2015-08-28 14:14:11 -0700715 */
716 public static final String KEY_ALLOW_NON_EMERGENCY_CALLS_IN_ECM_BOOL =
Tyler Gunn6ef57c32015-08-31 13:15:27 -0700717 "allow_non_emergency_calls_in_ecm_bool";
Tyler Gunn387ce2f2015-08-28 14:14:11 -0700718
Tyler Gunn1cee4772015-12-04 21:03:30 -0800719 /**
Tyler Gunnabfdaea2015-05-28 15:09:10 -0700720 * Flag indicating whether to allow carrier video calls to emergency numbers.
721 * When {@code true}, video calls to emergency numbers will be allowed. When {@code false},
722 * video calls to emergency numbers will be initiated as audio-only calls instead.
Tyler Gunnabfdaea2015-05-28 15:09:10 -0700723 */
Tyler Gunnf0836192016-03-15 20:33:13 -0700724 public static final String KEY_ALLOW_EMERGENCY_VIDEO_CALLS_BOOL =
725 "allow_emergency_video_calls_bool";
Tyler Gunn3e122f72016-01-11 19:25:00 -0800726
727 /**
728 * Flag indicating whether the carrier supports RCS presence indication for video calls. When
729 * {@code true}, the carrier supports RCS presence indication for video calls. When presence
730 * is supported, the device should use the
731 * {@link android.provider.ContactsContract.Data#CARRIER_PRESENCE} bit mask and set the
732 * {@link android.provider.ContactsContract.Data#CARRIER_PRESENCE_VT_CAPABLE} bit to indicate
733 * whether each contact supports video calling. The UI is made aware that presence is enabled
734 * via {@link android.telecom.PhoneAccount#CAPABILITY_VIDEO_CALLING_RELIES_ON_PRESENCE}
735 * and can choose to hide or show the video calling icon based on whether a contact supports
736 * video.
Tyler Gunn3e122f72016-01-11 19:25:00 -0800737 */
Tyler Gunn3e122f72016-01-11 19:25:00 -0800738 public static final String KEY_USE_RCS_PRESENCE_BOOL = "use_rcs_presence_bool";
739
Abhijith Shastryd48935872016-02-04 17:28:03 -0800740 /**
741 * The duration in seconds that platform call and message blocking is disabled after the user
742 * contacts emergency services. Platform considers values in the range 0 to 604800 (one week) as
743 * valid. See {@link android.provider.BlockedNumberContract#isBlocked(Context, String)}).
744 */
745 public static final String KEY_DURATION_BLOCKING_DISABLED_AFTER_EMERGENCY_INT =
746 "duration_blocking_disabled_after_emergency_int";
747
qingxi247e7f42016-06-03 15:24:33 -0700748 /**
Jordan Liubd3f2a72016-09-07 12:01:24 -0700749 * For carriers which require an empty flash to be sent before sending the normal 3-way calling
750 * flash, the duration in milliseconds of the empty flash to send. When {@code 0}, no empty
751 * flash is sent.
752 * @hide
753 */
754 public static final String KEY_CDMA_3WAYCALL_FLASH_DELAY_INT = "cdma_3waycall_flash_delay_int";
755
756
757 /**
qingxi247e7f42016-06-03 15:24:33 -0700758 * @hide
759 * The default value for preferred CDMA roaming mode (aka CDMA system select.)
760 * CDMA_ROAMING_MODE_RADIO_DEFAULT = the default roaming mode from the radio
761 * CDMA_ROAMING_MODE_HOME = Home Networks
762 * CDMA_ROAMING_MODE_AFFILIATED = Roaming on Affiliated networks
763 * CDMA_ROAMING_MODE_ANY = Roaming on any networks
764 */
765 public static final String KEY_CDMA_ROAMING_MODE_INT = "cdma_roaming_mode_int";
766 /** @hide */
767 public static final int CDMA_ROAMING_MODE_RADIO_DEFAULT = -1;
768 /** @hide */
769 public static final int CDMA_ROAMING_MODE_HOME = 0;
770 /** @hide */
771 public static final int CDMA_ROAMING_MODE_AFFILIATED = 1;
772 /** @hide */
773 public static final int CDMA_ROAMING_MODE_ANY = 2;
774
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800775 /** The default value for every variable. */
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -0700776 private final static PersistableBundle sDefaults;
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800777
778 static {
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -0700779 sDefaults = new PersistableBundle();
Jonathan Basseri69822f02015-06-04 13:48:08 -0700780 sDefaults.putBoolean(KEY_ADDITIONAL_CALL_SETTING_BOOL, true);
781 sDefaults.putBoolean(KEY_ALLOW_EMERGENCY_NUMBERS_IN_CALL_LOG_BOOL, false);
782 sDefaults.putBoolean(KEY_ALLOW_LOCAL_DTMF_TONES_BOOL, true);
783 sDefaults.putBoolean(KEY_APN_EXPAND_BOOL, true);
784 sDefaults.putBoolean(KEY_AUTO_RETRY_ENABLED_BOOL, false);
785 sDefaults.putBoolean(KEY_CARRIER_SETTINGS_ENABLE_BOOL, false);
786 sDefaults.putBoolean(KEY_CARRIER_VOLTE_AVAILABLE_BOOL, false);
Junda Liue5c7ca72015-06-24 14:41:14 -0700787 sDefaults.putBoolean(KEY_CARRIER_VT_AVAILABLE_BOOL, false);
Jordan Liuf2456cb2016-09-01 13:25:13 -0700788 sDefaults.putString(KEY_DEFAULT_VM_NUMBER_STRING, "");
Junda Liue4786492015-06-15 13:15:28 -0700789 sDefaults.putBoolean(KEY_CARRIER_WFC_IMS_AVAILABLE_BOOL, false);
fionaxudcf5c2b2016-05-12 13:40:05 -0700790 sDefaults.putBoolean(KEY_CARRIER_WFC_SUPPORTS_WIFI_ONLY_BOOL, false);
fionaxuc71e8242016-03-08 11:46:55 -0800791 sDefaults.putBoolean(KEY_CARRIER_DEFAULT_WFC_IMS_ENABLED_BOOL, false);
792 sDefaults.putBoolean(KEY_CARRIER_DEFAULT_WFC_IMS_ROAMING_ENABLED_BOOL, false);
793 sDefaults.putInt(KEY_CARRIER_DEFAULT_WFC_IMS_MODE_INT, 2);
Jack Yua4f2da32015-07-22 13:36:42 -0700794 sDefaults.putBoolean(KEY_CARRIER_FORCE_DISABLE_ETWS_CMAS_TEST_BOOL, false);
Junda Liue5c7ca72015-06-24 14:41:14 -0700795 sDefaults.putBoolean(KEY_CARRIER_VOLTE_PROVISIONING_REQUIRED_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -0700796 sDefaults.putBoolean(KEY_CARRIER_VOLTE_TTY_SUPPORTED_BOOL, true);
Junda Liue5c7ca72015-06-24 14:41:14 -0700797 sDefaults.putBoolean(KEY_CARRIER_ALLOW_TURNOFF_IMS_BOOL, true);
Pavel Zhamaitsiakb4faf342015-10-16 16:39:00 -0700798 sDefaults.putBoolean(KEY_CARRIER_IMS_GBA_REQUIRED_BOOL, false);
Tyler Gunnac2aefc2015-07-31 15:34:46 -0700799 sDefaults.putBoolean(KEY_CARRIER_INSTANT_LETTERING_AVAILABLE_BOOL, false);
Etan Cohencd811f02015-08-18 11:11:29 -0700800 sDefaults.putBoolean(KEY_CARRIER_USE_IMS_FIRST_FOR_EMERGENCY_BOOL, true);
Tyler Gunneb5fcb92015-09-04 13:16:37 -0700801 sDefaults.putString(KEY_CARRIER_INSTANT_LETTERING_INVALID_CHARS_STRING, "");
Tyler Gunn14be4cf2015-09-10 13:33:28 -0700802 sDefaults.putString(KEY_CARRIER_INSTANT_LETTERING_ESCAPED_CHARS_STRING, "");
Tyler Gunndb3da5c2015-09-21 22:11:30 -0700803 sDefaults.putString(KEY_CARRIER_INSTANT_LETTERING_ENCODING_STRING, "");
804 sDefaults.putInt(KEY_CARRIER_INSTANT_LETTERING_LENGTH_LIMIT_INT, 64);
Jonathan Basseri69822f02015-06-04 13:48:08 -0700805 sDefaults.putBoolean(KEY_DISABLE_CDMA_ACTIVATION_CODE_BOOL, false);
806 sDefaults.putBoolean(KEY_DTMF_TYPE_ENABLED_BOOL, false);
807 sDefaults.putBoolean(KEY_ENABLE_DIALER_KEY_VIBRATION_BOOL, true);
808 sDefaults.putBoolean(KEY_HAS_IN_CALL_NOISE_SUPPRESSION_BOOL, false);
809 sDefaults.putBoolean(KEY_HIDE_CARRIER_NETWORK_SETTINGS_BOOL, false);
Junda Liue15cca72015-06-17 09:55:57 -0700810 sDefaults.putBoolean(KEY_HIDE_SIM_LOCK_SETTINGS_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -0700811 sDefaults.putBoolean(KEY_IGNORE_SIM_NETWORK_LOCKED_EVENTS_BOOL, false);
812 sDefaults.putBoolean(KEY_OPERATOR_SELECTION_EXPAND_BOOL, true);
813 sDefaults.putBoolean(KEY_PREFER_2G_BOOL, true);
814 sDefaults.putBoolean(KEY_SHOW_APN_SETTING_CDMA_BOOL, false);
815 sDefaults.putBoolean(KEY_SHOW_CDMA_CHOICES_BOOL, false);
816 sDefaults.putBoolean(KEY_SHOW_ONSCREEN_DIAL_BUTTON_BOOL, true);
817 sDefaults.putBoolean(KEY_SIM_NETWORK_UNLOCK_ALLOW_DISMISS_BOOL, true);
Omkar Kolangade2e8f8fe2015-12-22 21:07:04 +0530818 sDefaults.putBoolean(KEY_SUPPORT_PAUSE_IMS_VIDEO_CALLS_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -0700819 sDefaults.putBoolean(KEY_SUPPORT_SWAP_AFTER_MERGE_BOOL, true);
820 sDefaults.putBoolean(KEY_USE_HFA_FOR_PROVISIONING_BOOL, false);
Jordan Liu3643dd12016-09-08 12:45:58 -0700821 sDefaults.putBoolean(KEY_EDITABLE_VOICEMAIL_NUMBER_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -0700822 sDefaults.putBoolean(KEY_USE_OTASP_FOR_PROVISIONING_BOOL, false);
823 sDefaults.putBoolean(KEY_VOICEMAIL_NOTIFICATION_PERSISTENT_BOOL, false);
Jonathan Basseri3360c262015-06-09 15:16:21 -0700824 sDefaults.putBoolean(KEY_VOICE_PRIVACY_DISABLE_UI_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -0700825 sDefaults.putBoolean(KEY_WORLD_PHONE_BOOL, false);
Chris Manton1ba0fa02015-09-01 13:56:46 -0700826 sDefaults.putBoolean(KEY_REQUIRE_ENTITLEMENT_CHECKS_BOOL, true);
Jordan Liu12bc4ea2016-09-12 10:57:27 -0700827 sDefaults.putBoolean(KEY_RESTART_RADIO_ON_PDP_FAIL_REGULAR_DEACTIVATION_BOOL, false);
Jonathan Basseri69822f02015-06-04 13:48:08 -0700828 sDefaults.putInt(KEY_VOLTE_REPLACEMENT_RAT_INT, 0);
Junda Liue4786492015-06-15 13:15:28 -0700829 sDefaults.putString(KEY_DEFAULT_SIM_CALL_MANAGER_STRING, "");
Jonathan Basseri69822f02015-06-04 13:48:08 -0700830 sDefaults.putString(KEY_VVM_DESTINATION_NUMBER_STRING, "");
831 sDefaults.putInt(KEY_VVM_PORT_NUMBER_INT, 0);
832 sDefaults.putString(KEY_VVM_TYPE_STRING, "");
Ta-wei Yen3f9306f2016-04-20 14:46:20 -0700833 sDefaults.putBoolean(KEY_VVM_CELLULAR_DATA_REQUIRED_BOOL, false);
834 sDefaults.putBoolean(KEY_VVM_PREFETCH_BOOL, true);
Jonathan Basseri69822f02015-06-04 13:48:08 -0700835 sDefaults.putString(KEY_CARRIER_VVM_PACKAGE_NAME_STRING, "");
Meng Wang6b2995a2016-03-14 10:08:41 -0700836 sDefaults.putBoolean(KEY_SHOW_ICCID_IN_SIM_STATUS_BOOL, false);
Amit Mahajan02008b72015-06-11 14:54:20 -0700837 sDefaults.putBoolean(KEY_CI_ACTION_ON_SYS_UPDATE_BOOL, false);
838 sDefaults.putString(KEY_CI_ACTION_ON_SYS_UPDATE_INTENT_STRING, "");
839 sDefaults.putString(KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_STRING, "");
840 sDefaults.putString(KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_VAL_STRING, "");
Jonathan Basseri019523a2015-06-19 11:07:22 -0700841 sDefaults.putBoolean(KEY_CSP_ENABLED_BOOL, false);
Amit Mahajan412e7c82015-10-05 11:05:02 -0700842 sDefaults.putBoolean(KEY_ALLOW_ADDING_APNS_BOOL, true);
Amit Mahajan0c081482016-01-12 18:25:33 -0800843 sDefaults.putBoolean(KEY_BROADCAST_EMERGENCY_CALL_STATE_CHANGES_BOOL, false);
Jack Yu6af6c342015-09-14 16:18:59 -0700844 sDefaults.putBoolean(KEY_ALWAYS_SHOW_EMERGENCY_ALERT_ONOFF_BOOL, false);
Jack Yu090dd722015-12-18 15:16:24 -0800845 sDefaults.putString(KEY_CARRIER_DATA_CALL_RETRY_CONFIG_DEFAULT_STRING,
846 "default_randomization=2000,5000,10000,20000,40000,80000:5000,160000:5000,"
847 + "320000:5000,640000:5000,1280000:5000,1800000:5000");
848 sDefaults.putString(KEY_CARRIER_DATA_CALL_RETRY_CONFIG_OTHERS_STRING,
849 "max_retries=3, 5000, 5000, 5000");
850 sDefaults.putLong(KEY_CARRIER_DATA_CALL_APN_DELAY_DEFAULT_LONG, 20000);
851 sDefaults.putLong(KEY_CARRIER_DATA_CALL_APN_DELAY_FASTER_LONG, 3000);
Jack Yu360dc212016-04-08 17:11:25 -0700852 sDefaults.putString(KEY_CARRIER_ERI_FILE_NAME_STRING, "eri.xml");
Abhijith Shastryd48935872016-02-04 17:28:03 -0800853 sDefaults.putInt(KEY_DURATION_BLOCKING_DISABLED_AFTER_EMERGENCY_INT, 7200);
Jack Yu66a6be32016-03-30 11:14:39 -0700854 sDefaults.putStringArray(KEY_CARRIER_METERED_APN_TYPES_STRINGS,
855 new String[]{"default", "mms", "dun", "supl"});
fionaxu28ffb602016-04-17 23:56:42 -0700856 sDefaults.putStringArray(KEY_CARRIER_METERED_ROAMING_APN_TYPES_STRINGS,
857 new String[]{"default", "mms", "dun", "supl"});
Jonathan Basserif31ac332015-05-27 01:18:46 -0700858
Jordan Liud109a6b2016-10-04 11:46:03 -0700859 sDefaults.putIntArray(KEY_ONLY_SINGLE_DC_ALLOWED_INT_ARRAY,
860 new int[]{
861 4, /* IS95A */
862 5, /* IS95B */
863 6, /* 1xRTT */
864 7, /* EVDO_0 */
865 8, /* EVDO_A */
866 12 /* EVDO_B */
867 });
Chris Mantonca16a792015-06-16 12:06:08 -0700868 sDefaults.putStringArray(KEY_GSM_ROAMING_NETWORKS_STRING_ARRAY, null);
869 sDefaults.putStringArray(KEY_GSM_NONROAMING_NETWORKS_STRING_ARRAY, null);
870 sDefaults.putStringArray(KEY_CDMA_ROAMING_NETWORKS_STRING_ARRAY, null);
871 sDefaults.putStringArray(KEY_CDMA_NONROAMING_NETWORKS_STRING_ARRAY, null);
Jordan Liu705cbc72016-09-09 11:48:48 -0700872 sDefaults.putStringArray(KEY_DIAL_STRING_REPLACE_STRING_ARRAY, null);
Chris Manton63f25b62015-06-24 16:47:49 -0700873 sDefaults.putBoolean(KEY_FORCE_HOME_NETWORK_BOOL, false);
Roshan Piusdc364fe2015-09-10 10:28:06 -0700874 sDefaults.putInt(KEY_GSM_DTMF_TONE_DELAY_INT, 0);
Roshan Pius9f81ce72015-08-12 12:01:42 -0700875 sDefaults.putInt(KEY_IMS_DTMF_TONE_DELAY_INT, 0);
Roshan Piusa52c5e22015-08-14 12:58:08 -0700876 sDefaults.putInt(KEY_CDMA_DTMF_TONE_DELAY_INT, 100);
Jordan Liubd3f2a72016-09-07 12:01:24 -0700877 sDefaults.putInt(KEY_CDMA_3WAYCALL_FLASH_DELAY_INT , 0);
Sungmin Choi8c651ae2015-08-14 15:55:13 -0700878 sDefaults.putBoolean(KEY_SUPPORT_CONFERENCE_CALL_BOOL, true);
Sungmin Choi8d2826b2015-08-25 23:30:34 -0700879 sDefaults.putBoolean(KEY_EDITABLE_ENHANCED_4G_LTE_BOOL, true);
Sungmin Choie9d3c112015-08-31 15:32:20 -0700880 sDefaults.putBoolean(KEY_HIDE_IMS_APN_BOOL, false);
Sungmin Choic03a1da2015-09-08 15:34:23 -0700881 sDefaults.putBoolean(KEY_HIDE_PREFERRED_NETWORK_TYPE_BOOL, false);
Tyler Gunnf0836192016-03-15 20:33:13 -0700882 sDefaults.putBoolean(KEY_ALLOW_EMERGENCY_VIDEO_CALLS_BOOL, false);
Sungmin Choid3b28262015-12-23 14:10:41 +0900883 sDefaults.putBoolean(KEY_EDITABLE_WFC_MODE_BOOL, true);
Pavel Zhamaitsiak7b7c4fc2016-04-12 14:24:07 -0700884 sDefaults.putStringArray(KEY_WFC_OPERATOR_ERROR_CODES_STRING_ARRAY, null);
885 sDefaults.putInt(KEY_WFC_SPN_FORMAT_IDX_INT, 0);
886 sDefaults.putInt(KEY_WFC_DATA_SPN_FORMAT_IDX_INT, 0);
Sunil Dutt7c5fda82016-04-05 22:08:57 +0530887 sDefaults.putBoolean(KEY_CONFIG_WIFI_DISABLE_IN_ECBM, false);
Sanket Padawe49b20422016-06-01 12:17:23 -0700888 sDefaults.putBoolean(KEY_CARRIER_NAME_OVERRIDE_BOOL, false);
889 sDefaults.putString(KEY_CARRIER_NAME_STRING, "");
Chris Mantonca16a792015-06-16 12:06:08 -0700890
Jonathan Basserif31ac332015-05-27 01:18:46 -0700891 // MMS defaults
Jonathan Basseri69822f02015-06-04 13:48:08 -0700892 sDefaults.putBoolean(KEY_MMS_ALIAS_ENABLED_BOOL, false);
893 sDefaults.putBoolean(KEY_MMS_ALLOW_ATTACH_AUDIO_BOOL, true);
894 sDefaults.putBoolean(KEY_MMS_APPEND_TRANSACTION_ID_BOOL, false);
895 sDefaults.putBoolean(KEY_MMS_GROUP_MMS_ENABLED_BOOL, true);
896 sDefaults.putBoolean(KEY_MMS_MMS_DELIVERY_REPORT_ENABLED_BOOL, false);
897 sDefaults.putBoolean(KEY_MMS_MMS_ENABLED_BOOL, true);
898 sDefaults.putBoolean(KEY_MMS_MMS_READ_REPORT_ENABLED_BOOL, false);
899 sDefaults.putBoolean(KEY_MMS_MULTIPART_SMS_ENABLED_BOOL, true);
900 sDefaults.putBoolean(KEY_MMS_NOTIFY_WAP_MMSC_ENABLED_BOOL, false);
901 sDefaults.putBoolean(KEY_MMS_SEND_MULTIPART_SMS_AS_SEPARATE_MESSAGES_BOOL, false);
902 sDefaults.putBoolean(KEY_MMS_SHOW_CELL_BROADCAST_APP_LINKS_BOOL, true);
903 sDefaults.putBoolean(KEY_MMS_SMS_DELIVERY_REPORT_ENABLED_BOOL, true);
904 sDefaults.putBoolean(KEY_MMS_SUPPORT_HTTP_CHARSET_HEADER_BOOL, false);
905 sDefaults.putBoolean(KEY_MMS_SUPPORT_MMS_CONTENT_DISPOSITION_BOOL, true);
906 sDefaults.putInt(KEY_MMS_ALIAS_MAX_CHARS_INT, 48);
907 sDefaults.putInt(KEY_MMS_ALIAS_MIN_CHARS_INT, 2);
908 sDefaults.putInt(KEY_MMS_HTTP_SOCKET_TIMEOUT_INT, 60 * 1000);
909 sDefaults.putInt(KEY_MMS_MAX_IMAGE_HEIGHT_INT, 480);
910 sDefaults.putInt(KEY_MMS_MAX_IMAGE_WIDTH_INT, 640);
911 sDefaults.putInt(KEY_MMS_MAX_MESSAGE_SIZE_INT, 300 * 1024);
912 sDefaults.putInt(KEY_MMS_MESSAGE_TEXT_MAX_SIZE_INT, -1);
913 sDefaults.putInt(KEY_MMS_RECIPIENT_LIMIT_INT, Integer.MAX_VALUE);
914 sDefaults.putInt(KEY_MMS_SMS_TO_MMS_TEXT_LENGTH_THRESHOLD_INT, -1);
915 sDefaults.putInt(KEY_MMS_SMS_TO_MMS_TEXT_THRESHOLD_INT, -1);
916 sDefaults.putInt(KEY_MMS_SUBJECT_MAX_LENGTH_INT, 40);
917 sDefaults.putString(KEY_MMS_EMAIL_GATEWAY_NUMBER_STRING, "");
918 sDefaults.putString(KEY_MMS_HTTP_PARAMS_STRING, "");
919 sDefaults.putString(KEY_MMS_NAI_SUFFIX_STRING, "");
920 sDefaults.putString(KEY_MMS_UA_PROF_TAG_NAME_STRING, "x-wap-profile");
921 sDefaults.putString(KEY_MMS_UA_PROF_URL_STRING, "");
922 sDefaults.putString(KEY_MMS_USER_AGENT_STRING, "");
Tyler Gunn387ce2f2015-08-28 14:14:11 -0700923 sDefaults.putBoolean(KEY_ALLOW_NON_EMERGENCY_CALLS_IN_ECM_BOOL, true);
Tyler Gunn3e122f72016-01-11 19:25:00 -0800924 sDefaults.putBoolean(KEY_USE_RCS_PRESENCE_BOOL, false);
qingxi247e7f42016-06-03 15:24:33 -0700925 sDefaults.putInt(KEY_CDMA_ROAMING_MODE_INT, CDMA_ROAMING_MODE_RADIO_DEFAULT);
fionaxub5592dc2016-04-08 13:19:31 -0700926
927 // Used for Sim card State detection app
928 sDefaults.putStringArray(KEY_SIM_PROVISIONING_STATUS_DETECTION_CARRIER_APP_STRING_ARRAY,
929 null);
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800930 }
931
932 /**
933 * Gets the configuration values for a particular subscription, which is associated with a
934 * specific SIM card. If an invalid subId is used, the returned config will contain default
935 * values.
936 *
Junda Liufbd740c2015-06-18 16:29:35 -0700937 * <p>Requires Permission:
938 * {@link android.Manifest.permission#READ_PHONE_STATE READ_PHONE_STATE}
939 *
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800940 * @param subId the subscription ID, normally obtained from {@link SubscriptionManager}.
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -0700941 * @return A {@link PersistableBundle} containing the config for the given subId, or default
942 * values for an invalid subId.
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800943 */
Jonathan Basserib731c3d2015-05-05 12:00:59 -0700944 @Nullable
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -0700945 public PersistableBundle getConfigForSubId(int subId) {
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800946 try {
Chenjie Luo90bc39d2015-12-03 12:24:12 -0800947 ICarrierConfigLoader loader = getICarrierConfigLoader();
948 if (loader == null) {
949 Rlog.w(TAG, "Error getting config for subId " + subId
950 + " ICarrierConfigLoader is null");
951 return null;
952 }
953 return loader.getConfigForSubId(subId);
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800954 } catch (RemoteException ex) {
Chenjie Luo90bc39d2015-12-03 12:24:12 -0800955 Rlog.e(TAG, "Error getting config for subId " + subId + ": "
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800956 + ex.toString());
957 }
958 return null;
959 }
960
961 /**
962 * Gets the configuration values for the default subscription.
963 *
Junda Liufbd740c2015-06-18 16:29:35 -0700964 * <p>Requires Permission:
965 * {@link android.Manifest.permission#READ_PHONE_STATE READ_PHONE_STATE}
966 *
Derek Tan818822a2016-05-25 18:37:05 +0000967 * @see #getConfigForSubId
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800968 */
Jonathan Basserib731c3d2015-05-05 12:00:59 -0700969 @Nullable
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -0700970 public PersistableBundle getConfig() {
Derek Tan818822a2016-05-25 18:37:05 +0000971 return getConfigForSubId(SubscriptionManager.getDefaultSubscriptionId());
Shishir Agrawal3bf26b52016-02-17 15:52:09 -0800972 }
973
974 /**
975 * Calling this method triggers telephony services to fetch the current carrier configuration.
976 * <p>
977 * Normally this does not need to be called because the platform reloads config on its own.
978 * This should be called by a carrier service app if it wants to update config at an arbitrary
979 * moment.
980 * </p>
981 * <p>Requires that the calling app has carrier privileges.
982 * @see #hasCarrierPrivileges
983 * <p>
984 * This method returns before the reload has completed, and
985 * {@link android.service.carrier.CarrierService#onLoadConfig} will be called from an
986 * arbitrary thread.
987 * </p>
Shishir Agrawal3bf26b52016-02-17 15:52:09 -0800988 */
989 public void notifyConfigChangedForSubId(int subId) {
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800990 try {
Chenjie Luo90bc39d2015-12-03 12:24:12 -0800991 ICarrierConfigLoader loader = getICarrierConfigLoader();
992 if (loader == null) {
993 Rlog.w(TAG, "Error reloading config for subId=" + subId
994 + " ICarrierConfigLoader is null");
995 return;
996 }
997 loader.notifyConfigChangedForSubId(subId);
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -0800998 } catch (RemoteException ex) {
999 Rlog.e(TAG, "Error reloading config for subId=" + subId + ": " + ex.toString());
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08001000 }
1001 }
1002
1003 /**
1004 * Request the carrier config loader to update the cofig for phoneId.
Jonathan Basseri9b56ad82015-04-27 14:14:38 -07001005 * <p>
1006 * Depending on simState, the config may be cleared or loaded from config app. This is only used
1007 * by SubscriptionInfoUpdater.
1008 * </p>
Nancy Chen9e4cd832015-05-22 17:29:43 -07001009 *
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08001010 * @hide
1011 */
1012 @SystemApi
1013 public void updateConfigForPhoneId(int phoneId, String simState) {
1014 try {
Chenjie Luo90bc39d2015-12-03 12:24:12 -08001015 ICarrierConfigLoader loader = getICarrierConfigLoader();
1016 if (loader == null) {
1017 Rlog.w(TAG, "Error updating config for phoneId=" + phoneId
1018 + " ICarrierConfigLoader is null");
1019 return;
1020 }
1021 loader.updateConfigForPhoneId(phoneId, simState);
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08001022 } catch (RemoteException ex) {
1023 Rlog.e(TAG, "Error updating config for phoneId=" + phoneId + ": " + ex.toString());
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08001024 }
1025 }
1026
1027 /**
Jonathan Basseri98927182015-04-23 23:34:15 -07001028 * Returns a new bundle with the default value for every supported configuration variable.
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08001029 *
1030 * @hide
1031 */
Jonathan Basserib731c3d2015-05-05 12:00:59 -07001032 @NonNull
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08001033 @SystemApi
Jonathan Basseri4f9ad1672015-05-12 10:06:32 -07001034 public static PersistableBundle getDefaultConfig() {
1035 return new PersistableBundle(sDefaults);
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08001036 }
1037
1038 /** @hide */
Chenjie Luo90bc39d2015-12-03 12:24:12 -08001039 @Nullable
Jonathan Basseri9a1c9b62015-02-25 13:01:52 -08001040 private ICarrierConfigLoader getICarrierConfigLoader() {
1041 return ICarrierConfigLoader.Stub
1042 .asInterface(ServiceManager.getService(Context.CARRIER_CONFIG_SERVICE));
1043 }
1044}