ApiDocumentation.java
package uk.gov.dhsc.htbhf.claimant;
import com.fasterxml.classmate.TypeResolver;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import springfox.bean.validators.configuration.BeanValidatorPluginsConfiguration;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import java.time.LocalDate;
import java.util.List;
import static java.util.Collections.emptyList;
import static springfox.documentation.schema.AlternateTypeRules.newRule;
/**
* Definitions of SpringFox beans to generate Swagger documentation.
*/
@Configuration
@Import(BeanValidatorPluginsConfiguration.class) // enable documentation of JSR-305 constraints
@Slf4j
public class ApiDocumentation {
@Value("${app.version:1.0}") // use APP_VERSION env variable if available, otherwise default to 1.0
private String appVersion;
@Autowired
private TypeResolver typeResolver;
@Bean
public Docket apiDocket() {
return new Docket(DocumentationType.SWAGGER_2)
.alternateTypeRules(
newRule(typeResolver.resolve(List.class, LocalDate.class),
typeResolver.resolve(List.class, String.class)))
.host("localhost:8090")
.select()
.apis(RequestHandlerSelectors.basePackage(this.getClass().getPackageName()))
.paths(PathSelectors.any())
.build()
.apiInfo(getApiInfo());
}
private ApiInfo getApiInfo() {
return new ApiInfo(
"Claimant Service",
"Responsible for the persistence and retrieval of Claims (and Claimants) for Help To Buy Healthy Food",
appVersion,
"",
new Contact("Department Of Health", "https://github.com/DepartmentOfHealth-htbhf", "dh-htbhf-team@equalexperts.com"),
"MIT",
"https://opensource.org/licenses/MIT",
emptyList()
);
}
}