diff options
Diffstat (limited to 'packages')
-rw-r--r-- | packages/CMSettingsProvider/src/org/cyanogenmod/cmsettings/CMSettingsProvider.java | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/packages/CMSettingsProvider/src/org/cyanogenmod/cmsettings/CMSettingsProvider.java b/packages/CMSettingsProvider/src/org/cyanogenmod/cmsettings/CMSettingsProvider.java index 5c837bd..ff65aab 100644 --- a/packages/CMSettingsProvider/src/org/cyanogenmod/cmsettings/CMSettingsProvider.java +++ b/packages/CMSettingsProvider/src/org/cyanogenmod/cmsettings/CMSettingsProvider.java @@ -522,9 +522,11 @@ public class CMSettingsProvider extends ContentProvider { // Validate value if inserting int System table final String name = values.getAsString(Settings.NameValueTable.NAME); + final String value = values.getAsString(Settings.NameValueTable.VALUE); if (CMDatabaseHelper.CMTableNames.TABLE_SYSTEM.equals(tableName)) { - final String value = values.getAsString(Settings.NameValueTable.VALUE); validateSystemSettingNameValue(name, value); + } else if (CMDatabaseHelper.CMTableNames.TABLE_SECURE.equals(tableName)) { + validateSecureSettingValue(name, value); } SQLiteDatabase db = dbHelper.getWritableDatabase(); @@ -591,9 +593,11 @@ public class CMSettingsProvider extends ContentProvider { // Validate value if updating System table final String name = values.getAsString(Settings.NameValueTable.NAME); + final String value = values.getAsString(Settings.NameValueTable.VALUE); if (CMDatabaseHelper.CMTableNames.TABLE_SYSTEM.equals(tableName)) { - final String value = values.getAsString(Settings.NameValueTable.VALUE); validateSystemSettingNameValue(name, value); + } else if (CMDatabaseHelper.CMTableNames.TABLE_SECURE.equals(tableName)) { + validateSecureSettingValue(name, value); } int callingUserId = UserHandle.getCallingUserId(); @@ -792,7 +796,7 @@ public class CMSettingsProvider extends ContentProvider { } private void validateSystemSettingNameValue(String name, String value) { - CMSettings.System.Validator validator = CMSettings.System.VALIDATORS.get(name); + CMSettings.Validator validator = CMSettings.System.VALIDATORS.get(name); if (validator == null) { throw new IllegalArgumentException("Invalid setting: " + name); } @@ -803,5 +807,16 @@ public class CMSettingsProvider extends ContentProvider { } } + private void validateSecureSettingValue(String name, String value) { + CMSettings.Validator validator = CMSettings.Secure.VALIDATORS.get(name); + + // Not all secure settings have validators, but if a validator exists, the validate method + // should return true + if (validator != null && !validator.validate(value)) { + throw new IllegalArgumentException("Invalid value: " + value + + " for setting: " + name); + } + } + // TODO Add caching } |