mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
mod_authz_internal, and more: New iteration of role API
These changes to the API (hopefully the last) introduce a cleaner separation between the user's primary (default) role, and their secondary (optional) roles. To keep the code sane and reduce complexity, a data migration is needed for people using stored roles in 0.12. This can be performed with prosodyctl mod_authz_internal migrate <host>
This commit is contained in:
parent
2b0676396d
commit
f5768f63c9
6 changed files with 188 additions and 63 deletions
|
@ -538,6 +538,7 @@ function api:load_resource(path, mode)
|
|||
end
|
||||
|
||||
function api:open_store(name, store_type)
|
||||
if self.host == "*" then return nil, "global-storage-not-supported"; end
|
||||
return require"core.storagemanager".open(self.host, name or self.name, store_type);
|
||||
end
|
||||
|
||||
|
@ -629,7 +630,7 @@ function api:may(action, context)
|
|||
local role;
|
||||
local node, host = jid_split(context);
|
||||
if host == self.host then
|
||||
role = hosts[host].authz.get_user_default_role(node);
|
||||
role = hosts[host].authz.get_user_role(node);
|
||||
else
|
||||
role = hosts[self.host].authz.get_jid_role(context);
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue