diff options
author | Kim Alvefur <zash@zash.se> | 2023-03-26 15:19:14 +0200 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2023-03-26 15:19:14 +0200 |
commit | 4bc62438dbabb8fbe7ff3c4eca69c30cc04dd8bd (patch) | |
tree | 0dfeba809d89b5bac9928b784e8e1872f32ea16e /teal-src/prosody | |
parent | 5427c2472d1b6ddd57b01eaafe90a0bc4f09ffaa (diff) | |
download | prosody-4bc62438dbabb8fbe7ff3c4eca69c30cc04dd8bd.tar.gz prosody-4bc62438dbabb8fbe7ff3c4eca69c30cc04dd8bd.zip |
util.jsonschema: Implement 'dependentRequired'
If this field exists, then these fields must also exist.
Diffstat (limited to 'teal-src/prosody')
-rw-r--r-- | teal-src/prosody/util/jsonschema.tl | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/teal-src/prosody/util/jsonschema.tl b/teal-src/prosody/util/jsonschema.tl index 8e5d69bc..fa230cac 100644 --- a/teal-src/prosody/util/jsonschema.tl +++ b/teal-src/prosody/util/jsonschema.tl @@ -295,6 +295,18 @@ function complex_validate (schema : json_schema_object, data : any, root : json_ end end + if schema.dependentRequired then + for k, reqs in pairs(schema.dependentRequired) do + if data[k] ~= nil then + for _, req in ipairs(reqs) do + if data[req] == nil then + return false + end + end + end + end + end + if schema.propertyNames ~= nil then for k in pairs(data) do if not validate(schema.propertyNames, k, root) then |