summaryrefslogtreecommitdiffstats
path: root/libktorrent/kademlia/rpcserver.h
blob: 387daee15c5ea8ee84777c93280f7f787e78292f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/***************************************************************************
 *   Copyright (C) 2005 by Joris Guisson                                   *
 *   joris.guisson@gmail.com                                               *
 *                                                                         *
 *   This program is free software; you can redistribute it and/or modify  *
 *   it under the terms of the GNU General Public License as published by  *
 *   the Free Software Foundation; either version 2 of the License, or     *
 *   (at your option) any later version.                                   *
 *                                                                         *
 *   This program is distributed in the hope that it will be useful,       *
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
 *   GNU General Public License for more details.                          *
 *                                                                         *
 *   You should have received a copy of the GNU General Public License     *
 *   along with this program; if not, write to the                         *
 *   Free Software Foundation, Inc.,                                       *
 *   51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.             *
 ***************************************************************************/
#ifndef DHTRPCSERVER_H
#define DHTRPCSERVER_H

#include <tqptrlist.h>
#include <kdatagramsocket.h>
#include <util/constants.h>
#include <util/array.h>
#include <util/ptrmap.h>


using KNetwork::KDatagramSocket;
using bt::Uint32;
using bt::Uint16;
using bt::Uint8;

namespace bt
{
	class BDictNode;
}

namespace dht
{
	class Key;
	class KBucketEntry;
	class RPCCall;
	class RPCMsg;
	class Node;
	class DHT;
	class MsgBase;

	/**
	 * @author Joris Guisson
	 *
	 * Class to handle incoming and outgoing RPC messages.
	 */
	class RPCServer : public TQObject
	{
		Q_OBJECT
  
	public:
		RPCServer(DHT* dh_table,Uint16 port,TQObject *parent = 0);
		virtual ~RPCServer();
		
		/// Start the server
		void start();
		
		/// Stop the server
		void stop();
		
		/**
		 * Do a RPC call.
		 * @param msg The message to send
		 * @return The call object
		 */
		RPCCall* doCall(MsgBase* msg);
		
		/**
		 * Send a message, this only sends the message, it does not keep any call
		 * information. This should be used for replies.
		 * @param msg The message to send
		 */
		void sendMsg(MsgBase* msg);
		
		
		/**
		 * A call was timed out.
		 * @param mtid mtid of call
		 */
		void timedOut(Uint8 mtid);
		
		/**
		 * Ping a node, we don't care about the MTID.
		 * @param addr The address
		 */
		void ping(const dht::Key & our_id,const KNetwork::KSocketAddress & addr);
		
		/**
		 * Find a RPC call, based on the mtid
		 * @param mtid The mtid
		 * @return The call
		 */
		const RPCCall* findCall(Uint8 mtid) const;
		
		/// Get the number of active calls
		Uint32 getNumActiveRPCCalls() const {return calls.count();}
	private slots:
		void readPacket();
		
	private:
		void send(const KNetwork::KSocketAddress & addr,const TQByteArray & msg);
		void doQueuedCalls();
			
	private:
		KDatagramSocket* sock;
		DHT* dh_table;
		bt::PtrMap<bt::Uint8,RPCCall> calls;
		TQPtrList<RPCCall> call_queue;
		bt::Uint8 next_mtid;
		bt::Uint16 port;
	};

}

#endif