diff options
author | Matthew Wild <mwild1@gmail.com> | 2015-01-31 12:25:00 +0000 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2015-01-31 12:25:00 +0000 |
commit | b242f3c94876f76ee7ccc5719bc1fc02c4bd0787 (patch) | |
tree | b6e23cf3da28e7d08ebc6ed95bf0fb5b553ae374 /core/sessionmanager.lua | |
parent | edd7f28ffeb00f26708185af9da72125f591cc80 (diff) | |
parent | a0f8ff2628e0ae3f27f6b872137a172f9f5bd717 (diff) | |
download | prosody-b242f3c94876f76ee7ccc5719bc1fc02c4bd0787.tar.gz prosody-b242f3c94876f76ee7ccc5719bc1fc02c4bd0787.zip |
Merge with 0.10
Diffstat (limited to 'core/sessionmanager.lua')
-rw-r--r-- | core/sessionmanager.lua | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/core/sessionmanager.lua b/core/sessionmanager.lua index 09920b7d..476de931 100644 --- a/core/sessionmanager.lua +++ b/core/sessionmanager.lua @@ -117,6 +117,16 @@ function bind_resource(session, resource) if session.resource then return nil, "cancel", "already-bound", "Cannot bind multiple resources on a single connection"; end -- We don't support binding multiple resources + local event_payload = { session = session, resource = resource }; + if hosts[session.host].events.fire_event("pre-resource-bind", event_payload) == false then + local err = event_payload.error; + if err then return nil, err.type, err.condition, err.text; end + return nil, "cancel", "not-allowed"; + else + -- In case a plugin wants to poke at it + resource = event_payload.resource; + end + resource = resourceprep(resource); resource = resource ~= "" and resource or uuid_generate(); --FIXME: Randomly-generated resources must be unique per-user, and never conflict with existing |