]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_globalload.cpp
This is better now.
[user/henk/code/inspircd.git] / src / modules / m_globalload.cpp
index e65f90b64246b0c87d0dbada175dc8c9889e21fe..d3dcf13dd95fdb4cfe6e2399196c93cd5dae731e 100644 (file)
@@ -24,7 +24,8 @@ using namespace std;
 #include "modules.h"
 #include "inspircd.h"
 
-
+/** Handle /GLOADMODULE
+ */
 class cmd_gloadmodule : public command_t
 {
  public:
@@ -50,6 +51,8 @@ class cmd_gloadmodule : public command_t
        }
 };
 
+/** Handle /GUNLOADMODULE
+ */
 class cmd_gunloadmodule : public command_t
 {
  public:
@@ -75,10 +78,43 @@ class cmd_gunloadmodule : public command_t
        }
 };
 
+/** Handle /GRELOADMODULE
+ */
+class cmd_greloadmodule : public command_t
+{
+ public:
+       cmd_greloadmodule (InspIRCd* Instance) : command_t(Instance, "GRELOADMODULE", 'o', 1)
+       {
+               this->source = "m_globalload.so";
+               syntax = "<modulename>";
+       }
+
+       CmdResult Handle(const char** parameters, int pcnt, userrec *user)
+       {
+               if (!ServerInstance->UnloadModule(parameters[0]))
+               {
+                       user->WriteServ("972 %s %s :Failed to unload module: %s",user->nick, parameters[0],ServerInstance->ModuleError());
+                       return CMD_FAILURE;
+               }
+
+               if (!ServerInstance->LoadModule(parameters[0]))
+               {
+                       user->WriteServ("974 %s %s :Failed to load module: %s",user->nick, parameters[0],ServerInstance->ModuleError());
+                       return CMD_FAILURE;
+               }
+
+               ServerInstance->WriteOpers("*** MODULE '%s' GLOBALLY RELOADED BY '%s'",parameters[0],user->nick);
+               user->WriteServ("975 %s %s :Module successfully loaded.",user->nick, parameters[0]);
+               
+               return CMD_SUCCESS;
+       }
+};
+
 class ModuleGlobalLoad : public Module
 {
        cmd_gloadmodule *mycommand;
        cmd_gunloadmodule *mycommand2;
+       cmd_greloadmodule *mycommand3;
        
  public:
        ModuleGlobalLoad(InspIRCd* Me) : Module::Module(Me)
@@ -86,8 +122,10 @@ class ModuleGlobalLoad : public Module
                
                mycommand = new cmd_gloadmodule(ServerInstance);
                mycommand2 = new cmd_gunloadmodule(ServerInstance);
+               mycommand3 = new cmd_greloadmodule(ServerInstance);
                ServerInstance->AddCommand(mycommand);
                ServerInstance->AddCommand(mycommand2);
+               ServerInstance->AddCommand(mycommand3);
        }
        
        virtual ~ModuleGlobalLoad()
@@ -96,7 +134,7 @@ class ModuleGlobalLoad : public Module
        
        virtual Version GetVersion()
        {
-               return Version(1, 0, 0, 0, VF_VENDOR);
+               return Version(1, 1, 0, 0, VF_VENDOR, API_VERSION);
        }
 };