summaryrefslogtreecommitdiff
path: root/modules/commands/cs_fantasy_top.cpp
diff options
context:
space:
mode:
authorAdam <Adam@anope.org>2013-07-29 12:02:40 +0000
committerAdam <Adam@anope.org>2013-07-29 12:02:40 +0000
commit402c624e455d13cc811bef2e8d1639846e892a34 (patch)
treeb6fd03ba6620167cb1365cd6739c651cfaf03b36 /modules/commands/cs_fantasy_top.cpp
parentfde83f6564c38635c7bfebd7edb60f30b012189c (diff)
Move chanstats stuff to stats/
Diffstat (limited to 'modules/commands/cs_fantasy_top.cpp')
-rw-r--r--modules/commands/cs_fantasy_top.cpp195
1 files changed, 0 insertions, 195 deletions
diff --git a/modules/commands/cs_fantasy_top.cpp b/modules/commands/cs_fantasy_top.cpp
deleted file mode 100644
index bc08c4c9d..000000000
--- a/modules/commands/cs_fantasy_top.cpp
+++ /dev/null
@@ -1,195 +0,0 @@
-/* Chanstats core functions
- *
- * (C) 2003-2013 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"
-#include "modules/sql.h"
-
-class MySQLInterface : public SQL::Interface
-{
- public:
- MySQLInterface(Module *o) : SQL::Interface(o) { }
-
- void OnResult(const SQL::Result &r) anope_override
- {
- }
-
- void OnError(const SQL::Result &r) anope_override
- {
- if (!r.GetQuery().query.empty())
- Log(LOG_DEBUG) << "Chanstats: Error executing query " << r.finished_query << ": " << r.GetError();
- else
- Log(LOG_DEBUG) << "Chanstats: Error executing query: " << r.GetError();
- }
-};
-
-class CommandCSTop : public Command
-{
- public:
- CommandCSTop(Module *creator) : Command (creator, "chanserv/top", 0, 2)
- {
- this->SetDesc(_("Displays the top 3 users of a channel"));
- this->SetSyntax(_("\037channel\037"));
- }
-
- void Execute(CommandSource &source, const std::vector<Anope::string> &params);
-};
-
-class CommandCSTop10 : public Command
-{
- public:
- CommandCSTop10(Module *creator) : Command (creator, "chanserv/top10", 0, 2)
- {
- this->SetDesc(_("Displays the top 10 users of a channel"));
- this->SetSyntax(_("\037channel\037"));
- }
-
- void Execute(CommandSource &source, const std::vector<Anope::string> &params);
-};
-
-class CommandCSGTop : public Command
-{
- public:
- CommandCSGTop(Module *creator) : Command (creator, "chanserv/gtop", 0, 1)
- {
- this->SetDesc(_("Displays the top 3 users of the network"));
- }
-
- void Execute(CommandSource &source, const std::vector<Anope::string> &params);
-};
-
-class CommandCSGTop10 : public Command
-{
- public:
- CommandCSGTop10(Module *creator) : Command (creator, "chanserv/gtop10", 0, 1)
- {
- this->SetDesc(_("Displays the top 10 users of the network"));
- }
-
- void Execute(CommandSource &source, const std::vector<Anope::string> &params);
-};
-
-
-class CSTop;
-static CSTop *me;
-class CSTop : public Module
-{
- CommandCSTop commandcstop;
- CommandCSGTop commandcsgtop;
- CommandCSTop10 commandcstop10;
- CommandCSGTop10 commandcsgtop10;
- ServiceReference<SQL::Provider> sql;
- MySQLInterface sqlinterface;
- Anope::string prefix;
-
- public:
- CSTop(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, VENDOR),
- commandcstop(this), commandcsgtop(this), commandcstop10(this), commandcsgtop10(this), sql("", ""),
- sqlinterface(this)
- {
- me = this;
-
- }
-
- void OnReload(Configuration::Conf *conf) anope_override
- {
- prefix = conf->GetModule(this)->Get<const Anope::string>("prefix");
- if (prefix.empty())
- prefix = "anope_";
- this->sql = ServiceReference<SQL::Provider>("SQL::Provider", conf->GetModule(this)->Get<const Anope::string>("engine"));
- }
-
- SQL::Result RunQuery(const SQL::Query &query)
- {
- if (!this->sql)
- throw SQL::Exception("Unable to locate SQL reference, is m_mysql loaded and configured correctly?");
-
- SQL::Result res = sql->RunQuery(query);
- if (!res.GetError().empty())
- throw SQL::Exception(res.GetError());
- return res;
- }
-
- void DoTop(CommandSource &source, const std::vector<Anope::string> &params, bool is_global, int limit = 1)
- {
- if (!source.c || !source.c->ci)
- return;
-
- Anope::string channel;
- if (is_global || params.empty())
- channel = source.c->ci->name;
- else if (!params.empty())
- channel = params[0];
- else
- {
- source.Reply(_("%s not found."), params[0].c_str());
- return;
- }
-
- try
- {
- SQL::Query query;
- query = "SELECT nick, letters, words, line, actions,"
- "smileys_happy+smileys_sad+smileys_other as smileys "
- "FROM `" + prefix + "chanstats` "
- "WHERE `nick` != '' AND `chan` = @channel@ AND `type` = 'total' "
- "ORDER BY `letters` DESC LIMIT @limit@;";
- query.SetValue("limit", limit, false);
-
- if (is_global)
- query.SetValue("channel", "");
- else
- query.SetValue("channel", channel.c_str());
-
- SQL::Result res = this->RunQuery(query);
-
- if (res.Rows() > 0)
- {
- source.Reply(_("Top %i of %s"), limit, (is_global ? "Network" : channel.c_str()));
- for (int i = 0; i < res.Rows(); ++i)
- {
- source.Reply(_("%2lu \002%-16s\002 letters: %s, words: %s, lines: %s, smileys %s, actions: %s"),
- i+1, res.Get(i, "nick").c_str(), res.Get(i, "letters").c_str(),
- res.Get(i, "words").c_str(), res.Get(i, "line").c_str(),
- res.Get(0, "smileys").c_str(), res.Get(0, "actions").c_str());
- }
- }
- else
- source.Reply(_("No stats for %s."), is_global ? "Network" : channel.c_str());
- }
- catch (const SQL::Exception &ex)
- {
- Log(LOG_DEBUG) << ex.GetReason();
- }
- }
-};
-
-void CommandCSTop::Execute(CommandSource &source, const std::vector<Anope::string> &params)
-{
- me->DoTop(source, params, false, 3);
-}
-
-void CommandCSTop10::Execute(CommandSource &source, const std::vector<Anope::string> &params)
-{
- me->DoTop(source, params, false, 10);
-}
-
-void CommandCSGTop::Execute(CommandSource &source, const std::vector<Anope::string> &params)
-{
- me->DoTop(source, params, true, 3);
-}
-
-void CommandCSGTop10::Execute(CommandSource &source, const std::vector<Anope::string> &params)
-{
- me->DoTop(source, params, true, 10);
-}
-
-
-MODULE_INIT(CSTop)