cmake: avoid de-duplication of user's CXXFLAGS
[quassel.git] / src / core / sslserver.h
index 6ca1b91..4997daa 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-2018 by the Quassel Project                        *
+ *   Copyright (C) 2005-2022 by the Quassel Project                        *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
 
 #pragma once
 
-#ifdef HAVE_SSL
-
+#include <QFile>
 #include <QSslCertificate>
 #include <QSslKey>
 #include <QTcpServer>
-#include <QLinkedList>
-#include <QFile>
+
+#include "metricsserver.h"
 
 class SslServer : public QTcpServer
 {
     Q_OBJECT
 
 public:
-    SslServer(QObject *parent = nullptr);
-
-    bool hasPendingConnections() const override { return !_pendingConnections.isEmpty(); }
-    QTcpSocket *nextPendingConnection() override;
+    SslServer(QObject* parent = nullptr);
 
-    const QSslCertificate &certificate() const { return _cert; }
-    const QSslKey &key() const { return _key; }
+    const QSslCertificatecertificate() const { return _cert; }
+    const QSslKeykey() const { return _key; }
     bool isCertValid() const { return _isCertValid; }
 
     /**
@@ -52,10 +48,12 @@ public:
      */
     bool reloadCerts();
 
+    void setMetricsServer(MetricsServer* metricsServer);
+
 protected:
     void incomingConnection(qintptr socketDescriptor) override;
 
-    bool setCertificate(const QString &path, const QString &keyPath);
+    bool setCertificate(const QString& path, const QString& keyPath);
 
 private:
     /**
@@ -67,18 +65,18 @@ private:
      * @return True if certificates loaded successfully, otherwise false.
      */
     bool loadCerts();
-    QSslKey loadKey(QFile *keyFile);
+    QSslKey loadKey(QFile* keyFile);
+
+    MetricsServer* _metricsServer{nullptr};
 
-    QLinkedList<QTcpSocket *> _pendingConnections;
     QSslCertificate _cert;
     QSslKey _key;
     QList<QSslCertificate> _ca;
     bool _isCertValid{false};
 
     // Used when reloading certificates later
-    QString _sslCertPath; /// Path to the certificate file
-    QString _sslKeyPath;  /// Path to the private key file (may be in same file as above)
-};
+    QString _sslCertPath;  /// Path to the certificate file
+    QString _sslKeyPath;   /// Path to the private key file (may be in same file as above)
 
-
-#endif //HAVE_SSL
+    QDateTime _certificateExpires;
+};