controller.java.vm 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. package ${packageName}.controller;
  2. import java.util.List;
  3. import lombok.RequiredArgsConstructor;
  4. import jakarta.servlet.http.HttpServletResponse;
  5. import jakarta.validation.constraints.*;
  6. import cn.dev33.satoken.annotation.SaCheckPermission;
  7. import org.springframework.web.bind.annotation.*;
  8. import org.springframework.validation.annotation.Validated;
  9. import org.dromara.common.idempotent.annotation.RepeatSubmit;
  10. import org.dromara.common.log.annotation.Log;
  11. import org.dromara.common.web.core.BaseController;
  12. import org.dromara.common.mybatis.core.page.PageQuery;
  13. import org.dromara.common.core.domain.R;
  14. import org.dromara.common.core.validate.AddGroup;
  15. import org.dromara.common.core.validate.EditGroup;
  16. import org.dromara.common.log.enums.BusinessType;
  17. import org.dromara.common.excel.utils.ExcelUtil;
  18. import ${packageName}.domain.vo.${ClassName}Vo;
  19. import ${packageName}.domain.bo.${ClassName}Bo;
  20. import ${packageName}.service.I${ClassName}Service;
  21. #if($table.crud || $table.sub)
  22. import org.dromara.common.mybatis.core.page.TableDataInfo;
  23. #elseif($table.tree)
  24. #end
  25. /**
  26. * ${functionName}
  27. *
  28. * @author ${author}
  29. * @date ${datetime}
  30. */
  31. @Validated
  32. @RequiredArgsConstructor
  33. @RestController
  34. @RequestMapping("/${moduleName}/${businessName}")
  35. public class ${ClassName}Controller extends BaseController {
  36. private final I${ClassName}Service ${className}Service;
  37. /**
  38. * 查询${functionName}列表
  39. */
  40. @SaCheckPermission("${permissionPrefix}:list")
  41. @GetMapping("/list")
  42. #if($table.crud || $table.sub)
  43. public TableDataInfo<${ClassName}Vo> list(${ClassName}Bo bo, PageQuery pageQuery) {
  44. return ${className}Service.queryPageList(bo, pageQuery);
  45. }
  46. #elseif($table.tree)
  47. public R<List<${ClassName}Vo>> list(${ClassName}Bo bo) {
  48. List<${ClassName}Vo> list = ${className}Service.queryList(bo);
  49. return R.ok(list);
  50. }
  51. #end
  52. /**
  53. * 导出${functionName}列表
  54. */
  55. @SaCheckPermission("${permissionPrefix}:export")
  56. @Log(title = "${functionName}", businessType = BusinessType.EXPORT)
  57. @PostMapping("/export")
  58. public void export(${ClassName}Bo bo, HttpServletResponse response) {
  59. List<${ClassName}Vo> list = ${className}Service.queryList(bo);
  60. ExcelUtil.exportExcel(list, "${functionName}", ${ClassName}Vo.class, response);
  61. }
  62. /**
  63. * 获取${functionName}详细信息
  64. *
  65. * @param ${pkColumn.javaField} 主键
  66. */
  67. @SaCheckPermission("${permissionPrefix}:query")
  68. @GetMapping("/{${pkColumn.javaField}}")
  69. public R<${ClassName}Vo> getInfo(@NotNull(message = "主键不能为空")
  70. @PathVariable ${pkColumn.javaType} ${pkColumn.javaField}) {
  71. return R.ok(${className}Service.queryById(${pkColumn.javaField}));
  72. }
  73. /**
  74. * 新增${functionName}
  75. */
  76. @SaCheckPermission("${permissionPrefix}:add")
  77. @Log(title = "${functionName}", businessType = BusinessType.INSERT)
  78. @RepeatSubmit()
  79. @PostMapping()
  80. public R<Void> add(@Validated(AddGroup.class) @RequestBody ${ClassName}Bo bo) {
  81. return toAjax(${className}Service.insertByBo(bo));
  82. }
  83. /**
  84. * 修改${functionName}
  85. */
  86. @SaCheckPermission("${permissionPrefix}:edit")
  87. @Log(title = "${functionName}", businessType = BusinessType.UPDATE)
  88. @RepeatSubmit()
  89. @PutMapping()
  90. public R<Void> edit(@Validated(EditGroup.class) @RequestBody ${ClassName}Bo bo) {
  91. return toAjax(${className}Service.updateByBo(bo));
  92. }
  93. /**
  94. * 删除${functionName}
  95. *
  96. * @param ${pkColumn.javaField}s 主键串
  97. */
  98. @SaCheckPermission("${permissionPrefix}:remove")
  99. @Log(title = "${functionName}", businessType = BusinessType.DELETE)
  100. @DeleteMapping("/{${pkColumn.javaField}s}")
  101. public R<Void> remove(@NotEmpty(message = "主键不能为空")
  102. @PathVariable ${pkColumn.javaType}[] ${pkColumn.javaField}s) {
  103. return toAjax(${className}Service.deleteWithValidByIds(List.of(${pkColumn.javaField}s), true));
  104. }
  105. }