1
0
mirror of https://github.com/anope/anope.git synced 2026-06-24 21:46:37 +02:00
Files
anope/modules/core/ms_info.cpp
T
2010-10-11 15:37:39 -04:00

218 lines
6.2 KiB
C++

/* MemoServ 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 CommandMSInfo : public Command
{
public:
CommandMSInfo() : Command("INFO", 0, 1)
{
}
CommandReturn Execute(User *u, const std::vector<Anope::string> &params)
{
const MemoInfo *mi;
NickAlias *na = NULL;
ChannelInfo *ci = NULL;
Anope::string nname = !params.empty() ? params[0] : "";
int hardmax = 0;
if (!nname.empty() && nname[0] != '#' && u->Account()->HasPriv("memoserv/info"))
{
na = findnick(nname);
if (!na)
{
u->SendMessage(MemoServ, NICK_X_NOT_REGISTERED, nname.c_str());
return MOD_CONT;
}
else if (na->HasFlag(NS_FORBIDDEN))
{
u->SendMessage(MemoServ, NICK_X_FORBIDDEN, nname.c_str());
return MOD_CONT;
}
mi = &na->nc->memos;
hardmax = na->nc->HasFlag(NI_MEMO_HARDMAX) ? 1 : 0;
}
else if (!nname.empty() && nname[0] == '#')
{
if (!(ci = cs_findchan(nname)))
{
u->SendMessage(MemoServ, CHAN_X_NOT_REGISTERED, nname.c_str());
return MOD_CONT;
}
else if (!check_access(u, ci, CA_MEMO))
{
u->SendMessage(MemoServ, ACCESS_DENIED);
return MOD_CONT;
}
mi = &ci->memos;
hardmax = ci->HasFlag(CI_MEMO_HARDMAX) ? 1 : 0;
}
else if (!nname.empty()) /* It's not a chan and we aren't services admin */
{
u->SendMessage(MemoServ, ACCESS_DENIED);
return MOD_CONT;
}
else
{
mi = &u->Account()->memos;
hardmax = u->Account()->HasFlag(NI_MEMO_HARDMAX) ? 1 : 0;
}
if (!nname.empty() && (ci || na->nc != u->Account()))
{
if (mi->memos.empty())
u->SendMessage(MemoServ, MEMO_INFO_X_NO_MEMOS, nname.c_str());
else if (mi->memos.size() == 1)
{
if (mi->memos[0]->HasFlag(MF_UNREAD))
u->SendMessage(MemoServ, MEMO_INFO_X_MEMO_UNREAD, nname.c_str());
else
u->SendMessage(MemoServ, MEMO_INFO_X_MEMO, nname.c_str());
}
else
{
unsigned count = 0, i, end;
for (i = 0, end = mi->memos.size(); i < end; ++i)
if (mi->memos[i]->HasFlag(MF_UNREAD))
++count;
if (count == mi->memos.size())
u->SendMessage(MemoServ, MEMO_INFO_X_MEMOS_ALL_UNREAD, nname.c_str(), count);
else if (!count)
u->SendMessage(MemoServ, MEMO_INFO_X_MEMOS, nname.c_str(), mi->memos.size());
else if (count == 1)
u->SendMessage(MemoServ, MEMO_INFO_X_MEMOS_ONE_UNREAD, nname.c_str(), mi->memos.size());
else
u->SendMessage(MemoServ, MEMO_INFO_X_MEMOS_SOME_UNREAD, nname.c_str(), mi->memos.size(), count);
}
if (!mi->memomax)
{
if (hardmax)
u->SendMessage(MemoServ, MEMO_INFO_X_HARD_LIMIT, nname.c_str(), mi->memomax);
else
u->SendMessage(MemoServ, MEMO_INFO_X_LIMIT, nname.c_str(), mi->memomax);
}
else if (mi->memomax > 0)
{
if (hardmax)
u->SendMessage(MemoServ, MEMO_INFO_X_HARD_LIMIT, nname.c_str(), mi->memomax);
else
u->SendMessage(MemoServ, MEMO_INFO_X_LIMIT, nname.c_str(), mi->memomax);
}
else
u->SendMessage(MemoServ, MEMO_INFO_X_NO_LIMIT, nname.c_str());
/* I ripped this code out of ircservices 4.4.5, since I didn't want
to rewrite the whole thing (it pisses me off). */
if (na)
{
if (na->nc->HasFlag(NI_MEMO_RECEIVE) && na->nc->HasFlag(NI_MEMO_SIGNON))
u->SendMessage(MemoServ, MEMO_INFO_X_NOTIFY_ON, nname.c_str());
else if (na->nc->HasFlag(NI_MEMO_RECEIVE))
u->SendMessage(MemoServ, MEMO_INFO_X_NOTIFY_RECEIVE, nname.c_str());
else if (na->nc->HasFlag(NI_MEMO_SIGNON))
u->SendMessage(MemoServ, MEMO_INFO_X_NOTIFY_SIGNON, nname.c_str());
else
u->SendMessage(MemoServ, MEMO_INFO_X_NOTIFY_OFF, nname.c_str());
}
}
else /* !nname || (!ci || na->nc == u->Account()) */
{
if (mi->memos.empty())
u->SendMessage(MemoServ, MEMO_INFO_NO_MEMOS);
else if (mi->memos.size() == 1)
{
if (mi->memos[0]->HasFlag(MF_UNREAD))
u->SendMessage(MemoServ, MEMO_INFO_MEMO_UNREAD);
else
u->SendMessage(MemoServ, MEMO_INFO_MEMO);
}
else
{
unsigned count = 0, i, end;
for (i = 0, end = mi->memos.size(); i < end; ++i)
if (mi->memos[i]->HasFlag(MF_UNREAD))
++count;
if (count == mi->memos.size())
u->SendMessage(MemoServ, MEMO_INFO_MEMOS_ALL_UNREAD, count);
else if (!count)
u->SendMessage(MemoServ, MEMO_INFO_MEMOS, mi->memos.size());
else if (count == 1)
u->SendMessage(MemoServ, MEMO_INFO_MEMOS_ONE_UNREAD, mi->memos.size());
else
u->SendMessage(MemoServ, MEMO_INFO_MEMOS_SOME_UNREAD, mi->memos.size(), count);
}
if (!mi->memomax)
{
if (!u->Account()->IsServicesOper() && hardmax)
u->SendMessage(MemoServ, MEMO_INFO_HARD_LIMIT_ZERO);
else
u->SendMessage(MemoServ, MEMO_INFO_LIMIT_ZERO);
}
else if (mi->memomax > 0)
{
if (!u->Account()->IsServicesOper() && hardmax)
u->SendMessage(MemoServ, MEMO_INFO_HARD_LIMIT, mi->memomax);
else
u->SendMessage(MemoServ, MEMO_INFO_LIMIT, mi->memomax);
}
else
u->SendMessage(MemoServ, MEMO_INFO_NO_LIMIT);
/* Ripped too. But differently because of a seg fault (loughs) */
if (u->Account()->HasFlag(NI_MEMO_RECEIVE) && u->Account()->HasFlag(NI_MEMO_SIGNON))
u->SendMessage(MemoServ, MEMO_INFO_NOTIFY_ON);
else if (u->Account()->HasFlag(NI_MEMO_RECEIVE))
u->SendMessage(MemoServ, MEMO_INFO_NOTIFY_RECEIVE);
else if (u->Account()->HasFlag(NI_MEMO_SIGNON))
u->SendMessage(MemoServ, MEMO_INFO_NOTIFY_SIGNON);
else
u->SendMessage(MemoServ, MEMO_INFO_NOTIFY_OFF);
}
return MOD_CONT;
}
bool OnHelp(User *u, const Anope::string &subcommand)
{
if (u->Account() && u->Account()->IsServicesOper())
u->SendMessage(MemoServ, MEMO_SERVADMIN_HELP_INFO);
else
u->SendMessage(MemoServ, MEMO_HELP_INFO);
return true;
}
void OnServHelp(User *u)
{
u->SendMessage(MemoServ, MEMO_HELP_CMD_INFO);
}
};
class MSInfo : public Module
{
CommandMSInfo commandmsinfo;
public:
MSInfo(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator)
{
this->SetAuthor("Anope");
this->SetType(CORE);
this->AddCommand(MemoServ, &commandmsinfo);
}
};
MODULE_INIT(MSInfo)