X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_antibottler.cpp;h=9c7d75ea26dd971e089d645fb06775a366473374;hb=d54fd9b1e6b31f69332a9241b5f17330c0ad61e0;hp=61e6bdc3681bc20c193199db88e329d5abfb9e12;hpb=4085f5dedc915399760ed14a6a9b404509aecf44;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_antibottler.cpp b/src/modules/m_antibottler.cpp index 61e6bdc36..9c7d75ea2 100644 --- a/src/modules/m_antibottler.cpp +++ b/src/modules/m_antibottler.cpp @@ -1,3 +1,20 @@ +/* +------------------------------------+ + * | Inspire Internet Relay Chat Daemon | + * +------------------------------------+ + * + * InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev. + * E-mail: + * + * + * + * Written by Craig Edwards, Craig McLure, and others. + * This program is free but copyrighted software; see + * the file COPYING for details. + * + * --------------------------------------------------- + */ +using namespace std; + #include "users.h" #include "channels.h" #include "modules.h" @@ -6,59 +23,64 @@ class ModuleAntiBottler : public Module { - private: - - Server *Srv; public: - ModuleAntiBottler() + ModuleAntiBottler(InspIRCd* Me) + : Module::Module(Me) { - Srv = new Server; + } + + void Implements(char* List) + { + List[I_OnServerRaw] = 1; + } + virtual ~ModuleAntiBottler() { - delete Srv; } virtual Version GetVersion() { - return Version(1,0,0,0); + return Version(1,0,0,1,VF_VENDOR); } - - virtual void OnServerRaw(std::string &raw, bool inbound) + virtual void OnServerRaw(std::string &raw, bool inbound, userrec* user) { if (inbound) { char data[MAXBUF]; - strncpy(data,raw.c_str(),MAXBUF); + strlcpy(data,raw.c_str(),MAXBUF); bool not_bottler = false; if (!strncmp(data,"user ",5)) { - for (int j = 0; j < strlen(data); j++) + for (char* j = data; *j; j++) { - if (data[j] = ':') + if (*j == ':') break; - if (data[j] = '"') + if (*j == '"') { not_bottler = true; } } // Bug Fix (#14) -- FCS - if (!strlen(data)) break; - char *user = strtok(data," "); - if (!strlen(data)) break; + + if (!(data) || !(*data)) + return; + + strtok(data," "); char *ident = strtok(NULL," "); - if (!strlen(data)) break; char *local = strtok(NULL," "); - if (!strlen(data)) break; char *remote = strtok(NULL," :"); - if (!strlen(data)) break; char *gecos = strtok(NULL,"\r\n"); - for (int j = 0; j < strlen(remote); j++) + + if (!ident || !local || !remote || !gecos) + return; + + for (char* j = remote; *j; j++) { - if (((remote[j] < '0') || (remote[j] > '9')) && (remote[j] != '.')) + if (((*j < '0') || (*j > '9')) && (*j != '.')) { not_bottler = true; } @@ -85,9 +107,9 @@ class ModuleAntiBottlerFactory : public ModuleFactory { } - virtual Module * CreateModule() + virtual Module * CreateModule(InspIRCd* Me) { - return new ModuleAntiBottler; + return new ModuleAntiBottler(Me); } };