From 7459015b00ae11b496be686df402449d588180fc Mon Sep 17 00:00:00 2001 From: Felix Dittrich <31076102+f11h@users.noreply.github.com> Date: Tue, 14 Feb 2023 14:34:01 +0100 Subject: [PATCH] Update to Spring Boot 3 (#211) * Upgrade Code-Base to Java 17 Upgrade Code-Base to Spring Boot 3+ * Update CI Jobs to JDK 17 Update Dependencies * Update OWASP Suppressions * Fix Typo --- .github/workflows/ci-dependency-check.yml | 2 +- .github/workflows/ci-main.yml | 12 +-- .github/workflows/ci-openapi.yml | 4 +- .github/workflows/ci-pull-request.yml | 4 +- .github/workflows/ci-release-notes.yml | 2 +- .github/workflows/ci-release.yml | 4 +- .github/workflows/ci-sonar.yml | 4 +- .github/workflows/codeql.yml | 4 +- owasp/suppressions.xml | 28 +++--- pom.xml | 97 +++++-------------- .../ec/dgc/gateway/client/JrcClient.java | 2 +- .../ec/dgc/gateway/config/ErrorHandler.java | 11 +-- .../gateway/config/MdcCleanupInterceptor.java | 4 +- .../config/ValidationRuleSchemaProvider.java | 2 +- .../dgc/gateway/entity/AuditEventEntity.java | 12 +-- .../gateway/entity/RevocationBatchEntity.java | 20 ++-- .../entity/SignerInformationEntity.java | 16 +-- .../gateway/entity/TrustedIssuerEntity.java | 16 +-- .../gateway/entity/TrustedPartyEntity.java | 22 ++--- .../gateway/entity/ValidationRuleEntity.java | 18 ++-- .../ec/dgc/gateway/entity/ValuesetEntity.java | 10 +- .../exception/DgcgResponseException.java | 6 +- .../ec/dgc/gateway/model/JrcRatValueset.java | 2 +- .../gateway/model/JrcRatValuesetResponse.java | 2 +- .../repository/RevocationBatchRepository.java | 18 ++-- .../SignerInformationRepository.java | 2 +- .../repository/ValidationRuleRepository.java | 2 +- .../repository/ValuesetRepository.java | 2 +- .../CertificateRevocationListController.java | 4 +- .../controller/TrustListController.java | 4 +- .../controller/ValidationRuleController.java | 2 +- .../RevocationBatchDeleteRequestDto.java | 2 +- .../dto/revocation/RevocationBatchDto.java | 6 +- .../revocation/RevocationBatchListDto.java | 2 +- .../CertificateAuthenticationFilter.java | 8 +- .../restapi/filter/IpLoggingFilter.java | 8 +- .../service/RatValuesetUpdateService.java | 4 +- .../service/RevocationListCleanUpService.java | 3 +- .../service/RevocationListService.java | 2 +- .../service/ValidationRuleService.java | 2 +- .../dgc/gateway/service/ValuesetService.java | 2 +- .../SignerCertificateIntegrationTest.java | 22 ++--- .../restapi/filter/CertAuthFilterTest.java | 22 ++--- .../service/RatValuesetUpdateServiceTest.java | 2 +- 44 files changed, 188 insertions(+), 235 deletions(-) diff --git a/.github/workflows/ci-dependency-check.yml b/.github/workflows/ci-dependency-check.yml index 47996d71..d7b27f1e 100644 --- a/.github/workflows/ci-dependency-check.yml +++ b/.github/workflows/ci-dependency-check.yml @@ -15,7 +15,7 @@ jobs: steps: - uses: actions/setup-java@v2 with: - java-version: 11 + java-version: 17 distribution: adopt - uses: actions/checkout@v2 with: diff --git a/.github/workflows/ci-main.yml b/.github/workflows/ci-main.yml index f5d7a949..667d4406 100644 --- a/.github/workflows/ci-main.yml +++ b/.github/workflows/ci-main.yml @@ -6,11 +6,11 @@ on: - main jobs: build: - runs-on: ubuntu-20.04 + runs-on: ubuntu-latest steps: - uses: actions/setup-java@v2 with: - java-version: 11 + java-version: 17 distribution: adopt - uses: actions/checkout@v2 with: @@ -61,11 +61,11 @@ jobs: name: DGCG001_PRD path: target/DGCG001_PRD* build-docker: - runs-on: ubuntu-20.04 + runs-on: ubuntu-latest steps: - uses: actions/setup-java@v2 with: - java-version: 11 + java-version: 17 distribution: adopt - uses: actions/checkout@v2 with: @@ -115,11 +115,11 @@ jobs: APP_PACKAGES_USERNAME: ${{ github.actor }} APP_PACKAGES_PASSWORD: ${{ secrets.GITHUB_TOKEN }} license: - runs-on: ubuntu-20.04 + runs-on: ubuntu-latest steps: - uses: actions/setup-java@v2 with: - java-version: 11 + java-version: 17 distribution: adopt - uses: actions/checkout@v2 with: diff --git a/.github/workflows/ci-openapi.yml b/.github/workflows/ci-openapi.yml index af396736..0bc6d212 100644 --- a/.github/workflows/ci-openapi.yml +++ b/.github/workflows/ci-openapi.yml @@ -6,11 +6,11 @@ on: - created jobs: release: - runs-on: ubuntu-20.04 + runs-on: ubuntu-latest steps: - uses: actions/setup-java@v2 with: - java-version: 11 + java-version: 17 distribution: adopt - uses: actions/checkout@v2 with: diff --git a/.github/workflows/ci-pull-request.yml b/.github/workflows/ci-pull-request.yml index c9233c81..2d2cd89e 100644 --- a/.github/workflows/ci-pull-request.yml +++ b/.github/workflows/ci-pull-request.yml @@ -7,11 +7,11 @@ on: - reopened jobs: build: - runs-on: ubuntu-20.04 + runs-on: ubuntu-latest steps: - uses: actions/setup-java@v2 with: - java-version: 11 + java-version: 17 distribution: adopt - uses: actions/checkout@v2 with: diff --git a/.github/workflows/ci-release-notes.yml b/.github/workflows/ci-release-notes.yml index b12c3216..0027745d 100644 --- a/.github/workflows/ci-release-notes.yml +++ b/.github/workflows/ci-release-notes.yml @@ -5,7 +5,7 @@ on: - created jobs: release-notes: - runs-on: ubuntu-20.04 + runs-on: ubuntu-latest steps: - uses: actions/checkout@v2 with: diff --git a/.github/workflows/ci-release.yml b/.github/workflows/ci-release.yml index f28aebf6..0ac0ce43 100644 --- a/.github/workflows/ci-release.yml +++ b/.github/workflows/ci-release.yml @@ -5,11 +5,11 @@ on: - created jobs: release: - runs-on: ubuntu-20.04 + runs-on: ubuntu-latest steps: - uses: actions/setup-java@v2 with: - java-version: 11 + java-version: 17 distribution: adopt - uses: actions/checkout@v2 with: diff --git a/.github/workflows/ci-sonar.yml b/.github/workflows/ci-sonar.yml index 90171d45..5e7dcc41 100644 --- a/.github/workflows/ci-sonar.yml +++ b/.github/workflows/ci-sonar.yml @@ -10,11 +10,11 @@ on: - reopened jobs: sonar: - runs-on: ubuntu-20.04 + runs-on: ubuntu-latest steps: - uses: actions/setup-java@v2 with: - java-version: 11 + java-version: 17 distribution: adopt - uses: actions/checkout@v2 with: diff --git a/.github/workflows/codeql.yml b/.github/workflows/codeql.yml index 3aa4ba9f..b91a1f60 100644 --- a/.github/workflows/codeql.yml +++ b/.github/workflows/codeql.yml @@ -29,10 +29,10 @@ jobs: with: languages: ${{ matrix.language }} - - name: Setup Java 11 + - name: Setup Java uses: actions/setup-java@v2 with: - java-version: 11 + java-version: 17 distribution: adopt - name: Build diff --git a/owasp/suppressions.xml b/owasp/suppressions.xml index c9656353..02f3e651 100644 --- a/owasp/suppressions.xml +++ b/owasp/suppressions.xml @@ -1,29 +1,29 @@ - Bug only affects not used features of embedded tomcat. - CVE-2022-23181 + no YAML content from users is parsed within this service + CVE-2022-1471 - False Positive - CVE-2016-1000027 + Bitcoin CLI is not used by the JSON LD Lib + CVE-2021-3401 + CVE-2021-31876 - False Positive - Updated to newest version - CVE-2018-14335 + H2 is only used for testing, not production + CVE-2022-45868 - False Positive - CVE-2020-5408 + False positive. CVE is matching for hutools. OWASP Check matches for json-lib + CVE-2022-45688 - Only affecting example code shipped with tomcat. - CVE-2022-34305 + Both CVE are matching for eclipse ide + CVE-2008-7271 + CVE-2010-4647 - DGCG is not using YML User Input, Bug is fixed with SnameYAML 1.32, but CVE Matcher is invalid - CVE-2022-38751 - CVE-2022-38752 + Still WIP + CVE-2022-41862 - diff --git a/pom.xml b/pom.xml index 65dcd701..f8f35518 100644 --- a/pom.xml +++ b/pom.xml @@ -5,9 +5,9 @@ 4.0.0 - org.springframework.boot - spring-boot-starter-parent - 2.7.4 + org.springframework.cloud + spring-cloud-starter-parent + 2022.0.1 @@ -36,32 +36,27 @@ war - 11 - 11 - 11 + 17 + 17 + 17 UTF-8 UTF-8 - 7.1.2 - 5.7.3 - 1.18.24 - 4.17.0 - 1.6.11 - 1.5.2.Final - 1.70 - 3.1.0 + 2.0.0 + 8.0.2 + 1.6.14 + 1.5.3.Final + 1.72 + 4.1.1 1.14.1 - 4.42.0 - 2021.0.4 - 2.1.214 - 1.3.2 + 5.1.0 3.4.2 - 3.2.0 + 3.2.1 3.9.1.2184 0.8.8 - 1.7.0 + 1.7.1 EU Digital Green Certificate Gateway Service / dgc-gateway 2021 @@ -132,26 +127,14 @@ - - - - org.springframework.cloud - spring-cloud-dependencies - ${spring.cloud.version} - pom - import - - - - eu.europa.ec.dgc dgc-lib - ${dgc.lib.version} + ${dgclib.version} - com.vdurmont + org.semver4j semver4j ${semver4j.version} @@ -161,28 +144,12 @@ ${json-schema.version} - mysql - mysql-connector-java - - - org.springframework.boot - spring-boot-starter - - - org.yaml - snakeyaml - - - - - org.yaml - snakeyaml - [1.33,) + com.mysql + mysql-connector-j com.fasterxml.jackson.core jackson-databind - [2.13.4.2,) org.springframework.boot @@ -226,17 +193,6 @@ org.liquibase liquibase-core - - - org.apache.commons - commons-text - - - - - org.apache.commons - commons-text - [1.10.0,) org.projectlombok @@ -251,7 +207,6 @@ com.h2database h2 - ${h2.version} runtime @@ -261,13 +216,12 @@ org.bouncycastle - bcpkix-jdk15on + bcpkix-jdk18on ${bcpkix.version} org.springframework.security spring-security-web - ${spring.security.version} net.javacrumbs.shedlock @@ -284,11 +238,6 @@ - - org.apache.maven.plugins - maven-checkstyle-plugin - ${plugin.checkstyle.version} - org.sonarsource.scanner.maven sonar-maven-plugin @@ -334,14 +283,14 @@ ./owasp/suppressions.xml true + false org.springframework.boot spring-boot-maven-plugin - ${project.parent.version} - dev + dev,log2console 5000 30 @@ -369,10 +318,10 @@ org.apache.maven.plugins maven-checkstyle-plugin + ${plugin.checkstyle.version} codestyle/checkstyle.xml target/**/* - UTF-8 true true warning diff --git a/src/main/java/eu/europa/ec/dgc/gateway/client/JrcClient.java b/src/main/java/eu/europa/ec/dgc/gateway/client/JrcClient.java index b43e2863..ea408a4a 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/client/JrcClient.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/client/JrcClient.java @@ -21,7 +21,7 @@ package eu.europa.ec.dgc.gateway.client; import eu.europa.ec.dgc.gateway.model.JrcRatValuesetResponse; -import javax.validation.Valid; +import jakarta.validation.Valid; import org.springframework.cloud.openfeign.FeignClient; import org.springframework.http.MediaType; import org.springframework.validation.annotation.Validated; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/config/ErrorHandler.java b/src/main/java/eu/europa/ec/dgc/gateway/config/ErrorHandler.java index 93f16dcb..c5dc61f8 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/config/ErrorHandler.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/config/ErrorHandler.java @@ -22,7 +22,7 @@ import eu.europa.ec.dgc.gateway.exception.DgcgResponseException; import eu.europa.ec.dgc.gateway.restapi.dto.ProblemReportDto; -import javax.validation.ConstraintViolationException; +import jakarta.validation.ConstraintViolationException; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.context.annotation.Configuration; @@ -31,7 +31,6 @@ import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.ControllerAdvice; import org.springframework.web.bind.annotation.ExceptionHandler; -import org.springframework.web.server.ResponseStatusException; import org.springframework.web.servlet.mvc.method.annotation.ResponseEntityExceptionHandler; @ControllerAdvice @@ -63,12 +62,12 @@ public ResponseEntity handleException(ConstraintViolationExcep @ExceptionHandler(Exception.class) public ResponseEntity handleException(Exception e) { - if (e instanceof DgcgResponseException) { - DgcgResponseException de = (DgcgResponseException) e; + if (e instanceof DgcgResponseException dgcgException) { return ResponseEntity - .status(((ResponseStatusException) e).getStatus()) + .status(dgcgException.getStatus()) .contentType(MediaType.APPLICATION_JSON) - .body(new ProblemReportDto(de.getCode(), de.getProblem(), de.getSentValues(), de.getDetails())); + .body(new ProblemReportDto(dgcgException.getCode(), dgcgException.getProblem(), + dgcgException.getSentValues(), dgcgException.getDetails())); } else { log.error("Uncaught exception", e); return ResponseEntity diff --git a/src/main/java/eu/europa/ec/dgc/gateway/config/MdcCleanupInterceptor.java b/src/main/java/eu/europa/ec/dgc/gateway/config/MdcCleanupInterceptor.java index 7804043e..e450d664 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/config/MdcCleanupInterceptor.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/config/MdcCleanupInterceptor.java @@ -21,8 +21,8 @@ package eu.europa.ec.dgc.gateway.config; import eu.europa.ec.dgc.gateway.utils.DgcMdc; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; import org.springframework.web.servlet.HandlerInterceptor; public class MdcCleanupInterceptor implements HandlerInterceptor { diff --git a/src/main/java/eu/europa/ec/dgc/gateway/config/ValidationRuleSchemaProvider.java b/src/main/java/eu/europa/ec/dgc/gateway/config/ValidationRuleSchemaProvider.java index 1033f3c3..58e8064d 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/config/ValidationRuleSchemaProvider.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/config/ValidationRuleSchemaProvider.java @@ -20,9 +20,9 @@ package eu.europa.ec.dgc.gateway.config; +import jakarta.annotation.PostConstruct; import java.io.IOException; import java.io.InputStream; -import javax.annotation.PostConstruct; import lombok.Getter; import lombok.RequiredArgsConstructor; import org.everit.json.schema.Schema; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/entity/AuditEventEntity.java b/src/main/java/eu/europa/ec/dgc/gateway/entity/AuditEventEntity.java index 2829f78b..66df288f 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/entity/AuditEventEntity.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/entity/AuditEventEntity.java @@ -20,13 +20,13 @@ package eu.europa.ec.dgc.gateway.entity; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import java.time.ZonedDateTime; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/entity/RevocationBatchEntity.java b/src/main/java/eu/europa/ec/dgc/gateway/entity/RevocationBatchEntity.java index fbb619ea..0585263d 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/entity/RevocationBatchEntity.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/entity/RevocationBatchEntity.java @@ -20,17 +20,17 @@ package eu.europa.ec.dgc.gateway.entity; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.EnumType; +import jakarta.persistence.Enumerated; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Index; +import jakarta.persistence.Lob; +import jakarta.persistence.Table; import java.time.ZonedDateTime; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.EnumType; -import javax.persistence.Enumerated; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Index; -import javax.persistence.Lob; -import javax.persistence.Table; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/entity/SignerInformationEntity.java b/src/main/java/eu/europa/ec/dgc/gateway/entity/SignerInformationEntity.java index 825e48f7..df68e905 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/entity/SignerInformationEntity.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/entity/SignerInformationEntity.java @@ -20,15 +20,15 @@ package eu.europa.ec.dgc.gateway.entity; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.EnumType; +import jakarta.persistence.Enumerated; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import java.time.ZonedDateTime; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.EnumType; -import javax.persistence.Enumerated; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/entity/TrustedIssuerEntity.java b/src/main/java/eu/europa/ec/dgc/gateway/entity/TrustedIssuerEntity.java index 02577dbd..6a17bd02 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/entity/TrustedIssuerEntity.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/entity/TrustedIssuerEntity.java @@ -20,15 +20,15 @@ package eu.europa.ec.dgc.gateway.entity; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.EnumType; +import jakarta.persistence.Enumerated; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import java.time.ZonedDateTime; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.EnumType; -import javax.persistence.Enumerated; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; import lombok.Getter; import lombok.Setter; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/entity/TrustedPartyEntity.java b/src/main/java/eu/europa/ec/dgc/gateway/entity/TrustedPartyEntity.java index 85d51778..f59e7a0b 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/entity/TrustedPartyEntity.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/entity/TrustedPartyEntity.java @@ -20,19 +20,19 @@ package eu.europa.ec.dgc.gateway.entity; +import jakarta.persistence.CollectionTable; +import jakarta.persistence.Column; +import jakarta.persistence.ElementCollection; +import jakarta.persistence.Entity; +import jakarta.persistence.EnumType; +import jakarta.persistence.Enumerated; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import java.time.ZonedDateTime; import java.util.List; -import javax.persistence.CollectionTable; -import javax.persistence.Column; -import javax.persistence.ElementCollection; -import javax.persistence.Entity; -import javax.persistence.EnumType; -import javax.persistence.Enumerated; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; import lombok.Getter; import lombok.Setter; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/entity/ValidationRuleEntity.java b/src/main/java/eu/europa/ec/dgc/gateway/entity/ValidationRuleEntity.java index ead22415..38fad1a5 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/entity/ValidationRuleEntity.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/entity/ValidationRuleEntity.java @@ -20,16 +20,16 @@ package eu.europa.ec.dgc.gateway.entity; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.EnumType; +import jakarta.persistence.Enumerated; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; +import jakarta.persistence.UniqueConstraint; import java.time.ZonedDateTime; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.EnumType; -import javax.persistence.Enumerated; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; -import javax.persistence.UniqueConstraint; import lombok.Getter; import lombok.Setter; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/entity/ValuesetEntity.java b/src/main/java/eu/europa/ec/dgc/gateway/entity/ValuesetEntity.java index 1ecfacb5..98be0660 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/entity/ValuesetEntity.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/entity/ValuesetEntity.java @@ -20,11 +20,11 @@ package eu.europa.ec.dgc.gateway.entity; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.Id; -import javax.persistence.Lob; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.Id; +import jakarta.persistence.Lob; +import jakarta.persistence.Table; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/exception/DgcgResponseException.java b/src/main/java/eu/europa/ec/dgc/gateway/exception/DgcgResponseException.java index 535ba93d..2ee3c068 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/exception/DgcgResponseException.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/exception/DgcgResponseException.java @@ -22,15 +22,15 @@ import lombok.Getter; import org.springframework.http.HttpStatus; -import org.springframework.web.server.ResponseStatusException; @Getter -public class DgcgResponseException extends ResponseStatusException { +public class DgcgResponseException extends RuntimeException { private final String code; private final String details; private final String sentValues; private final String problem; + private final HttpStatus status; /** * All Args constructor for DgcgResponseException. @@ -42,7 +42,7 @@ public class DgcgResponseException extends ResponseStatusException { * @param problem short problem description. */ public DgcgResponseException(HttpStatus status, String code, String problem, String sentValues, String details) { - super(status); + this.status = status; this.code = code; this.details = details; this.sentValues = sentValues; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/model/JrcRatValueset.java b/src/main/java/eu/europa/ec/dgc/gateway/model/JrcRatValueset.java index 647a67ea..b950aaab 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/model/JrcRatValueset.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/model/JrcRatValueset.java @@ -22,9 +22,9 @@ import com.fasterxml.jackson.annotation.JsonFormat; import com.fasterxml.jackson.annotation.JsonProperty; +import jakarta.validation.constraints.NotNull; import java.time.ZonedDateTime; import java.util.List; -import javax.validation.constraints.NotNull; import lombok.Data; @Data diff --git a/src/main/java/eu/europa/ec/dgc/gateway/model/JrcRatValuesetResponse.java b/src/main/java/eu/europa/ec/dgc/gateway/model/JrcRatValuesetResponse.java index 46173393..a996ff3f 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/model/JrcRatValuesetResponse.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/model/JrcRatValuesetResponse.java @@ -22,9 +22,9 @@ import com.fasterxml.jackson.annotation.JsonFormat; import com.fasterxml.jackson.annotation.JsonProperty; +import jakarta.validation.constraints.NotNull; import java.time.ZonedDateTime; import java.util.List; -import javax.validation.constraints.NotNull; import lombok.Data; @Data diff --git a/src/main/java/eu/europa/ec/dgc/gateway/repository/RevocationBatchRepository.java b/src/main/java/eu/europa/ec/dgc/gateway/repository/RevocationBatchRepository.java index 74a5a02d..94d6fc17 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/repository/RevocationBatchRepository.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/repository/RevocationBatchRepository.java @@ -22,10 +22,10 @@ import eu.europa.ec.dgc.gateway.entity.RevocationBatchEntity; import eu.europa.ec.dgc.gateway.entity.RevocationBatchProjection; +import jakarta.transaction.Transactional; import java.time.ZonedDateTime; import java.util.List; import java.util.Optional; -import javax.transaction.Transactional; import org.springframework.data.domain.Pageable; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.data.jpa.repository.Modifying; @@ -44,14 +44,18 @@ public interface RevocationBatchRepository extends JpaRepository getByBatchId(String batchId); @Modifying - @Query("UPDATE RevocationBatchEntity r SET r.signedBatch = null, r.deleted = true, " - + "r.changed = current_timestamp WHERE r.batchId = :batchId") - int markBatchAsDeleted(@Param("batchId") String batchId); + @Query(""" + UPDATE RevocationBatchEntity r SET r.signedBatch = null, r.deleted = true, + r.changed = :currentTimestamp WHERE r.batchId = :batchId""") + int markBatchAsDeleted(@Param("batchId") String batchId, + @Param("currentTimestamp") ZonedDateTime currentTimestamp); @Modifying - @Query("UPDATE RevocationBatchEntity r SET r.signedBatch = null, r.deleted = true, " - + "r.changed = current_timestamp WHERE r.deleted = false AND r.expires < :threshold") - int markExpiredBatchesAsDeleted(@Param("threshold") ZonedDateTime threshold); + @Query(""" + UPDATE RevocationBatchEntity r SET r.signedBatch = null, r.deleted = true, + r.changed = :currentTimestamp WHERE r.deleted = false AND r.expires < :threshold""") + int markExpiredBatchesAsDeleted(@Param("threshold") ZonedDateTime threshold, + @Param("currentTimestamp") ZonedDateTime currentTimestamp); @Modifying @Query("DELETE FROM RevocationBatchEntity r WHERE r.deleted = true AND r.changed < :threshold") diff --git a/src/main/java/eu/europa/ec/dgc/gateway/repository/SignerInformationRepository.java b/src/main/java/eu/europa/ec/dgc/gateway/repository/SignerInformationRepository.java index e0f5a3ec..cfd26b40 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/repository/SignerInformationRepository.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/repository/SignerInformationRepository.java @@ -21,10 +21,10 @@ package eu.europa.ec.dgc.gateway.repository; import eu.europa.ec.dgc.gateway.entity.SignerInformationEntity; +import jakarta.transaction.Transactional; import java.time.ZonedDateTime; import java.util.List; import java.util.Optional; -import javax.transaction.Transactional; import org.springframework.data.domain.Pageable; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.data.jpa.repository.Modifying; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/repository/ValidationRuleRepository.java b/src/main/java/eu/europa/ec/dgc/gateway/repository/ValidationRuleRepository.java index 2f38175f..580093de 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/repository/ValidationRuleRepository.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/repository/ValidationRuleRepository.java @@ -21,10 +21,10 @@ package eu.europa.ec.dgc.gateway.repository; import eu.europa.ec.dgc.gateway.entity.ValidationRuleEntity; +import jakarta.transaction.Transactional; import java.time.ZonedDateTime; import java.util.List; import java.util.Optional; -import javax.transaction.Transactional; import org.springframework.data.domain.Pageable; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.data.jpa.repository.Modifying; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/repository/ValuesetRepository.java b/src/main/java/eu/europa/ec/dgc/gateway/repository/ValuesetRepository.java index 3b2346dc..eb3c099d 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/repository/ValuesetRepository.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/repository/ValuesetRepository.java @@ -21,8 +21,8 @@ package eu.europa.ec.dgc.gateway.repository; import eu.europa.ec.dgc.gateway.entity.ValuesetEntity; +import jakarta.transaction.Transactional; import java.util.List; -import javax.transaction.Transactional; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.data.jpa.repository.Query; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/CertificateRevocationListController.java b/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/CertificateRevocationListController.java index f68e93a3..b9fe0874 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/CertificateRevocationListController.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/CertificateRevocationListController.java @@ -43,9 +43,9 @@ import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.responses.ApiResponse; import io.swagger.v3.oas.annotations.security.SecurityRequirement; +import jakarta.validation.Valid; +import jakarta.validation.constraints.Pattern; import java.time.ZonedDateTime; -import javax.validation.Valid; -import javax.validation.constraints.Pattern; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.format.annotation.DateTimeFormat; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/TrustListController.java b/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/TrustListController.java index 4da39412..48a1bb69 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/TrustListController.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/TrustListController.java @@ -42,11 +42,11 @@ import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.responses.ApiResponse; import io.swagger.v3.oas.annotations.security.SecurityRequirement; +import jakarta.validation.Valid; +import jakarta.validation.constraints.Size; import java.time.ZonedDateTime; import java.util.List; import java.util.Locale; -import javax.validation.Valid; -import javax.validation.constraints.Size; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.apache.commons.collections.CollectionUtils; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/ValidationRuleController.java b/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/ValidationRuleController.java index 220eba22..fcd748f6 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/ValidationRuleController.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/restapi/controller/ValidationRuleController.java @@ -41,11 +41,11 @@ import io.swagger.v3.oas.annotations.parameters.RequestBody; import io.swagger.v3.oas.annotations.responses.ApiResponse; import io.swagger.v3.oas.annotations.security.SecurityRequirement; +import jakarta.validation.Valid; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; -import javax.validation.Valid; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.hibernate.validator.constraints.Length; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchDeleteRequestDto.java b/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchDeleteRequestDto.java index 6c5f3a63..44d962c7 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchDeleteRequestDto.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchDeleteRequestDto.java @@ -21,7 +21,7 @@ package eu.europa.ec.dgc.gateway.restapi.dto.revocation; import io.swagger.v3.oas.annotations.media.Schema; -import javax.validation.constraints.Pattern; +import jakarta.validation.constraints.Pattern; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchDto.java b/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchDto.java index a1b5039f..21b15234 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchDto.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchDto.java @@ -21,11 +21,11 @@ package eu.europa.ec.dgc.gateway.restapi.dto.revocation; import io.swagger.v3.oas.annotations.media.Schema; +import jakarta.validation.constraints.NotNull; +import jakarta.validation.constraints.Pattern; +import jakarta.validation.constraints.Size; import java.time.ZonedDateTime; import java.util.List; -import javax.validation.constraints.NotNull; -import javax.validation.constraints.Pattern; -import javax.validation.constraints.Size; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchListDto.java b/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchListDto.java index 590719aa..10b32424 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchListDto.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/restapi/dto/revocation/RevocationBatchListDto.java @@ -21,9 +21,9 @@ package eu.europa.ec.dgc.gateway.restapi.dto.revocation; import io.swagger.v3.oas.annotations.media.Schema; +import jakarta.validation.constraints.Pattern; import java.time.ZonedDateTime; import java.util.List; -import javax.validation.constraints.Pattern; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/restapi/filter/CertificateAuthenticationFilter.java b/src/main/java/eu/europa/ec/dgc/gateway/restapi/filter/CertificateAuthenticationFilter.java index 18adf0df..2bc88434 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/restapi/filter/CertificateAuthenticationFilter.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/restapi/filter/CertificateAuthenticationFilter.java @@ -26,6 +26,10 @@ import eu.europa.ec.dgc.gateway.restapi.mapper.CertificateRoleMapper; import eu.europa.ec.dgc.gateway.service.TrustedPartyService; import eu.europa.ec.dgc.gateway.utils.DgcMdc; +import jakarta.servlet.FilterChain; +import jakarta.servlet.ServletException; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; import java.io.IOException; import java.net.URLDecoder; import java.nio.charset.StandardCharsets; @@ -34,10 +38,6 @@ import java.util.Map; import java.util.Optional; import java.util.stream.Collectors; -import javax.servlet.FilterChain; -import javax.servlet.ServletException; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; import lombok.AllArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.bouncycastle.util.encoders.DecoderException; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/restapi/filter/IpLoggingFilter.java b/src/main/java/eu/europa/ec/dgc/gateway/restapi/filter/IpLoggingFilter.java index 0ee1bcb7..b8ba49a8 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/restapi/filter/IpLoggingFilter.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/restapi/filter/IpLoggingFilter.java @@ -21,11 +21,11 @@ package eu.europa.ec.dgc.gateway.restapi.filter; import eu.europa.ec.dgc.gateway.utils.DgcMdc; +import jakarta.servlet.FilterChain; +import jakarta.servlet.ServletException; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; import java.io.IOException; -import javax.servlet.FilterChain; -import javax.servlet.ServletException; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; import lombok.AllArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Component; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/service/RatValuesetUpdateService.java b/src/main/java/eu/europa/ec/dgc/gateway/service/RatValuesetUpdateService.java index 0d9d0f8f..b16b5258 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/service/RatValuesetUpdateService.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/service/RatValuesetUpdateService.java @@ -31,13 +31,13 @@ import eu.europa.ec.dgc.gateway.model.Valueset; import eu.europa.ec.dgc.gateway.utils.DgcMdc; import feign.FeignException; +import jakarta.annotation.PostConstruct; +import jakarta.validation.ConstraintViolationException; import java.time.LocalDate; import java.time.ZonedDateTime; import java.util.Comparator; import java.util.HashMap; import java.util.Optional; -import javax.annotation.PostConstruct; -import javax.validation.ConstraintViolationException; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import net.javacrumbs.shedlock.spring.annotation.SchedulerLock; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/service/RevocationListCleanUpService.java b/src/main/java/eu/europa/ec/dgc/gateway/service/RevocationListCleanUpService.java index b8e74304..49c65a83 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/service/RevocationListCleanUpService.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/service/RevocationListCleanUpService.java @@ -46,7 +46,8 @@ public class RevocationListCleanUpService { public void cleanup() { log.info("Starting Revocation List Cleanup Job."); - int affectedRowsMarkAsDeleted = revocationBatchRepository.markExpiredBatchesAsDeleted(ZonedDateTime.now()); + int affectedRowsMarkAsDeleted = revocationBatchRepository + .markExpiredBatchesAsDeleted(ZonedDateTime.now(), ZonedDateTime.now()); log.info("Marked {} Revocation Batches as deleted.", affectedRowsMarkAsDeleted); int affectedRowsDeleted = revocationBatchRepository.deleteDeletedBatchesOlderThan( diff --git a/src/main/java/eu/europa/ec/dgc/gateway/service/RevocationListService.java b/src/main/java/eu/europa/ec/dgc/gateway/service/RevocationListService.java index e436f647..56f53840 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/service/RevocationListService.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/service/RevocationListService.java @@ -177,7 +177,7 @@ public void deleteRevocationBatch( log.info("Deleting Revocation Batch with Batch ID {} from DB", parsedDeleteRequest.getBatchId()); - revocationBatchRepository.markBatchAsDeleted(parsedDeleteRequest.getBatchId()); + revocationBatchRepository.markBatchAsDeleted(parsedDeleteRequest.getBatchId(), ZonedDateTime.now()); auditService.addAuditEvent( authenticatedCountryCode, diff --git a/src/main/java/eu/europa/ec/dgc/gateway/service/ValidationRuleService.java b/src/main/java/eu/europa/ec/dgc/gateway/service/ValidationRuleService.java index bf01f4e3..71050de4 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/service/ValidationRuleService.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/service/ValidationRuleService.java @@ -25,7 +25,6 @@ import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.DeserializationFeature; import com.fasterxml.jackson.databind.ObjectMapper; -import com.vdurmont.semver4j.Semver; import eu.europa.ec.dgc.gateway.config.ValidationRuleSchemaProvider; import eu.europa.ec.dgc.gateway.entity.TrustedPartyEntity; import eu.europa.ec.dgc.gateway.entity.ValidationRuleEntity; @@ -51,6 +50,7 @@ import org.everit.json.schema.ValidationException; import org.json.JSONException; import org.json.JSONObject; +import org.semver4j.Semver; import org.springframework.data.domain.PageRequest; import org.springframework.stereotype.Service; diff --git a/src/main/java/eu/europa/ec/dgc/gateway/service/ValuesetService.java b/src/main/java/eu/europa/ec/dgc/gateway/service/ValuesetService.java index af1ec74a..4a0595b7 100644 --- a/src/main/java/eu/europa/ec/dgc/gateway/service/ValuesetService.java +++ b/src/main/java/eu/europa/ec/dgc/gateway/service/ValuesetService.java @@ -23,9 +23,9 @@ import eu.europa.ec.dgc.gateway.entity.ValuesetEntity; import eu.europa.ec.dgc.gateway.repository.ValuesetRepository; import eu.europa.ec.dgc.gateway.utils.DgcMdc; +import jakarta.transaction.Transactional; import java.util.List; import java.util.Optional; -import javax.transaction.Transactional; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; diff --git a/src/test/java/eu/europa/ec/dgc/gateway/restapi/controller/SignerCertificateIntegrationTest.java b/src/test/java/eu/europa/ec/dgc/gateway/restapi/controller/SignerCertificateIntegrationTest.java index 3c1021d8..40a13b91 100644 --- a/src/test/java/eu/europa/ec/dgc/gateway/restapi/controller/SignerCertificateIntegrationTest.java +++ b/src/test/java/eu/europa/ec/dgc/gateway/restapi/controller/SignerCertificateIntegrationTest.java @@ -106,7 +106,7 @@ void testSuccessfulUpload() throws Exception { String authCertHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .content(payload) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) @@ -157,7 +157,7 @@ void testUploadFailedConflict() throws Exception { String authCertHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .content(payload) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) @@ -165,7 +165,7 @@ void testUploadFailedConflict() throws Exception { ) .andExpect(status().isCreated()); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .content(payload) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) @@ -203,7 +203,7 @@ void testUploadFailedInvalidCSCA() throws Exception { String authCertHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .content(payload) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) @@ -242,7 +242,7 @@ void testUploadFailedInvalidCSCAWrongCountryCode() throws Exception { String authCertHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .content(payload) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) @@ -281,7 +281,7 @@ void testUploadFailedPayloadCertCountryWrong() throws Exception { String authCertHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .content(payload) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) @@ -320,7 +320,7 @@ void testUploadFailedWrongSignerCertificate() throws Exception { String authCertHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .content(payload) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) @@ -361,7 +361,7 @@ void testUploadFailedInvalidCmsMessage() throws Exception { String authCertHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .content(payload) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) @@ -407,7 +407,7 @@ void testReupload() throws Exception { String authCertHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .content(payloadString) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) @@ -432,7 +432,7 @@ void testReupload() throws Exception { /* * Step 2: Delete DSC */ - mockMvc.perform(delete("/signerCertificate/") + mockMvc.perform(delete("/signerCertificate") .content(payloadString) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) @@ -456,7 +456,7 @@ void testReupload() throws Exception { /* * Step 3: Reupload DSC */ - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .content(payloadString) .contentType("application/cms") .header(dgcConfigProperties.getCertAuth().getHeaderFields().getThumbprint(), authCertHash) diff --git a/src/test/java/eu/europa/ec/dgc/gateway/restapi/filter/CertAuthFilterTest.java b/src/test/java/eu/europa/ec/dgc/gateway/restapi/filter/CertAuthFilterTest.java index c3491cf6..a58bf6da 100644 --- a/src/test/java/eu/europa/ec/dgc/gateway/restapi/filter/CertAuthFilterTest.java +++ b/src/test/java/eu/europa/ec/dgc/gateway/restapi/filter/CertAuthFilterTest.java @@ -58,7 +58,7 @@ void testRequestShouldFailIfDNHeaderIsMissing() throws Exception { String certHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") .header(properties.getCertAuth().getHeaderFields().getThumbprint(), certHash) ).andExpect(status().isUnauthorized()); @@ -66,7 +66,7 @@ void testRequestShouldFailIfDNHeaderIsMissing() throws Exception { @Test void testRequestShouldFailIfThumbprintHeaderIsMissing() throws Exception { - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") .header(properties.getCertAuth().getHeaderFields().getDistinguishedName(), authDn) ).andExpect(status().isUnauthorized()); @@ -74,14 +74,14 @@ void testRequestShouldFailIfThumbprintHeaderIsMissing() throws Exception { @Test void testRequestShouldFailIfCertHeadersAreMissing() throws Exception { - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") ).andExpect(status().isUnauthorized()); } @Test void testRequestShouldFailIfCertIsNotOnWhitelist() throws Exception { - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") .header(properties.getCertAuth().getHeaderFields().getThumbprint(), "randomString") .header(properties.getCertAuth().getHeaderFields().getDistinguishedName(), authDn) @@ -93,7 +93,7 @@ void testFilterShouldAppendCountryAndThumbprintToRequestObject() throws Exceptio String certHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") .header(properties.getCertAuth().getHeaderFields().getThumbprint(), certHash) .header(properties.getCertAuth().getHeaderFields().getDistinguishedName(), authDn) @@ -115,7 +115,7 @@ void testFilterShouldDecodeDnString() throws Exception { String certHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") .header(properties.getCertAuth().getHeaderFields().getThumbprint(), certHash) .header(properties.getCertAuth().getHeaderFields().getDistinguishedName(), encodedDnString) @@ -144,7 +144,7 @@ void testFilterShouldDecodeBase64AndUrlEncodedCertThumbprint() throws Exception String encodedThumbprint = URLEncoder.encode(Base64.getEncoder().encodeToString(certHashBytes), StandardCharsets.UTF_8); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") .header(properties.getCertAuth().getHeaderFields().getThumbprint(), encodedThumbprint) .header(properties.getCertAuth().getHeaderFields().getDistinguishedName(), @@ -173,7 +173,7 @@ void testFilterShouldDecodeBase64EncodedCertThumbprint() throws Exception { String encodedThumbprint = Base64.getEncoder().encodeToString(certHashBytes); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") .header(properties.getCertAuth().getHeaderFields().getThumbprint(), encodedThumbprint) .header(properties.getCertAuth().getHeaderFields().getDistinguishedName(), @@ -194,7 +194,7 @@ void testRequestShouldFailIfCountryIsNotPresentInDnString() throws Exception { String certHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") .header(properties.getCertAuth().getHeaderFields().getThumbprint(), certHash) .header(properties.getCertAuth().getHeaderFields().getDistinguishedName(), @@ -207,7 +207,7 @@ void testFilterShouldFindCountryEvenOnMalformedDnString() throws Exception { String certHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") .header(properties.getCertAuth().getHeaderFields().getThumbprint(), certHash) .header(properties.getCertAuth().getHeaderFields().getDistinguishedName(), @@ -221,7 +221,7 @@ void testRequestShouldNotFailIfDnStringContainsDuplicatedKeys() throws Exception String certHash = trustedPartyTestHelper.getHash(TrustedPartyEntity.CertificateType.AUTHENTICATION, countryCode); - mockMvc.perform(post("/signerCertificate/") + mockMvc.perform(post("/signerCertificate") .contentType("application/cms") .header(properties.getCertAuth().getHeaderFields().getThumbprint(), certHash) .header(properties.getCertAuth().getHeaderFields().getDistinguishedName(), diff --git a/src/test/java/eu/europa/ec/dgc/gateway/service/RatValuesetUpdateServiceTest.java b/src/test/java/eu/europa/ec/dgc/gateway/service/RatValuesetUpdateServiceTest.java index a386d8bd..3ed0f9aa 100644 --- a/src/test/java/eu/europa/ec/dgc/gateway/service/RatValuesetUpdateServiceTest.java +++ b/src/test/java/eu/europa/ec/dgc/gateway/service/RatValuesetUpdateServiceTest.java @@ -36,6 +36,7 @@ import feign.FeignException; import feign.Request; import feign.RequestTemplate; +import jakarta.validation.ConstraintViolationException; import java.time.LocalDate; import java.time.ZonedDateTime; import java.time.temporal.ChronoUnit; @@ -43,7 +44,6 @@ import java.util.HashMap; import java.util.List; import java.util.Map; -import javax.validation.ConstraintViolationException; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test;