Merge 0.9->0.10
authorKim Alvefur <zash@zash.se>
Wed, 26 Aug 2015 13:17:10 +0200
changeset 6801 8b4c8e957211
parent 6799 87ec4e783ebd (current diff)
parent 6800 509b70437035 (diff)
child 6802 4fc6b0a090bb
child 6805 442019e955dc
Merge 0.9->0.10
tools/ejabberd2prosody.lua
--- a/tools/ejabberd2prosody.lua	Wed Aug 26 13:08:51 2015 +0200
+++ b/tools/ejabberd2prosody.lua	Wed Aug 26 13:17:10 2015 +0200
@@ -72,7 +72,22 @@
 	print("["..(err or "success").."] vCard: "..node.."@"..host);
 end
 function password(node, host, password)
-	local ret, err = dm.store(node, host, "accounts", {password = password});
+	local data = {};
+	if type(password) == "string" then
+		data.password = password;
+	elseif type(password) == "table" and password[1] == "scram" then
+		local unb64 = require"mime".unb64;
+		local function hex(s)
+			return s:gsub(".", function (c)
+				return ("%02x"):format(c:byte());
+			end);
+		end
+		data.stored_key = hex(unb64(password[2]));
+		data.server_key = hex(unb64(password[3]));
+		data.salt = unb64(password[4]);
+		data.iteration_count = password[5];
+	end
+	local ret, err = dm.store(node, host, "accounts", data);
 	print("["..(err or "success").."] accounts: "..node.."@"..host);
 end
 function roster(node, host, jid, item)