aboutsummaryrefslogtreecommitdiffstats
path: root/core/sessionmanager.lua
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2015-02-09 00:48:08 +0100
committerKim Alvefur <zash@zash.se>2015-02-09 00:48:08 +0100
commitca2fda7c2a628983457c836f9e89c2db29eb4f60 (patch)
tree49e5401cc7a67229f027c050c934149317ef2146 /core/sessionmanager.lua
parent887c81f09119032163fda9826df0e20d067c03e0 (diff)
parent7c0ead1c91558b669c73affb1e7ef92900c92444 (diff)
downloadprosody-ca2fda7c2a628983457c836f9e89c2db29eb4f60.tar.gz
prosody-ca2fda7c2a628983457c836f9e89c2db29eb4f60.zip
Merge 0.10->trunk
Diffstat (limited to 'core/sessionmanager.lua')
-rw-r--r--core/sessionmanager.lua10
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