diff options
author | Adam <Adam@anope.org> | 2010-07-15 22:55:02 -0400 |
---|---|---|
committer | Adam <Adam@anope.org> | 2010-07-15 22:55:02 -0400 |
commit | a22f8d3b2de88b9bb6f80f0c2780846ae23ab389 (patch) | |
tree | a2fdf570868896a787df8a1169951b0028e68d6b /modules/core/ns_help.cpp | |
parent | 43b1e43afb85639485e36d24da351dc0f121be6e (diff) |
Moved some files and diretories around, made cmake skip files it knows it can't compile because of missing dependices.
Diffstat (limited to 'modules/core/ns_help.cpp')
-rw-r--r-- | modules/core/ns_help.cpp | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/modules/core/ns_help.cpp b/modules/core/ns_help.cpp new file mode 100644 index 000000000..d23cbd208 --- /dev/null +++ b/modules/core/ns_help.cpp @@ -0,0 +1,67 @@ +/* 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 CommandNSHelp : public Command +{ + public: + CommandNSHelp() : Command("HELP", 1, 1) + { + this->SetFlag(CFLAG_ALLOW_UNREGISTERED); + } + + CommandReturn Execute(User *u, const std::vector<ci::string> ¶ms) + { + ci::string cmd = params[0]; + + if (cmd == "SET LANGUAGE") + { + int i; + notice_help(Config.s_NickServ, u, NICK_HELP_SET_LANGUAGE); + for (i = 0; i < NUM_LANGS && langlist[i] >= 0; ++i) + u->SendMessage(Config.s_NickServ, " %2d) %s", i + 1, langnames[langlist[i]]); + } + else + mod_help_cmd(NickServ, u, cmd.c_str()); + + return MOD_CONT; + } + + void OnSyntaxError(User *u, const ci::string &subcommand) + { + notice_help(Config.s_NickServ, u, NICK_HELP); + for (CommandMap::const_iterator it = NickServ->Commands.begin(), it_end = NickServ->Commands.end(); it != it_end; ++it) + if (!Config.HidePrivilegedCommands || it->second->permission.empty() || (u->Account() && u->Account()->HasCommand(it->second->permission))) + it->second->OnServHelp(u); + if (u->Account() && u->Account()->IsServicesOper()) + notice_help(Config.s_NickServ, u, NICK_SERVADMIN_HELP); + if (Config.NSExpire >= 86400) + notice_help(Config.s_NickServ, u, NICK_HELP_EXPIRES, Config.NSExpire / 86400); + notice_help(Config.s_NickServ, u, NICK_HELP_FOOTER); + } +}; + +class NSHelp : public Module +{ + public: + NSHelp(const std::string &modname, const std::string &creator) : Module(modname, creator) + { + this->SetAuthor("Anope"); + this->SetType(CORE); + + this->AddCommand(NickServ, new CommandNSHelp()); + } +}; + +MODULE_INIT(NSHelp) |