From 0fae04f96a4cc827ba570446a46525061917aa39 Mon Sep 17 00:00:00 2001 From: orignal Date: Sun, 26 May 2024 10:21:26 -0400 Subject: [PATCH] update local RouterInfo timestamp by timer even in hidden mode --- libi2pd/RouterContext.cpp | 28 +++++++++++++++------------- 1 file changed, 15 insertions(+), 13 deletions(-) diff --git a/libi2pd/RouterContext.cpp b/libi2pd/RouterContext.cpp index 1bc7a203..4869ec32 100644 --- a/libi2pd/RouterContext.cpp +++ b/libi2pd/RouterContext.cpp @@ -57,11 +57,8 @@ namespace i2p { m_Service.reset (new RouterService); m_Service->Start (); - if (!m_IsHiddenMode) - { - m_PublishTimer.reset (new boost::asio::deadline_timer (m_Service->GetService ())); - ScheduleInitialPublish (); - } + m_PublishTimer.reset (new boost::asio::deadline_timer (m_Service->GetService ())); + ScheduleInitialPublish (); m_CongestionUpdateTimer.reset (new boost::asio::deadline_timer (m_Service->GetService ())); ScheduleCongestionUpdate (); m_CleanupTimer.reset (new boost::asio::deadline_timer (m_Service->GetService ())); @@ -1348,16 +1345,21 @@ namespace i2p { if (ecode != boost::asio::error::operation_aborted) { - m_PublishExcluded.clear (); - m_PublishReplyToken = 0; - if (IsFloodfill ()) + UpdateTimestamp (i2p::util::GetSecondsSinceEpoch ()); + if (!m_IsHiddenMode) { - UpdateStats (); // for floodfill - m_PublishExcluded.insert (i2p::context.GetIdentHash ()); // don't publish to ourselves + m_PublishExcluded.clear (); + m_PublishReplyToken = 0; + if (IsFloodfill ()) + { + UpdateStats (); // for floodfill + m_PublishExcluded.insert (i2p::context.GetIdentHash ()); // don't publish to ourselves + } + Publish (); + SchedulePublishResend (); } - UpdateTimestamp (i2p::util::GetSecondsSinceEpoch ()); - Publish (); - SchedulePublishResend (); + else + SchedulePublish (); } }