diff options
author | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2004-04-07 18:01:00 +0000 |
---|---|---|
committer | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2004-04-07 18:01:00 +0000 |
commit | 632ca0fd6a2cfa3d06f87b77ccffcc2e5a835572 (patch) | |
tree | 93c5e9f94c0e12cf0e2213907c277b8ce0372657 /src/modules/m_saquit.cpp | |
parent | 31ea9ef00c26301789b05673977179bb6ab75d94 (diff) |
Fixed actions in m_filter
Added new m_saquit by w00t
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@422 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/modules/m_saquit.cpp')
-rw-r--r-- | src/modules/m_saquit.cpp | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/src/modules/m_saquit.cpp b/src/modules/m_saquit.cpp new file mode 100644 index 000000000..d7151e5ec --- /dev/null +++ b/src/modules/m_saquit.cpp @@ -0,0 +1,86 @@ +/* + * SAQUIT module for InspIRCd + * Author: w00t + * Version: 1.0.0.0 + * + * Syntax: /SAQUIT <user> [reason] + * Makes it appear as though <user> has /quit with [reason] + * + */ + +#include <stdio.h> +#include <string> +#include "users.h" +#include "channels.h" +#include "modules.h" + +/* $ModDesc: Provides support for an SAQUIT command, exits user with a reason */ + +Server *Srv; + +void handle_saquit(char **parameters, int pcnt, userrec *user) +{ + userrec* dest = Srv->FindNick(std::string(parameters[0])); + if (dest) + { + + std::string line = ""; + for (int i = 1; i < pcnt - 1; i++) + { + line = line + std::string(parameters[i]) + " "; + } + line = line + std::string(parameters[pcnt-1]) + + Srv->SendOpers(std::string(user->nick)+" used SAQUIT to make "+std::string(dest->nick)+" quit with a reason of "+line); + Srv->QuitUser(dest, line); + } +} + + +class ModuleSaquit : public Module +{ + public: + ModuleSaquit() + { + Srv = new Server; + Srv->AddCommand("SAQUIT",handle_saquit,'o',2); + } + + virtual ~ModuleSaquit() + { + delete Srv; + } + + virtual Version GetVersion() + { + return Version(1,0,0,0); + } + +}; + +// stuff down here is the module-factory stuff. For basic modules you can ignore this. + +class ModuleSaquitFactory : public ModuleFactory +{ + public: + ModuleSaquitFactory() + { + } + + ~ModuleSaquitFactory() + { + } + + virtual Module * CreateModule() + { + return new ModuleSaquit; + } + +}; + + +extern "C" void * init_module( void ) +{ + return new ModuleSaquitFactory; +} + |