diff options
author | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2006-02-26 12:30:16 +0000 |
---|---|---|
committer | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2006-02-26 12:30:16 +0000 |
commit | 3b7bc208c576f2c596932eb62b9e5d6b534fca69 (patch) | |
tree | 9c66e12204887808a098b968f3b650072545e104 | |
parent | 617b8e2058f95c4c3c6eec447aa1f3d059f7ea61 (diff) |
Added m_operwho, allows opers to list everyone
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@3334 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r-- | src/modules/m_operwho.cpp | 235 |
1 files changed, 235 insertions, 0 deletions
diff --git a/src/modules/m_operwho.cpp b/src/modules/m_operwho.cpp new file mode 100644 index 000000000..15ff74c6d --- /dev/null +++ b/src/modules/m_operwho.cpp @@ -0,0 +1,235 @@ +/* +------------------------------------+ + * | Inspire Internet Relay Chat Daemon | + * +------------------------------------+ + * + * InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev. + * E-mail: + * <brain@chatspike.net> + * <Craig@chatspike.net> + * + * 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 <time.h> +#include <string> +#ifdef GCC3 +#include <ext/hash_map> +#else +#include <hash_map> +#endif +#include <map> +#include <sstream> +#include <vector> +#include <deque> +#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<userrec*> all_opers; +extern std::vector<userrec*> 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<userrec*>::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; +} |