]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/cmd_ison.cpp
INFO now looks much prettier than it did 5 seconds ago :o
[user/henk/code/inspircd.git] / src / cmd_ison.cpp
index cf60b6f6b3bc7689a1e14c9b7caf666f488e9c42..4ca319afcd21a8a187518c867bbc382501fe58b2 100644 (file)
@@ -2,39 +2,86 @@
  *       | Inspire Internet Relay Chat Daemon |
  *       +------------------------------------+
  *
- *  InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev.
- *                       E-mail:
- *                <brain@chatspike.net>
- *                <Craig@chatspike.net>
+ *  InspIRCd: (C) 2002-2007 InspIRCd Development Team
+ * See: http://www.inspircd.org/wiki/index.php/Credits
  *
- * Written by Craig Edwards, Craig McLure, and others.
  * This program is free but copyrighted software; see
  *            the file COPYING for details.
  *
  * ---------------------------------------------------
  */
 
-#include "users.h"
 #include "inspircd.h"
 #include "commands/cmd_ison.h"
 
-void cmd_ison::Handle (const char** parameters, int pcnt, userrec *user)
+extern "C" DllExport command_t* init_command(InspIRCd* Instance)
 {
-       char retbuf[MAXBUF];
-       userrec *u;
+       return new cmd_ison(Instance);
+}
 
-       snprintf(retbuf, MAXBUF, "303 %s :", user->nick);
+/** Handle /ISON
+ */
+CmdResult cmd_ison::Handle (const char** parameters, int pcnt, userrec *user)
+{
+       std::map<userrec*,userrec*> ison_already;
+       userrec *u;
+       std::string reply = std::string("303 ") + user->nick + " :";
 
        for (int i = 0; i < pcnt; i++)
        {
                u = ServerInstance->FindNick(parameters[i]);
+               if (ison_already.find(u) != ison_already.end())
+                       continue;
 
                if (u)
                {
-                       strlcat(retbuf, u->nick, MAXBUF);
-                       charlcat(retbuf, ' ', MAXBUF);
+                       if (u->Visibility && !u->Visibility->VisibleTo(user))
+                               continue;
+
+                       reply.append(u->nick).append(" ");
+                       if (reply.length() > 450)
+                       {
+                               user->WriteServ(reply);
+                               reply = std::string("303 ") + user->nick + " :";
+                       }
+                       ison_already[u] = u;
+               }
+               else
+               {
+                       if ((i == pcnt-1) && (strchr(parameters[i],' ')))
+                       {
+                               /* Its a space seperated list of nicks (RFC1459 says to support this)
+                                */
+                               irc::spacesepstream list(parameters[i]);
+                               std::string item;
+
+                               while (list.GetToken(item))
+                               {
+                                       u = ServerInstance->FindNick(item);
+                                       if (ison_already.find(u) != ison_already.end())
+                                               continue;
+
+                                       if (u)
+                                       {
+                                               if (u->Visibility && !u->Visibility->VisibleTo(user))
+                                                       continue;
+
+                                               reply.append(u->nick).append(" ");
+                                               if (reply.length() > 450)
+                                               {
+                                                       user->WriteServ(reply);
+                                                       reply = std::string("303 ") + user->nick + " :";
+                                               }
+                                               ison_already[u] = u;
+                                       }
+                               }
+                       }
                }
        }
 
-       user->WriteServ( retbuf);
+       if (!reply.empty())
+               user->WriteServ(reply);
+
+       return CMD_SUCCESS;
 }
+