1 /***************************************************************************
2 * Copyright (C) 2005-2016 by the Quassel Project *
3 * devel@quassel-irc.org *
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. *
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. *
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 ***************************************************************************/
23 #include <QAbstractSocket>
24 #include <QDataStream>
27 #include "authhandler.h"
30 #include "signalproxy.h"
32 class Peer : public QObject
37 explicit Peer(AuthHandler *authHandler, QObject *parent = 0);
39 virtual Protocol::Type protocol() const = 0;
40 virtual QString description() const = 0;
42 virtual SignalProxy *signalProxy() const = 0;
43 virtual void setSignalProxy(SignalProxy *proxy) = 0;
45 QDateTime connectedSince() const;
46 void setConnectedSince(const QDateTime &connectedSince);
48 QString buildDate() const;
49 void setBuildDate(const QString &buildDate);
51 QString clientVersion() const;
52 void setClientVersion(const QString &clientVersion);
54 Quassel::Features features() const;
55 void setFeatures(Quassel::Features features);
60 AuthHandler *authHandler() const;
62 virtual bool isOpen() const = 0;
63 virtual bool isSecure() const = 0;
64 virtual bool isLocal() const = 0;
66 virtual int lag() const = 0;
68 virtual QString address() const = 0;
69 virtual quint16 port() const = 0;
72 /* Handshake messages */
73 virtual void dispatch(const Protocol::RegisterClient &) = 0;
74 virtual void dispatch(const Protocol::ClientDenied &) = 0;
75 virtual void dispatch(const Protocol::ClientRegistered &) = 0;
76 virtual void dispatch(const Protocol::SetupData &) = 0;
77 virtual void dispatch(const Protocol::SetupFailed &) = 0;
78 virtual void dispatch(const Protocol::SetupDone &) = 0;
79 virtual void dispatch(const Protocol::Login &) = 0;
80 virtual void dispatch(const Protocol::LoginFailed &) = 0;
81 virtual void dispatch(const Protocol::LoginSuccess &) = 0;
82 virtual void dispatch(const Protocol::SessionState &) = 0;
84 /* Sigproxy messages */
85 virtual void dispatch(const Protocol::SyncMessage &) = 0;
86 virtual void dispatch(const Protocol::RpcCall &) = 0;
87 virtual void dispatch(const Protocol::InitRequest &) = 0;
88 virtual void dispatch(const Protocol::InitData &) = 0;
90 virtual void close(const QString &reason = QString()) = 0;
94 void secureStateChanged(bool secure = true);
95 void lagUpdated(int msecs);
99 void handle(const T &protoMessage);
102 QPointer<AuthHandler> _authHandler;
104 QDateTime _connectedSince;
107 QString _clientVersion;
108 Quassel::Features _features;
113 // We need to special-case Peer* in attached signals/slots, so typedef it for the meta type system
114 typedef Peer * PeerPtr;
115 Q_DECLARE_METATYPE(PeerPtr)
117 QDataStream &operator<<(QDataStream &out, PeerPtr ptr);
118 QDataStream &operator>>(QDataStream &in, PeerPtr &ptr);
121 // Template method needed in the header
122 template<typename T> inline
123 void Peer::handle(const T &protoMessage)
125 switch(protoMessage.handler()) {
126 case Protocol::Handler::SignalProxy:
127 if (!signalProxy()) {
128 qWarning() << Q_FUNC_INFO << "Cannot handle message without a SignalProxy!";
131 signalProxy()->handle(this, protoMessage);
134 case Protocol::Handler::AuthHandler:
135 if (!authHandler()) {
136 qWarning() << Q_FUNC_INFO << "Cannot handle auth messages without an active AuthHandler!";
139 authHandler()->handle(protoMessage);
143 qWarning() << Q_FUNC_INFO << "Unknown handler for protocol message!";