From 9463bf562c59ae1cfaee897136b4707653f719f7 Mon Sep 17 00:00:00 2001 From: Alva Swanson Date: Thu, 9 Jan 2025 20:25:38 +0000 Subject: [PATCH] RestApi: Fix parseBlockCompleteAfterBatchProcessing data race The parseBlockCompleteAfterBatchProcessing field is set on the block parsing thread and read by Jersey's HTTP threads. By default, Jersey handles requests synchronous on multiple threads. --- restapi/src/main/java/bisq/restapi/RestApi.java | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/restapi/src/main/java/bisq/restapi/RestApi.java b/restapi/src/main/java/bisq/restapi/RestApi.java index ad68481293..bb7d586514 100644 --- a/restapi/src/main/java/bisq/restapi/RestApi.java +++ b/restapi/src/main/java/bisq/restapi/RestApi.java @@ -38,6 +38,8 @@ import bisq.common.app.Version; import bisq.common.config.Config; +import java.util.concurrent.atomic.AtomicBoolean; + import lombok.Getter; import lombok.extern.slf4j.Slf4j; @@ -69,7 +71,7 @@ public class RestApi extends ExecutableForAppWithP2p { private OfferBookService offerBookService; private PriceFeedService priceFeedService; @Getter - private boolean parseBlockCompleteAfterBatchProcessing; + private final AtomicBoolean parseBlockCompleteAfterBatchProcessing = new AtomicBoolean(); public RestApi() { super("Bisq Rest Api", "bisq_restapi", "bisq_restapi", Version.VERSION); @@ -108,7 +110,7 @@ protected void applyInjector() { @Override public void onParseBlockCompleteAfterBatchProcessing(Block block) { log.error("onParseBlockCompleteAfterBatchProcessing"); - parseBlockCompleteAfterBatchProcessing = true; + parseBlockCompleteAfterBatchProcessing.set(true); } }); } @@ -130,6 +132,6 @@ protected void onHiddenServicePublished() { } public void checkDaoReady() { - checkArgument(parseBlockCompleteAfterBatchProcessing, "DAO not ready yet"); + checkArgument(parseBlockCompleteAfterBatchProcessing.get(), "DAO not ready yet"); } }