class ModuleNoNickChange : public Module
{
NoNicks nn;
+ bool override;
public:
ModuleNoNickChange() : nn(this)
{
+ OnRehash(NULL);
ServerInstance->Modes->AddMode(&nn);
- Implementation eventlist[] = { I_OnUserPreNick, I_On005Numeric };
- ServerInstance->Modules->Attach(eventlist, this, 2);
+ Implementation eventlist[] = { I_OnUserPreNick, I_On005Numeric, I_OnRehash };
+ ServerInstance->Modules->Attach(eventlist, this, 3);
}
virtual ~ModuleNoNickChange()
virtual Version GetVersion()
{
- return Version("Provides support for channel mode +N & extban +b N: which prevents nick changes on channel", VF_COMMON | VF_VENDOR, API_VERSION);
+ return Version("Provides support for channel mode +N & extban +b N: which prevents nick changes on channel", VF_COMMON | VF_VENDOR);
}
Channel* curr = *i;
ModResult res;
- FIRST_MOD_RESULT(OnChannelRestrictionApply, res, (curr->GetUser(user),curr,"nonick"));
+ FIRST_MOD_RESULT(OnChannelRestrictionApply, res, (user,curr,"nonick"));
if (res == MOD_RES_ALLOW)
continue;
+ if (override && IS_OPER(user))
+ continue;
+
if (!curr->GetExtBanStatus(user, 'N').check(!curr->IsModeSet('N')))
{
user->WriteNumeric(ERR_CANTCHANGENICK, "%s :Can't change nickname while on %s (+N is set)",
return MOD_RES_PASSTHRU;
}
+
+ virtual void OnRehash(User* user)
+ {
+ ConfigReader Conf;
+ override = Conf.ReadFlag("nonicks", "operoverride", "no", 0);
+ }
};
MODULE_INIT(ModuleNoNickChange)