From 678299116bd432746ac3cd7ca50bc794329550ee Mon Sep 17 00:00:00 2001 From: halvorbmundal Date: Tue, 4 Jun 2024 17:10:55 +0200 Subject: [PATCH] =?UTF-8?q?Legg=20til=20mulighet=20for=20=C3=A5=20kunne=20?= =?UTF-8?q?kj=C3=B8re=20M=C3=A5nedligValutajustering=20utenom=20f=C3=B8rst?= =?UTF-8?q?e=20virkedag=20i=20m=C3=A5ned=20(#4604)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ### 💰 Hva skal gjøres, og hvorfor? Funksjonen som starter månedlig valutajustering tillater enn så lenge kun av vi starter det første virkedag i måneden. Endrer så vi starter månedlig valutajustering umiddelbart dersom vi starter det fra endepunkt. --- .../ba/sak/internal/ForvalterController.kt | 3 ++- .../M\303\245nedligValutajusteringScheduler.kt" | 17 +++++++++++------ .../BehandlingHentOgPersisterService.kt | 3 ++- .../behandling/domene/BehandlingRepository.kt | 5 ++--- ...245nedligValutajusteringFinnFagsakerTask.kt" | 10 ++++++++-- 5 files changed, 25 insertions(+), 13 deletions(-) diff --git a/src/main/kotlin/no/nav/familie/ba/sak/internal/ForvalterController.kt b/src/main/kotlin/no/nav/familie/ba/sak/internal/ForvalterController.kt index bf20c9d396a..54f2b27dbf7 100644 --- a/src/main/kotlin/no/nav/familie/ba/sak/internal/ForvalterController.kt +++ b/src/main/kotlin/no/nav/familie/ba/sak/internal/ForvalterController.kt @@ -50,6 +50,7 @@ import org.springframework.web.bind.annotation.RequestParam import org.springframework.web.bind.annotation.RestController import java.math.BigDecimal import java.time.LocalDate +import java.time.LocalDateTime import java.time.YearMonth import java.util.UUID import kotlin.concurrent.thread @@ -342,7 +343,7 @@ class ForvalterController( @PostMapping("/start-valutajustering-scheduler") @Operation(summary = "Start valutajustering for alle sekundærlandsaker i gjeldende måned") fun lagMånedligValutajusteringTask(): ResponseEntity> { - månedligValutajusteringScheduler.lagMånedligValutajusteringTask() + månedligValutajusteringScheduler.lagMånedligValutajusteringTask(triggerTid = LocalDateTime.now()) return ResponseEntity.ok(Ressurs.success("Kjørt ok")) } diff --git "a/src/main/kotlin/no/nav/familie/ba/sak/kjerne/autovedtak/m\303\245nedligvalutajustering/M\303\245nedligValutajusteringScheduler.kt" "b/src/main/kotlin/no/nav/familie/ba/sak/kjerne/autovedtak/m\303\245nedligvalutajustering/M\303\245nedligValutajusteringScheduler.kt" index 495955b052e..73277e04cbd 100644 --- "a/src/main/kotlin/no/nav/familie/ba/sak/kjerne/autovedtak/m\303\245nedligvalutajustering/M\303\245nedligValutajusteringScheduler.kt" +++ "b/src/main/kotlin/no/nav/familie/ba/sak/kjerne/autovedtak/m\303\245nedligvalutajustering/M\303\245nedligValutajusteringScheduler.kt" @@ -13,6 +13,7 @@ import org.springframework.scheduling.annotation.Scheduled import org.springframework.stereotype.Component import org.springframework.transaction.annotation.Transactional import java.time.LocalDate +import java.time.LocalDateTime import java.time.YearMonth @Component @@ -31,7 +32,9 @@ class MånedligValutajusteringScheduler( */ @Scheduled(cron = "0 0 $KLOKKETIME_SCHEDULER_TRIGGES 1 * *") @Transactional - fun lagMånedligValutajusteringTask() { + fun lagScheduledMånedligValutajusteringTask() = lagMånedligValutajusteringTask(triggerTid = hentNesteVirkedag()) + + fun lagMånedligValutajusteringTask(triggerTid: LocalDateTime) { val inneværendeMåned = YearMonth.now() if (!unleashService.isEnabled(FeatureToggleConfig.KAN_KJØRE_AUTOMATISK_VALUTAJUSTERING_FOR_ALLE_SAKER)) { logger.info("FeatureToggle ${FeatureToggleConfig.KAN_KJØRE_AUTOMATISK_VALUTAJUSTERING_FOR_ALLE_SAKER} er skrudd av. Avbryter månedlig valutajustering.") @@ -43,16 +46,18 @@ class MånedligValutajusteringScheduler( taskRepository.save( MånedligValutajusteringFinnFagsakerTask.lagTask( inneværendeMåned = inneværendeMåned, - triggerTid = - VirkedagerProvider.nesteVirkedag( - LocalDate.now().minusDays(1), - ).atTime(KLOKKETIME_SCHEDULER_TRIGGES.inc(), 0), + triggerTid = triggerTid, ), ) } } + private fun hentNesteVirkedag(): LocalDateTime = + VirkedagerProvider.nesteVirkedag( + LocalDate.now().minusDays(1), + ).atTime(KLOKKETIME_SCHEDULER_TRIGGES.inc(), 0) + companion object { - const val KLOKKETIME_SCHEDULER_TRIGGES = 6 + const val KLOKKETIME_SCHEDULER_TRIGGES = 2 } } diff --git a/src/main/kotlin/no/nav/familie/ba/sak/kjerne/behandling/BehandlingHentOgPersisterService.kt b/src/main/kotlin/no/nav/familie/ba/sak/kjerne/behandling/BehandlingHentOgPersisterService.kt index 63c129fafa2..d303c0c9e0a 100644 --- a/src/main/kotlin/no/nav/familie/ba/sak/kjerne/behandling/BehandlingHentOgPersisterService.kt +++ b/src/main/kotlin/no/nav/familie/ba/sak/kjerne/behandling/BehandlingHentOgPersisterService.kt @@ -1,6 +1,7 @@ package no.nav.familie.ba.sak.kjerne.behandling import no.nav.familie.ba.sak.common.Feil +import no.nav.familie.ba.sak.common.førsteDagIInneværendeMåned import no.nav.familie.ba.sak.kjerne.behandling.domene.Behandling import no.nav.familie.ba.sak.kjerne.behandling.domene.BehandlingRepository import no.nav.familie.ba.sak.kjerne.behandling.domene.BehandlingStatus @@ -104,7 +105,7 @@ class BehandlingHentOgPersisterService( behandlingRepository.finnSisteIverksatteBehandlingFraLøpendeFagsaker() fun hentAlleFagsakerMedLøpendeValutakursIMåned(måned: YearMonth): List = - behandlingRepository.finnAlleFagsakerMedLøpendeValutakursIMåned(måned) + behandlingRepository.finnAlleFagsakerMedLøpendeValutakursIMåned(måned.førsteDagIInneværendeMåned()) fun hentBehandlinger(fagsakId: Long): List { return behandlingRepository.finnBehandlinger(fagsakId) diff --git a/src/main/kotlin/no/nav/familie/ba/sak/kjerne/behandling/domene/BehandlingRepository.kt b/src/main/kotlin/no/nav/familie/ba/sak/kjerne/behandling/domene/BehandlingRepository.kt index 4f68e94eb91..4635114dce5 100644 --- a/src/main/kotlin/no/nav/familie/ba/sak/kjerne/behandling/domene/BehandlingRepository.kt +++ b/src/main/kotlin/no/nav/familie/ba/sak/kjerne/behandling/domene/BehandlingRepository.kt @@ -6,7 +6,6 @@ import org.springframework.data.jpa.repository.Lock import org.springframework.data.jpa.repository.Query import java.time.LocalDate import java.time.LocalDateTime -import java.time.YearMonth interface BehandlingRepository : JpaRepository { @Query(value = "SELECT b FROM Behandling b WHERE b.id = :behandlingId") @@ -79,10 +78,10 @@ interface BehandlingRepository : JpaRepository { WHERE f.status = 'LØPENDE' AND f.arkivert = false AND ty.stonad_tom >= :måned - AND (v.tom >= :måned OR v.tom IS null)""", + AND (v.tom IS null OR v.tom >= :måned)""", nativeQuery = true, ) - fun finnAlleFagsakerMedLøpendeValutakursIMåned(måned: YearMonth): List + fun finnAlleFagsakerMedLøpendeValutakursIMåned(måned: LocalDate): List @Query( """select b from Behandling b diff --git "a/src/main/kotlin/no/nav/familie/ba/sak/task/M\303\245nedligValutajusteringFinnFagsakerTask.kt" "b/src/main/kotlin/no/nav/familie/ba/sak/task/M\303\245nedligValutajusteringFinnFagsakerTask.kt" index 5dce072107d..52e457a1e59 100644 --- "a/src/main/kotlin/no/nav/familie/ba/sak/task/M\303\245nedligValutajusteringFinnFagsakerTask.kt" +++ "b/src/main/kotlin/no/nav/familie/ba/sak/task/M\303\245nedligValutajusteringFinnFagsakerTask.kt" @@ -9,10 +9,13 @@ import no.nav.familie.ba.sak.kjerne.eøs.valutakurs.ValutakursService import no.nav.familie.ba.sak.kjerne.eøs.valutakurs.erAlleValutakurserOppdaterteIMåned import no.nav.familie.ba.sak.kjerne.fagsak.FagsakService import no.nav.familie.kontrakter.felles.objectMapper +import no.nav.familie.log.IdUtils +import no.nav.familie.log.mdc.MDCConstants import no.nav.familie.prosessering.AsyncTaskStep import no.nav.familie.prosessering.TaskStepBeskrivelse import no.nav.familie.prosessering.domene.Task import org.slf4j.LoggerFactory +import org.slf4j.MDC import org.springframework.stereotype.Service import java.time.LocalDateTime import java.time.YearMonth @@ -40,7 +43,7 @@ class MånedligValutajusteringFinnFagsakerTask( logger.info("Starter månedlig valutajustering for ${data.måned}") - val fagsakerMedLøpendeValutakurs = behandlingService.hentAlleFagsakerMedLøpendeValutakursIMåned(data.måned).toSet().sorted() + val fagsakerMedLøpendeValutakurs = behandlingService.hentAlleFagsakerMedLøpendeValutakursIMåned(data.måned) // Hardkoder denne til å kun ta 10 behanldinger i første omgang slik at vi er helt sikre på at vi ikke kjører på alle behandlinger mens vi tester. fagsakerMedLøpendeValutakurs.take(10).forEach { fagsakId -> @@ -64,7 +67,10 @@ class MånedligValutajusteringFinnFagsakerTask( Task( type = MånedligValutajusteringFinnFagsakerTask.TASK_STEP_TYPE, payload = objectMapper.writeValueAsString(MånedligValutajusteringFinnFagsakerTaskDto(inneværendeMåned)), - mapOf("måned" to inneværendeMåned.toString()).toProperties(), + mapOf( + "måned" to inneværendeMåned.toString(), + "callId" to (MDC.get(MDCConstants.MDC_CALL_ID) ?: IdUtils.generateId()), + ).toProperties(), ).medTriggerTid( triggerTid = triggerTid, )