Diff

util/dataforms.lua @ 4884:b8d852aea3ad

util.dataforms: Do field validation and normalization in field readers.
author Kim Alvefur <zash@zash.se>
date Thu, 17 May 2012 21:01:44 +0200
parent 4435:ea69296afaef
child 4886:26d8e4665ce9
line wrap: on
line diff
--- a/util/dataforms.lua	Wed May 16 20:30:53 2012 +0100
+++ b/util/dataforms.lua	Thu May 17 21:01:44 2012 +0200
@@ -105,7 +105,6 @@
 end
 
 local field_readers = {};
-local field_verifiers = {};
 
 function form_t.data(layout, stanza)
 	local data = {};
@@ -126,12 +125,8 @@
 			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
+				data[field.name], errors[field.name] = reader(tag, field.required);
 			end
 		end
 	end
@@ -142,137 +137,94 @@
 end
 
 field_readers["text-single"] =
-	function (field_tag)
-		local value = field_tag:child_with_name("value");
-		if value then
-			return value[1];
-		end
-	end
-
-field_verifiers["text-single"] =
-	function (data, field_tag, required)
-		if ((not data) or (#data == 0)) and required then
-			return "Required value missing";
+	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
 	end
 
 field_readers["text-private"] =
 	field_readers["text-single"];
 
-field_verifiers["text-private"] =
-	field_verifiers["text-single"];
-
 field_readers["jid-single"] =
-	field_readers["text-single"];
-
-field_verifiers["jid-single"] =
-	function (data, field_tag, required)
-		if ((not data) or (#data == 0)) and required then
-			return "Required value missing";
-		end
-		if not jid_prep(data) then
-			return "Invalid JID";
+	function (field_tag, required)
+		local raw_data = field_tag:get_child_text("value")
+		local data = jid_prep(raw_data);
+		if data and #data > 0 then
+			return data
+		elseif raw_data then
+			return raw_data, "Invalid JID";
+		elseif required then
+			return nil, "Required value missing";
 		end
 	end
 
 field_readers["jid-multi"] =
-	function (field_tag)
+	function (field_tag, required)
 		local result = {};
-		for value_tag in field_tag:childtags() do
-			if value_tag.name == "value" then
-				result[#result+1] = value_tag[1];
+		local err = {};
+		for value_tag in field_tag:childtags("value") do
+			local raw_value = value_tag:get_text();
+			local value = jid_prep(raw_value);
+			result[#result+1] = value;
+			if raw_value and not value then
+				err[#err+1] = ("Invalid JID: " .. raw_value);
 			end
 		end
-		return result;
-	end
-
-field_verifiers["jid-multi"] =
-	function (data, field_tag, required)
-		if #data == 0 and required then
-			return "Required value missing";
-		end
-
-		for _, jid in ipairs(data) do
-			if not jid_prep(jid) then
-				return "Invalid JID";
-			end
+		if #result > 0 then
+			return result, (#err > 0 and t_concat(err, "\n") or nil);
+		elseif required then
+			return nil, "Required value missing";
 		end
 	end
 
-field_readers["text-multi"] =
-	function (field_tag)
+field_readers["list-multi"] =
+	function (field_tag, required)
 		local result = {};
-		for value_tag in field_tag:childtags() do
-			if value_tag.name == "value" then
-				result[#result+1] = value_tag[1];
-			end
+		for value in field_tag:childtags("value") do
+			result[#result+1] = value;
 		end
-		return t_concat(result, "\n");
+		return result, (required and #result == 0 and "Required value missing" or nil);
 	end
 
-field_verifiers["text-multi"] =
-	field_verifiers["text-single"];
+field_readers["text-multi"] =
+	function (field_tag, required)
+		local data, err = field_readers["list-multi"](field_tag, required);
+		if data then
+			data = t_concat(data, "\n");
+		end
+		return data, err;
+	end
 
 field_readers["list-single"] =
 	field_readers["text-single"];
 
-field_verifiers["list-single"] =
-	field_verifiers["text-single"];
-
-field_readers["list-multi"] =
-	function (field_tag)
-		local result = {};
-		for value_tag in field_tag:childtags() do
-			if value_tag.name == "value" then
-				result[#result+1] = value_tag[1];
-			end
-		end
-		return result;
-	end
-
-field_verifiers["list-multi"] =
-	function (data, field_tag, required)
-		if #data == 0 and required then
-			return "Required value missing";
-		end
-	end
+	local boolean_values = {
+		["1"] = true, ["true"] = true,
+		["0"] = false, ["false"] = false,
+	};
 
 field_readers["boolean"] =
-	function (field_tag)
-		local value = field_tag:child_with_name("value");
-		if value then
-			if value[1] == "1" or value[1] == "true" then
-				return true;
-			else
-				return false;
-			end
-		end
-	end
-
-field_verifiers["boolean"] =
-	function (data, field_tag, required)
-		data = field_readers["text-single"](field_tag);
-		if ((not data) or (#data == 0)) and required then
-			return "Required value missing";
-		end
-		if data ~= "1" and data ~= "true" and data ~= "0" and data ~= "false" then
+	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 "Invalid boolean representation";
+		elseif required then
+			return nil, "Required value missing";
 		end
 	end
 
 field_readers["hidden"] =
 	function (field_tag)
-		local value = field_tag:child_with_name("value");
-		if value then
-			return value[1];
-		end
+		return field_tag:get_child_text("value");
 	end
 
-field_verifiers["hidden"] =
-	function (data, field_tag, required)
-		return nil;
-	end
-	
 return _M;