From 5d7991e4f7c1c8953b5b98409eca33e62590e921 Mon Sep 17 00:00:00 2001 From: woodser Date: Tue, 7 May 2024 18:44:23 -0400 Subject: [PATCH] repeat refresh offer on TTL error --- .../main/java/haveno/core/offer/OpenOfferManager.java | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/core/src/main/java/haveno/core/offer/OpenOfferManager.java b/core/src/main/java/haveno/core/offer/OpenOfferManager.java index 2301dc9f46..cefb735678 100644 --- a/core/src/main/java/haveno/core/offer/OpenOfferManager.java +++ b/core/src/main/java/haveno/core/offer/OpenOfferManager.java @@ -1788,7 +1788,7 @@ public class OpenOfferManager implements PeerManager.Listener, DecryptedDirectMe UserThread.runAfterRandomDelay(() -> { // we need to check if in the meantime the offer has been removed if (openOffers.contains(openOffer) && openOffer.isAvailable()) - refreshOffer(openOffer); + refreshOffer(openOffer, 0, 1); }, minDelay, maxDelay, TimeUnit.MILLISECONDS); } } else { @@ -1801,10 +1801,15 @@ public class OpenOfferManager implements PeerManager.Listener, DecryptedDirectMe log.trace("periodicRefreshOffersTimer already stated"); } - private void refreshOffer(OpenOffer openOffer) { + private void refreshOffer(OpenOffer openOffer, int numAttempts, int maxAttempts) { offerBookService.refreshTTL(openOffer.getOffer().getOfferPayload(), () -> log.debug("Successful refreshed TTL for offer"), - log::warn); + (errorMessage) -> { + log.warn(errorMessage); + if (numAttempts + 1 < maxAttempts) { + UserThread.runAfter(() -> refreshOffer(openOffer, numAttempts + 1, maxAttempts), 10); + } + }); } private void restart() {