summaryrefslogtreecommitdiff
path: root/modules/webcpanel/pages/chanserv/akick.cpp
diff options
context:
space:
mode:
authorAdam <Adam@anope.org>2014-01-02 11:02:14 -0500
committerAdam <Adam@anope.org>2014-01-02 11:03:33 -0500
commit004c4cbe5f4c37cf455cb6d0caa434fbbb3406ea (patch)
tree0e6675dfe28a829f5786b0b2f993566c61662de7 /modules/webcpanel/pages/chanserv/akick.cpp
parent072202c181943901c727782e64881adadf13d7dd (diff)
Move modules out of extras that dont have external dependencies
Diffstat (limited to 'modules/webcpanel/pages/chanserv/akick.cpp')
-rw-r--r--modules/webcpanel/pages/chanserv/akick.cpp94
1 files changed, 94 insertions, 0 deletions
diff --git a/modules/webcpanel/pages/chanserv/akick.cpp b/modules/webcpanel/pages/chanserv/akick.cpp
new file mode 100644
index 000000000..bff38910c
--- /dev/null
+++ b/modules/webcpanel/pages/chanserv/akick.cpp
@@ -0,0 +1,94 @@
+/*
+ * (C) 2003-2014 Anope Team
+ * Contact us at team@anope.org
+ *
+ * Please read COPYING and README for further details.
+ */
+
+#include "../../webcpanel.h"
+#include "utils.h"
+
+WebCPanel::ChanServ::Akick::Akick(const Anope::string &cat, const Anope::string &u) : WebPanelProtectedPage(cat, u)
+{
+}
+
+bool WebCPanel::ChanServ::Akick::OnRequest(HTTPProvider *server, const Anope::string &page_name, HTTPClient *client, HTTPMessage &message, HTTPReply &reply, NickAlias *na, TemplateFileServer::Replacements &replacements)
+{
+ const Anope::string &chname = message.get_data["channel"];
+ TemplateFileServer Page("chanserv/akick.html");
+
+ BuildChanList(na, replacements);
+
+ if (chname.empty())
+ {
+ Page.Serve(server, page_name, client, message, reply, replacements);
+ return true;
+ }
+
+ ChannelInfo *ci = ChannelInfo::Find(chname);
+
+ if (!ci)
+ {
+ replacements["MESSAGES"] = "Channel not registered";
+ Page.Serve(server, page_name, client, message, reply, replacements);
+ return true;
+ }
+
+ AccessGroup u_access = ci->AccessFor(na->nc);
+ bool has_priv = na->nc->IsServicesOper() && na->nc->o->ot->HasPriv("chanserv/access/modify");
+
+ if (!u_access.HasPriv("AKICK") && !has_priv)
+ {
+ replacements["MESSAGES"] = "Permission denied.";
+ Page.Serve(server, page_name, client, message, reply, replacements);
+ return true;
+ }
+
+ replacements["AKICK"] = "YES";
+
+ if (message.get_data["del"].empty() == false && message.get_data["mask"].empty() == false)
+ {
+ std::vector<Anope::string> params;
+ params.push_back(ci->name);
+ params.push_back("DEL");
+ params.push_back(message.get_data["mask"]);
+
+ WebPanel::RunCommand(na->nc->display, na->nc, "ChanServ", "chanserv/akick", params, replacements);
+ }
+ else if (message.post_data["mask"].empty() == false)
+ {
+ std::vector<Anope::string> params;
+ params.push_back(ci->name);
+ params.push_back("ADD");
+ params.push_back(message.post_data["mask"]);
+ if (message.post_data["reason"].empty() == false)
+ params.push_back(message.post_data["reason"]);
+
+ WebPanel::RunCommand(na->nc->display, na->nc, "ChanServ", "chanserv/akick", params, replacements);
+ }
+
+ replacements["ESCAPED_CHANNEL"] = HTTPUtils::URLEncode(chname);
+
+ for (unsigned i = 0; i < ci->GetAkickCount(); ++i)
+ {
+ AutoKick *akick = ci->GetAkick(i);
+
+ if (akick->nc)
+ replacements["MASKS"] = HTTPUtils::Escape(akick->nc->display);
+ else
+ replacements["MASKS"] = HTTPUtils::Escape(akick->mask);
+ replacements["CREATORS"] = HTTPUtils::Escape(akick->creator);
+ replacements["REASONS"] = HTTPUtils::Escape(akick->reason);
+ }
+
+ Page.Serve(server, page_name, client, message, reply, replacements);
+ return true;
+}
+
+std::set<Anope::string> WebCPanel::ChanServ::Akick::GetData()
+{
+ std::set<Anope::string> v;
+ v.insert("channel");
+ return v;
+}
+