X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_antibottler.cpp;h=9c7d75ea26dd971e089d645fb06775a366473374;hb=66098d307c036997e51eaea21724615e27fdc3e9;hp=8b11c80c5dcb6c73faf0e7ca442c48b48d877bb0;hpb=2d821f2980825be73e3f90b47ffff365b0ec5ecb;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_antibottler.cpp b/src/modules/m_antibottler.cpp index 8b11c80c5..9c7d75ea2 100644 --- a/src/modules/m_antibottler.cpp +++ b/src/modules/m_antibottler.cpp @@ -2,7 +2,7 @@ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * - * Inspire is copyright (C) 2002-2004 ChatSpike-Dev. + * InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev. * E-mail: * * @@ -23,15 +23,18 @@ using namespace std; class ModuleAntiBottler : public Module { - private: - - Server *Srv; public: - ModuleAntiBottler(Server* Me) + ModuleAntiBottler(InspIRCd* Me) : Module::Module(Me) { - Srv = Me; + } + + void Implements(char* List) + { + List[I_OnServerRaw] = 1; + } + virtual ~ModuleAntiBottler() { @@ -42,40 +45,42 @@ class ModuleAntiBottler : public Module return Version(1,0,0,1,VF_VENDOR); } - 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 (unsigned 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)) return; + + if (!(data) || !(*data)) + return; + strtok(data," "); - if (!strlen(data)) return; char *ident = strtok(NULL," "); - if (!strlen(data)) return; char *local = strtok(NULL," "); - if (!strlen(data)) return; char *remote = strtok(NULL," :"); - if (!strlen(data)) return; char *gecos = strtok(NULL,"\r\n"); - for (unsigned 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; } @@ -102,7 +107,7 @@ class ModuleAntiBottlerFactory : public ModuleFactory { } - virtual Module * CreateModule(Server* Me) + virtual Module * CreateModule(InspIRCd* Me) { return new ModuleAntiBottler(Me); }