summaryrefslogtreecommitdiff
path: root/src/modules/m_clones.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/modules/m_clones.cpp')
-rw-r--r--src/modules/m_clones.cpp68
1 files changed, 46 insertions, 22 deletions
diff --git a/src/modules/m_clones.cpp b/src/modules/m_clones.cpp
index 68c9639c2..06956c564 100644
--- a/src/modules/m_clones.cpp
+++ b/src/modules/m_clones.cpp
@@ -20,43 +20,64 @@
#include "inspircd.h"
+#include "modules/ircv3_batch.h"
-/** Handle /CLONES
- */
-class CommandClones : public Command
+enum
+{
+ // InspIRCd-specific.
+ RPL_CLONES = 399
+};
+
+class CommandClones : public SplitCommand
{
+ private:
+ IRCv3::Batch::API batchmanager;
+ IRCv3::Batch::Batch batch;
+
public:
- CommandClones(Module* Creator) : Command(Creator,"CLONES", 1)
+ CommandClones(Module* Creator)
+ : SplitCommand(Creator,"CLONES", 1)
+ , batchmanager(Creator)
+ , batch("inspircd.org/clones")
{
- flags_needed = 'o'; syntax = "<limit>";
+ flags_needed = 'o';
+ syntax = "<limit>";
}
- CmdResult Handle(User* user, const Params& parameters) CXX11_OVERRIDE
+ CmdResult HandleLocal(LocalUser* user, const Params& parameters) CXX11_OVERRIDE
{
+ unsigned int limit = ConvToNum<unsigned int>(parameters[0]);
- std::string clonesstr = "CLONES ";
-
- unsigned long limit = strtoul(parameters[0].c_str(), NULL, 10);
-
- /*
- * Syntax of a /clones reply:
- * :server.name 304 target :CLONES START
- * :server.name 304 target :CLONES <count> <ip>
- * :server.name 304 target :CLONES END
- */
+ // Syntax of a CLONES reply:
+ // :irc.example.com BATCH +<id> inspircd.org/clones :<min-count>
+ // @batch=<id> :irc.example.com 399 <client> <local-count> <remote-count> <cidr-mask>
+ /// :irc.example.com BATCH :-<id>
- user->WriteNumeric(304, clonesstr + "START");
+ if (batchmanager)
+ {
+ batchmanager->Start(batch);
+ batch.GetBatchStartMessage().PushParam(ConvToStr(limit));
+ }
- /* hostname or other */
const UserManager::CloneMap& clonemap = ServerInstance->Users->GetCloneMap();
for (UserManager::CloneMap::const_iterator i = clonemap.begin(); i != clonemap.end(); ++i)
{
const UserManager::CloneCounts& counts = i->second;
- if (counts.global >= limit)
- user->WriteNumeric(304, clonesstr + ConvToStr(counts.global) + " " + i->first.str());
+ if (counts.global < limit)
+ continue;
+
+ Numeric::Numeric numeric(RPL_CLONES);
+ numeric.push(counts.local);
+ numeric.push(counts.global);
+ numeric.push(i->first.str());
+
+ ClientProtocol::Messages::Numeric numericmsg(numeric, user);
+ batch.AddToBatch(numericmsg);
+ user->Send(ServerInstance->GetRFCEvents().numeric, numericmsg);
}
- user->WriteNumeric(304, clonesstr + "END");
+ if (batchmanager)
+ batchmanager->End(batch);
return CMD_SUCCESS;
}
@@ -64,9 +85,12 @@ class CommandClones : public Command
class ModuleClones : public Module
{
+ public:
CommandClones cmd;
+
public:
- ModuleClones() : cmd(this)
+ ModuleClones()
+ : cmd(this)
{
}