diff options
author | Lee *!* Clagett <code@leeclagett.com> | 2021-08-24 19:25:45 -0400 |
---|---|---|
committer | Lee Clagett <code@leeclagett.com> | 2021-07-29 08:54:13 +0000 |
commit | 2a8a51129f7fa916dac6fb721b774784f42b360d (patch) | |
tree | debbeb38457cf870f43b6c8858e78e283f026389 /src/p2p | |
parent | Merge pull request #7881 (diff) | |
download | monero-2a8a51129f7fa916dac6fb721b774784f42b360d.tar.xz |
Quicker resource cleanup on p2p socks timeout
Diffstat (limited to 'src/p2p')
-rw-r--r-- | src/p2p/net_node.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/src/p2p/net_node.cpp b/src/p2p/net_node.cpp index 84cc1581e..d3034b081 100644 --- a/src/p2p/net_node.cpp +++ b/src/p2p/net_node.cpp @@ -339,6 +339,7 @@ namespace nodetool } }; + net::socks::client::close_on_exit close_client{}; boost::unique_future<client_result> socks_result{}; { boost::promise<client_result> socks_promise{}; @@ -347,6 +348,7 @@ namespace nodetool auto client = net::socks::make_connect_client( boost::asio::ip::tcp::socket{service}, net::socks::version::v4a, notify{std::move(socks_promise)} ); + close_client.self = client; if (!start_socks(std::move(client), proxy, remote)) return boost::none; } @@ -368,7 +370,10 @@ namespace nodetool { auto result = socks_result.get(); if (!result.first) + { + close_client.self.reset(); return {std::move(result.second)}; + } MERROR("Failed to make socks connection to " << remote.str() << " (via " << proxy << "): " << result.first.message()); } |