diff options
author | Kim Alvefur <zash@zash.se> | 2015-09-17 22:15:26 +0200 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2015-09-17 22:15:26 +0200 |
commit | 195c1407b6d3eb2b4f47051eb81a9ddee889c690 (patch) | |
tree | aae43eb039122cfd152c9a26e2f40154cad08440 /util | |
parent | a38d2115a2d8d4a2b6e6e0772f345cb7e1201aaf (diff) | |
parent | 32bb9cbee2e75029b69367ef3f0d3d76e5dd9f34 (diff) | |
download | prosody-195c1407b6d3eb2b4f47051eb81a9ddee889c690.tar.gz prosody-195c1407b6d3eb2b4f47051eb81a9ddee889c690.zip |
Merge 0.10->trunk
Diffstat (limited to 'util')
-rw-r--r-- | util/dataforms.lua | 48 |
1 files changed, 22 insertions, 26 deletions
diff --git a/util/dataforms.lua b/util/dataforms.lua index 244fb3f3..05846ab3 100644 --- a/util/dataforms.lua +++ b/util/dataforms.lua @@ -145,30 +145,29 @@ function form_t.data(layout, stanza) return data; end -field_readers["text-single"] = - function (field_tag, required) - local data = field_tag:get_child_text("value"); - if data and #data > 0 then - return data - elseif required then - return nil, "Required value missing"; - end +local function simple_text(field_tag, required) + local data = field_tag:get_child_text("value"); + -- XEP-0004 does not say if an empty string is acceptable for a required value + -- so we will follow HTML5 which says that empty string means missing + if required and (data == nil or data == "") then + return nil, "Required value missing"; end + return data; -- Return whatever get_child_text returned, even if empty string +end -field_readers["text-private"] = - field_readers["text-single"]; +field_readers["text-single"] = simple_text; + +field_readers["text-private"] = simple_text; field_readers["jid-single"] = function (field_tag, required) - local raw_data = field_tag:get_child_text("value") + local raw_data, err = simple_text(field_tag, required); + if not raw_data then return raw_data, err; end local data = jid_prep(raw_data); - if data and #data > 0 then - return data - elseif raw_data then + if not data then return nil, "Invalid JID: " .. raw_data; - elseif required then - return nil, "Required value missing"; end + return data; end field_readers["jid-multi"] = @@ -212,8 +211,7 @@ field_readers["text-multi"] = return data, err; end -field_readers["list-single"] = - field_readers["text-single"]; +field_readers["list-single"] = simple_text; local boolean_values = { ["1"] = true, ["true"] = true, @@ -222,15 +220,13 @@ local boolean_values = { field_readers["boolean"] = function (field_tag, required) - local raw_value = field_tag:get_child_text("value"); - local value = boolean_values[raw_value ~= nil and raw_value]; - if value ~= nil then - return value; - elseif raw_value then - return nil, "Invalid boolean representation"; - elseif required then - return nil, "Required value missing"; + local raw_value, err = simple_text(field_tag, required); + if not raw_value then return raw_value, err; end + local value = boolean_values[raw_value]; + if value == nil then + return nil, "Invalid boolean representation:" .. raw_value; end + return value; end field_readers["hidden"] = |