com.github.xiaoymin.swaggerbootstrapui.plugin.OperationAuthorBuilderPlugin Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of swagger-bootstrap-ui Show documentation
Show all versions of swagger-bootstrap-ui Show documentation
Swagger-Bootstrap-UI is the front of the UI Swagger implementation, using jQuery+bootstrap implementation, the purpose is to replace the default UI Swagger implementation of the Swagger-UI, so that the document is more friendly...
The newest version!
/*
* Copyright (C) 2018 Zhejiang xiaominfo Technology CO.,LTD.
* All rights reserved.
* Official Web Site: http://www.xiaominfo.com.
* Developer Web Site: http://open.xiaominfo.com.
*/
package com.github.xiaoymin.swaggerbootstrapui.plugin;
import com.google.common.base.Optional;
import com.google.common.collect.Lists;
import io.swagger.annotations.ApiOperationSupport;
import org.springframework.core.Ordered;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import springfox.documentation.service.StringVendorExtension;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spi.service.contexts.OperationContext;
/***
*
* @since:swagger-bootstrap-ui 1.0
* @author [email protected]
* 2019/06/06 20:16
*/
@Component
@Order(Ordered.HIGHEST_PRECEDENCE+101)
public class OperationAuthorBuilderPlugin extends AbstractOperationBuilderPlugin {
/***
* 添加作者属性
* @param context 接口上下文
*/
@Override
public void apply(OperationContext context) {
Optional apiOperationSupportOptional=context.findAnnotation(ApiOperationSupport.class);
if (apiOperationSupportOptional.isPresent()){
String author=apiOperationSupportOptional.get().author();
//判断非空
if (author!=null&&!"".equals(author)&&!"null".equals(author)){
context.operationBuilder().extensions(Lists.newArrayList(new StringVendorExtension("x-author",author)));
}
}
}
@Override
public boolean supports(DocumentationType delimiter) {
return true;
}
}