]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_spanningtree/protocolinterface.cpp
m_spanningtree Remove SpanningTreeUtilities* fields and parameters
[user/henk/code/inspircd.git] / src / modules / m_spanningtree / protocolinterface.cpp
index 93a1387580c909322bb2073df7d3fb74dbae9942..0f5c40cc10884269dd66646d5f78e292e5e602c3 100644 (file)
@@ -89,35 +89,25 @@ void SpanningTreeProtocolInterface::SendTopic(Channel* channel, std::string &top
        Utils->DoOneToMany(ServerInstance->Config->GetSID(),"FTOPIC", params);
 }
 
-void SpanningTreeProtocolInterface::SendMode(const std::string &target, const parameterlist &modedata, const std::vector<TranslateType> &translate)
+void SpanningTreeProtocolInterface::SendMode(User* source, User* u, Channel* c, 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);
+       parameterlist params;
 
-       User* a = ServerInstance->FindNick(uidtarget);
-       if (a)
+       if (u)
        {
-               Utils->DoOneToMany(ServerInstance->Config->GetSID(),"MODE",outlist);
-               return;
+               if (u->registered != REG_ALL)
+                       return;
+
+               params.push_back(u->uuid);
+               params.insert(params.end(), modedata.begin(), modedata.end());
+               Utils->DoOneToMany(source->uuid, "MODE", params);
        }
        else
        {
-               Channel* c = ServerInstance->FindChan(target);
-               if (c)
-               {
-                       outlist.insert(outlist.begin() + 1, ConvToStr(c->age));
-                       Utils->DoOneToMany(ServerInstance->Config->GetSID(),"FMODE",outlist);
-               }
+               params.push_back(c->name);
+               params.push_back(ConvToStr(c->age));
+               params.push_back(CommandParser::TranslateUIDs(translate, modedata));
+               Utils->DoOneToMany(source->uuid, "FMODE", params);
        }
 }