mod_muc_restrict_nick/mod_muc_restrict_nick.lua
author Kim Alvefur <zash@zash.se>
Tue, 05 Mar 2024 00:32:00 +0100
changeset 5862 761142ee0ff2
parent 4592 e7b126161e7b
permissions -rw-r--r--
mod_http_oauth2: Reflect changes to defaults etc - Resource owner password grant was disabled by default - Tokens now include a hash of client_id making it possible to be reasonable sure that they were issued to a particular client

local jid = require "util.jid";
local st = require "util.stanza";

local nick_pattern = module:get_option_string("muc_restrict_nick_pattern", "^%w+$");

module:hook("muc-occupant-pre-join", function (event)
	local nick = jid.resource(event.occupant.nick);
	if not nick:match(nick_pattern) then
		local reply = st.error_reply(event.stanza, "modify", "policy-violation", "Unacceptable nickname, please try another");
		module:send(reply);
		return true;
	end
end);