mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
util.roles: Add a :policies() method to iterate through available policies
We don't expose the policies directly, to force people to go through :may(). However, there are times when we really just need to know what policies a role has inside it (e.g. for reporting or debugging purposes).
This commit is contained in:
parent
bda9ea678c
commit
d08ddc1f4a
1 changed files with 10 additions and 0 deletions
|
@ -86,6 +86,16 @@ function role_methods:set_permission(permission_name, policy, overwrite)
|
|||
return true;
|
||||
end
|
||||
|
||||
function role_methods:policies()
|
||||
local policy_iterator, s, v = it.join(pairs(self[permissions_key]));
|
||||
if self.inherits then
|
||||
for _, inherited_role in ipairs(self.inherits) do
|
||||
policy_iterator:append(inherited_role:policies());
|
||||
end
|
||||
end
|
||||
return policy_iterator, s, v;
|
||||
end
|
||||
|
||||
function role_mt.__tostring(self)
|
||||
return ("role<[%s] %s>"):format(self.id or "nil", self.name or "[no name]");
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue