mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
moduleapi: may(): Support explicit actor_jid in context object
This commit is contained in:
parent
836b370fa8
commit
1d1e2cdd9c
1 changed files with 24 additions and 18 deletions
|
@ -715,29 +715,35 @@ function api:may(action, context, peek)
|
|||
if action:byte(1) == 58 then -- action begins with ':'
|
||||
action = self.name..action; -- prepend module name
|
||||
end
|
||||
if type(context) == "string" then -- check JID permissions
|
||||
local role;
|
||||
local node, host = jid_split(context);
|
||||
if host == self.host then
|
||||
role = hosts[host].authz.get_user_role(node);
|
||||
else
|
||||
role = hosts[self.host].authz.get_jid_role(context);
|
||||
end
|
||||
if not role then
|
||||
if not peek then
|
||||
self:log("debug", "Access denied: JID <%s> may not %s (no role found)", context, action);
|
||||
|
||||
do
|
||||
-- JID-based actor
|
||||
local actor_jid = type(context) == "string" and context or context.actor_jid;
|
||||
if actor_jid then -- check JID permissions
|
||||
local role;
|
||||
local node, host = jid_split(actor_jid);
|
||||
if host == self.host then
|
||||
role = hosts[host].authz.get_user_role(node);
|
||||
else
|
||||
role = hosts[self.host].authz.get_jid_role(actor_jid);
|
||||
end
|
||||
return false;
|
||||
end
|
||||
local permit = role:may(action);
|
||||
if not permit then
|
||||
if not peek then
|
||||
self:log("debug", "Access denied: JID <%s> may not %s (not permitted by role %s)", context, action, role.name);
|
||||
if not role then
|
||||
if not peek then
|
||||
self:log("debug", "Access denied: JID <%s> may not %s (no role found)", actor_jid, action);
|
||||
end
|
||||
return false;
|
||||
end
|
||||
local permit = role:may(action);
|
||||
if not permit then
|
||||
if not peek then
|
||||
self:log("debug", "Access denied: JID <%s> may not %s (not permitted by role %s)", actor_jid, action, role.name);
|
||||
end
|
||||
end
|
||||
return permit;
|
||||
end
|
||||
return permit;
|
||||
end
|
||||
|
||||
-- Session-based actor
|
||||
local session = context.origin or context.session;
|
||||
if type(session) ~= "table" then
|
||||
error("Unable to identify actor session from context");
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue