提交 294a10fa 编写于 作者: sq3536's avatar sq3536

url改造

上级 d43bc8ba
package cn.ibizlab; package cn.ibizlab;
import cn.ibizlab.core.util.config.FilterDataResolver;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient; import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
...@@ -40,7 +39,7 @@ public class DevBootApplication extends WebMvcConfigurerAdapter { ...@@ -40,7 +39,7 @@ public class DevBootApplication extends WebMvcConfigurerAdapter {
@Autowired @Autowired
FilterDataResolver filterDataResolver; SearchContextHandlerMethodArgumentResolver resolver;
public static void main(String[] args) { public static void main(String[] args) {
SpringApplication.run(DevBootApplication.class, args); SpringApplication.run(DevBootApplication.class, args);
...@@ -49,6 +48,6 @@ public class DevBootApplication extends WebMvcConfigurerAdapter { ...@@ -49,6 +48,6 @@ public class DevBootApplication extends WebMvcConfigurerAdapter {
@Override @Override
public void addArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) { public void addArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) {
super.addArgumentResolvers(argumentResolvers); super.addArgumentResolvers(argumentResolvers);
argumentResolvers.add(filterDataResolver); argumentResolvers.add(resolver);
} }
} }
...@@ -115,10 +115,20 @@ public class DevBootSecurityConfig extends WebSecurityConfigurerAdapter { ...@@ -115,10 +115,20 @@ public class DevBootSecurityConfig extends WebSecurityConfigurerAdapter {
.antMatchers( HttpMethod.GET, "/"+logoutPath).permitAll() .antMatchers( HttpMethod.GET, "/"+logoutPath).permitAll()
// 文件操作 // 文件操作
.antMatchers("/"+downloadpath+"/**").permitAll() .antMatchers("/"+downloadpath+"/**").permitAll()
.antMatchers("/ibiz-repository/**").permitAll()
.antMatchers("/ibiz-repo/**").permitAll()
.antMatchers("/"+uploadpath).permitAll() .antMatchers("/"+uploadpath).permitAll()
.antMatchers("/"+previewpath+"/**").permitAll(); .antMatchers("/"+previewpath+"/**").permitAll()
.antMatchers( HttpMethod.POST, "/ibiz-repo**/**/"+loginPath).permitAll()
//放行注销请求
.antMatchers( HttpMethod.GET, "/ibiz-repo**/**/"+logoutPath).permitAll()
// 文件操作
.antMatchers("/ibiz-repo**/**/"+downloadpath+"/**").permitAll()
.antMatchers("/ibiz-repo**/**/"+uploadpath).permitAll()
.antMatchers("/ibiz-repo**/**/"+previewpath+"/**").permitAll()
;
for (String excludePattern : excludesPattern) { for (String excludePattern : excludesPattern) {
......
package cn.ibizlab.config;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.cloud.netflix.zuul.filters.support.FilterConstants;
import org.springframework.stereotype.Component;
import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
@Component
public class DevUrlRedirectFilter extends ZuulFilter {
@Override
public Object run() {
RequestContext ctx = RequestContext.getCurrentContext();
HttpServletRequest request = ctx.getRequest();
String url = request.getRequestURI();
if(url.startsWith("/ibiz-repo"))
{
String[] split = url.split("/");
if (split.length>2) {
url=url.replaceFirst("/"+split[1]+"/"+split[2]+"/", "/");
ctx.put(FilterConstants.REQUEST_URI_KEY, url);
}
}
return null;
}
@Override
public boolean shouldFilter() {
return true;
}
@Override
public int filterOrder() {
return 1;
}
@Override
public String filterType() {
return FilterConstants.ROUTE_TYPE;
}
}
\ No newline at end of file
spring: spring:
jackson:
date-format: yyyy-MM-dd HH:mm:ss
time-zone: GMT+8
datasource: datasource:
username: root username: root
password: root password: root
...@@ -43,3 +46,61 @@ spring: ...@@ -43,3 +46,61 @@ spring:
cache: cache:
caffeine: caffeine:
spec: initialCapacity=5,maximumSize=50000,expireAfterWrite=3600s spec: initialCapacity=5,maximumSize=50000,expireAfterWrite=3600s
zuul:
routes:
repo-loginv7:
path: /ibiz-repo**/**/v7/login
serviceId: ${ibiz.ref.service.uaa:ibzuaa-api}
stripPrefix: true
repo-changepwd:
path: /ibiz-rep**/**/v7/changepwd
serviceId: ${ibiz.ref.service.uaa:ibzuaa-api}
stripPrefix: false
repo-uaa:
path: /ibiz-rep**/**/uaa/**
serviceId: ${ibiz.ref.service.uaa:ibzuaa-api}
stripPrefix: false
repo-config:
path: /ibiz-rep**/**/configs/**
serviceId: ${ibiz.ref.service.uaa:ibzuaa-api}
stripPrefix: false
repo-oucore:
path: /ibiz-rep**/**/ibzorganizations/**
serviceId: ${ibiz.ref.service.ou:ibzou-api}
stripPrefix: false
repo-oudict:
path: /ibiz-rep**/**/dictionarys/**/Ibzou**
serviceId: ${ibiz.ref.service.ou:ibzou-api}
stripPrefix: false
repo-ou:
path: /ibiz-rep**/**/ibzdepartments/**
serviceId: ${ibiz.ref.service.ou:ibzou-api}
stripPrefix: false
repo-uaadict:
path: /ibiz-rep**/**/dictionarys/**/SysOperator
serviceId: ${ibiz.ref.service.uaa:ibzuaa-api}
stripPrefix: false
repo-dict:
path: /ibiz-rep**/**/dictionarys/**
serviceId: ${ibiz.ref.service.dict:ibzdict-api}
stripPrefix: false
repo-disk:
path: /ibiz-rep**/**/net-disk/**
serviceId: ${ibiz.ref.service.disk:ibzdisk-api}
stripPrefix: false
repo-ou_sys_org:
path: /ibiz-rep**/**/sysorganizations/**
serviceId: ${ibiz.ref.service.ou:ibzou-api}
stripPrefix: false
repo-ou_sys_dept:
path: /ibiz-rep**/**/sysdepartments/**
serviceId: ${ibiz.ref.service.ou:ibzou-api}
stripPrefix: false
repo-lite-core:
path: /ibiz-rep**/**/lite/**
serviceId: ${ibiz.ref.service.lite:ibzlite-api}
stripPrefix: false
repo-sysauthlog:
path: /ibiz-rep**/**/sysauthlogs
serviceId: ${ibiz.ref.service.uaa:ibzuaa-api}
stripPrefix: false
\ No newline at end of file
...@@ -8,6 +8,7 @@ import com.alibaba.fastjson.annotation.JSONField; ...@@ -8,6 +8,7 @@ import com.alibaba.fastjson.annotation.JSONField;
import com.fasterxml.jackson.annotation.JsonIgnore; import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties; import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude; import com.fasterxml.jackson.annotation.JsonInclude;
import org.springframework.util.ObjectUtils;
import java.io.Serializable; import java.io.Serializable;
import java.util.Map; import java.util.Map;
...@@ -41,6 +42,12 @@ public class BaseData extends DataObj ...@@ -41,6 +42,12 @@ public class BaseData extends DataObj
return this; return this;
} }
@Override
public BaseData remove(Object key) {
super.remove(key);
return this;
}
@JsonIgnore @JsonIgnore
@JSONField(serialize = false) @JSONField(serialize = false)
private POSchema _poschema; private POSchema _poschema;
...@@ -121,4 +128,15 @@ public class BaseData extends DataObj ...@@ -121,4 +128,15 @@ public class BaseData extends DataObj
{ {
return getSerializableValue("_key"); return getSerializableValue("_key");
} }
public static BaseData fromContext(Map map)
{
if(map==null)
return null;
map.remove("datasource");
if(map.size()==0)
return null;
return new BaseData().setAll(map);
}
} }
...@@ -291,7 +291,7 @@ public class FilterData<T> extends BaseData ...@@ -291,7 +291,7 @@ public class FilterData<T> extends BaseData
{ {
if(!StringUtils.isEmpty(this.getQuery())) if(!StringUtils.isEmpty(this.getQuery()))
{ {
if(ObjectUtils.isEmpty(this.getPOSchema().getQuickSearch())) if(!ObjectUtils.isEmpty(this.getPOSchema().getQuickSearch()))
{ {
searchCond.and(qw-> { searchCond.and(qw-> {
int i=0; int i=0;
...@@ -376,4 +376,15 @@ public class FilterData<T> extends BaseData ...@@ -376,4 +376,15 @@ public class FilterData<T> extends BaseData
return sql; return sql;
} }
public static FilterData fromContext(Map map)
{
if(map==null)
return null;
map.remove("datasource");
if(map.size()==0)
return null;
return new FilterData().setAll(map);
}
} }
...@@ -219,13 +219,16 @@ public class DynamicModelService { ...@@ -219,13 +219,16 @@ public class DynamicModelService {
for(IPSDEField defield:dataEntity.getAllPSDEFields()) for(IPSDEField defield:dataEntity.getAllPSDEFields())
{ {
String dict=null;
try { dict=defield.getPSCodeList()!=null?defield.getPSCodeList().getCodeName():null; } catch (Exception ex){}
FieldModel fieldModel=new FieldModel(); FieldModel fieldModel=new FieldModel();
MetaFieldModel metaFieldModel=new MetaFieldModel(); MetaFieldModel metaFieldModel=new MetaFieldModel();
metaFieldModel.setFieldId(defield.getId()).setFieldName(defield.getName()).setCodeName(defield.getCodeName()).setFieldLogicName(defield.getLogicName()) metaFieldModel.setFieldId(defield.getId()).setFieldName(defield.getName()).setCodeName(defield.getCodeName()).setFieldLogicName(defield.getLogicName())
.setEntityId(dataEntity.getId()).setEntityCodeName(dataEntity.getCodeName()).setEntityName(dataEntity.getName()).setSystemId(metaEntityModel.getSystemId()) .setEntityId(dataEntity.getId()).setEntityCodeName(dataEntity.getCodeName()).setEntityName(dataEntity.getName()).setSystemId(metaEntityModel.getSystemId())
.setFieldUniName(dataEntity.getName()+"."+defield.getName()).setFieldShowName(String.format("%1$s-%2$s[%3$s]",defield.getName(),defield.getLogicName(),dataEntity.getName())) .setFieldUniName(dataEntity.getName()+"."+defield.getName()).setFieldShowName(String.format("%1$s-%2$s[%3$s]",defield.getName(),defield.getLogicName(),dataEntity.getName()))
.setKeyField(defield.isKeyDEField()?1:null).setMajorField(defield.isMajorDEField()?1:null).setUnionKey(defield.getUnionKeyValue()).setFieldType(defield.getDataType()) .setKeyField(defield.isKeyDEField()?1:null).setMajorField(defield.isMajorDEField()?1:null).setUnionKey(defield.getUnionKeyValue()).setFieldType(defield.getDataType())
.setPredefined(defield.getPredefinedType()).setDict(defield.getPSCodeList()!=null?defield.getPSCodeList().getCodeName():null).setNullable(defield.isAllowEmpty()?1:0) .setPredefined(defield.getPredefinedType()).setDict(dict).setNullable(defield.isAllowEmpty()?1:0)
.setPhysicalField(defield.isPhisicalDEField()?1:0).setDataType(DataType.findTypeName(defield.getStdDataType())).setDataLength(defield.getLength()).setDataPreci(defield.getPrecision()) .setPhysicalField(defield.isPhisicalDEField()?1:0).setDataType(DataType.findTypeName(defield.getStdDataType())).setDataLength(defield.getLength()).setDataPreci(defield.getPrecision())
.setIsEnableAudit(defield.isEnableAudit()?1:null).setShowOrder(defield.getImportOrder()); .setIsEnableAudit(defield.isEnableAudit()?1:null).setShowOrder(defield.getImportOrder());
......
...@@ -556,7 +556,7 @@ public class POSchema { ...@@ -556,7 +556,7 @@ public class POSchema {
@Accessors(chain = true) @Accessors(chain = true)
@JsonInclude(JsonInclude.Include.NON_EMPTY) @JsonInclude(JsonInclude.Include.NON_EMPTY)
@JsonIgnoreProperties(ignoreUnknown = true) @JsonIgnoreProperties(ignoreUnknown = true)
public static class Segment{ public static class Segment {
private String name; private String name;
private String vendorProvider; private String vendorProvider;
private String declare; private String declare;
...@@ -564,13 +564,21 @@ public class POSchema { ...@@ -564,13 +564,21 @@ public class POSchema {
private String format; private String format;
private Map params; private Map params;
public Segment setVendorProvider(String vendorProvider) public Segment setVendorProvider(String vendorProvider) {
{ if (!StringUtils.isEmpty(vendorProvider))
if(!StringUtils.isEmpty(vendorProvider)) this.vendorProvider = provider.get(vendorProvider.toLowerCase());
this.vendorProvider=provider.get(vendorProvider.toLowerCase());
return this; return this;
} }
@JsonIgnore
@JSONField(serialize = false)
public String getSql()
{
if(!StringUtils.isEmpty(format))
return String.format(format,body);
return body;
}
} }
...@@ -622,7 +630,7 @@ public class POSchema { ...@@ -622,7 +630,7 @@ public class POSchema {
@JSONField(ordinal = 12) @JSONField(ordinal = 12)
public Segment defaultQueryScript; public Segment defaultQueryScript;
public POSchema setDefaultQueryScript(String sql) public POSchema setDefaultQueryScriptSQL(String sql)
{ {
defaultQueryScript=new Segment().setName("default_query_script").setVendorProvider("").setBody(sql); defaultQueryScript=new Segment().setName("default_query_script").setVendorProvider("").setBody(sql);
return this; return this;
...@@ -637,7 +645,7 @@ public class POSchema { ...@@ -637,7 +645,7 @@ public class POSchema {
segment=this.getSegment("dq-default-",this.getDsType()); segment=this.getSegment("dq-default-",this.getDsType());
if(segment!=null) if(segment!=null)
{ {
setDefaultQueryScript(segment.getBody()); setDefaultQueryScriptSQL(segment.getBody());
return defaultQueryScript; return defaultQueryScript;
} }
else if(!StringUtils.isEmpty(this.getDsType())) else if(!StringUtils.isEmpty(this.getDsType()))
...@@ -647,7 +655,7 @@ public class POSchema { ...@@ -647,7 +655,7 @@ public class POSchema {
segment=this.getSegment("dq-default-",""); segment=this.getSegment("dq-default-","");
if(segment!=null) if(segment!=null)
{ {
setDefaultQueryScript(segment.getBody().replace("`","").replace("[","").replace("]","")); setDefaultQueryScriptSQL(segment.getBody().replace("`","").replace("[","").replace("]",""));
return defaultQueryScript; return defaultQueryScript;
} }
} }
...@@ -707,13 +715,30 @@ public class POSchema { ...@@ -707,13 +715,30 @@ public class POSchema {
public BaseData trans(BaseData source) public BaseData trans(BaseData source)
{ {
if(!needTrans)
{
for (String key : resultMap.keySet()) {
if(!source.keySet().contains(key))
{
if((!key.equals(key.toUpperCase()))&&source.keySet().contains(key.toUpperCase()))
{
needTrans=true;
break;
}
else if((!key.equals(key.toLowerCase()))&&source.keySet().contains(key.toLowerCase()))
{
needTrans=true;
break;
}
}
}
}
if(!needTrans) if(!needTrans)
return source; return source;
else { else {
BaseData target = new BaseData(); BaseData target = new BaseData();
for (Map.Entry<String, String> entry : resultMap.entrySet()) { for (Map.Entry<String, String> entry : resultMap.entrySet()) {
if(source.keySet().contains(entry.getKey())) target.set(entry.getValue().toLowerCase(),source.get(entry.getKey()));
target.set(entry.getValue(),source.get(entry.getKey()));
} }
return target; return target;
} }
...@@ -721,6 +746,25 @@ public class POSchema { ...@@ -721,6 +746,25 @@ public class POSchema {
public List<BaseData> trans(List<BaseData> source) public List<BaseData> trans(List<BaseData> source)
{ {
if(!needTrans&&source.size()>0)
{
BaseData src=source.get(0);
for (String key : resultMap.keySet()) {
if(!src.keySet().contains(key))
{
if((!key.equals(key.toUpperCase()))&&src.keySet().contains(key.toUpperCase()))
{
needTrans=true;
break;
}
else if((!key.equals(key.toLowerCase()))&&src.keySet().contains(key.toLowerCase()))
{
needTrans=true;
break;
}
}
}
}
if(!needTrans) if(!needTrans)
return source; return source;
else { else {
......
...@@ -63,6 +63,13 @@ public class PojoSchema { ...@@ -63,6 +63,13 @@ public class PojoSchema {
return this; return this;
} }
@JSONField(serialize = false)
@JsonIgnore
public String getCodeName()
{
return this.getOptions()==null?this.getName():this.getOptions().getStringValue("code_name",this.getName());
}
@JSONField(serialize = false) @JSONField(serialize = false)
@JsonIgnore @JsonIgnore
public String getSystem() public String getSystem()
......
...@@ -297,7 +297,7 @@ public class TransUtils { ...@@ -297,7 +297,7 @@ public class TransUtils {
} }
String defaultQueryScript=pojoSchema.getOptions().getDefaultQueryScript(); String defaultQueryScript=pojoSchema.getOptions().getDefaultQueryScript();
if(!StringUtils.isEmpty(defaultQueryScript)) if(!StringUtils.isEmpty(defaultQueryScript))
poSchema.setDefaultQueryScript(defaultQueryScript); poSchema.setDefaultQueryScriptSQL(defaultQueryScript);
return poSchema; return poSchema;
} }
......
...@@ -24,15 +24,14 @@ import java.util.Map; ...@@ -24,15 +24,14 @@ import java.util.Map;
@Slf4j @Slf4j
@Api(tags = {"数据" }) @Api(tags = {"数据" })
@RestController("api-data") @RestController("api-data")
@RequestMapping("") @RequestMapping({"/ibiz-repository/{system}/{scope}","/ibiz-repo/{system}"})
public class DataResource public class DataResource
{ {
@Autowired @Autowired
public IDataService dataService; public IDataService dataService;
@ApiOperation(value = "callMethod数据", tags = {"数据" }, notes = "callMethod数据") @ApiOperation(value = "callMethod数据", tags = {"数据" }, notes = "callMethod数据")
@RequestMapping(method = {RequestMethod.GET}, value = {"/ibiz-repository/{system}/{scope}/{entity}/{method}","/ibiz-repo/{system}/{entity}/{method}", @RequestMapping(method = {RequestMethod.GET}, value = {"/{entity}/call{method}","/{entity}/{key}/call{method}"})
"/ibiz-repository/{system}/{scope}/{entity}/{key}/{method}","/ibiz-repo/{system}/{entity}/{key}/{method}"})
public ResponseEntity call(@PathVariable(name = "system",required = true) String system, public ResponseEntity call(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
...@@ -40,14 +39,12 @@ public class DataResource ...@@ -40,14 +39,12 @@ public class DataResource
@PathVariable(name = "key",required = false) String key, @PathVariable(name = "key",required = false) String key,
@RequestParam Map map) { @RequestParam Map map) {
RequestData requestData=new RequestData().setAll(map); RequestData requestData=new RequestData().setAll(map);
ResponseData responseData=dataService.call(system,scope,entity,datasource,method,requestData.setKey(key)); return doCall(system,scope,entity,datasource,method,key,requestData);
return ResponseEntity.status(HttpStatus.OK).body(responseData.getBody());
} }
@ApiOperation(value = "callMethod数据", tags = {"数据" }, notes = "callMethod数据") @ApiOperation(value = "callMethod数据", tags = {"数据" }, notes = "callMethod数据")
@RequestMapping(method = {RequestMethod.POST}, value = {"/ibiz-repository/{system}/{scope}/{entity}/{method}","/ibiz-repo/{system}/{entity}/{method}", @RequestMapping(method = {RequestMethod.POST}, value = {"/{entity}/call{method}","/{entity}/{key}/call{method}"})
"/ibiz-repository/{system}/{scope}/{entity}/{key}/{method}","/ibiz-repo/{system}/{entity}/{key}/{method}"}) public ResponseEntity doCall(@PathVariable(name = "system",required = true) String system,
public ResponseEntity callPost(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
@PathVariable(name = "method",required = true) String method, @PathVariable(name = "method",required = true) String method,
...@@ -59,7 +56,7 @@ public class DataResource ...@@ -59,7 +56,7 @@ public class DataResource
} }
@ApiOperation(value = "批量callMethod数据", tags = {"数据" }, notes = "批量callMethod数据") @ApiOperation(value = "批量callMethod数据", tags = {"数据" }, notes = "批量callMethod数据")
@RequestMapping(method = {RequestMethod.POST}, value = {"/ibiz-repository/{system}/{scope}/{entity}/{method}batch","/ibiz-repo/{system}/{entity}/{method}batch"}) @RequestMapping(method = {RequestMethod.POST}, value = {"/{entity}/call{method}batch"})
public ResponseEntity callBatch(@PathVariable(name = "system",required = true) String system, public ResponseEntity callBatch(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
...@@ -72,8 +69,7 @@ public class DataResource ...@@ -72,8 +69,7 @@ public class DataResource
@ApiOperation(value = "新建数据", tags = {"数据" }, notes = "新建数据") @ApiOperation(value = "新建数据", tags = {"数据" }, notes = "新建数据")
@RequestMapping(method = RequestMethod.POST, value = {"/ibiz-repository/{system}/{scope}/{entity}","/ibiz-repo/{system}/{entity}", @RequestMapping(method = RequestMethod.POST, value = {"/{entity}","/{entity}/create"})
"/ibiz-repository/{system}/{scope}/{entity}/create","/ibiz-repo/{system}/{entity}/create"})
public ResponseEntity<BaseData> create(@PathVariable(name = "system",required = true) String system, public ResponseEntity<BaseData> create(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @Validated @RequestBody BaseData baseData) { @RequestParam(name = "datasource",required = false) String datasource, @Validated @RequestBody BaseData baseData) {
...@@ -82,8 +78,7 @@ public class DataResource ...@@ -82,8 +78,7 @@ public class DataResource
} }
@ApiOperation(value = "批量新建数据", tags = {"数据" }, notes = "批量新建数据") @ApiOperation(value = "批量新建数据", tags = {"数据" }, notes = "批量新建数据")
@RequestMapping(method = RequestMethod.POST, value = {"/ibiz-repository/{system}/{scope}/{entity}/batch","/ibiz-repo/{system}/{entity}/batch", @RequestMapping(method = RequestMethod.POST, value = {"/{entity}/batch","/{entity}/createbatch"})
"/ibiz-repository/{system}/{scope}/{entity}/createbatch","/ibiz-repo/{system}/{entity}/createbatch"})
public ResponseEntity<Boolean> createBatch(@PathVariable(name = "system",required = true) String system, public ResponseEntity<Boolean> createBatch(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestBody List<BaseData> baseDatas) { @RequestParam(name = "datasource",required = false) String datasource, @RequestBody List<BaseData> baseDatas) {
...@@ -92,17 +87,18 @@ public class DataResource ...@@ -92,17 +87,18 @@ public class DataResource
} }
@ApiOperation(value = "获取数据", tags = {"数据" }, notes = "获取数据") @ApiOperation(value = "获取数据", tags = {"数据" }, notes = "获取数据")
@RequestMapping(method = RequestMethod.GET, value = {"/ibiz-repository/{system}/{scope}/{entity}/{key}","/ibiz-repo/{system}/{entity}/{key}"}) @RequestMapping(method = RequestMethod.GET, value = {"/{entity}","/{entity}/{key}"})
public ResponseEntity<BaseData> get(@PathVariable(name = "system",required = true) String system, public ResponseEntity<BaseData> get(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @PathVariable(name = "key",required = true) String key) { @RequestParam(name = "datasource",required = false) String datasource,
return ResponseEntity.status(HttpStatus.OK).body(dataService.get(system,scope,entity,datasource,key)); @PathVariable(name = "key",required = false) String key,@RequestParam Map map) {
BaseData baseData=BaseData.fromContext(map);
return doGet(system,scope,entity,datasource,key,baseData);
} }
@ApiOperation(value = "获取数据", tags = {"数据" }, notes = "获取数据") @ApiOperation(value = "获取数据", tags = {"数据" }, notes = "获取数据")
@RequestMapping(method = RequestMethod.POST, value = {"/ibiz-repository/{system}/{scope}/{entity}/get","/ibiz-repo/{system}/{entity}/get", @RequestMapping(method = RequestMethod.POST, value = {"/{entity}/get","/{entity}/{key}/get"})
"/ibiz-repository/{system}/{scope}/{entity}/{key}/get","/ibiz-repo/{system}/{entity}/{key}/get"}) public ResponseEntity<BaseData> doGet(@PathVariable(name = "system",required = true) String system,
public ResponseEntity<BaseData> get(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
@PathVariable(name = "key",required = false) String key,@Validated @RequestBody(required = false) BaseData baseData) { @PathVariable(name = "key",required = false) String key,@Validated @RequestBody(required = false) BaseData baseData) {
...@@ -116,25 +112,18 @@ public class DataResource ...@@ -116,25 +112,18 @@ public class DataResource
} }
@ApiOperation(value = "删除数据", tags = {"数据" }, notes = "删除数据") @ApiOperation(value = "删除数据", tags = {"数据" }, notes = "删除数据")
@RequestMapping(method = RequestMethod.DELETE, value = {"/ibiz-repository/{system}/{scope}/{entity}/{key}","/ibiz-repo/{system}/{entity}/{key}", @RequestMapping(method = RequestMethod.DELETE, value = {"/{entity}","/{entity}/{key}"})
"/ibiz-repository/{system}/{scope}/{entity}","/ibiz-repo/{system}/{entity}"})
public ResponseEntity<Boolean> remove(@PathVariable(name = "system",required = true) String system, public ResponseEntity<Boolean> remove(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
@PathVariable(name = "key",required = false) String key,@RequestBody(required = false) BaseData baseData) { @PathVariable(name = "key",required = false) String key,@RequestParam Map map) {
if(baseData==null) BaseData baseData=BaseData.fromContext(map);
{ return doRemove(system,scope,entity,datasource,key,baseData);
if(StringUtils.isEmpty(key))
throw new BadRequestAlertException("未找到要删除的键值信息",entity,null);
baseData=new BaseData();
}
return ResponseEntity.status(HttpStatus.OK).body(dataService.removeByMap(system,scope,entity,datasource,baseData.setKey(key)));
} }
@ApiOperation(value = "删除数据", tags = {"数据" }, notes = "删除数据") @ApiOperation(value = "删除数据", tags = {"数据" }, notes = "删除数据")
@RequestMapping(method = RequestMethod.POST, value = {"/ibiz-repository/{system}/{scope}/{entity}/remove","/ibiz-repo/{system}/{entity}/remove", @RequestMapping(method = RequestMethod.POST, value = {"/{entity}/remove","/{entity}/{key}/remove"})
"/ibiz-repository/{system}/{scope}/{entity}/{key}/remove","/ibiz-repo/{system}/{entity}/{key}/remove"}) public ResponseEntity<Boolean> doRemove(@PathVariable(name = "system",required = true) String system,
public ResponseEntity<Boolean> removePost(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
@PathVariable(name = "key",required = false) String key,@Validated @RequestBody(required = false) BaseData baseData) { @PathVariable(name = "key",required = false) String key,@Validated @RequestBody(required = false) BaseData baseData) {
...@@ -148,17 +137,16 @@ public class DataResource ...@@ -148,17 +137,16 @@ public class DataResource
} }
@ApiOperation(value = "批量删除数据", tags = {"数据" }, notes = "批量删除数据") @ApiOperation(value = "批量删除数据", tags = {"数据" }, notes = "批量删除数据")
@RequestMapping(method = RequestMethod.DELETE, value = {"/ibiz-repository/{system}/{scope}/{entity}/batch","/ibiz-repo/{system}/{entity}/batch"}) @RequestMapping(method = RequestMethod.DELETE, value = {"/{entity}/batch"})
public ResponseEntity<Boolean> removeBatch(@PathVariable(name = "system",required = true) String system, public ResponseEntity<Boolean> removeBatch(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestBody List ids) { @RequestParam(name = "datasource",required = false) String datasource, @RequestBody List ids) {
dataService.removeBatch(system,scope,entity,datasource,ids); return doRemoveBatch(system,scope,entity,datasource,ids);
return ResponseEntity.status(HttpStatus.OK).body(true);
} }
@ApiOperation(value = "批量删除数据", tags = {"数据" }, notes = "批量删除数据") @ApiOperation(value = "批量删除数据", tags = {"数据" }, notes = "批量删除数据")
@RequestMapping(method = RequestMethod.POST, value = {"/ibiz-repository/{system}/{scope}/{entity}/removebatch","/ibiz-repo/{system}/{entity}/removebatch"}) @RequestMapping(method = RequestMethod.POST, value = {"/{entity}/removebatch"})
public ResponseEntity<Boolean> removeBatchPost(@PathVariable(name = "system",required = true) String system, public ResponseEntity<Boolean> doRemoveBatch(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestBody List ids) { @RequestParam(name = "datasource",required = false) String datasource, @RequestBody List ids) {
dataService.removeBatch(system,scope,entity,datasource,ids); dataService.removeBatch(system,scope,entity,datasource,ids);
...@@ -166,20 +154,17 @@ public class DataResource ...@@ -166,20 +154,17 @@ public class DataResource
} }
@ApiOperation(value = "更新数据", tags = {"数据" }, notes = "更新数据") @ApiOperation(value = "更新数据", tags = {"数据" }, notes = "更新数据")
@RequestMapping(method = RequestMethod.PUT, value = {"/ibiz-repository/{system}/{scope}/{entity}/{key}","/ibiz-repo/{system}/{entity}/{key}", @RequestMapping(method = RequestMethod.PUT, value = {"/{entity}","/{entity}/{key}"})
"/ibiz-repository/{system}/{scope}/{entity}","/ibiz-repo/{system}/{entity}"})
public ResponseEntity<BaseData> update(@PathVariable(name = "system",required = true) String system, public ResponseEntity<BaseData> update(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
@PathVariable(name = "key",required = false) String key, @RequestBody BaseData baseData) { @PathVariable(name = "key",required = false) String key, @RequestBody BaseData baseData) {
dataService.update(system,scope,entity,datasource,baseData.setKey(key)); return doUpdate(system,scope,entity,datasource,key,baseData);
return ResponseEntity.status(HttpStatus.OK).body(baseData);
} }
@ApiOperation(value = "更新数据", tags = {"数据" }, notes = "更新数据") @ApiOperation(value = "更新数据", tags = {"数据" }, notes = "更新数据")
@RequestMapping(method = RequestMethod.POST, value = {"/ibiz-repository/{system}/{scope}/{entity}/update","/ibiz-repo/{system}/{entity}/update", @RequestMapping(method = RequestMethod.POST, value = {"/{entity}/update","/{entity}/{key}/update"})
"/ibiz-repository/{system}/{scope}/{entity}/{key}/update","/ibiz-repo/{system}/{entity}/{key}/update"}) public ResponseEntity<BaseData> doUpdate(@PathVariable(name = "system",required = true) String system,
public ResponseEntity<BaseData> updatePost(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
@PathVariable(name = "key",required = false) String key, @RequestBody BaseData baseData) { @PathVariable(name = "key",required = false) String key, @RequestBody BaseData baseData) {
...@@ -188,17 +173,16 @@ public class DataResource ...@@ -188,17 +173,16 @@ public class DataResource
} }
@ApiOperation(value = "批量更新数据", tags = {"数据" }, notes = "批量更新数据") @ApiOperation(value = "批量更新数据", tags = {"数据" }, notes = "批量更新数据")
@RequestMapping(method = RequestMethod.PUT, value = {"/ibiz-repository/{system}/{scope}/{entity}/batch","/ibiz-repo/{system}/{entity}/batch"}) @RequestMapping(method = RequestMethod.PUT, value = {"/{entity}/batch"})
public ResponseEntity<Boolean> updateBatch(@PathVariable(name = "system",required = true) String system, public ResponseEntity<Boolean> updateBatch(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestBody List<BaseData> baseDatas) { @RequestParam(name = "datasource",required = false) String datasource, @RequestBody List<BaseData> baseDatas) {
dataService.updateBatch(system,scope,entity,datasource,baseDatas); return doUpdateBatch(system,scope,entity,datasource,baseDatas);
return ResponseEntity.status(HttpStatus.OK).body(true);
} }
@ApiOperation(value = "批量更新数据", tags = {"数据" }, notes = "批量更新数据") @ApiOperation(value = "批量更新数据", tags = {"数据" }, notes = "批量更新数据")
@RequestMapping(method = RequestMethod.POST, value = {"/ibiz-repository/{system}/{scope}/{entity}/updatebatch","/ibiz-repo/{system}/{entity}/updatebatch"}) @RequestMapping(method = RequestMethod.POST, value = {"/{entity}/updatebatch"})
public ResponseEntity<Boolean> updateBatchPost(@PathVariable(name = "system",required = true) String system, public ResponseEntity<Boolean> doUpdateBatch(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestBody List<BaseData> baseDatas) { @RequestParam(name = "datasource",required = false) String datasource, @RequestBody List<BaseData> baseDatas) {
dataService.updateBatch(system,scope,entity,datasource,baseDatas); dataService.updateBatch(system,scope,entity,datasource,baseDatas);
...@@ -206,26 +190,19 @@ public class DataResource ...@@ -206,26 +190,19 @@ public class DataResource
} }
@ApiOperation(value = "检查数据", tags = {"数据" }, notes = "检查数据") @ApiOperation(value = "检查数据", tags = {"数据" }, notes = "检查数据")
@RequestMapping(method = {RequestMethod.GET}, value = {"/ibiz-repository/{system}/{scope}/{entity}/checkkey","/ibiz-repo/{system}/{entity}/checkkey", @RequestMapping(method = {RequestMethod.GET}, value = {"/{entity}/checkkey","/{entity}/{key}/checkkey"})
"/ibiz-repository/{system}/{scope}/{entity}/{key}/checkkey","/ibiz-repo/{system}/{entity}/{key}/checkkey"})
public ResponseEntity<Boolean> checkKey(@PathVariable(name = "system",required = true) String system, public ResponseEntity<Boolean> checkKey(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
@PathVariable(name = "key",required = false) String key, @PathVariable(name = "key",required = false) String key,
@RequestParam Map map) { @RequestParam Map map) {
BaseData baseData=new BaseData().setAll(map); BaseData baseData=BaseData.fromContext(map);
if(baseData.size()==0) return doCheckKey(system,scope,entity,datasource,key,baseData);
{
if(StringUtils.isEmpty(key))
throw new BadRequestAlertException("未找到要检查的键值信息",entity,null);
}
return ResponseEntity.status(HttpStatus.OK).body(dataService.checkKey(system,scope,entity,datasource,baseData.setKey(key)));
} }
@ApiOperation(value = "检查数据", tags = {"数据" }, notes = "检查数据") @ApiOperation(value = "检查数据", tags = {"数据" }, notes = "检查数据")
@RequestMapping(method = {RequestMethod.POST}, value = {"/ibiz-repository/{system}/{scope}/{entity}/checkkey","/ibiz-repo/{system}/{entity}/checkkey", @RequestMapping(method = {RequestMethod.POST}, value = {"/{entity}/checkkey","/{entity}/{key}/checkkey"})
"/ibiz-repository/{system}/{scope}/{entity}/{key}/checkkey","/ibiz-repo/{system}/{entity}/{key}/checkkey"}) public ResponseEntity<Boolean> doCheckKey(@PathVariable(name = "system",required = true) String system,
public ResponseEntity<Boolean> checkKeyPost(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
@PathVariable(name = "key",required = false) String key,@RequestBody(required = false) BaseData baseData) { @PathVariable(name = "key",required = false) String key,@RequestBody(required = false) BaseData baseData) {
...@@ -240,21 +217,19 @@ public class DataResource ...@@ -240,21 +217,19 @@ public class DataResource
@ApiOperation(value = "获取数据草稿", tags = {"数据" }, notes = "获取数据草稿") @ApiOperation(value = "获取数据草稿", tags = {"数据" }, notes = "获取数据草稿")
@RequestMapping(method = {RequestMethod.GET}, value = {"/ibiz-repository/{system}/{scope}/{entity}/getdraft","/ibiz-repo/{system}/{entity}/getdraft", @RequestMapping(method = {RequestMethod.GET}, value = {"/{entity}/getdraft","/{entity}/{key}/getdraft"})
"/ibiz-repository/{system}/{scope}/{entity}/{key}/getdraft","/ibiz-repo/{system}/{entity}/{key}/getdraft"})
public ResponseEntity<BaseData> getDraft(@PathVariable(name = "system",required = true) String system, public ResponseEntity<BaseData> getDraft(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
@PathVariable(name = "key",required = false) String key, @PathVariable(name = "key",required = false) String key,
@RequestParam Map map) { @RequestParam Map map) {
BaseData baseData=new BaseData().setAll(map); BaseData baseData=BaseData.fromContext(map);
return ResponseEntity.status(HttpStatus.OK).body(dataService.getDraft(system,scope,entity,datasource,baseData.setKey(key))); return doGetDraft(system,scope,entity,datasource,key,baseData);
} }
@ApiOperation(value = "获取数据草稿", tags = {"数据" }, notes = "获取数据草稿") @ApiOperation(value = "获取数据草稿", tags = {"数据" }, notes = "获取数据草稿")
@RequestMapping(method = {RequestMethod.POST}, value = {"/ibiz-repository/{system}/{scope}/{entity}/getdraft","/ibiz-repo/{system}/{entity}/getdraft", @RequestMapping(method = {RequestMethod.POST}, value = {"/{entity}/getdraft","/{entity}/{key}/getdraft"})
"/ibiz-repository/{system}/{scope}/{entity}/{key}/getdraft","/ibiz-repo/{system}/{entity}/{key}/getdraft"}) public ResponseEntity<BaseData> doGetDraft(@PathVariable(name = "system",required = true) String system,
public ResponseEntity<BaseData> getDraftPost(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
@PathVariable(name = "key",required = false) String key, @RequestBody(required = false) BaseData baseData) { @PathVariable(name = "key",required = false) String key, @RequestBody(required = false) BaseData baseData) {
...@@ -263,8 +238,7 @@ public class DataResource ...@@ -263,8 +238,7 @@ public class DataResource
} }
@ApiOperation(value = "保存数据", tags = {"数据" }, notes = "保存数据,自动判断插入和更新") @ApiOperation(value = "保存数据", tags = {"数据" }, notes = "保存数据,自动判断插入和更新")
@RequestMapping(method = RequestMethod.POST, value = {"/ibiz-repository/{system}/{scope}/{entity}/save","/ibiz-repo/{system}/{entity}/save", @RequestMapping(method = RequestMethod.POST, value = {"/{entity}/save","/{entity}/{key}/save"})
"/ibiz-repository/{system}/{scope}/{entity}/{key}/save","/ibiz-repo/{system}/{entity}/{key}/save"})
public ResponseEntity<BaseData> save(@PathVariable(name = "system",required = true) String system, public ResponseEntity<BaseData> save(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource, @RequestParam(name = "datasource",required = false) String datasource,
...@@ -274,7 +248,7 @@ public class DataResource ...@@ -274,7 +248,7 @@ public class DataResource
} }
@ApiOperation(value = "批量保存数据", tags = {"数据" }, notes = "批量保存数据,自动判断插入和更新") @ApiOperation(value = "批量保存数据", tags = {"数据" }, notes = "批量保存数据,自动判断插入和更新")
@RequestMapping(method = RequestMethod.POST, value = {"/ibiz-repository/{system}/{scope}/{entity}/savebatch","/ibiz-repo/{system}/{entity}/savebatch"}) @RequestMapping(method = RequestMethod.POST, value = {"/{entity}/savebatch"})
public ResponseEntity<Boolean> saveBatch(@PathVariable(name = "system",required = true) String system, public ResponseEntity<Boolean> saveBatch(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource,@RequestBody List<BaseData> baseDatas) { @RequestParam(name = "datasource",required = false) String datasource,@RequestBody List<BaseData> baseDatas) {
...@@ -283,37 +257,22 @@ public class DataResource ...@@ -283,37 +257,22 @@ public class DataResource
} }
@ApiOperation(value = "获取数据集", tags = {"数据" } ,notes = "获取数据集,GET,返回body<list>+header<page,total>") @ApiOperation(value = "获取数据集", tags = {"数据" } ,notes = "获取数据集,GET,返回body<list>+header<page,total>")
@RequestMapping(method= RequestMethod.GET , value={"/ibiz-repository/{system}/{scope}/{entity}/fetch{dataset}","/ibiz-repo/{system}/{entity}/fetch{dataset}"}) @RequestMapping(method= RequestMethod.GET , value={"/{entity}/fetch{dataset}"})
public ResponseEntity<List<BaseData>> fetch(@PathVariable(name = "system",required = true) String system, public ResponseEntity<List<BaseData>> fetch(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataset",required = true) String dataset, @RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataset",required = true) String dataset,
@RequestParam Map map) { @RequestParam Map map) {
FilterData context=new FilterData().setAll(map); FilterData context=FilterData.fromContext(map);
if(context.needPage()) { return doFetch(system,scope,entity,datasource,dataset,context);
Page<BaseData> baseDatas = dataService.fetch(system, scope, entity, context.getDataSource(), dataset, context, context.getPageable());
List<BaseData> list = baseDatas.getContent();
return ResponseEntity.status(HttpStatus.OK)
.header("x-page", String.valueOf(context.getPageable().getPageNumber()))
.header("x-per-page", String.valueOf(context.getPageable().getPageSize()))
.header("x-total", String.valueOf(baseDatas.getTotalElements()))
.body(list);
}
else {
List<BaseData> list = dataService.fetch(system,scope,entity,datasource,dataset,context) ;
return ResponseEntity.status(HttpStatus.OK)
.header("x-page", "0")
.header("x-per-page", String.valueOf(list.size()))
.header("x-total", String.valueOf(list.size()))
.body(list);
}
} }
@ApiOperation(value = "获取数据集", tags = {"数据" } ,notes = "获取数据集,POST,返回body<list>+header<page,total>") @ApiOperation(value = "获取数据集", tags = {"数据" } ,notes = "获取数据集,POST,返回body<list>+header<page,total>")
@RequestMapping(method= RequestMethod.POST , value={"/ibiz-repository/{system}/{scope}/{entity}/fetch{dataset}","/ibiz-repo/{system}/{entity}/fetch{dataset}"}) @RequestMapping(method= RequestMethod.POST , value={"/{entity}/fetch{dataset}","/{entity}/fetch{dataset}"})
public ResponseEntity<List<BaseData>> fetchPost(@PathVariable(name = "system",required = true) String system, public ResponseEntity<List<BaseData>> doFetch(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataset",required = true) String dataset, @RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataset",required = true) String dataset,
@RequestBody FilterData context) { @RequestBody(required = false) FilterData context) {
if(context==null)context=new FilterData();
if(context.needPage()) { if(context.needPage()) {
Page<BaseData> baseDatas = dataService.fetch(system, scope, entity, datasource, dataset, context, context.getPageable()); Page<BaseData> baseDatas = dataService.fetch(system, scope, entity, datasource, dataset, context, context.getPageable());
List<BaseData> list = baseDatas.getContent(); List<BaseData> list = baseDatas.getContent();
...@@ -334,11 +293,12 @@ public class DataResource ...@@ -334,11 +293,12 @@ public class DataResource
} }
@ApiOperation(value = "获取数据集", tags = {"数据" } ,notes = "获取数据集,POST,返回body<page,total,list>") @ApiOperation(value = "获取数据集", tags = {"数据" } ,notes = "获取数据集,POST,返回body<page,total,list>")
@RequestMapping(method= RequestMethod.POST , value={"/ibiz-repository/{system}/{scope}/{entity}/search{dataset}","/ibiz-repo/{system}/{entity}/search{dataset}"}) @RequestMapping(method= RequestMethod.POST , value={"/{entity}/search{dataset}","/{entity}/search{dataset}"})
public ResponseEntity<Page<BaseData>> search(@PathVariable(name = "system",required = true) String system, public ResponseEntity<Page<BaseData>> search(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataset",required = true) String dataset, @RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataset",required = true) String dataset,
@RequestBody FilterData context) { @RequestBody(required = false) FilterData context) {
if(context==null)context=new FilterData();
Page<BaseData> baseDatas = dataService.fetch(system,scope,entity,datasource,dataset,context,context.getPageable()) ; Page<BaseData> baseDatas = dataService.fetch(system,scope,entity,datasource,dataset,context,context.getPageable()) ;
return ResponseEntity.status(HttpStatus.OK) return ResponseEntity.status(HttpStatus.OK)
.body(new PageImpl(baseDatas.getContent(), context.getPageable(), baseDatas.getTotalElements())); .body(new PageImpl(baseDatas.getContent(), context.getPageable(), baseDatas.getTotalElements()));
...@@ -347,37 +307,22 @@ public class DataResource ...@@ -347,37 +307,22 @@ public class DataResource
@ApiOperation(value = "查询数据", tags = {"数据" } ,notes = "查询数据,GET,返回body<list>+header<page,total>") @ApiOperation(value = "查询数据", tags = {"数据" } ,notes = "查询数据,GET,返回body<list>+header<page,total>")
@RequestMapping(method= RequestMethod.GET , value={"/ibiz-repository/{system}/{scope}/{entity}/query{dataquery}","/ibiz-repo/{system}/{entity}/query{dataquery}"}) @RequestMapping(method= RequestMethod.GET , value={"/{entity}/query{dataquery}","/{entity}/query{dataquery}"})
public ResponseEntity<List<BaseData>> query(@PathVariable(name = "system",required = true) String system, public ResponseEntity<List<BaseData>> query(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataquery",required = true) String dataquery, @RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataquery",required = true) String dataquery,
@RequestParam Map map) { @RequestParam Map map) {
FilterData context=new FilterData().setAll(map); FilterData context=FilterData.fromContext(map);
if(context.needPage()) { return doQuery(system,scope,entity,datasource,dataquery,context);
Page<BaseData> baseDatas = dataService.fetch(system, scope, entity, context.getDataSource(), dataquery, context, context.getPageable());
List<BaseData> list = baseDatas.getContent();
return ResponseEntity.status(HttpStatus.OK)
.header("x-page", String.valueOf(context.getPageable().getPageNumber()))
.header("x-per-page", String.valueOf(context.getPageable().getPageSize()))
.header("x-total", String.valueOf(baseDatas.getTotalElements()))
.body(list);
}
else {
List<BaseData> list = dataService.query(system,scope,entity,datasource,dataquery,context) ;
return ResponseEntity.status(HttpStatus.OK)
.header("x-page", "0")
.header("x-per-page", String.valueOf(list.size()))
.header("x-total", String.valueOf(list.size()))
.body(list);
}
} }
@ApiOperation(value = "查询数据", tags = {"数据" } ,notes = "查询数据,POST,返回body<list>+header<page,total>") @ApiOperation(value = "查询数据", tags = {"数据" } ,notes = "查询数据,POST,返回body<list>+header<page,total>")
@RequestMapping(method= RequestMethod.POST , value={"/ibiz-repository/{system}/{scope}/{entity}/query{dataquery}","/ibiz-repo/{system}/{entity}/query{dataquery}"}) @RequestMapping(method= RequestMethod.POST , value={"/{entity}/query{dataquery}","/{entity}/query{dataquery}"})
public ResponseEntity<List<BaseData>> queryPost(@PathVariable(name = "system",required = true) String system, public ResponseEntity<List<BaseData>> doQuery(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataquery",required = true) String dataquery, @RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataquery",required = true) String dataquery,
@RequestBody FilterData context) { @RequestBody(required = false) FilterData context) {
if(context==null)context=new FilterData();
if(context.needPage()) { if(context.needPage()) {
Page<BaseData> baseDatas = dataService.query(system,scope,entity,datasource,dataquery,context,context.getPageable()) ; Page<BaseData> baseDatas = dataService.query(system,scope,entity,datasource,dataquery,context,context.getPageable()) ;
List<BaseData> list = baseDatas.getContent(); List<BaseData> list = baseDatas.getContent();
...@@ -398,11 +343,12 @@ public class DataResource ...@@ -398,11 +343,12 @@ public class DataResource
} }
@ApiOperation(value = "查询数据", tags = {"数据" } ,notes = "查询数据,POST,返回body<page,total,list>") @ApiOperation(value = "查询数据", tags = {"数据" } ,notes = "查询数据,POST,返回body<page,total,list>")
@RequestMapping(method= RequestMethod.POST , value={"/ibiz-repository/{system}/{scope}/{entity}/page{dataquery}","/ibiz-repo/{system}/{entity}/page{dataquery}"}) @RequestMapping(method= RequestMethod.POST , value={"/{entity}/page{dataquery}","/{entity}/page{dataquery}"})
public ResponseEntity<Page<BaseData>> queryPage(@PathVariable(name = "system",required = true) String system, public ResponseEntity<Page<BaseData>> queryPage(@PathVariable(name = "system",required = true) String system,
@PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity, @PathVariable(name = "scope",required = false) String scope,@PathVariable(name = "entity",required = true) String entity,
@RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataquery",required = true) String dataquery, @RequestParam(name = "datasource",required = false) String datasource,@PathVariable(name = "dataquery",required = true) String dataquery,
@RequestBody FilterData context) { @RequestBody(required = false) FilterData context) {
if(context==null)context=new FilterData();
Page<BaseData> baseDatas = dataService.fetch(system,scope,entity,datasource,dataquery,context,context.getPageable()) ; Page<BaseData> baseDatas = dataService.fetch(system,scope,entity,datasource,dataquery,context,context.getPageable()) ;
return ResponseEntity.status(HttpStatus.OK) return ResponseEntity.status(HttpStatus.OK)
.body(new PageImpl(baseDatas.getContent(), context.getPageable(), baseDatas.getTotalElements())); .body(new PageImpl(baseDatas.getContent(), context.getPageable(), baseDatas.getTotalElements()));
......
...@@ -165,8 +165,29 @@ public class ModelService { ...@@ -165,8 +165,29 @@ public class ModelService {
String entityName=file.getName().replace(".json",""); String entityName=file.getName().replace(".json","");
String id=system.concat(".domain.").concat(entityName); String id=system.concat(".domain.").concat(entityName);
if(!entities.containsKey(entityName.toLowerCase())) if(!entities.containsKey(entityName.toLowerCase())) {
entities.put(entityName.toLowerCase(),id); entities.put(entityName.toLowerCase(), id);
try {
PojoSchema pojoSchema=PojoSchema.fromPath(file.toPath());
entityName=pojoSchema.getName();
if((StringUtils.isEmpty(entityName))&&(!entities.containsKey(pojoSchema.getName()))) {
entities.put(pojoSchema.getName(), id);
}
String codeName=pojoSchema.getCodeName();
if((StringUtils.isEmpty(codeName))&&(!entities.containsKey(codeName))) {
entities.put(codeName, id);
if(!codeName.equals(codeName.toLowerCase()))
entities.put(codeName.toLowerCase(), id);
String pluralize= Inflector.getInstance().pluralize(codeName).toLowerCase();
if(!entities.containsKey(pluralize)) {
entities.put(pluralize, id);
}
}
}catch (Exception ex){}
}
} }
} }
......
...@@ -240,7 +240,7 @@ public class DbDataServiceImpl implements IDataService { ...@@ -240,7 +240,7 @@ public class DbDataServiceImpl implements IDataService {
@Override @Override
public BaseData getDraft(DOModel model, String scope, String datasource, BaseData et) public BaseData getDraft(DOModel model, String scope, String datasource, BaseData et)
{ {
return null; return et;
} }
@Override @Override
......
package cn.ibizlab.core.util.config;
import cn.ibizlab.core.data.dto.BaseData;
import cn.ibizlab.core.data.dto.FilterData;
import cn.ibizlab.core.data.filter.SearchContextBase;
import com.fasterxml.jackson.databind.ObjectMapper;
import lombok.extern.slf4j.Slf4j;
import org.springframework.core.MethodParameter;
import org.springframework.web.bind.support.WebDataBinderFactory;
import org.springframework.web.context.request.NativeWebRequest;
import org.springframework.web.method.support.HandlerMethodArgumentResolver;
import org.springframework.web.method.support.ModelAndViewContainer;
import java.util.LinkedHashMap;
import java.util.Map;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
@Slf4j
@Configuration
public class FilterDataResolver implements HandlerMethodArgumentResolver {
@Value("${ibiz.pageLimit:1000}")
private int pageLimit=1000;
private static ObjectMapper objectMapper=new ObjectMapper();
@Override
public boolean supportsParameter(MethodParameter parameter) {
Class<?> type = parameter.getParameterType();
return SearchContextBase.class==type
|| FilterData.class==type
|| BaseData.class==type;
}
@Override
public Object resolveArgument(MethodParameter parameter, ModelAndViewContainer mavContainer,
NativeWebRequest webRequest, WebDataBinderFactory binderFactory) throws Exception {
Map<String, String[]> params = webRequest.getParameterMap();
LinkedHashMap<String,Object> set = new LinkedHashMap<>();
for (String key : params.keySet()) {
set.put(key,params.get(key)[0]);
}
if(SearchContextBase.class.isAssignableFrom(parameter.getParameterType()) && (!set.containsKey("size"))){
set.put("size", pageLimit);
}
if(FilterData.class.isAssignableFrom(parameter.getParameterType()) && (!set.containsKey("size"))){
set.put("size", pageLimit);
}
String json = objectMapper.writeValueAsString(set);
return objectMapper.readValue(json, parameter.getParameterType());
}
}
\ No newline at end of file
...@@ -32,7 +32,7 @@ ...@@ -32,7 +32,7 @@
select t1.* from select t1.* from
<choose> <choose>
<when test="schema.defaultQueryScript!=null"> <when test="schema.defaultQueryScript!=null">
( ${schema.defaultQueryScript.body} ) t1 where ( ${schema.defaultQueryScript.sql} ) t1 where
</when> </when>
<otherwise> <otherwise>
${schema.name} t1 where ${schema.name} t1 where
...@@ -50,7 +50,7 @@ ...@@ -50,7 +50,7 @@
select t1.* from select t1.* from
<choose> <choose>
<when test="schema.defaultQueryScript!=null"> <when test="schema.defaultQueryScript!=null">
( ${schema.defaultQueryScript.body} ) t1 where ( ${schema.defaultQueryScript.sql} ) t1 where
</when> </when>
<otherwise> <otherwise>
${schema.name} t1 where ${schema.name} t1 where
...@@ -74,7 +74,7 @@ ...@@ -74,7 +74,7 @@
select t1.* from select t1.* from
<choose> <choose>
<when test="schema.defaultQueryScript!=null"> <when test="schema.defaultQueryScript!=null">
( ${schema.defaultQueryScript.body} ) t1 where ( ${schema.defaultQueryScript.sql} ) t1 where
</when> </when>
<otherwise> <otherwise>
${schema.name} t1 where ${schema.name} t1 where
......
...@@ -29,7 +29,7 @@ public class AppController { ...@@ -29,7 +29,7 @@ public class AppController {
@Autowired @Autowired
private AuthenticationUserService userDetailsService; private AuthenticationUserService userDetailsService;
@RequestMapping(method = RequestMethod.GET, value = "/appdata") @RequestMapping(method = RequestMethod.GET, value = {"/ibiz-repository/{system}/{scope}/appdata","/ibiz-repo/{system}/appdata","/appdata"})
public ResponseEntity<JSONObject> getAppData() { public ResponseEntity<JSONObject> getAppData() {
JSONObject appData = new JSONObject() ; JSONObject appData = new JSONObject() ;
......
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册