* | Inspire Internet Relay Chat Daemon |
* +------------------------------------+
*
- * Inspire is copyright (C) 2002-2004 ChatSpike-Dev.
+ * InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev.
* E-mail:
* <brain@chatspike.net>
* <Craig@chatspike.net>
* ---------------------------------------------------
*/
+using namespace std;
+
#include <stdio.h>
#include <string>
#include "users.h"
#include "channels.h"
#include "modules.h"
+#include "helperfuncs.h"
/* $ModDesc: Provides support for USERIP command */
Server *Srv;
-
-void handle_userip(char **parameters, int pcnt, userrec *user)
+
+class cmd_userip : public command_t
{
- char Return[MAXBUF],junk[MAXBUF];
- snprintf(Return,MAXBUF,"302 %s :",user->nick);
- for (int i = 0; i < pcnt; i++)
- {
- userrec *u = Find(parameters[i]);
- if (u)
- {
- snprintf(junk,MAXBUF,"%s%s=+%s@%s ",u->nick,strchr(u->modes,'o') ? "*" : "",u->ident,u->ip);
- strlcat(Return,junk,MAXBUF);
- }
- }
- WriteServ(user->fd,Return);
-}
+ public:
+ cmd_userip () : command_t("USERIP", 'o', 1)
+ {
+ this->source = "m_userip.so";
+ }
+ void Handle (char **parameters, int pcnt, userrec *user)
+ {
+ char Return[MAXBUF],junk[MAXBUF];
+ snprintf(Return,MAXBUF,"340 %s :",user->nick);
+ for (int i = 0; i < pcnt; i++)
+ {
+ userrec *u = Find(parameters[i]);
+ if (u)
+ {
+ snprintf(junk,MAXBUF,"%s%s=+%s@%s ",u->nick,strchr(u->modes,'o') ? "*" : "",u->ident,u->ip);
+ strlcat(Return,junk,MAXBUF);
+ }
+ }
+ WriteServ(user->fd,Return);
+ }
+};
class ModuleUserIP : public Module
{
+ cmd_userip* mycommand;
public:
- ModuleUserIP()
+ ModuleUserIP(Server* Me)
+ : Module::Module(Me)
+ {
+ Srv = Me;
+ mycommand = new cmd_userip();
+ Srv->AddCommand(mycommand);
+ }
+
+ void Implements(char* List)
{
- Srv = new Server;
- Srv->AddCommand("USERIP",handle_UserIP,'o',1,"m_Userip.so");
+ List[I_On005Numeric] = 1;
}
+
+ virtual void On005Numeric(std::string &output)
+ {
+ output = output + std::string(" USERIP");
+ }
virtual ~ModuleUserIP()
{
- delete Srv;
}
virtual Version GetVersion()
{
}
- virtual Module * CreateModule()
+ virtual Module * CreateModule(Server* Me)
{
- return new ModuleUserIP;
+ return new ModuleUserIP(Me);
}
};