fix: ignore late pings (#5457)

This commit is contained in:
nerix 2024-06-16 11:34:00 +02:00 committed by GitHub
parent 538bead45b
commit 86871eec5a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 28 additions and 1 deletions

View file

@ -16,6 +16,7 @@
- Bugfix: If a network request errors with 200 OK, Qt's error code is now reported instead of the HTTP status. (#5378) - Bugfix: If a network request errors with 200 OK, Qt's error code is now reported instead of the HTTP status. (#5378)
- Bugfix: Fixed restricted users usernames not being clickable. (#5405) - Bugfix: Fixed restricted users usernames not being clickable. (#5405)
- Bugfix: Fixed a crash that could occur when logging was enabled in IRC servers that were removed. (#5419) - Bugfix: Fixed a crash that could occur when logging was enabled in IRC servers that were removed. (#5419)
- Bugfix: Fixed message history occasionally not loading after a sleep. (#5457)
- Dev: Update Windows build from Qt 6.5.0 to Qt 6.7.1. (#5420) - Dev: Update Windows build from Qt 6.5.0 to Qt 6.7.1. (#5420)
- Dev: Update vcpkg build Qt from 6.5.0 to 6.7.0, boost from 1.83.0 to 1.85.0, openssl from 3.1.3 to 3.3.0. (#5422) - Dev: Update vcpkg build Qt from 6.5.0 to 6.7.0, boost from 1.83.0 to 1.85.0, openssl from 3.1.3 to 3.3.0. (#5422)
- Dev: Use Qt's high DPI scaling. (#4868, #5400) - Dev: Use Qt's high DPI scaling. (#4868, #5400)

View file

@ -3,6 +3,10 @@
#include "common/QLogging.hpp" #include "common/QLogging.hpp"
#include "common/Version.hpp" #include "common/Version.hpp"
#include <chrono>
using namespace std::chrono_literals;
namespace chatterino { namespace chatterino {
namespace { namespace {
@ -56,6 +60,7 @@ IrcConnection::IrcConnection(QObject *parent)
// Send ping every x seconds // Send ping every x seconds
this->pingTimer_.setInterval(5000); this->pingTimer_.setInterval(5000);
this->pingTimer_.start(); this->pingTimer_.start();
this->lastPing_ = std::chrono::system_clock::now();
QObject::connect(&this->pingTimer_, &QTimer::timeout, [this] { QObject::connect(&this->pingTimer_, &QTimer::timeout, [this] {
if (this->isConnected()) if (this->isConnected())
{ {
@ -64,7 +69,25 @@ IrcConnection::IrcConnection(QObject *parent)
// If we're still receiving messages, all is well // If we're still receiving messages, all is well
this->recentlyReceivedMessage_ = false; this->recentlyReceivedMessage_ = false;
this->waitingForPong_ = false; this->waitingForPong_ = false;
this->heartbeat.invoke();
// Check if we got invoked too late (e.g. due to a sleep)
auto now = std::chrono::system_clock::now();
auto elapsed = now - this->lastPing_;
if (elapsed < 3 * 5000ms)
{
this->heartbeat.invoke();
}
else
{
qCDebug(chatterinoIrc).nospace()
<< "Got late ping (skipping heartbeat): "
<< std::chrono::duration_cast<
std::chrono::milliseconds>(elapsed)
.count()
<< "ms";
}
this->lastPing_ = now;
return; return;
} }

View file

@ -6,6 +6,8 @@
#include <pajlada/signals/signal.hpp> #include <pajlada/signals/signal.hpp>
#include <QTimer> #include <QTimer>
#include <chrono>
namespace chatterino { namespace chatterino {
class IrcConnection : public Communi::IrcConnection class IrcConnection : public Communi::IrcConnection
@ -33,6 +35,7 @@ private:
QTimer pingTimer_; QTimer pingTimer_;
QTimer reconnectTimer_; QTimer reconnectTimer_;
std::atomic<bool> recentlyReceivedMessage_{true}; std::atomic<bool> recentlyReceivedMessage_{true};
std::chrono::time_point<std::chrono::system_clock> lastPing_;
// Reconnect with a base delay of 1 second and max out at 1 second * (2^(5-1)) (i.e. 16 seconds) // Reconnect with a base delay of 1 second and max out at 1 second * (2^(5-1)) (i.e. 16 seconds)
ExponentialBackoff<5> reconnectBackoff_{std::chrono::milliseconds{1000}}; ExponentialBackoff<5> reconnectBackoff_{std::chrono::milliseconds{1000}};