Skip to content

Commit

Permalink
Merge branch 'master' of https://github.com/navikt/testnorge into fea…
Browse files Browse the repository at this point in the history
…ture/bestillingsvisning-omskrivning
  • Loading branch information
betsytraran committed Jan 6, 2025
2 parents d2edbee + 4bf6d6c commit 233aca8
Show file tree
Hide file tree
Showing 121 changed files with 941 additions and 485 deletions.
10 changes: 1 addition & 9 deletions .github/workflows/integration-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ on:
push:
paths:
- 'apps/bruker-service/**'
- 'apps/person-organisasjon-tilgang-service/**'
workflow_dispatch:

jobs:
Expand All @@ -14,11 +13,4 @@ jobs:
working-directory: 'apps/bruker-service/'
healthcheck: 'http://localhost:8002/internal/isAlive'
secrets:
NAV_TOKEN: ${{ secrets.NAV_TOKEN }}
person-organisasjon-tilgang-service:
if: github.event.pull_request.draft == false
uses: ./.github/workflows/common.integration-test.yml
with:
working-directory: 'apps/person-organisasjon-tilgang-service/'
healthcheck: 'http://localhost:8001/internal/isAlive'
secrets: inherit
NAV_TOKEN: ${{ secrets.NAV_TOKEN }}
7 changes: 4 additions & 3 deletions apps/adresse-service/src/main/resources/application.yml
Original file line number Diff line number Diff line change
Expand Up @@ -34,12 +34,13 @@ management:
enabled-by-default: true
web:
base-path: /internal
exposure.include: prometheus,heapdump,health
exposure:
include: prometheus,health
path-mapping:
prometheus: metrics
endpoint:
prometheus.enabled: true
heapdump.enabled: true
prometheus:
enabled: true
prometheus:
metrics:
export:
Expand Down
1 change: 1 addition & 0 deletions apps/altinn3-tilgang-service/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,3 +10,4 @@ Swagger finnes under [/swagger-ui.html](https://testnav-altinn3-tilgang-service.
## Lokal kjøring
* [Generelt.](../../docs/local_general.md)
* [Secret Manager.](../../docs/local_secretmanager.md)
* [Database i GCP.](../../docs/gcp_db.md)
1 change: 1 addition & 0 deletions apps/altinn3-tilgang-service/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ sonarqube {
}

dependencies {
implementation "no.nav.testnav.libs:data-transfer-objects"
implementation "no.nav.testnav.libs:reactive-core"
implementation "no.nav.testnav.libs:reactive-security"

Expand Down
4 changes: 2 additions & 2 deletions apps/altinn3-tilgang-service/config.dev.yml
Original file line number Diff line number Diff line change
Expand Up @@ -23,15 +23,15 @@ spec:
consumes:
- name: altinn:resourceregistry/accesslist.read
- name: altinn:resourceregistry/accesslist.write
- name: altinn:accessmanagement/authorizedparties.resourceowner
accessPolicy:
inbound:
rules:
- application: dolly-frontend
- application: dolly-frontend-dev
- application: dolly-frontend-dev-unstable
- application: dolly-idporten
- application: team-dolly-lokal-app
- application: testnav-oversikt-frontend
- application: testnav-bruker-service-dev
outbound:
external:
- host: platform.tt02.altinn.no
Expand Down
5 changes: 1 addition & 4 deletions apps/altinn3-tilgang-service/config.prod.yml
Original file line number Diff line number Diff line change
Expand Up @@ -23,15 +23,12 @@ spec:
consumes:
- name: altinn:resourceregistry/accesslist.read
- name: altinn:resourceregistry/accesslist.write
- name: altinn:accessmanagement/authorizedparties.resourceowner
accessPolicy:
inbound:
rules:
- application: dolly-frontend
cluster: dev-gcp
- application: dolly-frontend-dev
cluster: dev-gcp
- application: dolly-frontend-dev-unstable
cluster: dev-gcp
- application: dolly-idporten
cluster: dev-gcp
- application: team-dolly-lokal-app
Expand Down
18 changes: 18 additions & 0 deletions apps/altinn3-tilgang-service/docker-compose.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
services:

cloud_sql_proxy:
image: gcr.io/cloud-sql-connectors/cloud-sql-proxy:2.14.2
network_mode: host
command:
- "dolly-dev-ff83:europe-north1:testnav-altinn3-tilgang-local"
- "--credentials-file=/application_default_credentials.json"
- "--run-connection-test"
volumes:
- type: bind
# Set a variable $DOLLY_APPLICATION_CREDENTIALS. We don't use
# GOOGLE_APPLICATION_CREDENTIALS, as this causes an extra step during login.
#
# - $HOME/.config/gcloud/application_default_credentials.json for Linux/macOS.
# - $APPDATA/gcloud/application_default_credentials.json for Windows.
source: $DOLLY_APPLICATION_CREDENTIALS
target: /application_default_credentials.json
2 changes: 1 addition & 1 deletion apps/altinn3-tilgang-service/settings.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,9 @@ rootProject.name = 'altinn3-tilgang-service'

includeBuild "../../plugins/java"

includeBuild '../../libs/data-transfer-objects'
includeBuild '../../libs/reactive-core'
includeBuild '../../libs/reactive-security'
includeBuild '../../libs/vault'

develocity {
buildScan {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,4 +22,4 @@ public class Altinn3TilgangServiceApplicationStarter {
public static void main(String[] args) {
SpringApplication.run(Altinn3TilgangServiceApplicationStarter.class, args);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,11 @@
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.command.CreateAccessListeMemberCommand;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.command.DeleteAccessListMemberCommand;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.command.GetAccessListMembersCommand;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.command.GetAuthorizedPartiesCommand;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.command.GetExchangeTokenCommand;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AltinnResponseDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AltinnAccessListResponseDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AltinnAuthorizedPartiesRequestDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AuthorizedPartyDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.BrregResponseDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.OrganisasjonCreateDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.OrganisasjonDeleteDTO;
Expand All @@ -25,6 +28,7 @@
import reactor.core.publisher.Flux;
import reactor.core.publisher.Mono;

import java.util.Arrays;
import java.util.List;
import java.util.Map;

Expand Down Expand Up @@ -76,7 +80,7 @@ public Flux<Organisasjon> delete(String organisasjonsnummer) {

return Flux.from(getAccessListMembers()
.flatMapMany(value -> Flux.fromIterable(value.getData()))
.map(AltinnResponseDTO.AccessListMembershipDTO::getIdentifiers)
.map(AltinnAccessListResponseDTO.AccessListMembershipDTO::getIdentifiers)
.collectList()
.map(data -> getIdentifier(data, organisasjonsnummer))
.map(identifier ->
Expand All @@ -96,27 +100,27 @@ public Flux<Organisasjon> delete(String organisasjonsnummer) {
.flatMap(Flux::from);
}

public Flux<Organisasjon> create(String organisasjonsnummer) {
public Mono<Organisasjon> create(String organisasjonsnummer) {

return maskinportenConsumer.getAccessToken()
return Mono.from(maskinportenConsumer.getAccessToken()
.flatMap(this::exchangeToken)
.flatMap(exchangeToken -> new CreateAccessListeMemberCommand(
webClient,
exchangeToken,
new OrganisasjonCreateDTO(organisasjonsnummer),
altinnConfig).call())
.flatMapMany(response ->
isBlank(response.getFeilmelding()) ?
Flux.fromIterable(response.getData())
.map(this::getOrgnummer)
.filter(organisasjonsnummer::equals)
.flatMap(brregConsumer::getEnheter) :
Mono.just(BrregResponseDTO.builder()
.organisasjonsnummer(organisasjonsnummer)
.feilmelding(response.getFeilmelding())
.status(response.getStatus())
.build()))
.map(response -> mapperFacade.map(response, Organisasjon.class));
isBlank(response.getFeilmelding()) ?
Flux.fromIterable(response.getData())
.map(this::getOrgnummer)
.filter(organisasjonsnummer::equals)
.flatMap(brregConsumer::getEnhet) :
Mono.just(BrregResponseDTO.builder()
.organisasjonsnummer(organisasjonsnummer)
.feilmelding(response.getFeilmelding())
.status(response.getStatus())
.build()))
.map(response -> mapperFacade.map(response, Organisasjon.class)));
}

public Flux<Organisasjon> getOrganisasjoner() {
Expand All @@ -125,7 +129,18 @@ public Flux<Organisasjon> getOrganisasjoner() {
.flatMapMany(this::convertToOrganisasjon);
}

private Mono<AltinnResponseDTO> getAccessListMembers() {
public Flux<AuthorizedPartyDTO> getAuthorizedParties(String ident) {

return maskinportenConsumer.getAccessToken()
.flatMap(this::exchangeToken)
.flatMap(exchangeToken -> new GetAuthorizedPartiesCommand(webClient,
new AltinnAuthorizedPartiesRequestDTO(ident),
exchangeToken).call())
.map(Arrays::asList)
.flatMapIterable(list -> list);
}

private Mono<AltinnAccessListResponseDTO> getAccessListMembers() {

return maskinportenConsumer.getAccessToken()
.flatMap(this::exchangeToken)
Expand All @@ -135,11 +150,11 @@ private Mono<AltinnResponseDTO> getAccessListMembers() {
altinnConfig).call());
}

private Flux<Organisasjon> convertToOrganisasjon(AltinnResponseDTO altInnResponse) {
private Flux<Organisasjon> convertToOrganisasjon(AltinnAccessListResponseDTO altInnResponse) {

return Flux.fromIterable(altInnResponse.getData())
.map(this::getOrgnummer)
.flatMap(brregConsumer::getEnheter)
.flatMap(brregConsumer::getEnhet)
.map(response -> mapperFacade.map(response, Organisasjon.class));
}

Expand All @@ -155,7 +170,7 @@ private OrganisasjonDeleteDTO getIdentifier(List<JsonNode> data, String organisa
}

@SneakyThrows
private String getOrgnummer(AltinnResponseDTO.AccessListMembershipDTO data) {
private String getOrgnummer(AltinnAccessListResponseDTO.AccessListMembershipDTO data) {

return data.getIdentifiers()
.get(ORGANISASJON_ID)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import no.nav.testnav.altinn3tilgangservice.config.AltinnConfig;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AltinnResponseDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AltinnAccessListResponseDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.OrganisasjonCreateDTO;
import no.nav.testnav.libs.reactivecore.utils.WebClientFilter;
import org.springframework.http.HttpHeaders;
Expand All @@ -16,7 +16,7 @@

@Slf4j
@RequiredArgsConstructor
public class CreateAccessListeMemberCommand implements Callable<Mono<AltinnResponseDTO>> {
public class CreateAccessListeMemberCommand implements Callable<Mono<AltinnAccessListResponseDTO>> {

private static final String ALTINN_URL = "/resourceregistry/api/v1/access-lists/{owner}/{identifier}/members";

Expand All @@ -27,7 +27,7 @@ public class CreateAccessListeMemberCommand implements Callable<Mono<AltinnRespo


@Override
public Mono<AltinnResponseDTO> call() {
public Mono<AltinnAccessListResponseDTO> call() {

return webClient
.post()
Expand All @@ -37,14 +37,14 @@ public Mono<AltinnResponseDTO> call() {
.header(HttpHeaders.AUTHORIZATION, "Bearer " + token)
.header(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE)
.retrieve()
.bodyToMono(AltinnResponseDTO.class)
.bodyToMono(AltinnAccessListResponseDTO.class)
.doOnError(WebClientFilter::logErrorMessage)
.doOnSuccess(value -> log.info("Altinn organisasjontilgang opprettet for {}",
organisasjon.getData().stream()
.map(data -> data.split(":"))
.map(data -> data[data.length-1])
.collect(Collectors.joining())))
.onErrorResume(throwable -> Mono.just(AltinnResponseDTO.builder()
.onErrorResume(throwable -> Mono.just(AltinnAccessListResponseDTO.builder()
.status(WebClientFilter.getStatus(throwable))
.feilmelding(WebClientFilter.getMessage(throwable))
.build()));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import no.nav.testnav.altinn3tilgangservice.config.AltinnConfig;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AltinnResponseDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AltinnAccessListResponseDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.OrganisasjonDeleteDTO;
import no.nav.testnav.libs.reactivecore.utils.WebClientFilter;
import org.springframework.http.HttpHeaders;
Expand All @@ -19,7 +19,7 @@

@Slf4j
@RequiredArgsConstructor
public class DeleteAccessListMemberCommand implements Callable<Mono<AltinnResponseDTO>> {
public class DeleteAccessListMemberCommand implements Callable<Mono<AltinnAccessListResponseDTO>> {

private static final String ALTINN_URL = "/resourceregistry/api/v1/access-lists/{owner}/{identifier}/members";

Expand All @@ -30,7 +30,7 @@ public class DeleteAccessListMemberCommand implements Callable<Mono<AltinnRespon


@Override
public Mono<AltinnResponseDTO> call() {
public Mono<AltinnAccessListResponseDTO> call() {

return webClient
.method(HttpMethod.DELETE)
Expand All @@ -41,7 +41,7 @@ public Mono<AltinnResponseDTO> call() {
.header(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE)
.bodyValue(identifiers)
.retrieve()
.bodyToMono(AltinnResponseDTO.class)
.bodyToMono(AltinnAccessListResponseDTO.class)
.doOnSuccess(value -> log.info("Altinn organisasjontilgang slettet for {}",
identifiers.getData().stream()
.filter(data -> data.contains(ORGANISASJON_ID))
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import no.nav.testnav.altinn3tilgangservice.config.AltinnConfig;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AltinnResponseDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AltinnAccessListResponseDTO;
import no.nav.testnav.libs.reactivecore.utils.WebClientFilter;
import org.springframework.http.HttpHeaders;
import org.springframework.http.MediaType;
Expand All @@ -14,7 +14,7 @@

@Slf4j
@RequiredArgsConstructor
public class GetAccessListMembersCommand implements Callable<Mono<AltinnResponseDTO>> {
public class GetAccessListMembersCommand implements Callable<Mono<AltinnAccessListResponseDTO>> {

private static final String ALTINN_URL = "/resourceregistry/api/v1/access-lists/{owner}/{identifier}/members";

Expand All @@ -23,7 +23,7 @@ public class GetAccessListMembersCommand implements Callable<Mono<AltinnResponse
private final AltinnConfig altinnConfig;

@Override
public Mono<AltinnResponseDTO> call() {
public Mono<AltinnAccessListResponseDTO> call() {

return webClient
.get()
Expand All @@ -32,7 +32,7 @@ public Mono<AltinnResponseDTO> call() {
.header(HttpHeaders.AUTHORIZATION, "Bearer " + token)
.header(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE)
.retrieve()
.bodyToMono(AltinnResponseDTO.class)
.bodyToMono(AltinnAccessListResponseDTO.class)
.doOnError(WebClientFilter::logErrorMessage)
.doOnSuccess(value -> log.info("Altinn-tilgang hentet"));
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
package no.nav.testnav.altinn3tilgangservice.consumer.altinn.command;

import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AltinnAuthorizedPartiesRequestDTO;
import no.nav.testnav.altinn3tilgangservice.consumer.altinn.dto.AuthorizedPartyDTO;
import no.nav.testnav.libs.reactivecore.utils.WebClientFilter;
import org.springframework.http.HttpHeaders;
import org.springframework.http.MediaType;
import org.springframework.web.reactive.function.client.WebClient;
import reactor.core.publisher.Mono;

import java.util.concurrent.Callable;

@Slf4j
@RequiredArgsConstructor
public class GetAuthorizedPartiesCommand implements Callable<Mono<AuthorizedPartyDTO[]>> {

private static final String ALTINN_URL = "/accessmanagement/api/v1/resourceowner/authorizedparties";

private final WebClient webClient;
private final AltinnAuthorizedPartiesRequestDTO request;
private final String token;

@Override
public Mono<AuthorizedPartyDTO[]> call() {

log.info("Spørring på bruker {}", request);
return webClient
.post()
.uri(builder -> builder.path(ALTINN_URL)
.build())
.header(HttpHeaders.AUTHORIZATION, "Bearer " + token)
.header(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE)
.bodyValue(request)
.retrieve()
.bodyToMono(AuthorizedPartyDTO[].class)
.doOnError(WebClientFilter::logErrorMessage);
}
}
Empty file.
Loading

0 comments on commit 233aca8

Please sign in to comment.