Software /
code /
prosody-modules
Diff
mod_invites_adhoc/mod_invites_adhoc.lua @ 5008:bd63feda3704
Merge role-auth
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Mon, 22 Aug 2022 15:39:02 +0100 |
parent | 5000:8b6fe33d1c9b |
child | 5040:fa99279f9d40 |
line wrap: on
line diff
--- a/mod_invites_adhoc/mod_invites_adhoc.lua Tue Aug 16 13:10:39 2022 +0200 +++ b/mod_invites_adhoc/mod_invites_adhoc.lua Mon Aug 22 15:39:02 2022 +0100 @@ -13,9 +13,19 @@ -- on the server, use the option above instead. local allow_contact_invites = module:get_option_boolean("allow_contact_invites", true); +-- These options are deprecated since module:may() local allow_user_invite_roles = module:get_option_set("allow_user_invites_by_roles"); local deny_user_invite_roles = module:get_option_set("deny_user_invites_by_roles"); +if module.may then + if allow_user_invites then + module:default_permission("prosody:user", ":invite-new-users"); + end + if not allow_user_invite_roles:empty() or not deny_user_invite_roles:empty() then + return error("allow_user_invites_by_roles and deny_user_invites_by_roles are deprecated options"); + end +end + local invites; if prosody.shutdown then -- COMPAT hack to detect prosodyctl invites = module:depends("invites"); @@ -42,8 +52,10 @@ -- This is for checking if the specified JID may create invites -- that allow people to register accounts on this host. -local function may_invite_new_users(jid) - if usermanager.get_roles then +local function may_invite_new_users(jid, context) + if module.may then + return module:may(":invite-new-users", context); + elseif usermanager.get_roles then -- COMPAT w/0.12 local user_roles = usermanager.get_roles(jid, module.host); if not user_roles then return; end if user_roles["prosody:admin"] then @@ -87,7 +99,7 @@ }; }; end - local invite = invites.create_contact(username, may_invite_new_users(data.from), { + local invite = invites.create_contact(username, may_invite_new_users(data.from, data), { source = data.from }); --TODO: check errors