X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_spy.cpp;h=053381472540cc8d77d691569b412836c515fee7;hb=94afde43b086f092bf8128d76d418cb63840e8eb;hp=7420d6d3c46e5ca3bef25c78c5c8803e0164a931;hpb=d36107cfe9bcc2b6edd64cafa99fdfc77c3a5fd9;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_spy.cpp b/src/modules/m_spy.cpp index 7420d6d3c..053381472 100644 --- a/src/modules/m_spy.cpp +++ b/src/modules/m_spy.cpp @@ -2,114 +2,42 @@ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * - * InspIRCd: (C) 2002-2007 InspIRCd Development Team + * InspIRCd: (C) 2002-2008 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. + * the file COPYING for details. * * --------------------------------------------------- */ -/* $ModDesc: Provides SPYLIST and SPYNAMES capability, allowing opers to see who's in +s channels */ +/* $ModDesc: Provides the ability to see the complete names list of channels an oper is not a member of */ #include "inspircd.h" #include "wildcard.h" -void spy_userlist(User *user, Channel *c) -{ - char list[MAXBUF]; - size_t dlen, curlen; - - dlen = curlen = snprintf(list,MAXBUF,"353 %s %c %s :", user->nick, c->IsModeSet('s') ? '@' : c->IsModeSet('p') ? '*' : '=', c->name); - - int numusers = 0; - char* ptr = list + dlen; - - CUList *ulist= c->GetUsers(); - - 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 %c %s :", user->nick, c->IsModeSet('s') ? '@' : c->IsModeSet('p') ? '*' : '=', 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 /SPYNAMES - */ -class CommandSpynames : public Command +class ModuleSpy : public Module { - public: - CommandSpynames (InspIRCd* Instance) : Command(Instance,"SPYNAMES", 'o', 0) + public: + ModuleSpy(InspIRCd* Me) : Module(Me) { - this->source = "m_spy.so"; - syntax = "{{,}}"; + ServerInstance->Modules->Attach(I_OnUserList, this); } - CmdResult Handle (const char** parameters, int pcnt, User *user) + virtual int OnUserList(User* user, Channel* Ptr, CUList* &nameslist) { - Channel* 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; + /* User is an oper and is NOT on the channel */ + if (IS_OPER(user) && !Ptr->HasUser(user)) + return -1; - 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; + return 0; } -}; - -class ModuleSpy : public Module -{ - CommandSpynames *mycommand2; - public: - ModuleSpy(InspIRCd* Me) : Module(Me) - { - - mycommand2 = new CommandSpynames(ServerInstance); - ServerInstance->AddCommand(mycommand2); + void Prioritize() + { + /* To ensure that we get priority over namesx and delayjoin for names list generation */ + Module* list[] = { ServerInstance->Modules->Find("m_namesx.so"), ServerInstance->Modules->Find("m_delayjoin.so") }; + ServerInstance->Modules->SetPriority(this, I_OnUserList, PRIO_BEFORE, list, 2); } virtual ~ModuleSpy()