DeviceInfo: move more prefereces in PreferenceController
Bug: 34774945 Test: make RunSettingsRoboTests Change-Id: Ie5e113a6df85bab5be50c947bd7b91cfacdccb7f
This commit is contained in:
@@ -20,63 +20,39 @@ import android.app.Activity;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.os.Build;
|
||||
import android.os.Bundle;
|
||||
import android.os.SELinux;
|
||||
import android.os.SystemClock;
|
||||
import android.os.SystemProperties;
|
||||
import android.os.UserHandle;
|
||||
import android.os.UserManager;
|
||||
import android.provider.SearchIndexableResource;
|
||||
import android.provider.Settings;
|
||||
import android.support.v7.preference.Preference;
|
||||
import android.support.v7.preference.PreferenceGroup;
|
||||
import android.text.TextUtils;
|
||||
import android.util.Log;
|
||||
|
||||
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
||||
import com.android.settings.core.PreferenceController;
|
||||
import com.android.settings.dashboard.DashboardFragment;
|
||||
import com.android.settings.dashboard.SummaryLoader;
|
||||
import com.android.settings.deviceinfo.AdditionalSystemUpdatePreferenceController;
|
||||
import com.android.settings.deviceinfo.BasebandVersionPreferenceController;
|
||||
import com.android.settings.deviceinfo.BuildNumberPreferenceController;
|
||||
import com.android.settings.deviceinfo.DeviceModelPreferenceController;
|
||||
import com.android.settings.deviceinfo.FccEquipmentIdPreferenceController;
|
||||
import com.android.settings.deviceinfo.FeedbackPreferenceController;
|
||||
import com.android.settings.deviceinfo.FirmwareVersionPreferenceController;
|
||||
import com.android.settings.deviceinfo.KernelVersionPreferenceController;
|
||||
import com.android.settings.deviceinfo.ManualPreferenceController;
|
||||
import com.android.settings.deviceinfo.RegulatoryInfoPreferenceController;
|
||||
import com.android.settings.deviceinfo.SELinuxStatusPreferenceController;
|
||||
import com.android.settings.deviceinfo.SafetyInfoPreferenceController;
|
||||
import com.android.settings.deviceinfo.SafetyLegalPreferenceController;
|
||||
import com.android.settings.deviceinfo.SecurityPatchPreferenceController;
|
||||
import com.android.settings.search.BaseSearchIndexProvider;
|
||||
import com.android.settings.search.Indexable;
|
||||
import com.android.settingslib.DeviceInfoUtils;
|
||||
import com.android.settingslib.RestrictedLockUtils;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
import static com.android.settingslib.RestrictedLockUtils.EnforcedAdmin;
|
||||
|
||||
public class DeviceInfoSettings extends DashboardFragment implements Indexable {
|
||||
|
||||
private static final String LOG_TAG = "DeviceInfoSettings";
|
||||
|
||||
private static final String KEY_REGULATORY_INFO = "regulatory_info";
|
||||
private static final String PROPERTY_SELINUX_STATUS = "ro.build.selinux";
|
||||
private static final String KEY_DEVICE_MODEL = "device_model";
|
||||
private static final String KEY_SELINUX_STATUS = "selinux_status";
|
||||
private static final String KEY_BASEBAND_VERSION = "baseband_version";
|
||||
private static final String KEY_FIRMWARE_VERSION = "firmware_version";
|
||||
private static final String KEY_SECURITY_PATCH = "security_patch";
|
||||
private static final String KEY_EQUIPMENT_ID = "fcc_equipment_id";
|
||||
private static final String PROPERTY_EQUIPMENT_ID = "ro.ril.fccid";
|
||||
|
||||
|
||||
long[] mHits = new long[3];
|
||||
private BuildNumberPreferenceController mBuildNumberPreferenceController;
|
||||
|
||||
private UserManager mUm;
|
||||
|
||||
private EnforcedAdmin mFunDisallowedAdmin;
|
||||
private boolean mFunDisallowedBySystem;
|
||||
|
||||
@Override
|
||||
public int getMetricsCategory() {
|
||||
return MetricsEvent.DEVICEINFO;
|
||||
@@ -87,12 +63,6 @@ public class DeviceInfoSettings extends DashboardFragment implements Indexable {
|
||||
return R.string.help_uri_about;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onAttach(Context context) {
|
||||
super.onAttach(context);
|
||||
mUm = (UserManager) context.getSystemService(Context.USER_SERVICE);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onActivityResult(int requestCode, int resultCode, Intent data) {
|
||||
if (mBuildNumberPreferenceController.onActivityResult(requestCode, resultCode, data)) {
|
||||
@@ -101,97 +71,6 @@ public class DeviceInfoSettings extends DashboardFragment implements Indexable {
|
||||
super.onActivityResult(requestCode, resultCode, data);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCreate(Bundle icicle) {
|
||||
super.onCreate(icicle);
|
||||
|
||||
setStringSummary(KEY_FIRMWARE_VERSION, Build.VERSION.RELEASE);
|
||||
findPreference(KEY_FIRMWARE_VERSION).setEnabled(true);
|
||||
|
||||
final String patch = DeviceInfoUtils.getSecurityPatch();
|
||||
if (!TextUtils.isEmpty(patch)) {
|
||||
setStringSummary(KEY_SECURITY_PATCH, patch);
|
||||
} else {
|
||||
getPreferenceScreen().removePreference(findPreference(KEY_SECURITY_PATCH));
|
||||
}
|
||||
|
||||
setValueSummary(KEY_BASEBAND_VERSION, "gsm.version.baseband");
|
||||
setStringSummary(KEY_DEVICE_MODEL, Build.MODEL + DeviceInfoUtils.getMsvSuffix());
|
||||
setValueSummary(KEY_EQUIPMENT_ID, PROPERTY_EQUIPMENT_ID);
|
||||
|
||||
if (!SELinux.isSELinuxEnabled()) {
|
||||
String status = getResources().getString(R.string.selinux_status_disabled);
|
||||
setStringSummary(KEY_SELINUX_STATUS, status);
|
||||
} else if (!SELinux.isSELinuxEnforced()) {
|
||||
String status = getResources().getString(R.string.selinux_status_permissive);
|
||||
setStringSummary(KEY_SELINUX_STATUS, status);
|
||||
}
|
||||
|
||||
// Remove selinux information if property is not present
|
||||
removePreferenceIfPropertyMissing(getPreferenceScreen(), KEY_SELINUX_STATUS,
|
||||
PROPERTY_SELINUX_STATUS);
|
||||
|
||||
// Remove Equipment id preference if FCC ID is not set by RIL
|
||||
removePreferenceIfPropertyMissing(getPreferenceScreen(), KEY_EQUIPMENT_ID,
|
||||
PROPERTY_EQUIPMENT_ID);
|
||||
|
||||
// Remove Baseband version if wifi-only device
|
||||
if (Utils.isWifiOnly(getActivity())) {
|
||||
getPreferenceScreen().removePreference(findPreference(KEY_BASEBAND_VERSION));
|
||||
}
|
||||
|
||||
// Remove regulatory labels if no activity present to handle intent.
|
||||
removePreferenceIfActivityMissing(
|
||||
KEY_REGULATORY_INFO, Settings.ACTION_SHOW_REGULATORY_INFO);
|
||||
|
||||
removePreferenceIfActivityMissing(
|
||||
"safety_info", "android.settings.SHOW_SAFETY_AND_REGULATORY_INFO");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onResume() {
|
||||
super.onResume();
|
||||
mFunDisallowedAdmin = RestrictedLockUtils.checkIfRestrictionEnforced(
|
||||
getActivity(), UserManager.DISALLOW_FUN, UserHandle.myUserId());
|
||||
mFunDisallowedBySystem = RestrictedLockUtils.hasBaseUserRestriction(
|
||||
getActivity(), UserManager.DISALLOW_FUN, UserHandle.myUserId());
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onPreferenceTreeClick(Preference preference) {
|
||||
if (preference.getKey().equals(KEY_FIRMWARE_VERSION)) {
|
||||
System.arraycopy(mHits, 1, mHits, 0, mHits.length - 1);
|
||||
mHits[mHits.length - 1] = SystemClock.uptimeMillis();
|
||||
if (mHits[0] >= (SystemClock.uptimeMillis() - 500)) {
|
||||
if (mUm.hasUserRestriction(UserManager.DISALLOW_FUN)) {
|
||||
if (mFunDisallowedAdmin != null && !mFunDisallowedBySystem) {
|
||||
RestrictedLockUtils.sendShowAdminSupportDetailsIntent(getActivity(),
|
||||
mFunDisallowedAdmin);
|
||||
}
|
||||
Log.d(LOG_TAG, "Sorry, no fun for you!");
|
||||
return false;
|
||||
}
|
||||
|
||||
Intent intent = new Intent(Intent.ACTION_MAIN);
|
||||
intent.setClassName("android",
|
||||
com.android.internal.app.PlatLogoActivity.class.getName());
|
||||
try {
|
||||
startActivity(intent);
|
||||
} catch (Exception e) {
|
||||
Log.e(LOG_TAG, "Unable to start activity " + intent.toString());
|
||||
}
|
||||
}
|
||||
} else if (preference.getKey().equals(KEY_SECURITY_PATCH)) {
|
||||
if (getPackageManager().queryIntentActivities(preference.getIntent(), 0).isEmpty()) {
|
||||
// Don't send out the intent to stop crash
|
||||
Log.w(LOG_TAG, "Stop click action on " + KEY_SECURITY_PATCH + ": "
|
||||
+ "queryIntentActivities() returns empty");
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return super.onPreferenceTreeClick(preference);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected String getLogTag() {
|
||||
return LOG_TAG;
|
||||
@@ -213,51 +92,17 @@ public class DeviceInfoSettings extends DashboardFragment implements Indexable {
|
||||
controllers.add(new ManualPreferenceController(context));
|
||||
controllers.add(new FeedbackPreferenceController(this, context));
|
||||
controllers.add(new KernelVersionPreferenceController(context));
|
||||
controllers.add(new BasebandVersionPreferenceController(context));
|
||||
controllers.add(new FirmwareVersionPreferenceController(context, getLifecycle()));
|
||||
controllers.add(new RegulatoryInfoPreferenceController(context));
|
||||
controllers.add(new DeviceModelPreferenceController(context));
|
||||
controllers.add(new SecurityPatchPreferenceController(context));
|
||||
controllers.add(new FccEquipmentIdPreferenceController(context));
|
||||
controllers.add(new SELinuxStatusPreferenceController(context));
|
||||
controllers.add(new SafetyInfoPreferenceController(context));
|
||||
return controllers;
|
||||
}
|
||||
|
||||
private void removePreferenceIfPropertyMissing(PreferenceGroup preferenceGroup,
|
||||
String preference, String property) {
|
||||
if (SystemProperties.get(property).equals("")) {
|
||||
// Property is missing so remove preference from group
|
||||
try {
|
||||
preferenceGroup.removePreference(findPreference(preference));
|
||||
} catch (RuntimeException e) {
|
||||
Log.d(LOG_TAG, "Property '" + property + "' missing and no '"
|
||||
+ preference + "' preference");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void removePreferenceIfActivityMissing(String preferenceKey, String action) {
|
||||
final Intent intent = new Intent(action);
|
||||
if (getPackageManager().queryIntentActivities(intent, 0).isEmpty()) {
|
||||
Preference pref = findPreference(preferenceKey);
|
||||
if (pref != null) {
|
||||
getPreferenceScreen().removePreference(pref);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void setStringSummary(String preference, String value) {
|
||||
try {
|
||||
findPreference(preference).setSummary(value);
|
||||
} catch (RuntimeException e) {
|
||||
findPreference(preference).setSummary(
|
||||
getResources().getString(R.string.device_info_default));
|
||||
}
|
||||
}
|
||||
|
||||
private void setValueSummary(String preference, String property) {
|
||||
try {
|
||||
findPreference(preference).setSummary(
|
||||
SystemProperties.get(property,
|
||||
getResources().getString(R.string.device_info_default)));
|
||||
} catch (RuntimeException e) {
|
||||
// No recovery
|
||||
}
|
||||
}
|
||||
|
||||
private static class SummaryProvider implements SummaryLoader.SummaryProvider {
|
||||
|
||||
private final Context mContext;
|
||||
@@ -281,7 +126,7 @@ public class DeviceInfoSettings extends DashboardFragment implements Indexable {
|
||||
= new SummaryLoader.SummaryProviderFactory() {
|
||||
@Override
|
||||
public SummaryLoader.SummaryProvider createSummaryProvider(Activity activity,
|
||||
SummaryLoader summaryLoader) {
|
||||
SummaryLoader summaryLoader) {
|
||||
return new SummaryProvider(activity, summaryLoader);
|
||||
}
|
||||
};
|
||||
@@ -290,41 +135,30 @@ public class DeviceInfoSettings extends DashboardFragment implements Indexable {
|
||||
* For Search.
|
||||
*/
|
||||
public static final SearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
||||
new BaseSearchIndexProvider() {
|
||||
new BaseSearchIndexProvider() {
|
||||
|
||||
@Override
|
||||
public List<SearchIndexableResource> getXmlResourcesToIndex(
|
||||
Context context, boolean enabled) {
|
||||
final SearchIndexableResource sir = new SearchIndexableResource(context);
|
||||
sir.xmlResId = R.xml.device_info_settings;
|
||||
return Arrays.asList(sir);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<String> getNonIndexableKeys(Context context) {
|
||||
final List<String> keys = new ArrayList<String>();
|
||||
if (isPropertyMissing(PROPERTY_SELINUX_STATUS)) {
|
||||
keys.add(KEY_SELINUX_STATUS);
|
||||
}
|
||||
new SafetyLegalPreferenceController(context).updateNonIndexableKeys(keys);
|
||||
if (isPropertyMissing(PROPERTY_EQUIPMENT_ID)) {
|
||||
keys.add(KEY_EQUIPMENT_ID);
|
||||
}
|
||||
// Remove Baseband version if wifi-only device
|
||||
if (Utils.isWifiOnly(context)) {
|
||||
keys.add((KEY_BASEBAND_VERSION));
|
||||
@Override
|
||||
public List<SearchIndexableResource> getXmlResourcesToIndex(
|
||||
Context context, boolean enabled) {
|
||||
final SearchIndexableResource sir = new SearchIndexableResource(context);
|
||||
sir.xmlResId = R.xml.device_info_settings;
|
||||
return Arrays.asList(sir);
|
||||
}
|
||||
|
||||
new FeedbackPreferenceController(null, context)
|
||||
.updateNonIndexableKeys(keys);
|
||||
new AdditionalSystemUpdatePreferenceController(context)
|
||||
.updateNonIndexableKeys(keys);
|
||||
return keys;
|
||||
}
|
||||
|
||||
private boolean isPropertyMissing(String property) {
|
||||
return SystemProperties.get(property).equals("");
|
||||
}
|
||||
};
|
||||
|
||||
@Override
|
||||
public List<String> getNonIndexableKeys(Context context) {
|
||||
final List<String> keys = new ArrayList<>();
|
||||
new SafetyLegalPreferenceController(context).updateNonIndexableKeys(keys);
|
||||
new BasebandVersionPreferenceController(context).updateNonIndexableKeys(keys);
|
||||
new FeedbackPreferenceController(null, context).updateNonIndexableKeys(keys);
|
||||
new AdditionalSystemUpdatePreferenceController(context)
|
||||
.updateNonIndexableKeys(keys);
|
||||
new RegulatoryInfoPreferenceController(context).updateNonIndexableKeys(keys);
|
||||
new SecurityPatchPreferenceController(context).updateNonIndexableKeys(keys);
|
||||
new FccEquipmentIdPreferenceController(context).updateNonIndexableKeys(keys);
|
||||
new SELinuxStatusPreferenceController(context).updateNonIndexableKeys(keys);
|
||||
new SafetyInfoPreferenceController(context).updateNonIndexableKeys(keys);
|
||||
return keys;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
Reference in New Issue
Block a user