AuthenticationTokenHeaderBuilderPlugin.java
package cn.home1.oss.lib.security.swagger;
import com.google.common.collect.Lists;
import cn.home1.oss.boot.autoconfigure.AppProperties;
import cn.home1.oss.boot.autoconfigure.AppSecurityProperties;
import cn.home1.oss.lib.security.api.Security;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.annotation.Order;
import springfox.documentation.builders.ParameterBuilder;
import springfox.documentation.schema.ModelRef;
import springfox.documentation.service.Parameter;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spi.service.OperationBuilderPlugin;
import springfox.documentation.spi.service.contexts.OperationContext;
import springfox.documentation.swagger.common.SwaggerPluginSupport;
import java.util.List;
/**
* Created by zhanghaolun on 16/11/1.
*/
@Order(SwaggerPluginSupport.SWAGGER_PLUGIN_ORDER)
public class AuthenticationTokenHeaderBuilderPlugin implements OperationBuilderPlugin {
private final ParameterBuilder parameterBuilder = new ParameterBuilder();
@Autowired
private AppProperties appProperties;
@Override
public void apply(final OperationContext operationContext) {
final AppSecurityProperties appSecurityProperties = this.appProperties.getSecurity();
final String loginEndpoint = appSecurityProperties.getLoginProcessingUrl();
// Get endpoint request mapping
final String mapping = operationContext.requestMappingPattern();
// Check if private api endpoint
if (appSecurityProperties.getEnabled() && !loginEndpoint.equals(mapping)) {
// Create auth header parameter
final String description = "Authentication token (see " + loginEndpoint + ")";
final List<Parameter> parameters = Lists.newArrayList( //
this.parameterBuilder
.parameterType("header")
.name(Security.HEADER_AUTH_TOKEN)
.modelRef(new ModelRef("string"))
.description(description)
.allowMultiple(false)
.required(false)
.build() //
);
// Add parameter to endpoint documentation
operationContext.operationBuilder().parameters(parameters);
}
}
@Override
public boolean supports(final DocumentationType delimiter) {
return DocumentationType.SWAGGER_2.equals(delimiter);
}
}