com.adama.api.config.apidoc.SwaggerConfiguration.java Source code

Java tutorial

Introduction

Here is the source code for com.adama.api.config.apidoc.SwaggerConfiguration.java

Source

package com.adama.api.config.apidoc;

import static springfox.documentation.builders.PathSelectors.regex;

import java.util.Date;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.domain.Pageable;
import org.springframework.http.ResponseEntity;
import org.springframework.util.StopWatch;

import com.adama.api.config.AdamaProperties;
import com.google.common.base.Predicates;

import lombok.extern.slf4j.Slf4j;
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 springfox.documentation.swagger2.annotations.EnableSwagger2;

/**
 * Springfox Swagger configuration.
 *
 */
@Slf4j
@Configuration
@EnableSwagger2
public class SwaggerConfiguration {
    /**
     * Swagger Springfox configuration.
     *
     * @param adamaProperties
     *            the properties of the application
     * @return the Swagger Springfox configuration
     */
    @Bean
    public Docket swaggerSpringfoxDocket(AdamaProperties adamaProperties) {
        log.debug("Starting Swagger");
        StopWatch watch = new StopWatch();
        watch.start();
        Contact contact = new Contact(adamaProperties.getSwagger().getContactName(),
                adamaProperties.getSwagger().getContactUrl(), adamaProperties.getSwagger().getContactEmail());
        ApiInfo apiInfo = new ApiInfo(adamaProperties.getSwagger().getTitle(),
                adamaProperties.getSwagger().getDescription(), adamaProperties.getSwagger().getVersion(),
                adamaProperties.getSwagger().getTermsOfServiceUrl(), contact,
                adamaProperties.getSwagger().getLicense(), adamaProperties.getSwagger().getLicenseUrl());
        Docket docket = new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo).forCodeGeneration(true)
                .genericModelSubstitutes(ResponseEntity.class).ignoredParameterTypes(Pageable.class)
                .useDefaultResponseMessages(false).directModelSubstitute(java.time.ZonedDateTime.class, Date.class)
                .directModelSubstitute(java.time.LocalDateTime.class, Date.class).select()
                .apis(Predicates.not(RequestHandlerSelectors.basePackage("org.springframework.boot")))
                .paths(regex("/.*")).build();
        watch.stop();
        log.debug("Started Swagger in {} ms", watch.getTotalTimeMillis());
        return docket;
    }
}