]> git.netwichtig.de Git - user/henk/code/inspircd.git/commitdiff
The rest of the server protocol interface and fix a warning in m_rline
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>
Fri, 4 Apr 2008 12:49:42 +0000 (12:49 +0000)
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>
Fri, 4 Apr 2008 12:49:42 +0000 (12:49 +0000)
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@9299 e03df62e-2008-0410-955e-edbf42e46eb7

include/protocol.h
src/modules/extra/m_rline.cpp
src/modules/m_spanningtree/protocolinterface.cpp
src/modules/m_spanningtree/protocolinterface.h

index 65369e781ea48fb815f9daaf507bdc1d2fb2ccc1..21e6b53965b8b2fe4449efdcae0bce6ac6299eca 100644 (file)
@@ -29,7 +29,7 @@ class ProtocolInterface : public Extensible
        virtual void SendEncapsulatedData(parameterlist &encap) { }
        virtual void SendMetaData(void* target, int type, const std::string &key, const std::string &data) { }
        virtual void SendTopic(Channel* channel, std::string &topic) { }
-       virtual void SendMode(const std::string &origin, const std::string &target, parameterlist &modedata) { }
+       virtual void SendMode(const std::string &target, parameterlist &modedata) { }
        virtual void SendOperNotice(const std::string &text) { }
        virtual void SendModeNotice(const std::string &modes, const std::string &text) { }
        virtual void SendSNONotice(const std::string &snomask, const std::string &text) { }
index 545757f592432908f8e8371d2af75e11fa18cbe6..88e40811bb878a267ad571d44862bcb76c34d510 100644 (file)
@@ -224,12 +224,12 @@ class ModuleRLine : public Module
        virtual void OnUserConnect(User* user)
        {
                // Apply lines on user connect
-               XLine *r = ServerInstance->XLines->MatchesLine("R", user);
+               XLine *rl = ServerInstance->XLines->MatchesLine("R", user);
 
-               if (r)
+               if (rl)
                {
                        // Bang. :P
-                       r->Apply(user);
+                       rl->Apply(user);
                }
        }
 };
index cf774d603e12f5ef73e30b922879da665aae302a..bbdca23054da334f8376baaa06a4971197827000 100644 (file)
@@ -42,23 +42,64 @@ 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, parameterlist &modedata)
 {
+       if (modedata.empty())
+               return;
+
+       /* Warning: in-place translation is only safe for type TR_NICK */
+       for (size_t n = 0; n < modedata.size(); n++)
+               ServerInstance->Parser->TranslateUIDs(TR_NICK, modedata[n], modedata[n]);
+
+       std::string uidtarget;
+       ServerInstance->Parser->TranslateUIDs(TR_NICK, target, uidtarget);
+       modedata.insert(modedata.begin(), uidtarget);
+
+       User* a = ServerInstance->FindNick(uidtarget);
+       if (a)
+       {
+               Utils->DoOneToMany(ServerInstance->Config->GetSID(),"MODE",modedata);
+               return;
+       }
+       else
+       {
+               Channel* c = ServerInstance->FindChan(target);
+               if (c)
+               {
+                       modedata.insert(modedata.begin() + 1, ConvToStr(c->age));
+                       Utils->DoOneToMany(ServerInstance->Config->GetSID(),"FMODE",modedata);
+               }
+       }
 }
 
 void SpanningTreeProtocolInterface::SendOperNotice(const std::string &text)
 {
+       parameterlist p;
+       p.push_back(":" + text);
+       Utils->DoOneToMany(ServerInstance->Config->GetSID(), "OPERNOTICE", p);
 }
 
 void SpanningTreeProtocolInterface::SendModeNotice(const std::string &modes, const std::string &text)
 {
+       parameterlist p;
+       p.push_back(modes);
+       p.push_back(":" + text);
+       Utils->DoOneToMany(ServerInstance->Config->GetSID(), "MODENOTICE", p);
 }
 
 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::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);
 }
 
index 568f334636dad271133d7bf83c80108b47e5c475..754e1bf6fb8888e1d6ce0ce5ca85d417a996401a 100644 (file)
@@ -16,7 +16,7 @@ class SpanningTreeProtocolInterface : public ProtocolInterface
         virtual void SendEncapsulatedData(parameterlist &encap);
         virtual void SendMetaData(void* target, int type, const std::string &key, const std::string &data);
         virtual void SendTopic(Channel* channel, std::string &topic);
-        virtual void SendMode(const std::string &origin, const std::string &target, parameterlist &modedata);
+        virtual void SendMode(const std::string &target, parameterlist &modedata);
         virtual void SendOperNotice(const std::string &text);
         virtual void SendModeNotice(const std::string &modes, const std::string &text);
         virtual void SendSNONotice(const std::string &snomask, const std::string &text);