X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcoreauthhandler.h;h=21a2c512a33043372bd29f3b8b7336b03839709a;hp=85580c93289fcde61a06f3362b1ae8ce47825e1e;hb=c0d6dc0dec628f2e143e37ecc95cec45e636f8a5;hpb=64cf9f9b8a737dad5f29447805d4004cfd03c454 diff --git a/src/core/coreauthhandler.h b/src/core/coreauthhandler.h index 85580c93..21a2c512 100644 --- a/src/core/coreauthhandler.h +++ b/src/core/coreauthhandler.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2013 by the Quassel Project * + * Copyright (C) 2005-2020 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -18,10 +18,12 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ -#ifndef COREAUTHHANDLER_H -#define COREAUTHHANDLER_H +#pragma once #include "authhandler.h" +#include "metricsserver.h" +#include "peerfactory.h" +#include "proxyline.h" #include "remotepeer.h" #include "types.h" @@ -30,33 +32,44 @@ class CoreAuthHandler : public AuthHandler Q_OBJECT public: - CoreAuthHandler(QTcpSocket *socket, QObject *parent = 0); + CoreAuthHandler(QSslSocket* socket, QObject* parent = nullptr); + + QHostAddress hostAddress() const; + bool isLocal() const override; signals: - void handshakeComplete(RemotePeer *peer, UserId uid); + void handshakeComplete(RemotePeer* peer, UserId uid); private: using AuthHandler::handle; - void handle(const Protocol::RegisterClient &msg); - void handle(const Protocol::SetupData &msg); - void handle(const Protocol::Login &msg); + void handle(const Protocol::RegisterClient& msg) override; + void handle(const Protocol::SetupData& msg) override; + void handle(const Protocol::Login& msg) override; + + void setPeer(RemotePeer* peer); + void startSsl(); bool checkClientRegistered(); private slots: - void startSsl(); -#ifdef HAVE_SSL + void onReadyRead(); + void onSslErrors(); -#endif - // only in compat mode + // only in legacy mode void onProtocolVersionMismatch(int actual, int expected); private: - RemotePeer *_peer; + RemotePeer* _peer; + MetricsServer* _metricsServer; + bool _proxyReceived; + ProxyLine _proxyLine; + bool _useProxyLine; + bool _magicReceived; + bool _legacy; bool _clientRegistered; + quint8 _connectionFeatures; + QVector _supportedProtos; }; - -#endif