Skip to content

Commit

Permalink
småjusteringer etter PR review
Browse files Browse the repository at this point in the history
  • Loading branch information
kenglxn committed Oct 8, 2024
1 parent f3e764d commit abf9278
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 54 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ import no.nav.arbeidsgiver.min_side.models.Organisasjon
import no.nav.arbeidsgiver.min_side.services.tokenExchange.TokenExchangeClient
import org.springframework.beans.factory.annotation.Value
import org.springframework.boot.web.client.RestTemplateBuilder
import org.springframework.cache.annotation.Cacheable
import org.springframework.http.HttpMethod
import org.springframework.http.MediaType
import org.springframework.http.RequestEntity
Expand All @@ -29,7 +28,7 @@ class AltinnService(

private val cache: Cache<String, AltinnTilgangerResponse> = Caffeine.newBuilder()
.maximumSize(10000)
.expireAfterWrite(30, TimeUnit.MINUTES)
.expireAfterWrite(10, TimeUnit.MINUTES)
.recordStats()
.build()

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,38 +50,39 @@ class UserInfoController(
suspend fun getUserInfo(): UserInfoRespons {
val (tilganger, organisasjoner, syfoVirksomheter, refusjoner) = supervisorScope {
val tilganger = async {
altinnService.hentAltinnTilganger().tilgangTilOrgNr.map { (tilgang, value) ->
if (tilgang.contains(":")) {
/**
* I frontend mappes tilganger til en record fra tjeneste "id" til et set med orgnr
* dette blir dobbeltarbeid. Endre frontend til å motta map direkte på form:
* {
* "tjenestekode:tjenesteversjon": ["orgnr1", "orgnr2"]
* }
*/
val (tjenestekode, tjenesteversjon) = tilgang.split(":")
UserInfoRespons.Tilgang(
id = idLookup[tilgang] ?: tilgang,
tjenestekode = tjenestekode,
tjenesteversjon = tjenesteversjon,
organisasjoner = value.toList(),
altinnError = false,
)
} else {
/**
* altinn3 ressurser har ingen tjenesteversjon
* her burde vi på sikt ha en bedre måte å skille på
* altinn2 tjeneste tilgang vs altinn3 ressurs tilgang
*/
UserInfoRespons.Tilgang(
id = tilgang,
tjenestekode = tilgang,
tjenesteversjon = "",
organisasjoner = value.toList(),
altinnError = false,
)
altinnService.hentAltinnTilganger().let {
it.tilgangTilOrgNr.map { (tilgang, value) ->
if (tilgang.contains(":")) {
/**
* I frontend mappes tilganger til en record fra tjeneste "id" til et set med orgnr
* dette blir dobbeltarbeid. Endre frontend til å motta map direkte på form:
* {
* "tjenestekode:tjenesteversjon": ["orgnr1", "orgnr2"]
* }
*/
val (tjenestekode, tjenesteversjon) = tilgang.split(":")
UserInfoRespons.Tilgang(
id = idLookup[tilgang] ?: tilgang,
tjenestekode = tjenestekode,
tjenesteversjon = tjenesteversjon,
organisasjoner = value.toList(),
altinnError = it.isError,
)
} else {
/**
* altinn3 ressurser har ingen tjenesteversjon
* her burde vi på sikt ha en bedre måte å skille på
* altinn2 tjeneste tilgang vs altinn3 ressurs tilgang
*/
UserInfoRespons.Tilgang(
id = tilgang,
tjenestekode = tilgang,
tjenesteversjon = "",
organisasjoner = value.toList(),
altinnError = it.isError,
)
}
}

}
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
package no.nav.arbeidsgiver.min_side.varslingstatus

import no.nav.arbeidsgiver.min_side.controller.AuthenticatedUserHolder
import no.nav.arbeidsgiver.min_side.services.altinn.AltinnService
import no.nav.arbeidsgiver.min_side.varslingstatus.VarslingStatusDto.Status
import org.springframework.web.bind.annotation.PostMapping
Expand All @@ -17,10 +16,7 @@ class VarslingStatusController(

@PostMapping("/api/varslingStatus/v1")
fun getVarslingStatus(@RequestBody requestBody: VarslingStatusRequest): VarslingStatus {
val virksomhetsnummer = requestBody.virksomhetsnummer
val harTilgang = altinnService.hentOrganisasjoner()
.any { it.organizationNumber == virksomhetsnummer }

val harTilgang = altinnService.harOrganisasjon(requestBody.virksomhetsnummer)
if (!harTilgang) {
return VarslingStatus(
status = Status.OK,
Expand All @@ -29,7 +25,7 @@ class VarslingStatusController(
)
}

return repository.varslingStatus(virksomhetsnummer = virksomhetsnummer)
return repository.varslingStatus(virksomhetsnummer = requestBody.virksomhetsnummer)
}

data class VarslingStatusRequest(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -66,9 +66,7 @@ class VarslingStatusIntegrationTest {

@Test
fun `bruker som ikke har tilgang får status ok som default`() {
`when`(
altinnService.hentOrganisasjoner()
).thenReturn(emptyList())
`when`(altinnService.harOrganisasjon("314")).thenReturn(false)

processVarslingStatus(
"""
Expand Down Expand Up @@ -96,9 +94,7 @@ class VarslingStatusIntegrationTest {

@Test
fun `bruker med tilgang men ingen status i databasen får OK som default`() {
`when`(
altinnService.hentOrganisasjoner()
).thenReturn(listOf(Organisasjon(organizationNumber = "314", name = "Foo & Co", organizationForm = "BEDR")))
`when`(altinnService.harOrganisasjon("314")).thenReturn(true)

processVarslingStatus(
"""
Expand Down Expand Up @@ -126,9 +122,7 @@ class VarslingStatusIntegrationTest {

@Test
fun `returnerer siste status for virksomhet`() {
`when`(
altinnService.hentOrganisasjoner()
).thenReturn(listOf(Organisasjon(organizationNumber = "314", name = "Foo & Co", organizationForm = "BEDR")))
`when`(altinnService.harOrganisasjon("314")).thenReturn(true)

listOf(
"MANGLER_KOFUVI" to "2021-01-02T00:00:00Z",
Expand Down Expand Up @@ -172,9 +166,7 @@ class VarslingStatusIntegrationTest {

@Test
fun `returnerer siste status for virksomhet OK`() {
`when`(
altinnService.hentOrganisasjoner()
).thenReturn(listOf(Organisasjon(organizationNumber = "314", name = "Foo & Co", organizationForm = "BEDR")))
`when`(altinnService.harOrganisasjon("314")).thenReturn(true)

listOf(
"MANGLER_KOFUVI" to "2021-01-01T00:00:00Z",
Expand Down Expand Up @@ -218,9 +210,7 @@ class VarslingStatusIntegrationTest {

@Test
fun `får ok dersom kontaktinfo er pollet og funnet`() {
`when`(
altinnService.hentOrganisasjoner()
).thenReturn(listOf(Organisasjon(organizationNumber = "314", name = "Foo & Co", organizationForm = "BEDR")))
`when`(altinnService.harOrganisasjon("314")).thenReturn(true)

processVarslingStatus(
"""
Expand Down

0 comments on commit abf9278

Please sign in to comment.