From 4bc62438dbabb8fbe7ff3c4eca69c30cc04dd8bd Mon Sep 17 00:00:00 2001 From: Kim Alvefur Date: Sun, 26 Mar 2023 15:19:14 +0200 Subject: util.jsonschema: Implement 'dependentRequired' If this field exists, then these fields must also exist. --- spec/util_jsonschema_spec.lua | 1 - teal-src/prosody/util/jsonschema.tl | 12 ++++++++++++ util/jsonschema.lua | 12 ++++++++++++ 3 files changed, 24 insertions(+), 1 deletion(-) diff --git a/spec/util_jsonschema_spec.lua b/spec/util_jsonschema_spec.lua index 735b4f32..7d05af4a 100644 --- a/spec/util_jsonschema_spec.lua +++ b/spec/util_jsonschema_spec.lua @@ -19,7 +19,6 @@ local skip = { ["const.json:9"] = "deepcompare", ["contains.json:0:5"] = "distinguishing objects from arrays", ["defs.json"] = "need built-in meta-schema", - ["dependentRequired.json"] = "NYI", ["dependentSchemas.json"] = "NYI", ["dynamicRef.json"] = "NYI", ["enum.json:1:3"] = "deepcompare", 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 diff --git a/util/jsonschema.lua b/util/jsonschema.lua index be0b72fd..1c4dcfbd 100644 --- a/util/jsonschema.lua +++ b/util/jsonschema.lua @@ -206,6 +206,18 @@ function complex_validate(schema, data, root) 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 -- cgit v1.2.3