]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_jumpserver.cpp
Improve the description of the maphide module.
[user/henk/code/inspircd.git] / src / modules / m_jumpserver.cpp
index 3104a0c5578fb59f4f05a39c2e535b1580a3bcdb..682e353d2b92e2f70cb08c9bfc3a0abd28aa2829 100644 (file)
 #include "inspircd.h"
 #include "modules/ssl.h"
 
+enum
+{
+       // From ircd-ratbox.
+       RPL_REDIR = 10
+};
+
 /** Handle /JUMPSERVER
  */
 class CommandJumpserver : public Command
@@ -42,7 +48,7 @@ class CommandJumpserver : public Command
                redirect_new_users = false;
        }
 
-       CmdResult Handle(const std::vector<std::string>& parameters, User* user) CXX11_OVERRIDE
+       CmdResult Handle(User* user, const Params& parameters) CXX11_OVERRIDE
        {
                int n_done = 0;
                reason = (parameters.size() < 4) ? "Please use this server/port instead" : parameters[3];
@@ -52,7 +58,7 @@ class CommandJumpserver : public Command
                std::string n_done_s;
 
                /* No parameters: jumpserver disabled */
-               if (!parameters.size())
+               if (parameters.empty())
                {
                        if (port)
                                user->WriteNotice("*** Disabled jumpserver (previously set to '" + redirect_to + ":" + ConvToStr(port) + "')");
@@ -155,6 +161,12 @@ class ModuleJumpServer : public Module
        {
        }
 
+       void OnModuleRehash(User* user, const std::string& param) CXX11_OVERRIDE
+       {
+               if (irc::equals(param, "jumpserver") && js.redirect_new_users)
+                       js.redirect_new_users = false;
+       }
+
        ModResult OnUserRegister(LocalUser* user) CXX11_OVERRIDE
        {
                if (js.redirect_new_users)