summaryrefslogtreecommitdiff
path: root/modules/commands/ns_saset.cpp
diff options
context:
space:
mode:
authorAdam <Adam@anope.org>2011-08-05 05:35:31 -0400
committerAdam <Adam@anope.org>2011-08-05 05:35:31 -0400
commite66063e6304538d34c40460ca0aa2be5ddb6bdec (patch)
treef50fe31097160f8f794669809e4f4ef87f477672 /modules/commands/ns_saset.cpp
parent9ec18a3b020932eee6242c878149c484f49b13cb (diff)
Rewrote the example configurations and split them
up into seperate files for each pseudo client. Also reorganized how the modules are stored, and made most of the old "extra" modules "core"
Diffstat (limited to 'modules/commands/ns_saset.cpp')
-rw-r--r--modules/commands/ns_saset.cpp173
1 files changed, 173 insertions, 0 deletions
diff --git a/modules/commands/ns_saset.cpp b/modules/commands/ns_saset.cpp
new file mode 100644
index 000000000..a4aa2f422
--- /dev/null
+++ b/modules/commands/ns_saset.cpp
@@ -0,0 +1,173 @@
+/* NickServ 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 CommandNSSASet : public Command
+{
+ public:
+ CommandNSSASet(Module *creator) : Command(creator, "nickserv/saset", 2, 4)
+ {
+ this->SetDesc(_("Set SET-options on another nickname"));
+ this->SetSyntax(_("\037option\037 \037nickname\037 \037parameters\037"));
+ }
+
+ void Execute(CommandSource &source, const std::vector<Anope::string> &params)
+ {
+ this->OnSyntaxError(source, "");
+ return;
+ }
+
+ bool OnHelp(CommandSource &source, const Anope::string &subcommand)
+ {
+ this->SendSyntax(source);
+ source.Reply(_("Sets various nickname options. \037option\037 can be one of:"));
+ Anope::string this_name = source.command;
+ for (BotInfo::command_map::iterator it = source.owner->commands.begin(), it_end = source.owner->commands.end(); it != it_end; ++it)
+ {
+ const Anope::string &c_name = it->first;
+ CommandInfo &info = it->second;
+
+ if (c_name.find_ci(this_name + " ") == 0)
+ {
+ service_reference<Command> command(info.name);
+ if (command)
+ {
+ source.command = c_name;
+ command->OnServHelp(source);
+ }
+ }
+ }
+ source.Reply(_("Type \002%s%s HELP SASET \037option\037\002 for more information\n"
+ "on a specific option. The options will be set on the given\n"
+ "\037nickname\037."), Config->UseStrictPrivMsgString.c_str(), Config->NickServ.c_str());
+ return true;
+ }
+};
+
+class CommandNSSASetDisplay : public Command
+{
+ public:
+ CommandNSSASetDisplay(Module *creator) : Command(creator, "nickserv/saset/display", 2, 2)
+ {
+ this->SetDesc(_("Set the display of the group in Services"));
+ this->SetSyntax(_("\037nickname\037 \037new-display\037"));
+ }
+
+ void Execute(CommandSource &source, const std::vector<Anope::string> &params)
+ {
+ NickAlias *setter_na = findnick(params[0]);
+ if (setter_na == NULL)
+ {
+ source.Reply(NICK_X_NOT_REGISTERED, params[0].c_str());
+ return;
+ }
+ NickCore *nc = setter_na->nc;
+
+ NickAlias *na = findnick(params[1]);
+ if (!na || na->nc != nc)
+ {
+ source.Reply(_("The new display for \002%s\002 MUST be a nickname of the nickname group!"), nc->display.c_str());
+ return;
+ }
+
+ change_core_display(nc, params[1]);
+ source.Reply(NICK_SET_DISPLAY_CHANGED, nc->display.c_str());
+ return;
+ }
+
+ bool OnHelp(CommandSource &source, const Anope::string &)
+ {
+ this->SendSyntax(source);
+ source.Reply(_("Changes the display used to refer to the nickname group in \n"
+ "Services. The new display MUST be a nick of the group."));
+ return true;
+ }
+};
+
+class CommandNSSASetPassword : public Command
+{
+ public:
+ CommandNSSASetPassword(Module *creator) : Command(creator, "nickserv/saset/password", 2, 2)
+ {
+ this->SetDesc(_("Set the nickname password"));
+ this->SetSyntax(_("\037nickname\037 \037new-password\037"));
+ }
+
+ void Execute(CommandSource &source, const std::vector<Anope::string> &params)
+ {
+ User *u = source.u;
+ NickAlias *setter_na = findnick(params[0]);
+ if (setter_na == NULL)
+ {
+ source.Reply(NICK_X_NOT_REGISTERED, params[0].c_str());
+ return;
+ }
+ NickCore *nc = setter_na->nc;
+
+ size_t len = params[1].length();
+
+ if (Config->NSSecureAdmins && u->Account() != nc && nc->IsServicesOper())
+ {
+ source.Reply(ACCESS_DENIED);
+ return;
+ }
+ else if (nc->display.equals_ci(params[1]) || (Config->StrictPasswords && len < 5))
+ {
+ source.Reply(MORE_OBSCURE_PASSWORD);
+ return;
+ }
+ else if (len > Config->PassLen)
+ {
+ source.Reply(PASSWORD_TOO_LONG);
+ return;
+ }
+
+ enc_encrypt(params[1], nc->pass);
+ Anope::string tmp_pass;
+ if (enc_decrypt(nc->pass, tmp_pass) == 1)
+ source.Reply(_("Password for \002%s\002 changed to \002%s\002."), nc->display.c_str(), tmp_pass.c_str());
+ else
+ source.Reply(_("Password for \002%s\002 changed."), nc->display.c_str());
+
+ return;
+ }
+
+ bool OnHelp(CommandSource &source, const Anope::string &)
+ {
+ this->SendSyntax(source);
+ source.Reply(" ");
+ source.Reply(_("Changes the password used to identify as the nick's owner."));
+ return true;
+ }
+};
+
+class NSSASet : public Module
+{
+ CommandNSSASet commandnssaset;
+ CommandNSSASetDisplay commandnssasetdisplay;
+ CommandNSSASetPassword commandnssasetpassword;
+
+ public:
+ NSSASet(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, CORE),
+ commandnssaset(this), commandnssasetdisplay(this), commandnssasetpassword(this)
+ {
+ this->SetAuthor("Anope");
+
+ ModuleManager::RegisterService(&commandnssaset);
+ ModuleManager::RegisterService(&commandnssasetdisplay);
+ ModuleManager::RegisterService(&commandnssasetpassword);
+ }
+};
+
+MODULE_INIT(NSSASet)