# HG changeset patch # User Tobias Markmann # Date 1295279421 -3600 # Node ID a2659baf8332dbc5e5e17d46be26bfc6f6f04c0a # Parent 574e91531994bf597975f349a05fa8cdb656d0d8 mod_saslauth: Check whether LuaSec supports getpeerfinished() binding. diff -r 574e91531994 -r a2659baf8332 plugins/mod_saslauth.lua --- a/plugins/mod_saslauth.lua Mon Jan 17 16:50:21 2011 +0100 +++ b/plugins/mod_saslauth.lua Mon Jan 17 16:50:21 2011 +0100 @@ -247,10 +247,14 @@ end origin.sasl_handler = usermanager_get_sasl_handler(module.host); if origin.secure then - origin.sasl_handler:add_cb_handler("tls-unique", function(self) - return self.userdata:getpeerfinished(); - end); - origin.sasl_handler["userdata"] = origin.conn:socket(); + -- check wether LuaSec has the nifty binding to the function needed for tls-unique + -- FIXME: would be nice to have this check only once and not for every socket + if origin.conn:socket().getpeerfinished then + origin.sasl_handler:add_cb_handler("tls-unique", function(self) + return self.userdata:getpeerfinished(); + end); + origin.sasl_handler["userdata"] = origin.conn:socket(); + end end features:tag("mechanisms", mechanisms_attr); for mechanism in pairs(origin.sasl_handler:mechanisms()) do