diff options
Diffstat (limited to 'modules/commands/help.cpp')
-rw-r--r-- | modules/commands/help.cpp | 130 |
1 files changed, 130 insertions, 0 deletions
diff --git a/modules/commands/help.cpp b/modules/commands/help.cpp new file mode 100644 index 000000000..2a4f25b6c --- /dev/null +++ b/modules/commands/help.cpp @@ -0,0 +1,130 @@ +/* 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<Anope::string> ¶ms) + { + FOREACH_MOD(I_OnPreHelp, OnPreHelp(source, params)); + + User *u = source.u; + BotInfo *bi = source.owner; + + if (params.empty()) + { + for (BotInfo::command_map::iterator it = bi->commands.begin(), it_end = bi->commands.end(); it != it_end; ++it) + { + const Anope::string &c_name = it->first; + CommandInfo &info = it->second; + + // Smaller command exists + Anope::string cmd = myStrGetToken(c_name, ' ', 0); + if (cmd != it->first && bi->commands.count(cmd)) + continue; + + service_reference<Command> c(info.name); + if (!c) + continue; + if (!Config->HidePrivilegedCommands || info.permission.empty() || u->HasCommand(info.permission)) + { + source.command = c_name; + 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()); + + BotInfo::command_map::iterator it = bi->commands.find(full_command); + if (it == bi->commands.end()) + continue; + + CommandInfo &info = it->second; + + service_reference<Command> c(info.name); + if (!c) + continue; + + if (Config->HidePrivilegedCommands && !info.permission.empty() && !u->HasCommand(info.permission)) + continue; + + const Anope::string &subcommand = params.size() > max ? params[max] : ""; + source.command = full_command; + if (!c->OnHelp(source, subcommand)) + continue; + + helped = true; + + /* Inform the user what permission is required to use the command */ + if (!info.permission.empty()) + { + source.Reply(" "); + source.Reply(_("Access to this command requires the permission \002%s\002 to be present in your opertype."), info.permission.c_str()); + } + if (!c->HasFlag(CFLAG_ALLOW_UNREGISTERED) && !u->IsIdentified()) + { + if (info.permission.empty()) + source.Reply(" "); + source.Reply( _("You need to be identified to use this command.")); + } + /* User doesn't have the proper permission to use this command */ + else if (!info.permission.empty() && !u->HasCommand(info.permission)) + { + source.Reply(_("You cannot 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) |