From a13ed4a3ae7cd17aa406f0e77f188b73a900550f Mon Sep 17 00:00:00 2001 From: Guilherme Salazar Date: Thu, 28 Nov 2024 09:56:41 -0300 Subject: [PATCH] fix(schema): run check on invalid field (#13923) This fixes a nil reference if a checker referred to an inexistent field. ``` ./kong/db/schema/init.lua:1267: attempt to index a nil value stack traceback: ./kong/db/schema/init.lua: in function 'run_entity_check' ./kong/db/schema/init.lua:1384: in function 'run_checks' ./kong/db/schema/init.lua:1400: in function 'run_entity_checks' ./kong/db/schema/init.lua:2101: in function 'validate' ./kong/db/schema/init.lua:957: in function 'validate_field' ./kong/db/schema/init.lua:1187: in function 'validate_fields' ./kong/db/schema/init.lua:2091: in function 'validate_insert' ./kong/db/dao/init.lua:470: in function 'check_insert' ./kong/db/dao/init.lua:1155: in function 'insert_entity' ./kong/api/endpoints.lua:409: in function 'fn' ./kong/api/api_helpers.lua:329: in function <./kong/api/api_helpers.lua:307> ``` --- .../kong/fix-nil-reference-schema-checker.yml | 3 +++ kong/db/schema/init.lua | 2 +- .../01-db/01-schema/01-schema_spec.lua | 20 +++++++++++++++++++ 3 files changed, 24 insertions(+), 1 deletion(-) create mode 100644 changelog/unreleased/kong/fix-nil-reference-schema-checker.yml diff --git a/changelog/unreleased/kong/fix-nil-reference-schema-checker.yml b/changelog/unreleased/kong/fix-nil-reference-schema-checker.yml new file mode 100644 index 00000000000..d335ea1f821 --- /dev/null +++ b/changelog/unreleased/kong/fix-nil-reference-schema-checker.yml @@ -0,0 +1,3 @@ +message: "Fix issue where the schema library would error with a nil reference if an entity checker referred to an inexistent field" +type: bugfix +scope: Core diff --git a/kong/db/schema/init.lua b/kong/db/schema/init.lua index f0bf9b3b881..9804ed017df 100644 --- a/kong/db/schema/init.lua +++ b/kong/db/schema/init.lua @@ -1301,7 +1301,7 @@ local function run_entity_check(self, name, input, arg, full_check, errors) if (not checker.run_with_missing_fields) and (not arg.run_with_missing_fields) and (required_fields and required_fields[fname]) and - (not get_schema_field(self, fname).nilable) then + (not (get_schema_field(self, fname) or {}).nilable) then missing = missing or {} insert(missing, fname) end diff --git a/spec/01-unit/01-db/01-schema/01-schema_spec.lua b/spec/01-unit/01-db/01-schema/01-schema_spec.lua index c2581ec5a2c..3cf7533cc32 100644 --- a/spec/01-unit/01-db/01-schema/01-schema_spec.lua +++ b/spec/01-unit/01-db/01-schema/01-schema_spec.lua @@ -1407,6 +1407,26 @@ describe("schema", function() describe("entity_checkers", function() + describe("at_least_one_of", function() + local Test = Schema.new({ + fields = { + { a = { type = "number" }, }, + { b = { type = "string" }, }, + { c = { type = "string" }, }, + }, + entity_checks = { + { at_least_one_of = {"d"} }, + } + }) + + it("runs check on invalid fields", function() + local ok, errs = Test:validate_insert({ a = 1 }) + assert.is_nil(ok) + assert.same({ + "at least one of these fields must be non-empty: 'd'" + }, errs["@entity"]) + end) + end) describe("conditional_at_least_one_of", function() local Test = Schema.new({ fields = {