com.github.xiaoymin.knife4j.spring.plugin.OperationDynamicResponseModelProvider Maven / Gradle / Ivy
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.knife4j.spring.plugin;
import com.fasterxml.classmate.ResolvedType;
import com.fasterxml.classmate.TypeResolver;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import com.github.xiaoymin.knife4j.annotations.DynamicParameter;
import com.github.xiaoymin.knife4j.annotations.DynamicResponseParameters;
import com.github.xiaoymin.knife4j.core.util.StrUtil;
import com.github.xiaoymin.knife4j.spring.util.ByteUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.Ordered;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spi.service.OperationModelsProviderPlugin;
import springfox.documentation.spi.service.contexts.RequestMappingContext;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
import java.util.Optional;
/***
* 动态添加响应类
* @since:swagger-bootstrap-ui 1.9.5
* @author [email protected]
* 2019/06/10 13:01
*/
@Component
@Order(Ordered.HIGHEST_PRECEDENCE+12)
public class OperationDynamicResponseModelProvider implements OperationModelsProviderPlugin {
@Autowired
private TypeResolver typeResolver;
private final Map cacheGenModelMaps=new HashMap<>();
@Override
public void apply(RequestMappingContext context) {
Optional supportOptional=context.findAnnotation(ApiOperationSupport.class);
//两个动态响应取1个
boolean flag=false;
if(supportOptional.isPresent()){
DynamicResponseParameters dynamicResponseParameters=supportOptional.get().responses();
if (dynamicResponseParameters!=null&&dynamicResponseParameters.properties()!=null&&dynamicResponseParameters.properties().length>0){
long count= Arrays.asList(dynamicResponseParameters.properties()).stream().filter(dynamicParameter -> StrUtil.isNotBlank(dynamicParameter.name())).count();
if (count>0){
flag=true;
collectDynamicParameter(supportOptional.get().responses(),context);
}
}
}
if (!flag){
Optional dynamicParametersOptional=context.findAnnotation(DynamicResponseParameters.class);
if (dynamicParametersOptional.isPresent()){
collectDynamicParameter(dynamicParametersOptional.get(),context);
}
}
}
@Override
public boolean supports(DocumentationType delimiter) {
return true;
}
private void collectDynamicParameter(DynamicResponseParameters dynamicParameters,RequestMappingContext context){
if (dynamicParameters!=null){
//name是否包含
String name=dynamicParameters.name();
if (name==null||"".equals(name)){
//gen
name=genClassName(context);
}
//判断是否存在
if (cacheGenModelMaps.containsKey(name)){
//存在,以方法名称作为ClassName
name=genClassName(context);
}
DynamicParameter[] dynamics=dynamicParameters.properties();
if (dynamics!=null&&dynamics.length>0){
cacheGenModelMaps.put(name,name);
//追加groupController
name=context.getGroupName().replaceAll("[_-]","")+"."+name+"Response";
Class> clazz= ByteUtils.createDynamicModelClass(name,dynamics);
if (clazz!=null){
ResolvedType modelType=context.alternateFor(typeResolver.resolve(clazz));
context.operationModelsBuilder().addReturn(modelType);
}
//context.operationModelsBuilder().addInputParam(typeResolver.resolve(clazz));
}
}
}
public String genClassName(RequestMappingContext context){
//gen
String name=context.getName();
if (name!=null&&!"".equals(name)){
name=name.replaceAll("[_-]","");
if (name.length()==1){
name=name.toUpperCase();
}else{
name=name.substring(0,1).toUpperCase()+name.substring(1);
}
}
return name;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy