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 | ca680c0562f7ad2b3754a65481f2a3196825f62e (patch) | |
tree | aae43eb039122cfd152c9a26e2f40154cad08440 /util/dataforms.lua | |
parent | 9b46c7aba5e4d842fffbfc4a1e96371ad06e63a1 (diff) | |
parent | 7774f56dfc98b7192e9f9c0b32b070a2949f3113 (diff) | |
download | prosody-ca680c0562f7ad2b3754a65481f2a3196825f62e.tar.gz prosody-ca680c0562f7ad2b3754a65481f2a3196825f62e.zip |
Merge 0.10->trunk
Diffstat (limited to 'util/dataforms.lua')
-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"] = |