From 332f679ca6bbbf361fffc8b79f149df7af6f21d9 Mon Sep 17 00:00:00 2001 From: Ruslan Lavrov <47384893+RuslanLavrov@users.noreply.github.com> Date: Tue, 23 Jan 2024 17:01:24 +0200 Subject: [PATCH] MODINV-950 - Make configurable params for instance sharing (#672) --- NEWS.md | 1 + .../consortium/util/RestDataImportHelper.java | 19 ++++++++++++++----- 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/NEWS.md b/NEWS.md index 39a5c2e0a..5302e0386 100644 --- a/NEWS.md +++ b/NEWS.md @@ -6,6 +6,7 @@ * Remove extra fields from 'holdings/move' mechanism [MODINV-948](https://issues.folio.org/browse/MODINV-948) * Allow to link local instance to shared instance [MODINV-901](https://issues.folio.org/browse/MODINV-901) * OOM issue in mod-inventory ([MODINV-944](https://issues.folio.org/browse/MODINV-944)) +* Make configurable params for instance sharing [MODINV-950](https://issues.folio.org/browse/MODINV-950) ## 20.1.0 2023-10-13 * Update status when user attempts to update shared auth record from member tenant ([MODDATAIMP-926](https://issues.folio.org/browse/MODDATAIMP-926)) diff --git a/src/main/java/org/folio/inventory/consortium/util/RestDataImportHelper.java b/src/main/java/org/folio/inventory/consortium/util/RestDataImportHelper.java index 5fc4cca1c..696cfa3e9 100644 --- a/src/main/java/org/folio/inventory/consortium/util/RestDataImportHelper.java +++ b/src/main/java/org/folio/inventory/consortium/util/RestDataImportHelper.java @@ -11,6 +11,7 @@ import org.apache.logging.log4j.Logger; import org.folio.Record; import org.folio.inventory.consortium.entities.SharingInstance; +import org.folio.kafka.SimpleConfigurationReader; import org.folio.rest.client.ChangeManagerClient; import org.folio.rest.jaxrs.model.InitJobExecutionsRqDto; import org.folio.rest.jaxrs.model.InitialRecord; @@ -46,10 +47,23 @@ public class RestDataImportHelper { public static final String STATUS_COMMITTED = "COMMITTED"; public static final String STATUS_ERROR = "ERROR"; + private static final String IMPORT_STATUS_POLL_INTERVAL_SEC_PARAM = + "inventory.sharing.di.status.poll.interval.seconds"; + private static final String IMPORT_STATUS_POLL_NUMBER_PARAM = + "inventory.sharing.di.status.poll.number"; + private static final String DEFAULT_IMPORT_STATUS_POLL_INTERVAL_SEC = "5"; + private static final String DEFAULT_IMPORT_STATUS_POLL_NUMBER = "5"; + private final Vertx vertx; + private final long durationInSec; + private final int attemptsNumber; public RestDataImportHelper(Vertx vertx) { this.vertx = vertx; + this.durationInSec = Integer.parseInt(SimpleConfigurationReader.getValue( + IMPORT_STATUS_POLL_INTERVAL_SEC_PARAM, DEFAULT_IMPORT_STATUS_POLL_INTERVAL_SEC)); + this.attemptsNumber = Integer.parseInt(SimpleConfigurationReader.getValue( + IMPORT_STATUS_POLL_NUMBER_PARAM, DEFAULT_IMPORT_STATUS_POLL_NUMBER)); } public static final JobProfileInfo JOB_PROFILE_INFO = new JobProfileInfo() @@ -73,11 +87,6 @@ public Future importMarcRecord(Record marcRecord, SharingInstance sharin ChangeManagerClient changeManagerClient = getChangeManagerClient(kafkaHeaders); - //TODO: move to config - //Constants for checkDataImportStatus method - final long durationInSec = 20; - final int attemptsNumber = 3; - return initJobExecution(instanceId, changeManagerClient, kafkaHeaders) .compose(jobExecutionId -> setDefaultJobProfileToJobExecution(jobExecutionId, changeManagerClient)) .compose(jobExecutionId -> {