]> git.netwichtig.de Git - user/henk/code/inspircd.git/blob - src/modules/m_spanningtree/pong.cpp
Merge pull request #590 from SaberUK/master+module-logging
[user/henk/code/inspircd.git] / src / modules / m_spanningtree / pong.cpp
1 /*
2  * InspIRCd -- Internet Relay Chat Daemon
3  *
4  *   Copyright (C) 2008 Robin Burchell <robin+git@viroteck.net>
5  *
6  * This file is part of InspIRCd.  InspIRCd is free software: you can
7  * redistribute it and/or modify it under the terms of the GNU General Public
8  * License as published by the Free Software Foundation, version 2.
9  *
10  * This program is distributed in the hope that it will be useful, but WITHOUT
11  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12  * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
13  * details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
17  */
18
19
20 #include "inspircd.h"
21
22 #include "utils.h"
23 #include "treeserver.h"
24 #include "treesocket.h"
25
26 /* $ModDep: m_spanningtree/main.h m_spanningtree/utils.h m_spanningtree/treeserver.h m_spanningtree/treesocket.h */
27
28 bool TreeSocket::LocalPong(const std::string &prefix, parameterlist &params)
29 {
30         if (params.size() < 1)
31                 return true;
32
33         const std::string& forwardto = params[0];
34         if (forwardto == ServerInstance->Config->GetSID())
35         {
36                 // PONG for us
37                 TreeServer* ServerSource = Utils->FindServer(prefix);
38                 if (ServerSource)
39                 {
40                         long ts = ServerInstance->Time() * 1000 + (ServerInstance->Time_ns() / 1000000);
41                         ServerSource->rtt = ts - ServerSource->LastPingMsec;
42                         ServerSource->SetPingFlag();
43                 }
44         }
45         else
46         {
47                 // not for us, pass it on :)
48                 Utils->DoOneToOne(prefix,"PONG",params,forwardto);
49         }
50         return true;
51 }
52