inspircd/modules/globalload.cpp

179 lines
5.4 KiB
C++
Raw Normal View History

/*
* InspIRCd -- Internet Relay Chat Daemon
*
2024-06-07 10:37:56 +01:00
* Copyright (C) 2013, 2017, 2019-2023 Sadie Powell <sadie@witchery.services>
2020-01-11 22:02:47 +00:00
* Copyright (C) 2012, 2014-2016 Attila Molnar <attilamolnar@hush.com>
2024-06-07 10:37:56 +01:00
* Copyright (C) 2012 Robby <robby@chatbelgie.be>
2020-01-11 22:02:47 +00:00
* Copyright (C) 2009-2010 Daniel De Graaf <danieldg@inspircd.org>
2021-02-26 06:58:13 +00:00
* Copyright (C) 2009 Robin Burchell <robin+git@viroteck.net>
* Copyright (C) 2007-2008 Dennis Friis <peavey@inspircd.org>
2024-06-07 10:37:56 +01:00
* Copyright (C) 2007-2008 Craig Edwards <brain@inspircd.org>
2024-06-21 10:36:09 +01:00
* Copyright (C) 2007 John Brooks <john@jbrooks.io>
*
* This file is part of InspIRCd. InspIRCd is free software: you can
* redistribute it and/or modify it under the terms of the GNU General Public
* License as published by the Free Software Foundation, version 2.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "inspircd.h"
2021-10-01 05:15:29 +01:00
class CommandGLoadModule final
: public Command
{
public:
CommandGLoadModule(Module* Creator)
2022-12-01 05:14:58 +00:00
: Command(Creator, "GLOADMODULE", 1)
{
access_needed = CmdAccess::OPERATOR;
syntax = { "<modulename> [<servermask>]" };
}
CmdResult Handle(User* user, const Params& parameters) override
{
std::string servername = parameters.size() > 1 ? parameters[1] : "*";
if (InspIRCd::Match(ServerInstance->Config->ServerName, servername))
{
if (ServerInstance->Modules.Load(parameters[0]))
{
ServerInstance->SNO.WriteToSnoMask('a', "NEW MODULE '{}' GLOBALLY LOADED BY '{}'", parameters[0], user->nick);
user->WriteRemoteNumeric(RPL_LOADEDMODULE, parameters[0], "Module successfully loaded.");
}
else
{
2021-01-29 18:15:32 +00:00
user->WriteRemoteNumeric(ERR_CANTLOADMODULE, parameters[0], ServerInstance->Modules.LastError());
}
}
else
ServerInstance->SNO.WriteToSnoMask('a', "MODULE '{}' GLOBAL LOAD BY '{}' (not loaded here)", parameters[0], user->nick);
return CmdResult::SUCCESS;
}
RouteDescriptor GetRouting(User* user, const Params& parameters) override
{
return ROUTE_BROADCAST;
}
};
2021-10-01 05:15:29 +01:00
class CommandGUnloadModule final
: public Command
{
public:
CommandGUnloadModule(Module* Creator)
2022-12-01 05:14:58 +00:00
: Command(Creator, "GUNLOADMODULE", 1)
{
access_needed = CmdAccess::OPERATOR;
syntax = { "<modulename> [<servermask>]" };
}
CmdResult Handle(User* user, const Params& parameters) override
{
if (InspIRCd::Match(parameters[0], "core_*", ascii_case_insensitive_map))
{
user->WriteRemoteNumeric(ERR_CANTUNLOADMODULE, parameters[0], "You cannot unload core commands!");
return CmdResult::FAILURE;
}
std::string servername = parameters.size() > 1 ? parameters[1] : "*";
if (InspIRCd::Match(ServerInstance->Config->ServerName, servername))
{
2019-02-07 12:16:33 +00:00
Module* m = ServerInstance->Modules.Find(parameters[0]);
if (m)
{
2019-02-07 12:16:33 +00:00
if (ServerInstance->Modules.Unload(m))
{
ServerInstance->SNO.WriteToSnoMask('a', "MODULE '{}' GLOBALLY UNLOADED BY '{}'", parameters[0], user->nick);
user->WriteRemoteNumeric(RPL_UNLOADEDMODULE, parameters[0], "Module successfully unloaded.");
}
else
{
2021-01-29 18:15:32 +00:00
user->WriteRemoteNumeric(ERR_CANTUNLOADMODULE, parameters[0], ServerInstance->Modules.LastError());
}
}
else
user->WriteRemoteNumeric(ERR_CANTUNLOADMODULE, parameters[0], "No such module");
}
else
ServerInstance->SNO.WriteToSnoMask('a', "MODULE '{}' GLOBAL UNLOAD BY '{}' (not unloaded here)", parameters[0], user->nick);
return CmdResult::SUCCESS;
}
RouteDescriptor GetRouting(User* user, const Params& parameters) override
{
return ROUTE_BROADCAST;
}
};
2021-10-01 05:15:29 +01:00
class CommandGReloadModule final
: public Command
{
public:
CommandGReloadModule(Module* Creator)
: Command(Creator, "GRELOADMODULE", 1)
{
access_needed = CmdAccess::OPERATOR;
syntax = { "<modulename> [<servermask>]" };
}
CmdResult Handle(User* user, const Params& parameters) override
{
std::string servername = parameters.size() > 1 ? parameters[1] : "*";
if (InspIRCd::Match(ServerInstance->Config->ServerName, servername))
{
2019-02-07 12:16:33 +00:00
Module* m = ServerInstance->Modules.Find(parameters[0]);
if (m)
{
ServerInstance->SNO.WriteToSnoMask('a', "MODULE '{}' GLOBALLY RELOADED BY '{}'", parameters[0], user->nick);
ServerInstance->Parser.CallHandler("RELOADMODULE", parameters, user);
}
else
{
user->WriteRemoteNumeric(ERR_CANTUNLOADMODULE, parameters[0], "Could not find a loaded module by that name");
return CmdResult::FAILURE;
}
}
else
ServerInstance->SNO.WriteToSnoMask('a', "MODULE '{}' GLOBAL RELOAD BY '{}' (not reloaded here)", parameters[0], user->nick);
return CmdResult::SUCCESS;
}
RouteDescriptor GetRouting(User* user, const Params& parameters) override
{
return ROUTE_BROADCAST;
}
};
2021-10-01 04:37:03 +01:00
class ModuleGlobalLoad final
: public Module
{
private:
CommandGLoadModule cmdgloadmodule;
CommandGUnloadModule cmdgunloadmodule;
CommandGReloadModule cmdgreloadmodule;
public:
ModuleGlobalLoad()
2020-04-11 14:00:48 +01:00
: Module(VF_VENDOR | VF_COMMON, "Adds the /GLOADMODULE, /GRELOADMODULE, and /GUNLOADMODULE commands which allows server operators to load, reload, and unload modules on remote servers.")
2021-01-29 18:15:32 +00:00
, cmdgloadmodule(this)
, cmdgunloadmodule(this)
, cmdgreloadmodule(this)
{
}
};
MODULE_INIT(ModuleGlobalLoad)