aboutsummaryrefslogtreecommitdiff
path: root/src/shared/validators/setting.js
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2017-10-01 12:25:49 +0900
committerShin'ya Ueoka <ueokande@i-beam.org>2017-10-01 12:25:49 +0900
commit1b2554adee528da1078ad39694a3f8264c639821 (patch)
tree0fcacdad33a51cf7611af77e601443eb827c2498 /src/shared/validators/setting.js
parent709fa95aa383b75e88fb12512f772ea55d757b06 (diff)
parent8c9051076f7782b898ab2f848b9afe4a694c3065 (diff)
Merge branch 'settings-validation'
Diffstat (limited to 'src/shared/validators/setting.js')
-rw-r--r--src/shared/validators/setting.js33
1 files changed, 33 insertions, 0 deletions
diff --git a/src/shared/validators/setting.js b/src/shared/validators/setting.js
new file mode 100644
index 0000000..df04e50
--- /dev/null
+++ b/src/shared/validators/setting.js
@@ -0,0 +1,33 @@
+import operations from '../../operations';
+
+const VALID_TOP_KEYS = ['keymaps'];
+const VALID_OPERATION_VALUES = Object.keys(operations).map((key) => {
+ return operations[key];
+});
+
+const validateInvalidTopKeys = (settings) => {
+ let invalidKey = Object.keys(settings).find((key) => {
+ return !VALID_TOP_KEYS.includes(key);
+ });
+ if (invalidKey) {
+ throw Error(`Unknown key: "${invalidKey}"`);
+ }
+};
+
+const validateKeymaps = (keymaps) => {
+ for (let key of Object.keys(keymaps)) {
+ let value = keymaps[key];
+ if (!VALID_OPERATION_VALUES.includes(value.type)) {
+ throw Error(`Unknown operation: "${value.type}"`);
+ }
+ }
+};
+
+const validate = (settings) => {
+ validateInvalidTopKeys(settings);
+ if (settings.keymaps) {
+ validateKeymaps(settings.keymaps);
+ }
+};
+
+export { validate };