From 186125607f2271af1387e28ce868fdf6d3dc9f1c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sa=C3=BAl=20Ibarra=20Corretg=C3=A9?= Date: Wed, 18 Aug 2021 09:09:18 +0200 Subject: [PATCH] fix(prosody) fix username not being set in mod_auth_jitsi-anonymous If the session was not resumed the plugin must generate a random username, just like the regular anonymous authentication plugin does. --- resources/prosody-plugins/mod_auth_jitsi-anonymous.lua | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/resources/prosody-plugins/mod_auth_jitsi-anonymous.lua b/resources/prosody-plugins/mod_auth_jitsi-anonymous.lua index d222e9cef..c959f96ac 100644 --- a/resources/prosody-plugins/mod_auth_jitsi-anonymous.lua +++ b/resources/prosody-plugins/mod_auth_jitsi-anonymous.lua @@ -2,6 +2,7 @@ -- * session resumption -- Copyright (C) 2021-present 8x8, Inc. +local generate_random_id = require "util.id".medium; local new_sasl = require "util.sasl".new; local sasl = require "util.sasl"; local sessions = prosody.full_sessions; @@ -57,10 +58,17 @@ end module:provides("auth", provider); local function anonymous(self, message) + -- Same as the vanilla anonymous auth plugin + local username = generate_random_id():lower(); + -- This calls the handler created in 'provider.get_sasl_handler(session)' local result, err, msg = self.profile.anonymous(self, username, self.realm); if result == true then + if (self.username == nil) then + -- Session was not resumed + self.username = username; + end return "success"; else return "failure", err, msg;