Validate data input *as is* instead of ignoring case

User input that is supposed to be in certain allowed values were
getting validated ignoring the case and this resulted in incorrect
behavior in the daemons that consume those values. Since the input
value is really the data, its acceptable to be strict about the case
and hence this patch validates the user input against the allowed
range being sensitive to the case.

Fixes openbmc/openbmc#961

Change-Id: I901600918691324b60512c27ab43925c531db09b
Signed-off-by: Vishwanatha Subbanna <vishwa@linux.vnet.ibm.com>
diff --git a/settings_manager.py b/settings_manager.py
index cf358d8..9c797d9 100644
--- a/settings_manager.py
+++ b/settings_manager.py
@@ -171,8 +171,8 @@
         if value not in range(min, max):
             raise ValueError("Invalid input. Data not in allowed range")
 
-    def validate_list_ignore_case(self, lst, value):
-        if value.lower() not in map(lambda val: val.lower(), lst):
+    def validate_list(self, lst, value):
+        if value not in map(lambda val: val, lst):
             raise ValueError("Invalid input. Data not in allowed values")
 
     # validate host network configuration
@@ -212,7 +212,7 @@
 
             elif key.lower() == 'addr_type':
                 allowed = ["STATIC", "DYNAMIC"]
-                self.validate_list_ignore_case(allowed, value)
+                self.validate_list(allowed, value)
 
         # Did user pass everything ??
         if set(all_config) - set(user_config):
@@ -233,7 +233,7 @@
         validation = shk.get('validation', None)
 
         if validation == 'list':
-            self.validate_list_ignore_case(shk['allowed'], value)
+            self.validate_list(shk['allowed'], value)
 
         elif validation == 'range':
             self.validate_range(shk['min'], shk['max']+1, value)