mirror of
https://github.com/anope/anope.git
synced 2026-07-01 22:26:39 +02:00
Rewrote the config reader to better handle invalid configs.
This prevents Anope from exploding when /os reload has errors.
This commit is contained in:
+18
-18
@@ -30,7 +30,7 @@ class CommandNSDrop : public Command
|
||||
|
||||
if (readonly)
|
||||
{
|
||||
notice_lang(Config.s_NickServ, u, NICK_DROP_DISABLED);
|
||||
notice_lang(Config->s_NickServ, u, NICK_DROP_DISABLED);
|
||||
return MOD_CONT;
|
||||
}
|
||||
|
||||
@@ -40,17 +40,17 @@ class CommandNSDrop : public Command
|
||||
{
|
||||
if ((nr = findrequestnick(nick)) && u->Account()->IsServicesOper())
|
||||
{
|
||||
if (Config.WallDrop)
|
||||
if (Config->WallDrop)
|
||||
ircdproto->SendGlobops(NickServ, "\2%s\2 used DROP on \2%s\2", u->nick.c_str(), nick.c_str());
|
||||
Alog() << Config.s_NickServ << ": " << u->GetMask() << " dropped nickname " << nr->nick << " (e-mail: " << nr->email << ")";
|
||||
Alog() << Config->s_NickServ << ": " << u->GetMask() << " dropped nickname " << nr->nick << " (e-mail: " << nr->email << ")";
|
||||
delete nr;
|
||||
notice_lang(Config.s_NickServ, u, NICK_X_DROPPED, nick.c_str());
|
||||
notice_lang(Config->s_NickServ, u, NICK_X_DROPPED, nick.c_str());
|
||||
}
|
||||
else
|
||||
notice_lang(Config.s_NickServ, u, NICK_X_NOT_REGISTERED, nick.c_str());
|
||||
notice_lang(Config->s_NickServ, u, NICK_X_NOT_REGISTERED, nick.c_str());
|
||||
}
|
||||
else
|
||||
notice_lang(Config.s_NickServ, u, NICK_NOT_REGISTERED);
|
||||
notice_lang(Config->s_NickServ, u, NICK_NOT_REGISTERED);
|
||||
return MOD_CONT;
|
||||
}
|
||||
|
||||
@@ -59,13 +59,13 @@ class CommandNSDrop : public Command
|
||||
my_nick = na->nick;
|
||||
|
||||
if (!is_mine && !u->Account()->HasPriv("nickserv/drop"))
|
||||
notice_lang(Config.s_NickServ, u, ACCESS_DENIED);
|
||||
else if (Config.NSSecureAdmins && !is_mine && na->nc->IsServicesOper())
|
||||
notice_lang(Config.s_NickServ, u, ACCESS_DENIED);
|
||||
notice_lang(Config->s_NickServ, u, ACCESS_DENIED);
|
||||
else if (Config->NSSecureAdmins && !is_mine && na->nc->IsServicesOper())
|
||||
notice_lang(Config->s_NickServ, u, ACCESS_DENIED);
|
||||
else
|
||||
{
|
||||
if (readonly)
|
||||
notice_lang(Config.s_NickServ, u, READ_ONLY_MODE);
|
||||
notice_lang(Config->s_NickServ, u, READ_ONLY_MODE);
|
||||
|
||||
if (ircd->sqline && na->HasFlag(NS_FORBIDDEN))
|
||||
{
|
||||
@@ -73,23 +73,23 @@ class CommandNSDrop : public Command
|
||||
ircdproto->SendSQLineDel(&x);
|
||||
}
|
||||
|
||||
Alog() << Config.s_NickServ << ": " << u->GetMask() << " dropped nickname " << na->nick << " (group " << na->nc->display << ") (e-mail: " << (!na->nc->email.empty() ? na->nc->email : "none") << ")";
|
||||
Alog() << Config->s_NickServ << ": " << u->GetMask() << " dropped nickname " << na->nick << " (group " << na->nc->display << ") (e-mail: " << (!na->nc->email.empty() ? na->nc->email : "none") << ")";
|
||||
delete na;
|
||||
|
||||
FOREACH_MOD(I_OnNickDrop, OnNickDrop(!my_nick.empty() ? my_nick : nick));
|
||||
|
||||
if (!is_mine)
|
||||
{
|
||||
if (Config.WallDrop)
|
||||
if (Config->WallDrop)
|
||||
ircdproto->SendGlobops(NickServ, "\2%s\2 used DROP on \2%s\2", u->nick.c_str(), nick.c_str());
|
||||
notice_lang(Config.s_NickServ, u, NICK_X_DROPPED, nick.c_str());
|
||||
notice_lang(Config->s_NickServ, u, NICK_X_DROPPED, nick.c_str());
|
||||
}
|
||||
else
|
||||
{
|
||||
if (!nick.empty())
|
||||
notice_lang(Config.s_NickServ, u, NICK_X_DROPPED, nick.c_str());
|
||||
notice_lang(Config->s_NickServ, u, NICK_X_DROPPED, nick.c_str());
|
||||
else
|
||||
notice_lang(Config.s_NickServ, u, NICK_DROPPED);
|
||||
notice_lang(Config->s_NickServ, u, NICK_DROPPED);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -99,16 +99,16 @@ class CommandNSDrop : public Command
|
||||
bool OnHelp(User *u, const Anope::string &subcommand)
|
||||
{
|
||||
if (u->Account() && u->Account()->HasPriv("nickserv/drop"))
|
||||
notice_help(Config.s_NickServ, u, NICK_SERVADMIN_HELP_DROP);
|
||||
notice_help(Config->s_NickServ, u, NICK_SERVADMIN_HELP_DROP);
|
||||
else
|
||||
notice_help(Config.s_NickServ, u, NICK_HELP_DROP);
|
||||
notice_help(Config->s_NickServ, u, NICK_HELP_DROP);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
void OnServHelp(User *u)
|
||||
{
|
||||
notice_lang(Config.s_NickServ, u, NICK_HELP_CMD_DROP);
|
||||
notice_lang(Config->s_NickServ, u, NICK_HELP_CMD_DROP);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user