Skip to content

Commit 59749c9

Browse files
Legg til endepunkt for å kunne hente uncached inntekt
1 parent c7548b6 commit 59749c9

File tree

2 files changed

+53
-3
lines changed

2 files changed

+53
-3
lines changed

.github/workflows/deploy.yaml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -49,7 +49,7 @@ jobs:
4949
deploy-dev:
5050
name: Deploy to dev
5151
needs: [build]
52-
if: github.ref == 'refs/heads/main'
52+
if: github.ref == 'refs/heads/uncached-inntekt-med-inntekt-id'
5353
runs-on: ubuntu-latest
5454
permissions:
5555
contents: "read"

dp-inntekt-api/src/main/kotlin/no/nav/dagpenger/inntekt/api/v1/UklassifisertInntektRoute.kt

Lines changed: 52 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -152,7 +152,8 @@ fun Route.uklassifisertInntekt(
152152
.getStoredInntektMedMetadata(inntektId)
153153
.let { storedInntektMedMetadata ->
154154
val person = personOppslag.hentPerson(storedInntektMedMetadata.fødselsnummer)
155-
val inntektsmottaker = Inntektsmottaker(storedInntektMedMetadata.fødselsnummer, person.sammensattNavn())
155+
val inntektsmottaker =
156+
Inntektsmottaker(storedInntektMedMetadata.fødselsnummer, person.sammensattNavn())
156157
val organisasjoner =
157158
hentOrganisasjoner(
158159
enhetsregisterClient,
@@ -198,7 +199,8 @@ fun Route.uklassifisertInntekt(
198199
beregningsdato = inntektPersonMapping.beregningsdato,
199200
).apply {
200201
this.opptjeningsperiode.førsteMåned = inntekterDto.periode.fraOgMed
201-
this.opptjeningsperiode.sisteAvsluttendeKalenderMåned = inntekterDto.periode.tilOgMed
202+
this.opptjeningsperiode.sisteAvsluttendeKalenderMåned =
203+
inntekterDto.periode.tilOgMed
202204
},
203205
inntekt = it.inntekt,
204206
manueltRedigert =
@@ -283,6 +285,54 @@ fun Route.uklassifisertInntekt(
283285
}
284286
}
285287
}
288+
289+
route("/uklassifisert/uncached/{inntektId}") {
290+
get {
291+
val callId = call.callId
292+
withContext(coroutineContext) {
293+
val inntektId = InntektId(call.parameters["inntektId"]!!)
294+
295+
call.withInntektRequest("GET /uklassifisert/uncached/") {
296+
inntektStore
297+
.getStoredInntektMedMetadata(inntektId)
298+
.let { storedInntektMedMetadata ->
299+
val person = personOppslag.hentPerson(storedInntektMedMetadata.fødselsnummer)
300+
val opptjeningsperiode = Opptjeningsperiode(storedInntektMedMetadata.beregningsdato)
301+
302+
toInntektskomponentRequest(person, opptjeningsperiode)
303+
.let {
304+
logger.info { "Henter nye inntekter fra inntektskomponenten" }
305+
inntektskomponentClient.getInntekt(it, callId = callId)
306+
}.let {
307+
logger.info { "Fikk nye inntekter fra inntektskomponenten" }
308+
val inntektsmottaker =
309+
Inntektsmottaker(person.fødselsnummer, person.sammensattNavn())
310+
val organisasjoner =
311+
hentOrganisasjoner(
312+
enhetsregisterClient,
313+
storedInntektMedMetadata.inntekt.arbeidsInntektMaaned
314+
?.flatMap { it.arbeidsInntektInformasjon?.inntektListe.orEmpty() }
315+
?.filter { inntekt ->
316+
inntekt.virksomhet?.aktoerType == AktoerType.ORGANISASJON &&
317+
(inntekt.opptjeningsland == "NO" || inntekt.opptjeningsland == null)
318+
}?.mapNotNull { it.virksomhet?.identifikator }
319+
?.toTypedArray()
320+
?.toList() ?: emptyList(),
321+
)
322+
323+
it.mapToFrontend(
324+
person = inntektsmottaker,
325+
organisasjoner = organisasjoner,
326+
storedInntektMedMetadata = storedInntektMedMetadata,
327+
)
328+
}.let {
329+
call.respond(HttpStatusCode.OK, it)
330+
}.also { inntektOppfriskingCounter.inc() }
331+
} ?: throw InntektNotFoundException("Inntekt with id $inntektId not found.")
332+
}
333+
}
334+
}
335+
}
286336
}
287337
route("/verdikoder") {
288338
get {

0 commit comments

Comments
 (0)