aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2014-03-22 14:45:04 +0100
committerKim Alvefur <zash@zash.se>2014-03-22 14:45:04 +0100
commit01628b047bf869c89a4083f57e283bbf663d8a1b (patch)
tree6254e4ab4822abedbda387f7af5dbafed3c2e6cd
parent9833b51da4e36251d94290577b504c9f8140d64d (diff)
downloadprosody-01628b047bf869c89a4083f57e283bbf663d8a1b.tar.gz
prosody-01628b047bf869c89a4083f57e283bbf663d8a1b.zip
util.sasl: Fix logic for when mechanisms with channel binding support are offered
-rw-r--r--util/sasl.lua14
1 files changed, 8 insertions, 6 deletions
diff --git a/util/sasl.lua b/util/sasl.lua
index c8490842..b91e29a6 100644
--- a/util/sasl.lua
+++ b/util/sasl.lua
@@ -100,14 +100,16 @@ end
function method:mechanisms()
local current_mechs = {};
for mech, _ in pairs(self.mechs) do
- if mechanism_channelbindings[mech] and self.profile.cb then
- local ok = false;
- for cb_name, _ in pairs(self.profile.cb) do
- if mechanism_channelbindings[mech][cb_name] then
- ok = true;
+ if mechanism_channelbindings[mech] then
+ if self.profile.cb then
+ local ok = false;
+ for cb_name, _ in pairs(self.profile.cb) do
+ if mechanism_channelbindings[mech][cb_name] then
+ ok = true;
+ end
end
+ if ok == true then current_mechs[mech] = true; end
end
- if ok == true then current_mechs[mech] = true; end
else
current_mechs[mech] = true;
end