aboutsummaryrefslogtreecommitdiffstats
path: root/packages
diff options
context:
space:
mode:
Diffstat (limited to 'packages')
-rw-r--r--packages/CMSettingsProvider/src/org/cyanogenmod/cmsettings/CMSettingsProvider.java21
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
}