diff options
author | Sandeep Gutta <sangutta@codeaurora.org> | 2015-08-10 15:09:59 +0530 |
---|---|---|
committer | Linux Build Service Account <lnxbuild@localhost> | 2015-10-06 03:21:11 -0600 |
commit | 5afcac32e5d9a27ea4f66fc108de886baa55c165 (patch) | |
tree | 8bd4d73cdb2b81d6d9678da2956eecb8c38e0c50 | |
parent | 61c2094ddaae547883efd5f2583c48e735a234c3 (diff) | |
download | packages_apps_Settings-5afcac32e5d9a27ea4f66fc108de886baa55c165.zip packages_apps_Settings-5afcac32e5d9a27ea4f66fc108de886baa55c165.tar.gz packages_apps_Settings-5afcac32e5d9a27ea4f66fc108de886baa55c165.tar.bz2 |
Telephony(MSIM): Manual provision related fixes
- Consider Manual provision state while displaying
active sub info list.
- Enable sms/data user preference option only
if more than one subscription active.
- Introduce below system proeprty to control AOSP
behavior of user selection of fallback preference
for sms/data
"persist.radio.aosp_usr_pref_sel"
Change-Id: I2b308b801f3f677c5a3ffaee5a8e6beda12aedd2
-rw-r--r-- | src/com/android/settings/sim/SimSelectNotification.java | 8 | ||||
-rw-r--r-- | src/com/android/settings/sim/SimSettings.java | 103 |
2 files changed, 54 insertions, 57 deletions
diff --git a/src/com/android/settings/sim/SimSelectNotification.java b/src/com/android/settings/sim/SimSelectNotification.java index fd54e9b..16f2508 100644 --- a/src/com/android/settings/sim/SimSelectNotification.java +++ b/src/com/android/settings/sim/SimSelectNotification.java @@ -26,6 +26,7 @@ import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.content.res.Resources; +import android.os.SystemProperties; import android.provider.Settings; import android.support.v4.app.NotificationCompat; import android.telephony.SubscriptionInfo; @@ -48,8 +49,11 @@ public class SimSelectNotification extends BroadcastReceiver { final boolean isInProvisioning = Settings.Global.getInt(context.getContentResolver(), Settings.Global.DEVICE_PROVISIONED, 0) == 0; - // Do not create notifications on single SIM devices or when provisiong i.e. Setup Wizard. - if (numSlots < 2 || isInProvisioning) { + // Do not create notifications on single SIM devices or when provisiong i.e. Setup Wizard + // or User selection of fallback user preference is disabled. + if (numSlots < 2 || isInProvisioning || + !SystemProperties.getBoolean("persist.radio.aosp_usr_pref_sel", false)) { + Log.d(TAG, " no of slots " + numSlots + " provision = " + isInProvisioning); return; } diff --git a/src/com/android/settings/sim/SimSettings.java b/src/com/android/settings/sim/SimSettings.java index 6299b55..7b2dd10 100644 --- a/src/com/android/settings/sim/SimSettings.java +++ b/src/com/android/settings/sim/SimSettings.java @@ -69,6 +69,13 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable private static final String TAG = "SimSettings"; private static final boolean DBG = false; + // These are the list of possible values that + // IExtTelephony.getCurrentUiccCardProvisioningStatus() can return + private static final int PROVISIONED = 1; + private static final int NOT_PROVISIONED = 0; + private static final int INVALID_STATE = -1; + private static final int CARD_NOT_PRESENT = -2; + private static final String DISALLOW_CONFIG_SIM = "no_config_sim"; private static final String SIM_CARD_CATEGORY = "sim_cards"; private static final String KEY_CELLULAR_DATA = "sim_cellular_data"; @@ -93,6 +100,12 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable private static AlertDialog sAlertDialog = null; private static ProgressDialog sProgressDialog = null; private boolean needUpdate = false; + private int mPhoneCount = TelephonyManager.getDefault().getPhoneCount(); + private int[] mUiccProvisionStatus = new int[mPhoneCount]; + + static final String ACTION_UICC_MANUAL_PROVISION_STATUS_CHANGED = + "org.codeaurora.intent.action.ACTION_UICC_MANUAL_PROVISION_STATUS_CHANGED"; + static final String EXTRA_NEW_PROVISION_STATE = "newProvisionState"; public SimSettings() { super(DISALLOW_CONFIG_SIM); @@ -118,17 +131,14 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable mAvailableSubInfos = new ArrayList<SubscriptionInfo>(mNumSlots); mSelectableSubInfos = new ArrayList<SubscriptionInfo>(); SimSelectNotification.cancelNotification(getActivity()); + + IntentFilter intentFilter = new IntentFilter(ACTION_UICC_MANUAL_PROVISION_STATUS_CHANGED); + mContext.registerReceiver(mReceiver, intentFilter); } @Override public void onDestroy() { - for (int i = 0; i < mSimCards.getPreferenceCount(); ++i) { - Preference pref = mSimCards.getPreference(i); - if (pref instanceof SimEnablerPreference) { - // Calling destroy() here to unregister all intent listeners. - ((SimEnablerPreference)pref).destroy(); - } - } + mContext.unregisterReceiver(mReceiver); Log.d(TAG,"on onDestroy"); super.onDestroy(); } @@ -149,10 +159,6 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable if (pref instanceof SimPreference) { mSimCards.removePreference(pref); } - if (pref instanceof SimEnablerPreference) { - // Calling destroy() here to unregister all intent listeners. - ((SimEnablerPreference)pref).destroy(); - } } mAvailableSubInfos.clear(); mSelectableSubInfos.clear(); @@ -164,7 +170,7 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable simPreference.setOrder(i-mNumSlots); mSimCards.addPreference(simPreference); mAvailableSubInfos.add(sir); - if (sir != null) { + if (sir != null && (isSubProvisioned(i))) { mSelectableSubInfos.add(sir); } } @@ -203,7 +209,7 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable } else if (sir == null) { simPref.setSummary(R.string.sim_selection_required_pref); } - simPref.setEnabled(mSelectableSubInfos.size() >= 1); + simPref.setEnabled(mSelectableSubInfos.size() > 1); } private void updateCellularDataValues() { @@ -217,7 +223,7 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable } else if (sir == null) { simPref.setSummary(R.string.sim_selection_required_pref); } - simPref.setEnabled(mSelectableSubInfos.size() >= 1); + simPref.setEnabled(mSelectableSubInfos.size() > 1); } private void updateCallValues() { @@ -273,7 +279,8 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable if (pref != null) { final boolean ecbMode = SystemProperties.getBoolean( TelephonyProperties.PROPERTY_INECM_MODE, false); - pref.setEnabled((state == TelephonyManager.CALL_STATE_IDLE) && !ecbMode); + pref.setEnabled((state == TelephonyManager.CALL_STATE_IDLE) && !ecbMode + && (mSelectableSubInfos.size() > 1)); } } }; @@ -384,16 +391,7 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable private static final int INVALID_INPUT = -2; private static final int REQUEST_IN_PROGRESS = -3; - // These are the list of possible values that - // IExtTelephony.getCurrentUiccCardProvisioningStatus() can return - static final int PROVISIONED = 1; - static final int NOT_PROVISIONED = 0; - static final int INVALID_STATE = -1; - static final int CARD_NOT_PRESENT = -2; - static final String ACTION_UICC_MANUAL_PROVISION_STATUS_CHANGED = - "org.codeaurora.intent.action.ACTION_UICC_MANUAL_PROVISION_STATUS_CHANGED"; - static final String EXTRA_NEW_PROVISION_STATE = "newProvisionState"; private static final String DISPLAY_NUMBERS_TYPE = "display_numbers_type"; @@ -408,8 +406,6 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable private static final int PROGRESS_DLG_TIME_OUT = 30000; private static final int MSG_DELAY_TIME = 2000; - private int mPhoneCount = TelephonyManager.getDefault().getPhoneCount(); - int[] mUiccProvisionStatus = new int[mPhoneCount]; private IExtTelephony mExtTelephony; @@ -432,9 +428,6 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable setSwitchVisibility(View.VISIBLE); setKey("sim" + mSlotId); update(); - IntentFilter intentFilter = new IntentFilter( - ACTION_UICC_MANUAL_PROVISION_STATUS_CHANGED); - mContext.registerReceiver(mReceiver, intentFilter); } private void sendMessage(int event, Handler handler, int delay) { @@ -783,23 +776,6 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable } }; - private final BroadcastReceiver mReceiver = new BroadcastReceiver() { - @Override - public void onReceive(Context context, Intent intent) { - String action = intent.getAction(); - logd("Intent received: " + action); - if (ACTION_UICC_MANUAL_PROVISION_STATUS_CHANGED.equals(action)) { - int phoneId = intent.getIntExtra(PhoneConstants.PHONE_KEY, - SubscriptionManager.INVALID_SUBSCRIPTION_ID); - int newProvisionedState = intent.getIntExtra(EXTRA_NEW_PROVISION_STATE, - NOT_PROVISIONED); - update(); - - logd("Received ACTION_UICC_MANUAL_PROVISION_STATUS_CHANGED on phoneId: " - + phoneId + " new sub state " + newProvisionedState); - } - } - }; private Handler mHandler = new Handler() { @Override @@ -844,15 +820,6 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable } }; - public void destroy() { - try { - mContext.unregisterReceiver(mReceiver); - } catch (IllegalArgumentException e) { - // May receive Receiver not registered error - logd(e.getMessage()); - } - } - private void logd(String msg) { if (DBG) Log.d(TAG + "(" + mSlotId + ")", msg); } @@ -894,4 +861,30 @@ public class SimSettings extends RestrictedSettingsFragment implements Indexable return result; } }; + + // Internal utility, returns true if Uicc card + // corresponds to given slotId is provisioned. + private boolean isSubProvisioned(int slotId) { + boolean retVal = false; + + if (mUiccProvisionStatus[slotId] == PROVISIONED) retVal = true; + return retVal; + } + + private final BroadcastReceiver mReceiver = new BroadcastReceiver() { + @Override + public void onReceive(Context context, Intent intent) { + String action = intent.getAction(); + Log.d(TAG, "Intent received: " + action); + if (ACTION_UICC_MANUAL_PROVISION_STATUS_CHANGED.equals(action)) { + int phoneId = intent.getIntExtra(PhoneConstants.PHONE_KEY, + SubscriptionManager.INVALID_SUBSCRIPTION_ID); + int newProvisionedState = intent.getIntExtra(EXTRA_NEW_PROVISION_STATE, + NOT_PROVISIONED); + updateSubscriptions(); + Log.d(TAG, "Received ACTION_UICC_MANUAL_PROVISION_STATUS_CHANGED on phoneId: " + + phoneId + " new sub state " + newProvisionedState); + } + } + }; } |