1/***************************************************************************
2 * Copyright (C) 2005-2014 by the Quassel Project *
3 * devel@quassel-irc.org *
4 * *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) version 3. *
9 * *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
14 * *
15 * You should have received a copy of the GNU General Public License *
16 * along with this program; if not, write to the *
17 * Free Software Foundation, Inc., *
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
19 ***************************************************************************/
20
21#include "peerfactory.h"
22
23#include "protocols/datastream/datastreampeer.h"
24#include "protocols/legacy/legacypeer.h"
25
26
27PeerFactory::ProtoList PeerFactory::supportedProtocols()
28{
29 ProtoList result;
30 result.append(ProtoDescriptor(Protocol::DataStreamProtocol, DataStreamPeer::supportedFeatures()));
31 result.append(ProtoDescriptor(Protocol::LegacyProtocol, 0));
32 return result;
33}
34
35
36RemotePeer *PeerFactory::createPeer(const ProtoDescriptor &protocol, AuthHandler *authHandler, QTcpSocket *socket, Compressor::CompressionLevel level, QObject *parent)
37{
38 return createPeer(ProtoList() << protocol, authHandler, socket, level, parent);
39}
40
41
42RemotePeer *PeerFactory::createPeer(const ProtoList &protocols, AuthHandler *authHandler, QTcpSocket *socket, Compressor::CompressionLevel level, QObject *parent)
43{
44 foreach(const ProtoDescriptor &protodesc, protocols) {
45 Protocol::Type proto = protodesc.first;
46 quint16 features = protodesc.second;
47 switch(proto) {
48 case Protocol::LegacyProtocol:
49 return new LegacyPeer(authHandler, socket, level, parent);
50 case Protocol::DataStreamProtocol:
51 if (DataStreamPeer::acceptsFeatures(features))
52 return new DataStreamPeer(authHandler, socket, features, level, parent);
53 break;
54 default:
55 break;
56 }
57 }
58
59 return 0;
60}
61