* | 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>
#include "users.h"
#include "channels.h"
#include "modules.h"
+#include "inspircd.h"
+
-Server *Srv;
-
-void handle_samode(char **parameters, int pcnt, userrec *user)
+
+class cmd_samode : public command_t
{
- /*
- * Handles an SAMODE request. Notifies all +s users.
- */
- int n=0;
- std::string result;
- Srv->Log(DEBUG,"SAMODE: Being handled");
- Srv->SendMode(parameters,pcnt,user);
- Srv->Log(DEBUG,"SAMODE: Modechange handled");
- result = std::string(user->nick) + std::string(" used SAMODE ");
- while (n<pcnt)
+ public:
+ cmd_samode (InspIRCd* Instance) : command_t(Instance,"SAMODE", 'o', 2)
{
- result=result + std::string(" ") + std::string(parameters[n]);
- n++;
+ this->source = "m_samode.so";
+ syntax = "<target> <modes> {<mode-parameters>}";
}
- Srv->SendOpers(result);
-}
+
+ void Handle (const char** parameters, int pcnt, userrec *user)
+ {
+ /*
+ * Handles an SAMODE request. Notifies all +s users.
+ */
+ std::string result;
+ log(DEBUG,"SAMODE: Being handled");
+ userrec* n = new userrec(ServerInstance);
+ n->fd = FD_MAGIC_NUMBER;
+ ServerInstance->SendMode(parameters,pcnt,n);
+ delete n;
+ log(DEBUG,"SAMODE: Modechange handled");
+ result = std::string(user->nick);
+ result.append(" used SAMODE");
+ for (int n = 0; n < pcnt; n++)
+ {
+ result.append(" ");
+ result.append(parameters[n]);
+ }
+ ServerInstance->WriteOpers(result);
+ }
+};
class ModuleSaMode : public Module
{
+ cmd_samode* mycommand;
public:
- ModuleSaMode()
+ ModuleSaMode(InspIRCd* Me)
+ : Module::Module(Me)
{
- Srv = new Server;
- Srv->AddCommand("SAMODE",handle_samode,'o',2,"m_samode.so");
+
+ mycommand = new cmd_samode(ServerInstance);
+ ServerInstance->AddCommand(mycommand);
}
virtual ~ModuleSaMode()
{
- delete Srv;
}
virtual Version GetVersion()
{
return Version(1,0,2,2,VF_VENDOR);
}
-
- virtual void OnUserConnect(userrec* user)
- {
- }
-
};
{
}
- virtual Module * CreateModule()
+ virtual Module * CreateModule(InspIRCd* Me)
{
- return new ModuleSaMode;
+ return new ModuleSaMode(Me);
}
};