From 8d31c9e72401ee2cb240b3d799225693a96b55c6 Mon Sep 17 00:00:00 2001 From: Luis Pollo Date: Mon, 7 Dec 2020 16:06:04 -0800 Subject: [PATCH] chore(swagger): Upgrade SpringFox and Swagger --- .../spinnaker/config/SwaggerConfig.java | 22 ++++++++----------- .../spinnaker-dependencies.gradle | 6 ++--- 2 files changed, 12 insertions(+), 16 deletions(-) diff --git a/kork-swagger/src/main/java/com/netflix/spinnaker/config/SwaggerConfig.java b/kork-swagger/src/main/java/com/netflix/spinnaker/config/SwaggerConfig.java index 54823325c..c1a0f8e13 100644 --- a/kork-swagger/src/main/java/com/netflix/spinnaker/config/SwaggerConfig.java +++ b/kork-swagger/src/main/java/com/netflix/spinnaker/config/SwaggerConfig.java @@ -16,13 +16,10 @@ package com.netflix.spinnaker.config; -import static com.google.common.base.Predicates.or; - -import com.google.common.base.Predicate; import com.google.common.collect.ImmutableList; import java.util.List; import java.util.Objects; -import java.util.stream.Collectors; +import java.util.function.Predicate; import javax.annotation.Nullable; import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; import org.springframework.boot.context.properties.ConfigurationProperties; @@ -32,11 +29,9 @@ import springfox.documentation.builders.RequestHandlerSelectors; import springfox.documentation.service.ApiInfo; import springfox.documentation.spi.DocumentationType; -import springfox.documentation.spring.web.paths.AbstractPathProvider; +import springfox.documentation.spring.web.paths.DefaultPathProvider; import springfox.documentation.spring.web.plugins.Docket; -import springfox.documentation.swagger2.annotations.EnableSwagger2; -@EnableSwagger2 @Configuration @ConditionalOnProperty("swagger.enabled") @ConfigurationProperties(prefix = "swagger") @@ -80,7 +75,7 @@ private static Class getClassIfPresent(String name) { } private Predicate paths() { - return or(patterns.stream().map(PathSelectors::regex).collect(Collectors.toList())); + return patterns.stream().map(PathSelectors::regex).reduce(x -> false, Predicate::or); } private ApiInfo apiInfo() { @@ -123,7 +118,8 @@ public String getDocumentationPath() { return documentationPath; } - public class BasePathProvider extends AbstractPathProvider { + // TODO: make sure this works given https://github.com/springfox/springfox/issues/3493 + public class BasePathProvider extends DefaultPathProvider { private String basePath; private String documentationPath; @@ -133,13 +129,13 @@ private BasePathProvider(String basePath, String documentationPath) { } @Override - protected String applicationPath() { - return basePath; + public String getOperationPath(String operationPath) { + return documentationPath + "/" + super.getOperationPath(operationPath); } @Override - protected String getDocumentationPath() { - return documentationPath; + public String getResourceListingPath(String groupName, String apiDeclaration) { + return documentationPath + "/" + super.getResourceListingPath(groupName, apiDeclaration); } } } diff --git a/spinnaker-dependencies/spinnaker-dependencies.gradle b/spinnaker-dependencies/spinnaker-dependencies.gradle index ede0cf42c..16fff9c59 100644 --- a/spinnaker-dependencies/spinnaker-dependencies.gradle +++ b/spinnaker-dependencies/spinnaker-dependencies.gradle @@ -25,8 +25,8 @@ ext { spring : "5.2.9.RELEASE", // this should be kept in sync with spring-boot / removed once the need for a version override is gone springBoot : "2.2.5.RELEASE", springCloud : "Hoxton.SR4", - springfoxSwagger : "2.9.2", - swagger : "1.5.20" //this should stay in sync with what springfoxSwagger expects + springfoxSwagger : "3.0.0", + swagger : "2.1.2" //this should stay in sync with what springfoxSwagger expects ] } @@ -127,7 +127,7 @@ dependencies { api("io.mockk:mockk:1.10.0") api("io.springfox:springfox-swagger-ui:${versions.springfoxSwagger}") api("io.springfox:springfox-swagger2:${versions.springfoxSwagger}") - api("io.swagger:swagger-annotations:${versions.swagger}") + api("io.swagger.core.v3:swagger-annotations:${versions.swagger}") api("javax.annotation:javax.annotation-api:1.3.2") api("javax.xml.bind:jaxb-api:2.3.1") api("mysql:mysql-connector-java:8.0.20")