anope- supernets anope source code & configuration |
git clone git://git.acid.vegas/anope.git |
Log | Files | Refs | Archive | README |
drop.cpp (1870B)
1 /* 2 * (C) 2003-2022 Anope Team 3 * Contact us at team@anope.org 4 * 5 * Please read COPYING and README for further details. 6 */ 7 8 #include "../../webcpanel.h" 9 #include "utils.h" 10 11 WebCPanel::ChanServ::Drop::Drop(const Anope::string &cat, const Anope::string &u) : WebPanelProtectedPage (cat, u) 12 { 13 } 14 15 16 bool WebCPanel::ChanServ::Drop::OnRequest(HTTPProvider *server, const Anope::string &page_name, HTTPClient *client, HTTPMessage &message, HTTPReply &reply, NickAlias *na, TemplateFileServer::Replacements &replacements) 17 { 18 19 if (message.post_data.count("channel") > 0 && message.post_data.count("confChan") > 0) 20 { 21 if (message.post_data["channel"] == message.post_data["confChan"]) 22 { 23 std::vector<Anope::string> params; 24 const Anope::string &channel = HTTPUtils::URLDecode(message.post_data["channel"]); 25 params.push_back(channel); 26 params.push_back(channel); 27 28 WebPanel::RunCommand(client, na->nc->display, na->nc, "ChanServ", "chanserv/drop", params, replacements); 29 } 30 else 31 replacements["MESSAGES"] = "Invalid Confirmation"; 32 } 33 34 std::deque<ChannelInfo *> queue; 35 na->nc->GetChannelReferences(queue); 36 for (unsigned i = 0; i < queue.size(); ++i) 37 { 38 ChannelInfo *ci = queue[i]; 39 if ((ci->HasExt("SECUREFOUNDER") ? ci->AccessFor(na->nc).founder : ci->AccessFor(na->nc).HasPriv("FOUNDER")) || (na->nc->IsServicesOper() && na->nc->o->ot->HasCommand("chanserv/drop"))) 40 { 41 replacements["CHANNEL_NAMES"] = ci->name; 42 replacements["ESCAPED_CHANNEL_NAMES"] = HTTPUtils::URLEncode(ci->name); 43 } 44 } 45 46 if (message.get_data.count("channel") > 0) 47 { 48 const Anope::string &chname = message.get_data["channel"]; 49 50 replacements["CHANNEL_DROP"] = chname; 51 replacements["ESCAPED_CHANNEL"] = HTTPUtils::URLEncode(chname); 52 } 53 54 TemplateFileServer page("chanserv/drop.html"); 55 page.Serve(server, page_name, client, message, reply, replacements); 56 return true; 57 58 }