mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
mod_saslauth: Support for SASL handlers forcing a specific resource
The token layer supports tokens that are tied to a given resource.
This commit is contained in:
parent
6db4afa0c3
commit
16137b3b14
1 changed files with 4 additions and 2 deletions
|
@ -54,6 +54,7 @@ local function handle_status(session, status, ret, err_msg)
|
|||
elseif status == "success" then
|
||||
local ok, err = sm_make_authenticated(session, session.sasl_handler.username, session.sasl_handler.role);
|
||||
if ok then
|
||||
session.sasl_resource = session.sasl_handler.resource;
|
||||
module:fire_event("authentication-success", { session = session });
|
||||
session.sasl_handler = nil;
|
||||
session:reset_stream();
|
||||
|
@ -374,14 +375,15 @@ end);
|
|||
|
||||
module:hook("stanza/iq/urn:ietf:params:xml:ns:xmpp-bind:bind", function(event)
|
||||
local origin, stanza = event.origin, event.stanza;
|
||||
local resource;
|
||||
if stanza.attr.type == "set" then
|
||||
local resource = origin.sasl_resource;
|
||||
if stanza.attr.type == "set" and not resource then
|
||||
local bind = stanza.tags[1];
|
||||
resource = bind:get_child("resource");
|
||||
resource = resource and #resource.tags == 0 and resource[1] or nil;
|
||||
end
|
||||
local success, err_type, err, err_msg = sm_bind_resource(origin, resource);
|
||||
if success then
|
||||
origin.sasl_resource = nil;
|
||||
origin.send(st.reply(stanza)
|
||||
:tag("bind", { xmlns = xmlns_bind })
|
||||
:tag("jid"):text(origin.full_jid));
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue