diff options
author | Florian Zeitz <florob@babelmonkeys.de> | 2011-12-02 19:24:54 +0100 |
---|---|---|
committer | Florian Zeitz <florob@babelmonkeys.de> | 2011-12-02 19:24:54 +0100 |
commit | 35f933d4a5653ec61864812342fe5da457df9062 (patch) | |
tree | 2b6a31fa026455722bc18005fccd5bbdaadd48d9 | |
parent | 786751f7302bc6bbaee879d6d55ae7a85d0237d2 (diff) | |
download | prosody-35f933d4a5653ec61864812342fe5da457df9062.tar.gz prosody-35f933d4a5653ec61864812342fe5da457df9062.zip |
util.dataforms: Fix form verification
-rw-r--r-- | util/dataforms.lua | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/util/dataforms.lua b/util/dataforms.lua index e4d24cf6..b69df819 100644 --- a/util/dataforms.lua +++ b/util/dataforms.lua @@ -120,12 +120,18 @@ function form_t.data(layout, stanza) end end - local reader = field_readers[field.type]; - local verifier = field.verifier or field_verifiers[field.type]; - if reader then - data[field.name] = reader(tag); - if verifier then - errors[field.name] = verifier(data[field.name], tag, field.required); + if not tag then + if field.required then + errors[field.name] = "Required value missing"; + end + else + local reader = field_readers[field.type]; + local verifier = field.verifier or field_verifiers[field.type]; + if reader then + data[field.name] = reader(tag); + if verifier then + errors[field.name] = verifier(data[field.name], tag, field.required); + end end end end @@ -161,7 +167,7 @@ field_readers["jid-single"] = field_verifiers["jid-single"] = function (data, field_tag, required) - if #data == 0 and required then + if ((not data) or (#data == 0)) and required then return "Required value missing"; end if not jid_prep(data) then |