From f858164deed48f2dcacd5ffc06a55398a54da7e8 Mon Sep 17 00:00:00 2001 From: Adam Date: Thu, 14 Jul 2011 02:31:12 -0400 Subject: Rewrote how commands are handled within Anope. This allows naming commands and having spaces within command names. --- modules/core/help.cpp | 120 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 120 insertions(+) create mode 100644 modules/core/help.cpp (limited to 'modules/core/help.cpp') diff --git a/modules/core/help.cpp b/modules/core/help.cpp new file mode 100644 index 000000000..8362b48d9 --- /dev/null +++ b/modules/core/help.cpp @@ -0,0 +1,120 @@ +/* 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 CommandHelp : public Command +{ + public: + CommandHelp(Module *creator) : Command(creator, "generic/help", 0) + { + this->SetDesc(_("Displays this list and give information about commands")); + this->SetFlag(CFLAG_STRIP_CHANNEL); + this->SetFlag(CFLAG_ALLOW_UNREGISTERED); + } + + void Execute(CommandSource &source, const std::vector ¶ms) + { + FOREACH_MOD(I_OnPreHelp, OnPreHelp(source, params)); + + User *u = source.u; + BotInfo *bi = source.owner; + + if (params.empty()) + { + for (command_map::iterator it = bi->commands.begin(), it_end = bi->commands.end(); it != it_end; ++it) + { + // Smaller command exists + Anope::string cmd = myStrGetToken(it->first, ' ', 0); + if (cmd != it->first && bi->commands.count(cmd)) + continue; + + service_reference c(it->second); + if (!c) + continue; + if (!Config->HidePrivilegedCommands || c->permission.empty() || u->HasCommand(c->permission)) + { + source.command = it->first; + c->OnServHelp(source); + } + } + } + else + { + bool helped = false; + for (unsigned max = params.size(); max > 0; --max) + { + Anope::string full_command; + for (unsigned i = 0; i < max; ++i) + full_command += " " + params[i]; + full_command.erase(full_command.begin()); + + std::map::iterator it = bi->commands.find(full_command); + if (it == bi->commands.end()) + continue; + + service_reference c(it->second); + if (!c) + continue; + + if (Config->HidePrivilegedCommands && !c->permission.empty() && !u->HasCommand(c->permission)) + continue; + + const Anope::string &subcommand = params.size() > max ? params[max] : ""; + source.command = full_command; + if (!c->OnHelp(source, subcommand)) + continue; + + helped = true; + source.Reply(" "); + + /* Inform the user what permission is required to use the command */ + if (!c->permission.empty()) + source.Reply(_("Access to this command requires the permission \002%s\002 to be present in your opertype."), c->permission.c_str()); + if (!c->HasFlag(CFLAG_ALLOW_UNREGISTERED) && !u->IsIdentified()) + source.Reply( _("You need to be identified to use this command.")); + /* User doesn't have the proper permission to use this command */ + else if (!c->permission.empty() && !u->HasCommand(c->permission)) + source.Reply(_("You cannot use this command.")); + /* User can use this command */ + else + source.Reply(_("You can use this command.")); + + break; + } + + if (helped == false) + source.Reply(_("No help available for \002%s\002."), params[0].c_str()); + } + + FOREACH_MOD(I_OnPostHelp, OnPostHelp(source, params)); + + return; + } +}; + +class Help : public Module +{ + CommandHelp commandhelp; + + public: + Help(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, CORE), + commandhelp(this) + { + this->SetAuthor("Anope"); + + ModuleManager::RegisterService(&commandhelp); + } +}; + +MODULE_INIT(Help) -- cgit