controller.java.vm 4.6 KB

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