From 29ca6bbd3488aa8ffa574bd61dfeea412c970cbf Mon Sep 17 00:00:00 2001 From: Kelly Kinkade Date: Sun, 19 Nov 2023 06:59:04 -0600 Subject: [PATCH] RemoteServer: reset fail counter after success should close #4040 --- library/RemoteServer.cpp | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/library/RemoteServer.cpp b/library/RemoteServer.cpp index 72f2a29b53..58a6f52ba9 100644 --- a/library/RemoteServer.cpp +++ b/library/RemoteServer.cpp @@ -80,7 +80,7 @@ namespace { struct BlockedException : std::exception { const char* what() const noexcept override { - return "Core has blocked all connection. This should have been catched."; + return "Core has blocked all connection. This should have been caught."; } }; } @@ -478,23 +478,26 @@ void ServerMainImpl::threadFn(std::promise promise, int port) CActiveSocket *client = nullptr; try { - for (int acceptFail = 0 ; server.socket.IsSocketValid() && acceptFail < 5 ; acceptFail++) + for (int acceptFail = 0; server.socket.IsSocketValid() && acceptFail < 5; acceptFail++) { if ((client = server.socket.Accept()) != NULL) { BlockGuard lock; ServerConnection::Accepted(client); client = nullptr; + acceptFail = 0; } else { WARN(socket).print("Connection failure: %s (%d of %d)\n", server.socket.DescribeError(), acceptFail + 1, 5); } } - } catch(BlockedException &) { + } + catch (BlockedException&) { if (client) client->Close(); delete client; + WARN(socket).print("Connection failure: unexpectedly blocked"); } if (server.socket.IsSocketValid())