X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_spy.cpp;h=b33a0ba54835e636988ad9a7e1943c2f7914f6ba;hb=31e2d052252c4113ae9ea63844f60df7759a03be;hp=beeb0f0d3ad66858b7d4a3c64e625c03b661205b;hpb=3e0bbf27906d0485c091457a76dd8447b9ad75ba;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_spy.cpp b/src/modules/m_spy.cpp index beeb0f0d3..b33a0ba54 100644 --- a/src/modules/m_spy.cpp +++ b/src/modules/m_spy.cpp @@ -2,12 +2,9 @@ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * - * InspIRCd is copyright (C) 2002-2006 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. * @@ -19,132 +16,124 @@ * WHOIS, WHICH IS SUPPORTED BY MOST IRCDS IN CORE. */ -using namespace std; - /* $ModDesc: Provides SPYLIST and SPYNAMES capability, allowing opers to see who's in +s channels */ -#include -#include -#include -#include "globals.h" -#include "inspircd_config.h" -#ifdef GCC3 -#include -#else -#include -#endif +#include "inspircd.h" #include "users.h" #include "channels.h" #include "modules.h" -#include "commands.h" -#include "socket.h" -#include "helperfuncs.h" -#include "inspircd.h" -#include "inspstring.h" -#include "hashcomp.h" -#include "message.h" -#include "xline.h" -#include "typedefs.h" -#include "cull_list.h" -#include "aes.h" +#include "wildcard.h" -#ifdef GCC3 -#define nspace __gnu_cxx -#else -#define nspace std -#endif +void spy_userlist(userrec *user, chanrec *c) +{ + char list[MAXBUF]; + size_t dlen, curlen; + dlen = curlen = snprintf(list,MAXBUF,"353 %s = %s :", user->nick, c->name); -Server *Srv; + int numusers = 0; + char* ptr = list + dlen; -extern ServerConfig* Config; -extern InspIRCd* ServerInstance; -extern chan_hash chanlist; + CUList *ulist= c->GetUsers(); -void spy_userlist(userrec *user,chanrec *c) -{ - static char list[MAXBUF]; - - if ((!c) || (!user)) - return; - - snprintf(list,MAXBUF,"353 %s = %s :", user->nick, c->name); - - std::map *ulist= c->GetUsers(); - for (std::map::iterator i = ulist->begin(); i != ulist->end(); i++) - { - char* o = i->second; - userrec* otheruser = (userrec*)o; - strlcat(list,cmode(otheruser,c),MAXBUF); - strlcat(list,otheruser->nick,MAXBUF); - strlcat(list," ",MAXBUF); - if (strlen(list)>(480-NICKMAX)) - { - /* list overflowed into - * multiple numerics */ - WriteServ_NoFormat(user->fd,list); - snprintf(list,MAXBUF,"353 %s = %s :", user->nick, c->name); - } - } - /* if whats left in the list isnt empty, send it */ - if (list[strlen(list)-1] != ':') - { - WriteServ_NoFormat(user->fd,list); - } -} + for (CUList::iterator i = ulist->begin(); i != ulist->end(); i++) + { + size_t ptrlen = snprintf(ptr, MAXBUF, "%s%s ", c->GetPrefixChar(i->first), i->first->nick); + + curlen += ptrlen; + ptr += ptrlen; + numusers++; + if (curlen > (480-NICKMAX)) + { + /* list overflowed into multiple numerics */ + user->WriteServ(std::string(list)); + + /* reset our lengths */ + dlen = curlen = snprintf(list,MAXBUF,"353 %s = %s :", user->nick, c->name); + ptr = list + dlen; + + ptrlen = 0; + numusers = 0; + } + } + /* if whats left in the list isnt empty, send it */ + if (numusers) + { + user->WriteServ(std::string(list)); + } + + user->WriteServ("366 %s %s :End of /NAMES list.", user->nick, c->name); + +} + +/** Handle /SPYLIST + */ class cmd_spylist : public command_t { public: - cmd_spylist () : command_t("SPYLIST", 'o', 0) - { - this->source = "m_spy.so"; - } + cmd_spylist (InspIRCd* Instance) : command_t(Instance,"SPYLIST", 'o', 0) + { + this->source = "m_spy.so"; + syntax.clear(); + } - void cmd_spylist::Handle (char **parameters, int pcnt, userrec *user) + CmdResult Handle (const char** parameters, int pcnt, userrec *user) { - WriteServ(user->fd,"321 %s Channel :Users Name",user->nick); - for (chan_hash::const_iterator i = chanlist.begin(); i != chanlist.end(); i++) - { - WriteServ(user->fd,"322 %s %s %d :[+%s] %s",user->nick,i->second->name,usercount_i(i->second),chanmodes(i->second,true),i->second->topic); - } - WriteServ(user->fd,"323 %s :End of channel list.",user->nick); + ServerInstance->WriteOpers("*** Oper %s used SPYLIST to list +s/+p channels and keys.",user->nick); + user->WriteServ("321 %s Channel :Users Name",user->nick); + for (chan_hash::const_iterator i = ServerInstance->chanlist->begin(); i != ServerInstance->chanlist->end(); i++) + { + if (pcnt && !match(i->second->name, parameters[0])) + continue; + user->WriteServ("322 %s %s %d :[+%s] %s",user->nick,i->second->name,i->second->GetUserCounter(),i->second->ChanModes(true),i->second->topic); + } + user->WriteServ("323 %s :End of channel list.",user->nick); + + /* Dont send out across the network */ + return CMD_LOCALONLY; } }; +/** Handle /SPYNAMES + */ class cmd_spynames : public command_t { public: - cmd_spynames () : command_t("SPYNAMES", 'o', 0) - { - this->source = "m_spy.so"; - } - - void cmd_spynames::Handle (char **parameters, int pcnt, userrec *user) - { - chanrec* c; - - if (!pcnt) - { - WriteServ(user->fd,"366 %s * :End of /NAMES list.",user->nick); - return; - } - - if (ServerInstance->Parser->LoopCall(this,parameters,pcnt,user,0,pcnt-1,0)) - return; - c = FindChan(parameters[0]); - if (c) - { - spy_userlist(user,c); - WriteServ(user->fd,"366 %s %s :End of /NAMES list.", user->nick, c->name); - } - else - { - WriteServ(user->fd,"401 %s %s :No such nick/channel",user->nick, parameters[0]); - } - } + cmd_spynames (InspIRCd* Instance) : command_t(Instance,"SPYNAMES", 'o', 0) + { + this->source = "m_spy.so"; + syntax = "{{,}}"; + } + + CmdResult Handle (const char** parameters, int pcnt, userrec *user) + { + chanrec* c = NULL; + + if (!pcnt) + { + user->WriteServ("366 %s * :End of /NAMES list.",user->nick); + return CMD_FAILURE; + } + + if (ServerInstance->Parser->LoopCall(user, this, parameters, pcnt, 0)) + return CMD_FAILURE; + + c = ServerInstance->FindChan(parameters[0]); + if (c) + { + ServerInstance->WriteOpers("*** Oper %s used SPYNAMES to view the users on %s", user->nick, parameters[0]); + spy_userlist(user,c); + } + else + { + user->WriteServ("401 %s %s :No such nick/channel",user->nick, parameters[0]); + } + + return CMD_LOCALONLY; + } }; class ModuleSpy : public Module @@ -152,13 +141,13 @@ class ModuleSpy : public Module cmd_spylist *mycommand; cmd_spynames *mycommand2; public: - ModuleSpy(Server* Me) : Module::Module(Me) + ModuleSpy(InspIRCd* Me) : Module(Me) { - Srv = Me; - mycommand = new cmd_spylist(); - mycommand2 = new cmd_spynames(); - Srv->AddCommand(mycommand); - Srv->AddCommand(mycommand2); + + mycommand = new cmd_spylist(ServerInstance); + mycommand2 = new cmd_spynames(ServerInstance); + ServerInstance->AddCommand(mycommand); + ServerInstance->AddCommand(mycommand2); } virtual ~ModuleSpy() @@ -167,31 +156,8 @@ class ModuleSpy : public Module virtual Version GetVersion() { - return Version(1, 0, 0, 0, VF_VENDOR); - } -}; - - -class ModuleSpyFactory : public ModuleFactory -{ - public: - ModuleSpyFactory() - { - } - - ~ModuleSpyFactory() - { + return Version(1, 1, 0, 0, VF_VENDOR, API_VERSION); } - - virtual Module * CreateModule(Server* Me) - { - return new ModuleSpy(Me); - } - }; - -extern "C" void * init_module( void ) -{ - return new ModuleSpyFactory; -} +MODULE_INIT(ModuleSpy)