From 644ed25d8d87874b55aef6b8e700e9e79017ec18 Mon Sep 17 00:00:00 2001 From: w00t Date: Mon, 21 Jul 2008 16:29:47 +0000 Subject: Add extban +b B: - matching users may not use caps, same as chmode +B (or +P in 1.1) git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@10058 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/modules/m_blockcaps.cpp | 10 +++++++--- src/modules/m_nonicks.cpp | 12 +++--------- 2 files changed, 10 insertions(+), 12 deletions(-) (limited to 'src') diff --git a/src/modules/m_blockcaps.cpp b/src/modules/m_blockcaps.cpp index 31542befd..aa91b6bcd 100644 --- a/src/modules/m_blockcaps.cpp +++ b/src/modules/m_blockcaps.cpp @@ -41,10 +41,14 @@ public: delete bc; throw ModuleException("Could not add new modes!"); } - Implementation eventlist[] = { I_OnUserPreMessage, I_OnUserPreNotice, I_OnRehash }; - ServerInstance->Modules->Attach(eventlist, this, 3); + Implementation eventlist[] = { I_OnUserPreMessage, I_OnUserPreNotice, I_OnRehash, I_On005Numeric }; + ServerInstance->Modules->Attach(eventlist, this, 4); } + virtual void On005Numeric(std::string &output) + { + ServerInstance->AddExtBanChar('B'); + } virtual void OnRehash(User* user, const std::string ¶m) { @@ -65,7 +69,7 @@ public: return 0; } - if (c->IsModeSet('B')) + if (c->IsModeSet('B') || c->IsExtBanned(user, 'B')) { int caps = 0; const char* actstr = "\1ACTION "; diff --git a/src/modules/m_nonicks.cpp b/src/modules/m_nonicks.cpp index f29cbf04a..9a1d0079e 100644 --- a/src/modules/m_nonicks.cpp +++ b/src/modules/m_nonicks.cpp @@ -85,16 +85,10 @@ class ModuleNoNickChange : public Module { Channel* curr = i->first; - if (curr->IsModeSet('N')) - { - if (CHANOPS_EXEMPT(ServerInstance, 'N') && curr->GetStatus(user) == STATUS_OP) - continue; - - user->WriteNumeric(ERR_CANTCHANGENICK, "%s :Can't change nickname while on %s (+N is set)", user->nick.c_str(), curr->name.c_str()); - return 1; - } + if (CHANOPS_EXEMPT(ServerInstance, 'N') && curr->GetStatus(user) == STATUS_OP) + continue; - if (curr->IsExtBanned(user, 'N')) + if (curr->IsModeSet('N') || curr->IsExtBanned(user, 'N')) { user->WriteNumeric(ERR_CANTCHANGENICK, "%s :Can't change nickname while on %s (+N is set)", user->nick.c_str(), curr->name.c_str()); return 1; -- cgit v1.2.3