]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_spanningtree/protocolinterface.cpp
Move MODENOTICE command to a command module
[user/henk/code/inspircd.git] / src / modules / m_spanningtree / protocolinterface.cpp
index cf774d603e12f5ef73e30b922879da665aae302a..843361e9e43d7043b55cdbddb8d118efe169dfe3 100644 (file)
@@ -1,29 +1,49 @@
 #include "inspircd.h"
-#include "m_spanningtree/main.h"
-#include "m_spanningtree/utils.h"
-#include "m_spanningtree/protocolinterface.h"
+#include "main.h"
+#include "utils.h"
+#include "treeserver.h"
+#include "treesocket.h"
+#include "protocolinterface.h"
+
+/*
+ * For documentation on this class, see include/protocol.h.
+ */
+
+void SpanningTreeProtocolInterface::GetServerList(ProtoServerList &sl)
+{
+       sl.clear();
+       for (server_hash::iterator i = Utils->serverlist.begin(); i != Utils->serverlist.end(); i++)
+       {
+               ProtoServer ps;
+               ps.servername = i->second->GetName();
+               TreeServer* s = i->second->GetParent();
+               ps.parentname = s ? s->GetName() : "";
+               ps.usercount = i->second->GetUserCount();
+               ps.opercount = i->second->GetOperCount();
+               ps.gecos = i->second->GetDesc();
+               ps.latencyms = i->second->rtt;
+               sl.push_back(ps);
+       }
+}
 
 void SpanningTreeProtocolInterface::SendEncapsulatedData(parameterlist &encap)
 {
        Utils->DoOneToMany(ServerInstance->Config->GetSID(), "ENCAP", encap);
 }
 
-void SpanningTreeProtocolInterface::SendMetaData(void* target, int type, const std::string &key, const std::string &data)
+void SpanningTreeProtocolInterface::SendMetaData(Extensible* target, const std::string &key, const std::string &data)
 {
        parameterlist params;
 
-       switch (type)
-       {
-               case TYPE_USER:
-                       params.push_back(((User*)target)->uuid);
-               break;
-               case TYPE_CHANNEL:
-                       params.push_back(((Channel*)target)->name);
-               break;
-               case TYPE_SERVER:
-                       params.push_back(ServerInstance->Config->GetSID());
-               break;
-       }
+       User* u = dynamic_cast<User*>(target);
+       Channel* c = dynamic_cast<Channel*>(target);
+       if (u)
+               params.push_back(u->uuid);
+       else if (c)
+               params.push_back(c->name);
+       else
+               params.push_back("*");
+
        params.push_back(key);
        params.push_back(":" + data);
 
@@ -42,23 +62,103 @@ void SpanningTreeProtocolInterface::SendTopic(Channel* channel, std::string &top
        Utils->DoOneToMany(ServerInstance->Config->GetSID(),"FTOPIC", params);
 }
 
-void SpanningTreeProtocolInterface::SendMode(const std::string &origin, const std::string &target, parameterlist &modedata)
+void SpanningTreeProtocolInterface::SendMode(const std::string &target, const parameterlist &modedata, const std::vector<TranslateType> &translate)
+{
+       if (modedata.empty())
+               return;
+
+       std::string outdata;
+       ServerInstance->Parser->TranslateUIDs(translate, modedata, outdata);
+
+       std::string uidtarget;
+       ServerInstance->Parser->TranslateUIDs(TR_NICK, target, uidtarget);
+
+       parameterlist outlist;
+       outlist.push_back(uidtarget);
+       outlist.push_back(outdata);
+
+       User* a = ServerInstance->FindNick(uidtarget);
+       if (a)
+       {
+               Utils->DoOneToMany(ServerInstance->Config->GetSID(),"MODE",outlist);
+               return;
+       }
+       else
+       {
+               Channel* c = ServerInstance->FindChan(target);
+               if (c)
+               {
+                       outlist.insert(outlist.begin() + 1, ConvToStr(c->age));
+                       Utils->DoOneToMany(ServerInstance->Config->GetSID(),"FMODE",outlist);
+               }
+       }
+}
+
+void SpanningTreeProtocolInterface::SendSNONotice(const std::string &snomask, const std::string &text)
 {
+       parameterlist p;
+       p.push_back(snomask);
+       p.push_back(":" + text);
+       Utils->DoOneToMany(ServerInstance->Config->GetSID(), "SNONOTICE", p);
 }
 
-void SpanningTreeProtocolInterface::SendOperNotice(const std::string &text)
+void SpanningTreeProtocolInterface::PushToClient(User* target, const std::string &rawline)
 {
+       parameterlist p;
+       p.push_back(target->uuid);
+       p.push_back(":" + rawline);
+       Utils->DoOneToOne(ServerInstance->Config->GetSID(), "PUSH", p, target->server);
 }
 
-void SpanningTreeProtocolInterface::SendModeNotice(const std::string &modes, const std::string &text)
+void SpanningTreeProtocolInterface::SendChannel(Channel* target, char status, const std::string &text)
 {
+       std::string cname = target->name;
+       if (status)
+               cname = status + cname;
+       TreeServerList list;
+       CUList exempt_list;
+       Utils->GetListOfServersForChannel(target,list,status,exempt_list);
+       for (TreeServerList::iterator i = list.begin(); i != list.end(); i++)
+       {
+               TreeSocket* Sock = i->second->GetSocket();
+               if (Sock)
+                       Sock->WriteLine(text);
+       }
 }
 
-void SpanningTreeProtocolInterface::SendSNONotice(const std::string &snomask, const std::string &text)
+
+void SpanningTreeProtocolInterface::SendChannelPrivmsg(Channel* target, char status, const std::string &text)
 {
+       SendChannel(target, status, ":" + ServerInstance->Config->GetSID()+" PRIVMSG "+target->name+" :"+text);
 }
 
-void SpanningTreeProtocolInterface::PushToClient(User* target, const std::string &rawline)
+void SpanningTreeProtocolInterface::SendChannelNotice(Channel* target, char status, const std::string &text)
 {
+       SendChannel(target, status, ":" + ServerInstance->Config->GetSID()+" NOTICE "+target->name+" :"+text);
 }
 
+void SpanningTreeProtocolInterface::SendUserPrivmsg(User* target, const std::string &text)
+{
+       TreeServer* serv = Utils->FindServer(target->server);
+       if (serv)
+       {
+               TreeSocket* sock = serv->GetSocket();
+               if (sock)
+               {
+                       sock->WriteLine(":" + ServerInstance->Config->GetSID() + " PRIVMSG " + target->nick + " :"+text);
+               }
+       }
+}
+
+void SpanningTreeProtocolInterface::SendUserNotice(User* target, const std::string &text)
+{
+       TreeServer* serv = Utils->FindServer(target->server);
+       if (serv)
+       {
+               TreeSocket* sock = serv->GetSocket();
+               if (sock)
+               {
+                       sock->WriteLine(":" + ServerInstance->Config->GetSID() + " NOTICE " + target->nick + " :"+text);
+               }
+       }
+}