1
0
mirror of https://github.com/anope/anope.git synced 2026-06-25 09:16:38 +02:00
Files
anope/modules/core/ns_alist.cpp
T

156 lines
3.9 KiB
C++

/* NickServ core functions
*
* (C) 2003-2010 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 CommandNSAList : public Command
{
public:
CommandNSAList() : Command("ALIST", 0, 2)
{
}
CommandReturn Execute(User *u, const std::vector<ci::string> &params)
{
/*
* List the channels that the given nickname has access on
*
* /ns ALIST [level]
* /ns ALIST [nickname] [level]
*
* -jester
*/
const char *nick = NULL;
NickAlias *na;
int min_level = 0;
int is_servadmin = u->Account()->IsServicesOper();
unsigned lev_param = 0;
if (!is_servadmin)
/* Non service admins can only see their own levels */
na = findnick(u->Account()->display);
else
{
/* Services admins can request ALIST on nicks.
* The first argument for service admins must
* always be a nickname.
*/
nick = params.size() ? params[0].c_str() : NULL;
lev_param = 1;
/* If an argument was passed, use it as the nick to see levels
* for, else check levels for the user calling the command */
if (nick)
na = findnick(nick);
else
na = findnick(u->nick);
}
/* If available, get level from arguments */
ci::string lev = params.size() > lev_param ? params[lev_param] : "";
/* if a level was given, make sure it's an int for later */
if (!lev.empty())
{
if (lev == "FOUNDER")
min_level = ACCESS_FOUNDER;
else if (lev == "SOP")
min_level = ACCESS_SOP;
else if (lev == "AOP")
min_level = ACCESS_AOP;
else if (lev == "HOP")
min_level = ACCESS_HOP;
else if (lev == "VOP")
min_level = ACCESS_VOP;
else
min_level = atoi(lev.c_str());
}
if (!na)
notice_lang(Config.s_NickServ, u, NICK_X_NOT_REGISTERED, nick);
else if (na->HasFlag(NS_FORBIDDEN))
notice_lang(Config.s_NickServ, u, NICK_X_FORBIDDEN, na->nick);
else if (min_level <= ACCESS_INVALID || min_level > ACCESS_FOUNDER)
notice_lang(Config.s_NickServ, u, CHAN_ACCESS_LEVEL_RANGE, ACCESS_INVALID + 1, ACCESS_FOUNDER - 1);
else
{
int level;
int chan_count = 0;
int match_count = 0;
notice_lang(Config.s_NickServ, u, is_servadmin ? NICK_ALIST_HEADER_X : NICK_ALIST_HEADER, na->nick);
for (registered_channel_map::const_iterator it = RegisteredChannelList.begin(), it_end = RegisteredChannelList.end(); it != it_end; ++it)
{
ChannelInfo *ci = it->second;
if ((level = get_access_level(ci, na)))
{
++chan_count;
if (min_level > level)
continue;
++match_count;
if (ci->HasFlag(CI_XOP) || level == ACCESS_FOUNDER)
{
const char *xop;
xop = get_xop_level(level);
notice_lang(Config.s_NickServ, u, NICK_ALIST_XOP_FORMAT, match_count, ci->HasFlag(CI_NO_EXPIRE) ? '!' : ' ', ci->name.c_str(), xop, ci->desc ? ci->desc : "");
}
else
notice_lang(Config.s_NickServ, u, NICK_ALIST_ACCESS_FORMAT, match_count, ci->HasFlag(CI_NO_EXPIRE) ? '!' : ' ', ci->name.c_str(), level, ci->desc ? ci->desc : "");
}
}
notice_lang(Config.s_NickServ, u, NICK_ALIST_FOOTER, match_count, chan_count);
}
return MOD_CONT;
}
bool OnHelp(User *u, const ci::string &subcommand)
{
if (u->Account() && u->Account()->IsServicesOper())
notice_help(Config.s_NickServ, u, NICK_SERVADMIN_HELP_ALIST);
else
notice_help(Config.s_NickServ, u, NICK_HELP_ALIST);
return true;
}
void OnServHelp(User *u)
{
notice_lang(Config.s_NickServ, u, NICK_HELP_CMD_ALIST);
}
};
class NSAList : public Module
{
public:
NSAList(const std::string &modname, const std::string &creator) : Module(modname, creator)
{
this->SetAuthor("Anope");
this->SetType(CORE);
this->AddCommand(NickServ, new CommandNSAList());
}
};
MODULE_INIT(NSAList)