X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_antibottler.cpp;h=38ef873d8eaef31d329288a9200b18d992ecba8a;hb=02c6ce1ad09a7471a6b03dc00bac4b843d157489;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..38ef873d8 100644 --- a/src/modules/m_antibottler.cpp +++ b/src/modules/m_antibottler.cpp @@ -2,19 +2,16 @@ * | 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. * * --------------------------------------------------- */ -using namespace std; +#include "inspircd.h" #include "users.h" #include "channels.h" #include "modules.h" @@ -23,15 +20,18 @@ using namespace std; class ModuleAntiBottler : public Module { - private: - - Server *Srv; public: - ModuleAntiBottler(Server* Me) - : Module::Module(Me) + ModuleAntiBottler(InspIRCd* Me) + : Module(Me) + { + + } + + void Implements(char* List) { - Srv = Me; + List[I_OnPreCommand] = 1; } + virtual ~ModuleAntiBottler() { @@ -39,55 +39,61 @@ class ModuleAntiBottler : public Module virtual Version GetVersion() { - return Version(1,0,0,1,VF_VENDOR); + return Version(1,1,0,1,VF_VENDOR,API_VERSION); } - - virtual void OnServerRaw(std::string &raw, bool inbound, userrec* user) + virtual int OnPreCommand(const std::string &command, const char** parameters, int pcnt, userrec *user, bool validated, const std::string &original_line) { - if (inbound) + char data[MAXBUF]; + strlcpy(data,original_line.c_str(),MAXBUF); + bool not_bottler = false; + if (!strncmp(data,"user ",5)) { - char data[MAXBUF]; - strncpy(data,raw.c_str(),MAXBUF); - bool not_bottler = false; - if (!strncmp(data,"user ",5)) + for (char* j = data; *j; j++) { - for (unsigned int j = 0; j < strlen(data); j++) - { - if (data[j] == ':') - break; - - if (data[j] == '"') - { - not_bottler = true; - } - } - // Bug Fix (#14) -- FCS - if (!strlen(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 (*j == ':') + break; + + if (*j == '"') { - if (((remote[j] < '0') || (remote[j] > '9')) && (remote[j] != '.')) - { - not_bottler = true; - } + not_bottler = true; } + } + // Bug Fix (#14) -- FCS + if (!(data) || !(*data)) + return 0; + + strtok(data," "); + char *ident = strtok(NULL," "); + char *local = strtok(NULL," "); + char *remote = strtok(NULL," :"); + char *gecos = strtok(NULL,"\r\n"); - if (!not_bottler) + if (!ident || !local || !remote || !gecos) + return 0; + + for (char* j = remote; *j; j++) + { + if (((*j < '0') || (*j > '9')) && (*j != '.')) { - raw = "USER bottler "+std::string(local)+" "+std::string(remote)+" "+std::string(gecos)+" [Possible bottler, ident: "+std::string(ident)+"]"; + not_bottler = true; } } + + if (!not_bottler) + { + std::string strgecos = std::string(gecos) + "[Possible bottler, ident: " + std::string(ident) + "]"; + const char* modified[3]; + modified[0] = "bottler"; + modified[1] = local; + modified[2] = remote; + modified[3] = strgecos.c_str(); + ServerInstance->Parser->CallHandler("USER", modified, 4, user); + return 1; + } } - } + return 0; + } }; @@ -102,7 +108,7 @@ class ModuleAntiBottlerFactory : public ModuleFactory { } - virtual Module * CreateModule(Server* Me) + virtual Module * CreateModule(InspIRCd* Me) { return new ModuleAntiBottler(Me); } @@ -110,7 +116,7 @@ class ModuleAntiBottlerFactory : public ModuleFactory }; -extern "C" void * init_module( void ) +extern "C" DllExport void * init_module( void ) { return new ModuleAntiBottlerFactory; }