File

plugins/mod_authz_internal.lua @ 11473:afe80b64e209

usermanager: expose set_roles through API
author Jonas Schäfer <jonas@wielicki.name>
date Mon, 22 Mar 2021 21:24:57 +0100
parent 11472:c32753ceb0f0
child 11474:8fba807e5256
line wrap: on
line source

local normalize = require "util.jid".prep;
local admin_jids = module:get_option_inherited_set("admins", {}) / normalize;
local host = module.host;
local role_store = module:open_store("roles");

local admin_role = { ["prosody:admin"] = true };

function get_user_roles(user)
	if admin_jids:contains(user.."@"..host) then
		return admin_role;
	end
	return role_store:get(user);
end

function set_user_roles(user, roles)
	role_store:set(user, roles)
	return true;
end

function get_jid_roles(jid)
	if admin_jids:contains(jid) then
		return admin_role;
	end
	return nil;
end

function set_jid_roles(jid)
	return false;
end