TestDemoController.java 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. package com.ruoyi.demo.controller;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import cn.hutool.core.bean.BeanUtil;
  4. import com.ruoyi.common.annotation.Log;
  5. import com.ruoyi.common.annotation.RepeatSubmit;
  6. import com.ruoyi.common.core.controller.BaseController;
  7. import com.ruoyi.common.core.domain.R;
  8. import com.ruoyi.common.core.domain.PageQuery;
  9. import com.ruoyi.common.core.page.TableDataInfo;
  10. import com.ruoyi.common.core.validate.AddGroup;
  11. import com.ruoyi.common.core.validate.EditGroup;
  12. import com.ruoyi.common.core.validate.QueryGroup;
  13. import com.ruoyi.common.enums.BusinessType;
  14. import com.ruoyi.common.excel.ExcelResult;
  15. import com.ruoyi.common.utils.ValidatorUtils;
  16. import com.ruoyi.common.utils.poi.ExcelUtil;
  17. import com.ruoyi.demo.domain.TestDemo;
  18. import com.ruoyi.demo.domain.bo.TestDemoBo;
  19. import com.ruoyi.demo.domain.bo.TestDemoImportVo;
  20. import com.ruoyi.demo.domain.vo.TestDemoVo;
  21. import com.ruoyi.demo.service.ITestDemoService;
  22. import io.swagger.annotations.*;
  23. import lombok.RequiredArgsConstructor;
  24. import org.springframework.validation.annotation.Validated;
  25. import org.springframework.web.bind.annotation.*;
  26. import org.springframework.web.multipart.MultipartFile;
  27. import javax.servlet.http.HttpServletResponse;
  28. import javax.validation.constraints.NotEmpty;
  29. import javax.validation.constraints.NotNull;
  30. import java.util.Arrays;
  31. import java.util.List;
  32. import java.util.concurrent.TimeUnit;
  33. /**
  34. * 测试单表Controller
  35. *
  36. * @author Lion Li
  37. * @date 2021-07-26
  38. */
  39. @Validated
  40. @Api(value = "测试单表控制器", tags = {"测试单表管理"})
  41. @RequiredArgsConstructor
  42. @RestController
  43. @RequestMapping("/demo/demo")
  44. public class TestDemoController extends BaseController {
  45. private final ITestDemoService iTestDemoService;
  46. /**
  47. * 查询测试单表列表
  48. */
  49. @ApiOperation("查询测试单表列表")
  50. @SaCheckPermission("demo:demo:list")
  51. @GetMapping("/list")
  52. public TableDataInfo<TestDemoVo> list(@Validated(QueryGroup.class) TestDemoBo bo, PageQuery pageQuery) {
  53. return iTestDemoService.queryPageList(bo, pageQuery);
  54. }
  55. /**
  56. * 自定义分页查询
  57. */
  58. @ApiOperation("自定义分页查询")
  59. @SaCheckPermission("demo:demo:list")
  60. @GetMapping("/page")
  61. public TableDataInfo<TestDemoVo> page(@Validated(QueryGroup.class) TestDemoBo bo, PageQuery pageQuery) {
  62. return iTestDemoService.customPageList(bo, pageQuery);
  63. }
  64. @ApiOperation("导入测试-校验")
  65. @ApiImplicitParams({
  66. @ApiImplicitParam(name = "file", value = "导入文件", dataType = "java.io.File", required = true),
  67. })
  68. @Log(title = "测试单表", businessType = BusinessType.IMPORT)
  69. @SaCheckPermission("demo:demo:import")
  70. @PostMapping("/importData")
  71. public R<Void> importData(@RequestPart("file") MultipartFile file) throws Exception {
  72. ExcelResult<TestDemoImportVo> excelResult = ExcelUtil.importExcel(file.getInputStream(), TestDemoImportVo.class, true);
  73. List<TestDemoImportVo> volist = excelResult.getList();
  74. List<TestDemo> list = BeanUtil.copyToList(volist, TestDemo.class);
  75. iTestDemoService.saveBatch(list);
  76. return R.ok(excelResult.getAnalysis());
  77. }
  78. /**
  79. * 导出测试单表列表
  80. */
  81. @ApiOperation("导出测试单表列表")
  82. @SaCheckPermission("demo:demo:export")
  83. @Log(title = "测试单表", businessType = BusinessType.EXPORT)
  84. @PostMapping("/export")
  85. public void export(@Validated TestDemoBo bo, HttpServletResponse response) {
  86. List<TestDemoVo> list = iTestDemoService.queryList(bo);
  87. // 测试雪花id导出
  88. // for (TestDemoVo vo : list) {
  89. // vo.setId(1234567891234567893L);
  90. // }
  91. ExcelUtil.exportExcel(list, "测试单表", TestDemoVo.class, response);
  92. }
  93. /**
  94. * 获取测试单表详细信息
  95. */
  96. @ApiOperation("获取测试单表详细信息")
  97. @SaCheckPermission("demo:demo:query")
  98. @GetMapping("/{id}")
  99. public R<TestDemoVo> getInfo(@ApiParam("测试ID")
  100. @NotNull(message = "主键不能为空")
  101. @PathVariable("id") Long id) {
  102. return R.ok(iTestDemoService.queryById(id));
  103. }
  104. /**
  105. * 新增测试单表
  106. */
  107. @ApiOperation("新增测试单表")
  108. @SaCheckPermission("demo:demo:add")
  109. @Log(title = "测试单表", businessType = BusinessType.INSERT)
  110. @RepeatSubmit(interval = 2, timeUnit = TimeUnit.SECONDS, message = "{repeat.submit.message}")
  111. @PostMapping()
  112. public R<Void> add(@RequestBody TestDemoBo bo) {
  113. // 使用校验工具对标 @Validated(AddGroup.class) 注解
  114. // 用于在非 Controller 的地方校验对象
  115. ValidatorUtils.validate(bo, AddGroup.class);
  116. return toAjax(iTestDemoService.insertByBo(bo) ? 1 : 0);
  117. }
  118. /**
  119. * 修改测试单表
  120. */
  121. @ApiOperation("修改测试单表")
  122. @SaCheckPermission("demo:demo:edit")
  123. @Log(title = "测试单表", businessType = BusinessType.UPDATE)
  124. @RepeatSubmit
  125. @PutMapping()
  126. public R<Void> edit(@Validated(EditGroup.class) @RequestBody TestDemoBo bo) {
  127. return toAjax(iTestDemoService.updateByBo(bo) ? 1 : 0);
  128. }
  129. /**
  130. * 删除测试单表
  131. */
  132. @ApiOperation("删除测试单表")
  133. @SaCheckPermission("demo:demo:remove")
  134. @Log(title = "测试单表", businessType = BusinessType.DELETE)
  135. @DeleteMapping("/{ids}")
  136. public R<Void> remove(@ApiParam("测试ID串")
  137. @NotEmpty(message = "主键不能为空")
  138. @PathVariable Long[] ids) {
  139. return toAjax(iTestDemoService.deleteWithValidByIds(Arrays.asList(ids), true) ? 1 : 0);
  140. }
  141. }