1
0
mirror of https://github.com/anope/anope.git synced 2026-07-05 20:33:13 +02:00

Made ns set/saset work like cs set/saset, cleans up a lot of code

This commit is contained in:
Adam
2010-08-03 01:49:15 -04:00
parent 7b27a4e491
commit 59ee16c7cb
11 changed files with 172 additions and 411 deletions
+27 -67
View File
@@ -16,72 +16,7 @@
class CommandNSSetKill : public Command
{
public:
CommandNSSetKill() : Command("KILL", 1)
{
}
CommandReturn Execute(User *u, const std::vector<Anope::string> &params)
{
if (params[0].equals_ci("ON"))
{
u->Account()->SetFlag(NI_KILLPROTECT);
u->Account()->UnsetFlag(NI_KILL_QUICK);
u->Account()->UnsetFlag(NI_KILL_IMMED);
notice_lang(Config.s_NickServ, u, NICK_SET_KILL_ON);
}
else if (params[0].equals_ci("QUICK"))
{
u->Account()->SetFlag(NI_KILLPROTECT);
u->Account()->SetFlag(NI_KILL_QUICK);
u->Account()->UnsetFlag(NI_KILL_IMMED);
notice_lang(Config.s_NickServ, u, NICK_SET_KILL_QUICK);
}
else if (params[0].equals_ci("IMMED"))
{
if (Config.NSAllowKillImmed)
{
u->Account()->SetFlag(NI_KILLPROTECT);
u->Account()->SetFlag(NI_KILL_IMMED);
u->Account()->UnsetFlag(NI_KILL_QUICK);
notice_lang(Config.s_NickServ, u, NICK_SET_KILL_IMMED);
}
else
notice_lang(Config.s_NickServ, u, NICK_SET_KILL_IMMED_DISABLED);
}
else if (params[0].equals_ci("OFF"))
{
u->Account()->UnsetFlag(NI_KILLPROTECT);
u->Account()->UnsetFlag(NI_KILL_QUICK);
u->Account()->UnsetFlag(NI_KILL_IMMED);
notice_lang(Config.s_NickServ, u, NICK_SET_KILL_OFF);
}
else
this->OnSyntaxError(u, "KILL");
return MOD_CONT;
}
bool OnHelp(User *u, const Anope::string &)
{
notice_help(Config.s_NickServ, u, NICK_HELP_SET_KILL);
return true;
}
void OnSyntaxError(User *u, const Anope::string &)
{
syntax_error(Config.s_NickServ, u, "SET KILL", Config.NSAllowKillImmed ? NICK_SET_KILL_IMMED_SYNTAX : NICK_SET_KILL_SYNTAX);
}
void OnServHelp(User *u)
{
notice_lang(Config.s_NickServ, u, NICK_HELP_CMD_SET_KILL);
}
};
class CommandNSSASetKill : public Command
{
public:
CommandNSSASetKill() : Command("KILL", 2, 2, "nickserv/saset/kill")
CommandNSSetKill(const Anope::string &spermission = "") : Command("KILL", 2, 3, spermission)
{
}
@@ -89,9 +24,10 @@ class CommandNSSASetKill : public Command
{
NickCore *nc = findcore(params[0]);
if (!nc)
throw CoreException("NULL nc in CommandNSSASetKill");
throw CoreException("NULL nc in CommandNSSetKill");
Anope::string param = params[1];
Anope::string arg = params.size() > 2 ? params[2] : "";
if (param.equals_ci("ON"))
{
@@ -132,6 +68,30 @@ class CommandNSSASetKill : public Command
return MOD_CONT;
}
bool OnHelp(User *u, const Anope::string &)
{
notice_help(Config.s_NickServ, u, NICK_HELP_SET_KILL);
return true;
}
void OnSyntaxError(User *u, const Anope::string &)
{
syntax_error(Config.s_NickServ, u, "SET KILL", Config.NSAllowKillImmed ? NICK_SET_KILL_IMMED_SYNTAX : NICK_SET_KILL_SYNTAX);
}
void OnServHelp(User *u)
{
notice_lang(Config.s_NickServ, u, NICK_HELP_CMD_SET_KILL);
}
};
class CommandNSSASetKill : public CommandNSSetKill
{
public:
CommandNSSASetKill() : CommandNSSetKill("nickserv/saset/kill")
{
}
bool OnHelp(User *u, const Anope::string &)
{
notice_help(Config.s_NickServ, u, NICK_HELP_SASET_KILL);