blob: 99c06eb5163e8a83b23c3995b99e8904fa1c4bf1 (
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
124
125
|
/***************************************************************************
* 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 BTSERVER_H
#define BTSERVER_H
#include <qptrlist.h>
#include <qobject.h>
#include "globals.h"
namespace bt
{
class PeerManager;
class ServerAuthenticate;
class SHA1Hash;
class ServerSocket;
/**
* @author Joris Guisson
*
* Class which listens for incoming connections.
* Handles authentication and then hands of the new
* connections to a PeerManager.
*
* All PeerManager's should register with this class when they
* are created and should unregister when they are destroyed.
*/
class Server : public QObject
{
Q_OBJECT
QPtrList<PeerManager> peer_managers;
ServerSocket* sock;
Uint16 port;
bool encryption;
bool allow_unencrypted;
public:
Server(Uint16 port);
virtual ~Server();
/// Check if everything is ok (are we successfully listening on the port)
bool isOK() const;
/**
* Change the port.
* @param port The new port
*/
void changePort(Uint16 port);
/// Get the port in use
Uint16 getPortInUse() const;
/**
* Add a PeerManager.
* @param pman The PeerManager
*/
void addPeerManager(PeerManager* pman);
/**
* Remove a PeerManager.
* @param pman The PeerManager
*/
void removePeerManager(PeerManager* pman);
/**
* Find the PeerManager given the info_hash of it's torrent.
* @param hash The info_hash
* @return The PeerManager or 0 if one can't be found
*/
PeerManager* findPeerManager(const SHA1Hash & hash);
/**
* Find the info_hash based on the skey hash. The skey hash is a hash
* of 'req2' followed by the info_hash. This function finds the info_hash
* which matches the skey hash.
* @param skey HASH('req2',info_hash)
* @param info_hash which matches
* @return true If one was found
*/
bool findInfoHash(const SHA1Hash & skey,SHA1Hash & info_hash);
/**
* Enable encryption.
* @param allow_unencrypted Allow unencrypted connections (if encryption fails)
*/
void enableEncryption(bool allow_unencrypted);
/**
* Disable encrypted authentication.
*/
void disableEncryption();
bool isEncryptionEnabled() const {return encryption;}
bool unencryptedConnectionsAllowed() const {return allow_unencrypted;}
void close();
private slots:
void newConnection(int sock);
void onError(int);
private:
friend class ServerSocket;
};
}
#endif
|