summaryrefslogtreecommitdiff
path: root/modules/core/cs_set_xop.cpp
diff options
context:
space:
mode:
authorAdam <Adam@anope.org>2011-08-01 22:37:27 -0400
committerAdam <Adam@anope.org>2011-08-01 22:37:27 -0400
commitf7adc0b35b50f06706872a161f1c7476e6e6981e (patch)
tree91fbe281f2772136a327fd4fc4c64740d1ab65ab /modules/core/cs_set_xop.cpp
parent710c02f3bd3581b7c5b3d48e7604756975219fc8 (diff)
Rewrote the access systems and added a flags access system
Diffstat (limited to 'modules/core/cs_set_xop.cpp')
-rw-r--r--modules/core/cs_set_xop.cpp146
1 files changed, 0 insertions, 146 deletions
diff --git a/modules/core/cs_set_xop.cpp b/modules/core/cs_set_xop.cpp
deleted file mode 100644
index 00b945fe2..000000000
--- a/modules/core/cs_set_xop.cpp
+++ /dev/null
@@ -1,146 +0,0 @@
-/* ChanServ 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"
-
-#define CHECKLEV(lev) (ci->levels[(lev)] != ACCESS_INVALID && access->level >= ci->levels[(lev)])
-
-class CommandCSSetXOP : public Command
-{
- public:
- CommandCSSetXOP(Module *creator, const Anope::string &cname = "chanserv/set/xop", const Anope::string &cpermission = "") : Command(creator, cname, 2, 2, cpermission)
- {
- this->SetDesc(_("Toggle the user privilege system"));
- this->SetSyntax(_("\037channel\037 {ON | OFF}"));
- }
-
- void Execute(CommandSource &source, const std::vector<Anope::string> &params)
- {
- User *u = source.u;
-
- if (!ModuleManager::FindModule("cs_xop"))
- {
- source.Reply(_("xOP system is not available."));
- return;
- }
-
- ChannelInfo *ci = cs_findchan(params[0]);
- if (ci == NULL)
- {
- source.Reply(CHAN_X_NOT_REGISTERED, params[0].c_str());
- return;
- }
-
- if (!this->permission.empty() && !check_access(u, ci, CA_SET))
- {
- source.Reply(ACCESS_DENIED);
- return;
- }
-
- if (params[1].equals_ci("ON"))
- {
- if (!ci->HasFlag(CI_XOP))
- {
- ChanAccess *access;
-
- for (unsigned i = ci->GetAccessCount(); i > 0; --i)
- {
- access = ci->GetAccess(i - 1);
-
- /* This will probably cause wrong levels to be set, but hey,
- * it's better than losing it altogether.
- */
- if (access->level == ACCESS_QOP)
- access->level = ACCESS_QOP;
- else if (CHECKLEV(CA_AKICK) || CHECKLEV(CA_SET))
- access->level = ACCESS_SOP;
- else if (CHECKLEV(CA_AUTOOP) || CHECKLEV(CA_OPDEOP) || CHECKLEV(CA_OPDEOPME))
- access->level = ACCESS_AOP;
- else if (ModeManager::FindChannelModeByName(CMODE_HALFOP) && (CHECKLEV(CA_AUTOHALFOP) || CHECKLEV(CA_HALFOP) || CHECKLEV(CA_HALFOPME)))
- access->level = ACCESS_HOP;
- else if (CHECKLEV(CA_AUTOVOICE) || CHECKLEV(CA_VOICE) || CHECKLEV(CA_VOICEME))
- access->level = ACCESS_VOP;
- else
- ci->EraseAccess(i - 1);
- }
-
- reset_levels(ci);
- ci->SetFlag(CI_XOP);
- }
-
- Log(LOG_COMMAND, u, this, ci) << "to enable XOP";
- source.Reply(_("xOP lists system for %s is now \002on\002."), ci->name.c_str());
- }
- else if (params[1].equals_ci("OFF"))
- {
- ci->UnsetFlag(CI_XOP);
-
- Log(LOG_COMMAND, u, this, ci) << "to disable XOP";
- source.Reply(_("xOP lists system for %s is now \002off\002."), ci->name.c_str());
- }
- else
- this->OnSyntaxError(source, "XOP");
-
- return;
- }
-
- bool OnHelp(CommandSource &source, const Anope::string &)
- {
- this->SendSyntax(source);
- source.Reply(" ");
- source.Reply(_("Enables or disables the xOP lists system for a channel.\n"
- "When \002XOP\002 is set, you have to use the \002AOP\002/\002SOP\002/\002VOP\002\n"
- "commands in order to give channel privileges to\n"
- "users, else you have to use the \002ACCESS\002 command.\n"
- " \n"
- "\002Technical Note\002: when you switch from access list to xOP \n"
- "lists system, your level definitions and user levels will be\n"
- "changed, so you won't find the same values if you\n"
- "switch back to access system! \n"
- " \n"
- "You should also check that your users are in the good xOP \n"
- "list after the switch from access to xOP lists, because the \n"
- "guess is not always perfect... in fact, it is not recommended \n"
- "to use the xOP lists if you changed level definitions with \n"
- "the \002LEVELS\002 command.\n"
- " \n"
- "Switching from xOP lists system to access list system\n"
- "causes no problem though."));
- return true;
- }
-};
-
-class CommandCSSASetXOP : public CommandCSSetXOP
-{
- public:
- CommandCSSASetXOP(Module *creator) : CommandCSSetXOP(creator, "chanserv/saset/xop", "chanserv/saset/xop")
- {
- }
-};
-
-class CSSetXOP : public Module
-{
- CommandCSSetXOP commandcssetxop;
- CommandCSSASetXOP commandcssasetxop;
-
- public:
- CSSetXOP(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, CORE),
- commandcssetxop(this), commandcssasetxop(this)
- {
- this->SetAuthor("Anope");
-
- ModuleManager::RegisterService(&commandcssetxop);
- ModuleManager::RegisterService(&commandcssasetxop);
- }
-};
-
-MODULE_INIT(CSSetXOP)