/* +------------------------------------+ * | 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; /* * DEVOICE module for InspIRCd * Syntax: /DEVOICE <#chan> */ /* $ModDesc: Provides an extended version of /WHO for opers */ #include "inspircd_config.h" #include "inspircd.h" #include "inspircd_io.h" #include #include #ifdef GCC3 #include #else #include #endif #include #include #include #include #include "users.h" #include "globals.h" #include "modules.h" #include "helperfuncs.h" #include "hashcomp.h" #include "typedefs.h" extern ServerConfig* Config; extern InspIRCd* ServerInstance; extern user_hash clientlist; extern chan_hash chanlist; extern std::vector all_opers; extern std::vector local_users; class ModuleOperWho : public Module { Server* Srv; public: ModuleOperWho(Server* Me) : Module::Module(Me) { Srv = Me; } virtual void Implements(char* List) { List[I_OnPreCommand] = 1; } virtual int OnPreCommand(std::string command, char **parameters, int pcnt, userrec *user, bool validated) { if (!*user->oper) return 0; chanrec* Ptr = NULL; char tmp[10]; if (!pcnt) { for (user_hash::const_iterator i = clientlist.begin(); i != clientlist.end(); i++) { *tmp = 0; Ptr = i->second->chans[0].channel; if (*i->second->awaymsg) { strlcat(tmp, "G", 9); } else { strlcat(tmp, "H", 9); } if (*i->second->oper) { strlcat(tmp, "*", 9); } WriteServ(user->fd,"352 %s %s %s %s %s %s %s :0 %s",user->nick, Ptr ? Ptr->name : "*", i->second->ident, i->second->host, i->second->server, i->second->nick, tmp, i->second->fullname); } WriteServ(user->fd,"315 %s * :End of /WHO list.",user->nick); return 1; } if (pcnt == 1) { if ((!strcmp(parameters[0],"0")) || (!strcmp(parameters[0],"*"))) { if ((user->chans.size()) && (user->chans[0].channel)) { int n_list = 0; for (user_hash::const_iterator i = clientlist.begin(); i != clientlist.end(); i++) { Ptr = i->second->chans[0].channel; // suggested by phidjit and FCS if ((!common_channels(user,i->second)) && (isnick(i->second->nick))) { // Bug Fix #29 *tmp = 0; if (*i->second->awaymsg) { strlcat(tmp, "G", 9); } else { strlcat(tmp, "H", 9); } if (*i->second->oper) { strlcat(tmp, "*", 9); } WriteServ(user->fd,"352 %s %s %s %s %s %s %s :0 %s",user->nick, Ptr ? Ptr->name : "*", i->second->ident, i->second->host, i->second->server, i->second->nick, tmp, i->second->fullname); } } } if (Ptr) { WriteServ(user->fd,"315 %s %s :End of /WHO list.",user->nick , parameters[0]); } else { WriteServ(user->fd,"315 %s %s :End of /WHO list.",user->nick, parameters[0]); } return 1; } if (parameters[0][0] == '#') { Ptr = FindChan(parameters[0]); if (Ptr) { int n_list = 0; for (user_hash::const_iterator i = clientlist.begin(); i != clientlist.end(); i++) { if ((has_channel(i->second,Ptr)) && (isnick(i->second->nick))) { // Fix Bug #29 - Part 2.. *tmp = 0; if (*i->second->awaymsg) { strlcat(tmp, "G", 9); } else { strlcat(tmp, "H", 9); } if (*i->second->oper) { strlcat(tmp, "*", 9); } strlcat(tmp, cmode(i->second, Ptr),5); WriteServ(user->fd,"352 %s %s %s %s %s %s %s :0 %s",user->nick, Ptr->name, i->second->ident, i->second->host, i->second->server, i->second->nick, tmp, i->second->fullname); } } WriteServ(user->fd,"315 %s %s :End of /WHO list.",user->nick, parameters[0]); } else { WriteServ(user->fd,"401 %s %s :No such nick/channel",user->nick, parameters[0]); } } else { userrec* u = Find(parameters[0]); if (u) { // Bug Fix #29 -- Part 29.. *tmp = 0; if (*u->awaymsg) { strlcat(tmp, "G" ,9); } else { strlcat(tmp, "H" ,9); } if (*u->oper) { strlcat(tmp, "*" ,9); } WriteServ(user->fd,"352 %s %s %s %s %s %s %s :0 %s",user->nick, u->chans.size() && u->chans[0].channel ? u->chans[0].channel->name : "*", u->ident, u->dhost, u->server, u->nick, tmp, u->fullname); } WriteServ(user->fd,"315 %s %s :End of /WHO list.",user->nick, parameters[0]); } } if (pcnt == 2) { if ((!strcmp(parameters[0],"0")) || (!strcmp(parameters[0],"*")) && (!strcmp(parameters[1],"o"))) { for (std::vector::iterator i = all_opers.begin(); i != all_opers.end(); i++) { // If i were a rich man.. I wouldn't need to me making these bugfixes.. // But i'm a poor bastard with nothing better to do. userrec* oper = *i; *tmp = 0; if (*oper->awaymsg) { strlcat(tmp, "G" ,9); } else { strlcat(tmp, "H" ,9); } WriteServ(user->fd,"352 %s %s %s %s %s %s %s* :0 %s", user->nick, oper->chans.size() && oper->chans[0].channel ? oper->chans[0].channel->name : "*", oper->ident, oper->host, oper->server, oper->nick, tmp, oper->fullname); } WriteServ(user->fd,"315 %s %s :End of /WHO list.",user->nick, parameters[0]); return 1; } } } virtual ~ModuleOperWho() { } virtual Version GetVersion() { return Version(1, 0, 0, 0, VF_VENDOR); } }; class ModuleOperWhoFactory : public ModuleFactory { public: ModuleOperWhoFactory() { } ~ModuleOperWhoFactory() { } virtual Module * CreateModule(Server* Me) { return new ModuleOperWho(Me); } }; extern "C" void * init_module( void ) { return new ModuleOperWhoFactory; }