From 5d6a86dad5247aaea719d8ee193b47c3249d38bf Mon Sep 17 00:00:00 2001 From: arvidn Date: Mon, 1 Feb 2021 01:02:25 +0100 Subject: [PATCH] don't announce stopped-event to websocket trackers. This (appears) to solve a shutdown stall where we send stopped-announces after aborting outstanding announces (including the persistent websocket connection). The announec causes the persistent connection to be re-established and sometimes not torn down properly again, to complete the shut down --- src/torrent.cpp | 7 ++++--- src/tracker_manager.cpp | 16 +++++++++++++--- 2 files changed, 17 insertions(+), 6 deletions(-) diff --git a/src/torrent.cpp b/src/torrent.cpp index c5484b1bbdc..737f3724ea1 100644 --- a/src/torrent.cpp +++ b/src/torrent.cpp @@ -5845,12 +5845,13 @@ namespace { } #if TORRENT_USE_RTC - void torrent::generate_rtc_offers(int count - , std::function)> handler) + void torrent::generate_rtc_offers(int const count + , std::function)> handler) { // rtc_signaling is created lazily - if(!m_rtc_signaling) + if (!m_rtc_signaling) { + TORRENT_ASSERT(count > 0); m_rtc_signaling = std::make_shared(m_ses.get_context() , this , std::bind(&torrent::on_rtc_stream, this, _1)); diff --git a/src/tracker_manager.cpp b/src/tracker_manager.cpp index e9f60f1f590..20ba26d7498 100644 --- a/src/tracker_manager.cpp +++ b/src/tracker_manager.cpp @@ -269,7 +269,7 @@ namespace libtorrent::aux { if (m_abort && req.event != event_t::stopped) return; #ifndef TORRENT_DISABLE_LOGGING - if(auto cb = c.lock()) + if (auto cb = c.lock()) cb->debug_log("*** QUEUE_TRACKER_REQUEST [ listen_port: %d ]", req.listen_port); #endif @@ -305,16 +305,26 @@ namespace libtorrent::aux { else if (protocol == "ws" || protocol == "wss") { std::shared_ptr cb = c.lock(); - if(!cb) return; + if (!cb) return; // TODO: introduce a setting for max_offers const int max_offers = 10; req.num_want = std::min(req.num_want, max_offers); + if (req.num_want == 0) + { + // when we're shutting down, we don't really want to + // re-establish the persistent websocket connection just to + // announce "stopped", and advertize 0 offers. It may hang + // shutdown. + post(ios, std::bind(&request_callback::tracker_request_error, cb, std::move(req) + , errors::torrent_aborted, operation_t::connect + , "", seconds32(0))); + } cb->generate_rtc_offers(req.num_want , [this, &ios, req = std::move(req), c](error_code const& ec , std::vector offers) mutable { - if(!ec) req.offers = std::move(offers); + if (!ec) req.offers = std::move(offers); auto it = m_websocket_conns.find(req.url); if (it != m_websocket_conns.end() && it->second->is_started()) {