From 621c6abfe61ee420da0b7866d2e90360aeb4c4f4 Mon Sep 17 00:00:00 2001 From: syeopite Date: Thu, 14 Nov 2024 16:59:17 -0800 Subject: [PATCH] Release client only when it still exists @pool.release should not be called when the client has already been deleted from the pool. --- src/invidious/connection/pool.cr | 31 +++++++++++++++++++++---------- 1 file changed, 21 insertions(+), 10 deletions(-) diff --git a/src/invidious/connection/pool.cr b/src/invidious/connection/pool.cr index 5e527187..a0ddfa70 100644 --- a/src/invidious/connection/pool.cr +++ b/src/invidious/connection/pool.cr @@ -51,21 +51,32 @@ module Invidious::ConnectionPool # Checks out a client in the pool private def client(&) - pool.checkout do |http_client| - # Proxy needs to be reinstated every time we get a client from the pool - http_client.proxy = make_configured_http_proxy_client() if CONFIG.http_proxy + # If a client has been deleted from the pool + # we won't try to release it + client_exists_in_pool = true - response = yield http_client + http_client = pool.checkout - return response - rescue ex - # Prevent broken client from being checked back into the pool - pool.delete(http_client) - raise ConnectionPool::Error.new(ex.message, cause: ex) - end + # Proxy needs to be reinstated every time we get a client from the pool + http_client.proxy = make_configured_http_proxy_client() if CONFIG.http_proxy + + response = yield http_client rescue ex : DB::PoolTimeout # Failed to checkout a client raise ConnectionPool::Error.new(ex.message, cause: ex) + rescue ex + # An error occurred with the client itself. + # Delete the client from the pool and close the connection + if http_client + client_exists_in_pool = false + @pool.delete(http_client) + http_client.close + end + + # Raise exception for outer methods to handle + raise ConnectionPool::Error.new(ex.message, cause: ex) + ensure + pool.release(http_client) if http_client && client_exists_in_pool end private def build_pool