X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_globops.cpp;h=efe50731d3b9b480ea11863aa5a13b22f447c550;hb=4e7c9f5a9257723765f9994aff90440a0b6cf3c9;hp=add0306a707bc8586042eb3a70c43d3c54a800e0;hpb=5cf80cf42c84f322ce8d53775ea747f8e632c402;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_globops.cpp b/src/modules/m_globops.cpp index add0306a7..efe50731d 100644 --- a/src/modules/m_globops.cpp +++ b/src/modules/m_globops.cpp @@ -2,105 +2,66 @@ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * - * InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev. - * E-mail: - * - * - * - * Written by Craig Edwards, Craig McLure, and others. + * InspIRCd: (C) 2002-2007 InspIRCd Development Team + * See: http://www.inspircd.org/wiki/index.php/Credits + * * This program is free but copyrighted software; see * the file COPYING for details. * * --------------------------------------------------- */ -using namespace std; - // Globops and +g support module by C.J.Edwards -#include -#include -#include "users.h" -#include "channels.h" -#include "modules.h" #include "inspircd.h" /* $ModDesc: Provides support for GLOBOPS and user mode +g */ -static Server *Srv; - +/** Handle /GLOBOPS + */ class cmd_globops : public command_t { public: - cmd_globops () : command_t("GLOBOPS",'o',1) + cmd_globops (InspIRCd* Instance) : command_t(Instance,"GLOBOPS",'o',1) { this->source = "m_globops.so"; + syntax = ""; } - - void Handle (char **parameters, int pcnt, userrec *user) + + CmdResult Handle (const char** parameters, int pcnt, userrec *user) { - std::string line = "*** GLOBOPS - From " + std::string(user->nick) + ": "; + std::string line = "From " + std::string(user->nick) + ": "; for (int i = 0; i < pcnt; i++) { line = line + std::string(parameters[i]) + " "; } - Srv->SendToModeMask("og",WM_AND,line); - } -}; - -class ModeGlobops : public ModeHandler -{ - public: - ModeGlobops() : ModeHandler('g', 0, 0, false, MODETYPE_USER, true) { } - - ModeAction OnModeChange(userrec* source, userrec* dest, chanrec* channel, std::string ¶meter, bool adding) - { - if (adding) - { - if (!dest->IsModeSet('g')) - { - dest->SetMode('P',true); - return MODEACTION_ALLOW; - } - } - else - { - if (dest->IsModeSet('g')) - { - dest->SetMode('P',false); - return MODEACTION_ALLOW; - } - } + ServerInstance->SNO->WriteToSnoMask('g',line); - return MODEACTION_DENY; + /* route it (ofc :p) */ + return CMD_SUCCESS; } }; - class ModuleGlobops : public Module { cmd_globops* mycommand; - ModeGlobops* mg; public: - ModuleGlobops(Server* Me) - : Module::Module(Me) + ModuleGlobops(InspIRCd* Me) + : Module(Me) { - Srv = Me; - mg = new ModeGlobops(); - Srv->AddMode(mg, 'g'); - mycommand = new cmd_globops(); - Srv->AddCommand(mycommand); + mycommand = new cmd_globops(ServerInstance); + ServerInstance->AddCommand(mycommand); + ServerInstance->SNO->EnableSnomask('g',"GLOBOPS"); } virtual ~ModuleGlobops() { - DELETE(mycommand); - DELETE(mg); + ServerInstance->SNO->DisableSnomask('g'); } virtual Version GetVersion() { - return Version(1,0,0,1,VF_STATIC|VF_VENDOR); + return Version(1, 1, 0, 1, VF_COMMON | VF_VENDOR, API_VERSION); } void Implements(char* List) @@ -108,27 +69,4 @@ class ModuleGlobops : public Module } }; -class ModuleGlobopsFactory : public ModuleFactory -{ - public: - ModuleGlobopsFactory() - { - } - - ~ModuleGlobopsFactory() - { - } - - virtual Module * CreateModule(Server* Me) - { - return new ModuleGlobops(Me); - } - -}; - - -extern "C" void * init_module( void ) -{ - return new ModuleGlobopsFactory; -} - +MODULE_INIT(ModuleGlobops)