Diff

plugins/mod_saslauth.lua @ 3062:892c49869293

mod_saslauth: Add return value and error message to the Cyrus SASL handle_status callback
author Matthew Wild <mwild1@gmail.com>
date Thu, 20 May 2010 11:08:51 +0100
parent 3061:c9f9b3964bb9
child 3064:596303990c7c
line wrap: on
line diff
--- a/plugins/mod_saslauth.lua	Thu May 20 11:05:43 2010 +0100
+++ b/plugins/mod_saslauth.lua	Thu May 20 11:08:51 2010 +0100
@@ -94,7 +94,7 @@
 	return reply;
 end
 
-local function handle_status(session, status)
+local function handle_status(session, status, ret, err_msg)
 	if status == "failure" then
 		session.sasl_handler = session.sasl_handler:clean_clone();
 	elseif status == "success" then
@@ -103,12 +103,13 @@
 			module:log("warn", "SASL succeeded but we didn't get a username!");
 			session.sasl_handler = nil;
 			session:reset_stream();
-			return;
+			return status, ret, err_msg;
 		end
 		sm_make_authenticated(session, session.sasl_handler.username);
 		session.sasl_handler = nil;
 		session:reset_stream();
 	end
+	return status, ret, err_msg;
 end
 
 local function sasl_handler(session, stanza)
@@ -142,7 +143,7 @@
 		end
 	end
 	local status, ret, err_msg = session.sasl_handler:process(text);
-	handle_status(session, status);
+	status, ret, err_msg = handle_status(session, status, ret, err_msg);
 	local s = build_reply(status, ret, err_msg);
 	log("debug", "sasl reply: %s", tostring(s));
 	session.send(s);