diff options
author | Adam <Adam@anope.org> | 2010-06-19 11:54:08 -0400 |
---|---|---|
committer | Adam <Adam@anope.org> | 2010-06-19 11:54:08 -0400 |
commit | 52058fe87b4b0475b1775198c725af14e540d355 (patch) | |
tree | c3597d6411a006ffbb670d2ce761101b9640e9b6 /src/core/ns_status.cpp | |
parent | 43e951aed54f838ba55a4c1552214773aee2fb2f (diff) | |
parent | df9d291bcba9788e51d11424ebaf6f05c26cc80f (diff) |
Merge remote branch 'origin/1.9.3' into 1.9
Diffstat (limited to 'src/core/ns_status.cpp')
-rw-r--r-- | src/core/ns_status.cpp | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/src/core/ns_status.cpp b/src/core/ns_status.cpp new file mode 100644 index 000000000..9695dd4fd --- /dev/null +++ b/src/core/ns_status.cpp @@ -0,0 +1,79 @@ +/* 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 CommandNSStatus : public Command +{ + public: + CommandNSStatus() : Command("STATUS", 0, 16) + { + this->SetFlag(CFLAG_ALLOW_UNREGISTERED); + } + + CommandReturn Execute(User *u, const std::vector<ci::string> ¶ms) + { + User *u2; + NickAlias *na = NULL; + std::string nick = params.size() ? params[0].c_str() : u->nick; + spacesepstream sep(nick); + std::string nickbuf; + + while (sep.GetToken(nickbuf)) + { + na = findnick(nick); + + if (!(u2 = finduser(nickbuf))) /* Nick is not online */ + notice_lang(Config.s_NickServ, u, NICK_STATUS_REPLY, nickbuf.c_str(), 0, ""); + else if (u2->IsIdentified() && na && na->nc == u2->Account()) /* Nick is identified */ + notice_lang(Config.s_NickServ, u, NICK_STATUS_REPLY, nickbuf.c_str(), 3, u2->Account()->display); + else if (u2->IsRecognized()) /* Nick is recognised, but NOT identified */ + notice_lang(Config.s_NickServ, u, NICK_STATUS_REPLY, nickbuf.c_str(), 2, (u2->Account() ? u2->Account()->display : "")); + else if (!na) /* Nick is online, but NOT a registered */ + notice_lang(Config.s_NickServ, u, NICK_STATUS_REPLY, nickbuf.c_str(), 0, ""); + else + /* Nick is not identified for the nick, but they could be logged into an account, + * so we tell the user about it + */ + notice_lang(Config.s_NickServ, u, NICK_STATUS_REPLY, nickbuf.c_str(), 1, (u2->Account() ? u2->Account()->display : "")); + } + return MOD_CONT; + } + + bool OnHelp(User *u, const ci::string &subcommand) + { + notice_help(Config.s_NickServ, u, NICK_HELP_STATUS); + return true; + } + + void OnServHelp(User *u) + { + notice_lang(Config.s_NickServ, u, NICK_HELP_CMD_STATUS); + } +}; + +class NSStatus : public Module +{ + public: + NSStatus(const std::string &modname, const std::string &creator) : Module(modname, creator) + { + this->SetAuthor("Anope"); + this->SetVersion(VERSION_STRING); + this->SetType(CORE); + + this->AddCommand(NickServ, new CommandNSStatus()); + } +}; + +MODULE_INIT(NSStatus) |