X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcore%2Fsslserver.h;h=b0f92b587156b65a1654fe9441b342c87addc45b;hb=f8ebd4fd9a59bcb34a6ce45ce1f0b4a22beae884;hp=bd72f29b22a7dae850a39936715505fce3255f43;hpb=695758015a80eb8c158a9ac4c0f1c0b547e70df3;p=quassel.git diff --git a/src/core/sslserver.h b/src/core/sslserver.h index bd72f29b..b0f92b58 100644 --- a/src/core/sslserver.h +++ b/src/core/sslserver.h @@ -42,6 +42,16 @@ public: virtual inline const QSslKey &key() const { return _key; } virtual inline bool isCertValid() const { return _isCertValid; } + /** + * Reloads SSL certificates used for connections + * + * If this command fails, it will try to maintain the most recent working certificate. Error + * conditions are automatically written to the log. + * + * @return True if certificates reloaded successfully, otherwise false. + */ + bool reloadCerts(); + protected: #if QT_VERSION >= 0x050000 virtual void incomingConnection(qintptr socketDescriptor); @@ -49,14 +59,28 @@ protected: virtual void incomingConnection(int socketDescriptor); #endif - virtual bool setCertificate(const QString &path); + virtual bool setCertificate(const QString &path, const QString &keyPath); private: + /** + * Loads SSL certificates used for connections + * + * If this command fails, it will try to maintain the most recent working certificate. Will log + * specific failure points, but does not offer verbose guidance. + * + * @return True if certificates loaded successfully, otherwise false. + */ + bool loadCerts(); + QLinkedList _pendingConnections; QSslCertificate _cert; QSslKey _key; QList _ca; bool _isCertValid; + + // 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) };