mirror of
https://github.com/anope/anope.git
synced 2026-06-25 06:16:39 +02:00
137 lines
3.6 KiB
C++
137 lines
3.6 KiB
C++
/* HostServ core functions
|
|
*
|
|
* (C) 2003-2011 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 CommandHSSetAll : public Command
|
|
{
|
|
public:
|
|
CommandHSSetAll() : Command("SETALL", 2, 2, "hostserv/set")
|
|
{
|
|
this->SetDesc(_("Set the vhost for all nicks in a group"));
|
|
}
|
|
|
|
CommandReturn Execute(CommandSource &source, const std::vector<Anope::string> ¶ms)
|
|
{
|
|
User *u = source.u;
|
|
|
|
const Anope::string &nick = params[0];
|
|
Anope::string rawhostmask = params[1];
|
|
|
|
int32 tmp_time;
|
|
|
|
NickAlias *na = findnick(nick);
|
|
if (!na)
|
|
{
|
|
source.Reply(_(NICK_X_NOT_REGISTERED), nick.c_str());
|
|
return MOD_CONT;
|
|
}
|
|
else if (na->HasFlag(NS_FORBIDDEN))
|
|
{
|
|
source.Reply(_(NICK_X_FORBIDDEN), nick.c_str());
|
|
return MOD_CONT;
|
|
}
|
|
|
|
Anope::string vIdent = myStrGetToken(rawhostmask, '@', 0); /* Get the first substring, @ as delimiter */
|
|
if (!vIdent.empty())
|
|
{
|
|
rawhostmask = myStrGetTokenRemainder(rawhostmask, '@', 1); /* get the remaining string */
|
|
if (rawhostmask.empty())
|
|
{
|
|
source.Reply(_("vhost for group \002%s\002 set to \002%s\002."), Config->s_HostServ.c_str());
|
|
return MOD_CONT;
|
|
}
|
|
if (vIdent.length() > Config->UserLen)
|
|
{
|
|
source.Reply(_(HOST_SET_IDENTTOOLONG), Config->UserLen);
|
|
return MOD_CONT;
|
|
}
|
|
else
|
|
{
|
|
for (Anope::string::iterator s = vIdent.begin(), s_end = vIdent.end(); s != s_end; ++s)
|
|
if (!isvalidchar(*s))
|
|
{
|
|
source.Reply(_(HOST_SET_IDENT_ERROR));
|
|
return MOD_CONT;
|
|
}
|
|
}
|
|
if (!ircd->vident)
|
|
{
|
|
source.Reply(_(HOST_NO_VIDENT));
|
|
return MOD_CONT;
|
|
}
|
|
}
|
|
|
|
Anope::string hostmask;
|
|
if (rawhostmask.length() < Config->HostLen)
|
|
hostmask = rawhostmask;
|
|
else
|
|
{
|
|
source.Reply(_(HOST_SET_TOOLONG), Config->HostLen);
|
|
return MOD_CONT;
|
|
}
|
|
|
|
if (!isValidHost(hostmask, 3))
|
|
{
|
|
source.Reply(_(HOST_SET_ERROR));
|
|
return MOD_CONT;
|
|
}
|
|
|
|
tmp_time = Anope::CurTime;
|
|
|
|
Log(LOG_ADMIN, u, this) << "to set the vhost for all nicks in group " << na->nc->display << " to " << (!vIdent.empty() ? vIdent + "@" : "") << hostmask;
|
|
|
|
na->hostinfo.SetVhost(vIdent, hostmask, u->nick);
|
|
HostServSyncVhosts(na);
|
|
FOREACH_MOD(I_OnSetVhost, OnSetVhost(na));
|
|
if (!vIdent.empty())
|
|
source.Reply(_("vhost for group \002%s\002 set to \002%s\002@\002%s\002."), nick.c_str(), vIdent.c_str(), hostmask.c_str());
|
|
else
|
|
source.Reply(_("vhost for group \002%s\002 set to \002%s\002."), nick.c_str(), hostmask.c_str());
|
|
return MOD_CONT;
|
|
}
|
|
|
|
bool OnHelp(CommandSource &source, const Anope::string &subcommand)
|
|
{
|
|
source.Reply(_("Syntax: \002SETALL\002 \002<nick>\002 \002<hostmask>\002.\n"
|
|
"Sets the vhost for all nicks in the same group as that\n"
|
|
"of the given nick. If your IRCD supports vIdents, then\n"
|
|
"using SETALL <nick> <ident>@<hostmask> will set idents\n"
|
|
"for users as well as vhosts.\n"
|
|
"* NOTE, this will not update the vhost for any nicks\n"
|
|
"added to the group after this command was used."));
|
|
return true;
|
|
}
|
|
|
|
void OnSyntaxError(CommandSource &source, const Anope::string &subcommand)
|
|
{
|
|
SyntaxError(source, "SETALL", _("SETALL \002<nick>\002 \002<hostmask>\002."));
|
|
}
|
|
};
|
|
|
|
class HSSetAll : public Module
|
|
{
|
|
CommandHSSetAll commandhssetall;
|
|
|
|
public:
|
|
HSSetAll(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator)
|
|
{
|
|
this->SetAuthor("Anope");
|
|
this->SetType(CORE);
|
|
|
|
this->AddCommand(HostServ, &commandhssetall);
|
|
}
|
|
};
|
|
|
|
MODULE_INIT(HSSetAll)
|