1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
/* OperServ core functions
*
* (C) 2003-2025 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*
* Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church.
*/
#include "module.h"
class CommandOSReload final
: public Command
{
public:
CommandOSReload(Module *creator) : Command(creator, "operserv/reload", 0, 0)
{
this->SetDesc(_("Reload services' configuration file"));
}
void Execute(CommandSource &source, const std::vector<Anope::string> ¶ms) override
{
try
{
Log(LOG_ADMIN, source, this);
auto *new_config = new Configuration::Conf();
Configuration::Conf *old = Config;
Config = new_config;
Config->Post(old);
delete old;
source.Reply(_("Services' configuration has been reloaded."));
}
catch (const ConfigException &ex)
{
Log(this->owner) << "Error reloading configuration file: " << ex.GetReason();
source.Reply(_("Error reloading configuration file: %s"), ex.GetReason().c_str());
}
}
bool OnHelp(CommandSource &source, const Anope::string &subcommand) override
{
this->SendSyntax(source);
source.Reply(" ");
source.Reply(_(
"Causes services to reload the configuration file. Note that "
"some directives still need the restart of the services to "
"take effect (such as services' nicknames, activation of the "
"session limitation, etc.)."
));
return true;
}
};
class OSReload final
: public Module
{
CommandOSReload commandosreload;
public:
OSReload(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, VENDOR),
commandosreload(this)
{
}
};
MODULE_INIT(OSReload)
|