summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-02-26 12:30:16 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-02-26 12:30:16 +0000
commit3b7bc208c576f2c596932eb62b9e5d6b534fca69 (patch)
tree9c66e12204887808a098b968f3b650072545e104
parent617b8e2058f95c4c3c6eec447aa1f3d059f7ea61 (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.cpp235
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;
+}