templates.controller.ftl Maven / Gradle / Ivy
package ${packageName}.controller.${moduleName};
import com.lframework.common.exceptions.impl.DefaultClientException;
import com.lframework.common.utils.CollectionUtil;
import com.lframework.starter.mybatis.resp.PageResult;
import com.lframework.starter.mybatis.utils.PageResultUtil;
import com.lframework.starter.web.resp.InvokeResult;
import com.lframework.starter.web.resp.InvokeResultBuilder;
<#if detail??>
import ${packageName}.bo.${moduleName}.${bizName}.Get${className}Bo;
#if>
<#if query??>
import ${packageName}.bo.${moduleName}.${bizName}.Query${className}Bo;
#if>
<#if queryParams??>
import ${packageName}.vo.${moduleName}.${bizName}.Query${className}Vo;
#if>
import ${packageName}.dto.${moduleName}.${bizName}.${className}Dto;
import ${packageName}.service.${moduleName}.I${className}Service;
<#if create??>
import ${packageName}.vo.${moduleName}.${bizName}.Create${className}Vo;
#if>
<#if update??>
import ${packageName}.vo.${moduleName}.${bizName}.Update${className}Vo;
#if>
<#if importPackages??>
<#list importPackages as p>
import ${p};
#list>
#if>
import com.lframework.starter.security.controller.DefaultBaseController;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import javax.validation.Valid;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotEmpty;
import java.util.List;
import java.util.stream.Collectors;
/**
* ${classDescription} Controller
*
<#if author??>
* @author ${author}
#if>
*/
@Validated
@RestController
@RequestMapping("/${moduleName}/${bizName}")
public class ${className}Controller extends DefaultBaseController {
@Autowired
private I${className}Service ${classNameProperty}Service;
<#if query?? && queryParams??>
/**
* 查询列表
*/
@PreAuthorize("@permission.valid('${moduleName}:${bizName}:query')")
@GetMapping("/query")
public InvokeResult query(@Valid Query${className}Vo vo) {
PageResult${r"<"}${className}Dto${r">"} pageResult = ${classNameProperty}Service.query(getPageIndex(vo), getPageSize(vo), vo);
List${r"<"}${className}Dto${r">"} datas = pageResult.getDatas();
if (!CollectionUtil.isEmpty(datas)) {
List${r"<"}Query${className}Bo${r">"} results = datas.stream().map(Query${className}Bo::new).collect(Collectors.toList());
PageResultUtil.rebuild(pageResult, results);
}
return InvokeResultBuilder.success(pageResult);
}
#if>
<#if detail??>
/**
* 根据ID查询
*/
@PreAuthorize("@permission.valid('${moduleName}:${bizName}:query')")
@GetMapping
public InvokeResult get(<#if keys[0].type == 'String'>@NotBlank<#else>@NotNull#if>(message = "${keys[0].name}不能为空!") ${keys[0].type} ${keys[0].name}) {
${className}Dto data = ${classNameProperty}Service.getById(${keys[0].name});
if (data == null) {
throw new DefaultClientException("${classDescription}不存在!");
}
Get${className}Bo result = new Get${className}Bo(data);
return InvokeResultBuilder.success(result);
}
#if>
<#if create??>
/**
* 新增
*/
@PreAuthorize("@permission.valid('${moduleName}:${bizName}:add')")
@PostMapping
public InvokeResult create(@Valid Create${className}Vo vo) {
${classNameProperty}Service.create(vo);
return InvokeResultBuilder.success();
}
#if>
<#if update??>
/**
* 修改
*/
@PreAuthorize("@permission.valid('${moduleName}:${bizName}:modify')")
@PutMapping
public InvokeResult update(@Valid Update${className}Vo vo) {
${classNameProperty}Service.update(vo);
return InvokeResultBuilder.success();
}
#if>
<#if hasDelete>
/**
* 根据ID删除
*/
@PreAuthorize("@permission.valid('${moduleName}:${bizName}:delete')")
@DeleteMapping
public InvokeResult deleteById(<#if keys[0].type == 'String'>@NotBlank<#else>@NotNull#if>(message = "${keys[0].name}不能为空!") ${keys[0].type} ${keys[0].name}) {
${classNameProperty}Service.deleteById(${keys[0].name});
return InvokeResultBuilder.success();
}
#if>
}