X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_globalload.cpp;h=be29b00a5db246f2876b19577d847c5119039db9;hb=1bfa48143c04504181d1b194af151fae2dac1eb1;hp=8514f03dc6b77041a7c92725056f8327936a98ab;hpb=66098d307c036997e51eaea21724615e27fdc3e9;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_globalload.cpp b/src/modules/m_globalload.cpp index 8514f03dc..be29b00a5 100644 --- a/src/modules/m_globalload.cpp +++ b/src/modules/m_globalload.cpp @@ -2,123 +2,161 @@ * | 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-2010 InspIRCd Development Team + * See: http://wiki.inspircd.org/Credits + * * This program is free but copyrighted software; see * the file COPYING for details. * * --------------------------------------------------- */ -using namespace std; - /* $ModDesc: Allows global loading of a module. */ -#include -#include "users.h" -#include "channels.h" -#include "modules.h" #include "inspircd.h" -#include "helperfuncs.h" -extern InspIRCd *ServerInstance; - -class cmd_gloadmodule : public command_t +/** Handle /GLOADMODULE + */ +class CommandGloadmodule : public Command { public: - cmd_gloadmodule (InspIRCd* Instance) : command_t(Instance,"GLOADMODULE", 'o', 1) + CommandGloadmodule(Module* Creator) : Command(Creator,"GLOADMODULE", 1) { - this->source = "m_globalload.so"; - syntax = ""; + flags_needed = 'o'; + syntax = " [servermask]"; + TRANSLATE3(TR_TEXT, TR_TEXT, TR_END); } - void Handle (const char** parameters, int pcnt, userrec *user) + CmdResult Handle (const std::vector ¶meters, User *user) { - if (ServerInstance->LoadModule(parameters[0])) + std::string servername = parameters.size() > 1 ? parameters[1] : "*"; + + if (InspIRCd::Match(ServerInstance->Config->ServerName.c_str(), servername)) { - ServerInstance->WriteOpers("*** NEW MODULE '%s' GLOBALLY LOADED BY '%s'",parameters[0],user->nick); - user->WriteServ("975 %s %s :Module successfully loaded.",user->nick, parameters[0]); + if (ServerInstance->Modules->Load(parameters[0].c_str())) + { + ServerInstance->SNO->WriteToSnoMask('a', "NEW MODULE '%s' GLOBALLY LOADED BY '%s'",parameters[0].c_str(), user->nick.c_str()); + user->WriteNumeric(975, "%s %s :Module successfully loaded.",user->nick.c_str(), parameters[0].c_str()); + } + else + { + user->WriteNumeric(974, "%s %s :%s",user->nick.c_str(), parameters[0].c_str(), ServerInstance->Modules->LastError().c_str()); + } } else - { - user->WriteServ("974 %s %s :Failed to load module: %s",user->nick, parameters[0],ServerInstance->ModuleError()); - } + ServerInstance->SNO->WriteToSnoMask('a', "MODULE '%s' GLOBAL LOAD BY '%s' (not loaded here)",parameters[0].c_str(), user->nick.c_str()); + + return CMD_SUCCESS; + } + + RouteDescriptor GetRouting(User* user, const std::vector& parameters) + { + return ROUTE_BROADCAST; } }; -class cmd_gunloadmodule : public command_t +/** Handle /GUNLOADMODULE + */ +class CommandGunloadmodule : public Command { public: - cmd_gunloadmodule (InspIRCd* Instance) : command_t(Instance,"GUNLOADMODULE", 'o', 1) + CommandGunloadmodule(Module* Creator) : Command(Creator,"GUNLOADMODULE", 1) { - this->source = "m_globalload.so"; - syntax = ""; + flags_needed = 'o'; + syntax = " [servermask]"; } - void Handle (const char** parameters, int pcnt, userrec *user) + CmdResult Handle (const std::vector ¶meters, User *user) { - if (ServerInstance->UnloadModule(parameters[0])) + std::string servername = parameters.size() > 1 ? parameters[1] : "*"; + + if (InspIRCd::Match(ServerInstance->Config->ServerName.c_str(), servername)) { - ServerInstance->WriteOpers("*** MODULE '%s' GLOBALLY UNLOADED BY '%s'",parameters[0],user->nick); - user->WriteServ("973 %s %s :Module successfully unloaded.",user->nick, parameters[0]); + Module* m = ServerInstance->Modules->Find(parameters[0]); + if (m && ServerInstance->Modules->Unload(m)) + { + ServerInstance->SNO->WriteToSnoMask('a', "MODULE '%s' GLOBALLY UNLOADED BY '%s'",parameters[0].c_str(), user->nick.c_str()); + user->SendText(":%s 973 %s %s :Module successfully unloaded.", + ServerInstance->Config->ServerName.c_str(), user->nick.c_str(), parameters[0].c_str()); + } + else + { + user->WriteNumeric(972, "%s %s :%s",user->nick.c_str(), parameters[0].c_str(), ServerInstance->Modules->LastError().c_str()); + } } else - { - user->WriteServ("972 %s %s :Failed to unload module: %s",user->nick, parameters[0],ServerInstance->ModuleError()); - } + ServerInstance->SNO->WriteToSnoMask('a', "MODULE '%s' GLOBAL UNLOAD BY '%s' (not unloaded here)",parameters[0].c_str(), user->nick.c_str()); + + return CMD_SUCCESS; + } + + RouteDescriptor GetRouting(User* user, const std::vector& parameters) + { + return ROUTE_BROADCAST; } }; -class ModuleGlobalLoad : public Module +/** Handle /GRELOADMODULE + */ +class CommandGreloadmodule : public Command { - cmd_gloadmodule *mycommand; - cmd_gunloadmodule *mycommand2; - public: - ModuleGlobalLoad(InspIRCd* Me) : Module::Module(Me) + CommandGreloadmodule(Module* Creator) : Command(Creator, "GRELOADMODULE", 1) { - - mycommand = new cmd_gloadmodule(ServerInstance); - mycommand2 = new cmd_gunloadmodule(ServerInstance); - ServerInstance->AddCommand(mycommand); - ServerInstance->AddCommand(mycommand2); + flags_needed = 'o'; syntax = " [servermask]"; } - - virtual ~ModuleGlobalLoad() + + CmdResult Handle(const std::vector ¶meters, User *user) { + std::string servername = parameters.size() > 1 ? parameters[1] : "*"; + + if (InspIRCd::Match(ServerInstance->Config->ServerName.c_str(), servername)) + { + Module* m = ServerInstance->Modules->Find(parameters[0]); + if (m) + ServerInstance->Modules->Reload(m, NULL); + else + { + user->WriteNumeric(975, "%s %s :Could not find module by that name", user->nick.c_str(), parameters[0].c_str()); + return CMD_FAILURE; + } + } + else + ServerInstance->SNO->WriteToSnoMask('a', "MODULE '%s' GLOBAL RELOAD BY '%s' (not reloaded here)",parameters[0].c_str(), user->nick.c_str()); + + return CMD_SUCCESS; } - - virtual Version GetVersion() + + RouteDescriptor GetRouting(User* user, const std::vector& parameters) { - return Version(1, 0, 0, 0, VF_VENDOR); + return ROUTE_BROADCAST; } }; - -class ModuleGlobalLoadFactory : public ModuleFactory +class ModuleGlobalLoad : public Module { + CommandGloadmodule cmd1; + CommandGunloadmodule cmd2; + CommandGreloadmodule cmd3; + public: - ModuleGlobalLoadFactory() + ModuleGlobalLoad() + : cmd1(this), cmd2(this), cmd3(this) { + ServerInstance->AddCommand(&cmd1); + ServerInstance->AddCommand(&cmd2); + ServerInstance->AddCommand(&cmd3); } - - ~ModuleGlobalLoadFactory() + + ~ModuleGlobalLoad() { } - - virtual Module * CreateModule(InspIRCd* Me) + + Version GetVersion() { - return new ModuleGlobalLoad(Me); + return Version("Allows global loading of a module.", VF_COMMON | VF_VENDOR); } - }; +MODULE_INIT(ModuleGlobalLoad) -extern "C" void * init_module( void ) -{ - return new ModuleGlobalLoadFactory; -}