X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_stripcolor.cpp;h=3254d98951495fcdc146f2778f6cfe71978f204a;hb=7f00015727fab50e37de46aa90d218b31c852c87;hp=ec7a57720b8871638f0f0bc16697b4209eab1b82;hpb=d53d8da69b4aecef4f929693b43c07046f2e2136;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_stripcolor.cpp b/src/modules/m_stripcolor.cpp index ec7a57720..3254d9895 100644 --- a/src/modules/m_stripcolor.cpp +++ b/src/modules/m_stripcolor.cpp @@ -2,66 +2,125 @@ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * - * Inspire is copyright (C) 2002-2004 ChatSpike-Dev. - * E-mail: - * - * - * - * Written by Craig Edwards, Craig McLure, and others. + * InspIRCd: (C) 2002-2007 InspIRCd Development Team + * See: http://www.inspircd.org/wiki/index.php/Credits + * * This program is free but copyrighted software; see * the file COPYING for details. * * --------------------------------------------------- */ -#include -#include #include "users.h" #include "channels.h" #include "modules.h" +#include "inspircd.h" /* $ModDesc: Provides channel +S mode (strip ansi colour) */ -class ModuleStripColor : public Module +/** Handles channel mode +S + */ +class ChannelStripColor : public ModeHandler { - Server *Srv; - ConfigReader *Conf, *MyConf; - public: - ModuleStripColor() + ChannelStripColor(InspIRCd* Instance) : ModeHandler(Instance, 'S', 0, 0, false, MODETYPE_CHANNEL, false) { } + + ModeAction OnModeChange(userrec* source, userrec* dest, chanrec* channel, std::string ¶meter, bool adding) { - Srv = new Server; + if (adding) + { + if (!channel->IsModeSet('S')) + { + channel->SetMode('S',true); + return MODEACTION_ALLOW; + } + } + else + { + if (channel->IsModeSet('S')) + { + channel->SetMode('S',false); + return MODEACTION_ALLOW; + } + } - Srv->AddExtendedMode('S',MT_CHANNEL,false,0,0); - Srv->AddExtendedMode('S',MT_CLIENT,false,0,0); + return MODEACTION_DENY; } +}; - virtual int OnExtendedMode(userrec* user, void* target, char modechar, int type, bool mode_on, string_list ¶ms) +/** Handles user mode +S + */ +class UserStripColor : public ModeHandler +{ + public: + UserStripColor(InspIRCd* Instance) : ModeHandler(Instance, 'S', 0, 0, false, MODETYPE_USER, false) { } + + ModeAction OnModeChange(userrec* source, userrec* dest, chanrec* channel, std::string ¶meter, bool adding) { - // check if this is our mode character... - if (modechar == 'S') - { - return 1; + /* Only opers can change other users modes */ + if ((source != dest) && (!*source->oper)) + return MODEACTION_DENY; + + if (adding) + { + if (!dest->IsModeSet('S')) + { + dest->SetMode('S',true); + return MODEACTION_ALLOW; + } } else { - return 0; + if (dest->IsModeSet('S')) + { + dest->SetMode('S',false); + return MODEACTION_ALLOW; + } } + + return MODEACTION_DENY; + } +}; + + +class ModuleStripColor : public Module +{ + + ConfigReader *Conf, *MyConf; + ChannelStripColor *csc; + UserStripColor *usc; + + public: + ModuleStripColor(InspIRCd* Me) + : Module::Module(Me) + { + + + usc = new UserStripColor(ServerInstance); + csc = new ChannelStripColor(ServerInstance); + + if (!ServerInstance->AddMode(usc, 'S') || !ServerInstance->AddMode(csc, 'S')) + throw ModuleException("Could not add new modes!"); + } + + void Implements(char* List) + { + List[I_OnUserPreMessage] = List[I_OnUserPreNotice] = 1; } - + virtual ~ModuleStripColor() { - delete Srv; + ServerInstance->Modes->DelMode(usc); + ServerInstance->Modes->DelMode(csc); + DELETE(usc); + DELETE(csc); } - // ANSI colour stripping by Doc (Peter Wood) - virtual void ReplaceLine(std::string &text) + // ANSI colour stripping based on C example by Doc (Peter Wood) + virtual void ReplaceLine(std::string &sentence) { int i, a, len, remove; - char sentence[MAXBUF]; - strncpy(sentence,text.c_str(),MAXBUF); - - len = strlen (sentence); + len = sentence.length(); for (i = 0; i < len; i++) { @@ -80,23 +139,24 @@ class ModuleStripColor : public Module case 3: remove = 1; - if (isdigit (sentence[i + remove])) + if (isdigit(sentence[i + remove])) remove++; - if (isdigit (sentence[i + remove])) + if (isdigit(sentence[i + remove])) remove++; if (sentence[i + remove] == ',') { remove += 2; - if (isdigit (sentence[i + remove])) - remove++; + if (isdigit(sentence[i + remove])) + remove++; } break; } - if (remove != 0) { + if (remove != 0) + { len -= remove; for (a = i; a <= len; a++) @@ -104,22 +164,23 @@ class ModuleStripColor : public Module i--; } } - - text = sentence; } - virtual int OnUserPreMessage(userrec* user,void* dest,int target_type, std::string &text) + virtual int OnUserPreMessage(userrec* user,void* dest,int target_type, std::string &text, char status, CUList &exempt_list) { + if (!IS_LOCAL(user)) + return 0; + bool active = false; if (target_type == TYPE_USER) { userrec* t = (userrec*)dest; - active = (strchr(t->modes,'S') > 0); + active = t->IsModeSet('S'); } else if (target_type == TYPE_CHANNEL) { chanrec* t = (chanrec*)dest; - active = (t->IsCustomModeSet('S')); + active = t->IsModeSet('S'); } if (active) { @@ -128,30 +189,14 @@ class ModuleStripColor : public Module return 0; } - virtual int OnUserPreNotice(userrec* user,void* dest,int target_type, std::string &text) + virtual int OnUserPreNotice(userrec* user,void* dest,int target_type, std::string &text, char status, CUList &exempt_list) { - bool active = false; - if (target_type == TYPE_USER) - { - userrec* t = (userrec*)dest; - active = (strchr(t->modes,'S') > 0); - } - else if (target_type == TYPE_CHANNEL) - { - chanrec* t = (chanrec*)dest; - active = (t->IsCustomModeSet('S')); - } - if (active) - { - this->ReplaceLine(text); - } - return 0; + return OnUserPreMessage(user,dest,target_type,text,status,exempt_list); } virtual Version GetVersion() { - // This is version 2 because version 1.x is the unreleased unrealircd module - return Version(1,0,0,0); + return Version(1, 1, 0, 0, VF_COMMON | VF_VENDOR, API_VERSION); } }; @@ -169,9 +214,9 @@ class ModuleStripColorFactory : public ModuleFactory { } - virtual Module * CreateModule() + virtual Module * CreateModule(InspIRCd* Me) { - return new ModuleStripColor; + return new ModuleStripColor(Me); } };