123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- package com.ruoyi.demo.controller;
- import cn.dev33.satoken.annotation.SaCheckPermission;
- import cn.hutool.core.bean.BeanUtil;
- import com.ruoyi.common.annotation.Log;
- import com.ruoyi.common.annotation.RepeatSubmit;
- import com.ruoyi.common.core.controller.BaseController;
- import com.ruoyi.common.core.domain.PageQuery;
- import com.ruoyi.common.core.domain.R;
- import com.ruoyi.common.core.page.TableDataInfo;
- import com.ruoyi.common.core.validate.AddGroup;
- import com.ruoyi.common.core.validate.EditGroup;
- import com.ruoyi.common.core.validate.QueryGroup;
- import com.ruoyi.common.enums.BusinessType;
- import com.ruoyi.common.excel.ExcelResult;
- import com.ruoyi.common.utils.ValidatorUtils;
- import com.ruoyi.common.utils.poi.ExcelUtil;
- import com.ruoyi.demo.domain.TestDemo;
- import com.ruoyi.demo.domain.bo.TestDemoBo;
- import com.ruoyi.demo.domain.bo.TestDemoImportVo;
- import com.ruoyi.demo.domain.vo.TestDemoVo;
- import com.ruoyi.demo.service.ITestDemoService;
- import io.swagger.v3.oas.annotations.Parameter;
- import io.swagger.v3.oas.annotations.Parameters;
- import io.swagger.v3.oas.annotations.enums.ParameterIn;
- import io.swagger.v3.oas.annotations.tags.Tag;
- import lombok.RequiredArgsConstructor;
- import org.springframework.validation.annotation.Validated;
- import org.springframework.web.bind.annotation.*;
- import org.springframework.web.multipart.MultipartFile;
- import javax.servlet.http.HttpServletResponse;
- import javax.validation.constraints.NotEmpty;
- import javax.validation.constraints.NotNull;
- import java.util.Arrays;
- import java.util.List;
- import java.util.concurrent.TimeUnit;
- /**
- * 测试单表Controller
- *
- * @author Lion Li
- * @date 2021-07-26
- */
- @Validated
- @Tag(name ="测试单表控制器", description = "测试单表管理")
- @RequiredArgsConstructor
- @RestController
- @RequestMapping("/demo/demo")
- public class TestDemoController extends BaseController {
- private final ITestDemoService iTestDemoService;
- /**
- * 查询测试单表列表
- */
- @SaCheckPermission("demo:demo:list")
- @GetMapping("/list")
- public TableDataInfo<TestDemoVo> list(@Validated(QueryGroup.class) TestDemoBo bo, PageQuery pageQuery) {
- return iTestDemoService.queryPageList(bo, pageQuery);
- }
- /**
- * 自定义分页查询
- */
- @SaCheckPermission("demo:demo:list")
- @GetMapping("/page")
- public TableDataInfo<TestDemoVo> page(@Validated(QueryGroup.class) TestDemoBo bo, PageQuery pageQuery) {
- return iTestDemoService.customPageList(bo, pageQuery);
- }
- @Parameters({
- @Parameter(name = "file", description = "导入文件", in = ParameterIn.QUERY, required = true),
- })
- @Log(title = "测试单表", businessType = BusinessType.IMPORT)
- @SaCheckPermission("demo:demo:import")
- @PostMapping("/importData")
- public R<Void> importData(@RequestPart("file") MultipartFile file) throws Exception {
- ExcelResult<TestDemoImportVo> excelResult = ExcelUtil.importExcel(file.getInputStream(), TestDemoImportVo.class, true);
- List<TestDemoImportVo> volist = excelResult.getList();
- List<TestDemo> list = BeanUtil.copyToList(volist, TestDemo.class);
- iTestDemoService.saveBatch(list);
- return R.ok(excelResult.getAnalysis());
- }
- /**
- * 导出测试单表列表
- */
- @SaCheckPermission("demo:demo:export")
- @Log(title = "测试单表", businessType = BusinessType.EXPORT)
- @PostMapping("/export")
- public void export(@Validated TestDemoBo bo, HttpServletResponse response) {
- List<TestDemoVo> list = iTestDemoService.queryList(bo);
- // 测试雪花id导出
- // for (TestDemoVo vo : list) {
- // vo.setId(1234567891234567893L);
- // }
- ExcelUtil.exportExcel(list, "测试单表", TestDemoVo.class, response);
- }
- /**
- * 获取测试单表详细信息
- */
- @SaCheckPermission("demo:demo:query")
- @GetMapping("/{id}")
- public R<TestDemoVo> getInfo(@Parameter(name = "测试ID")
- @NotNull(message = "主键不能为空")
- @PathVariable("id") Long id) {
- return R.ok(iTestDemoService.queryById(id));
- }
- /**
- * 新增测试单表
- */
- @SaCheckPermission("demo:demo:add")
- @Log(title = "测试单表", businessType = BusinessType.INSERT)
- @RepeatSubmit(interval = 2, timeUnit = TimeUnit.SECONDS, message = "{repeat.submit.message}")
- @PostMapping()
- public R<Void> add(@RequestBody TestDemoBo bo) {
- // 使用校验工具对标 @Validated(AddGroup.class) 注解
- // 用于在非 Controller 的地方校验对象
- ValidatorUtils.validate(bo, AddGroup.class);
- return toAjax(iTestDemoService.insertByBo(bo) ? 1 : 0);
- }
- /**
- * 修改测试单表
- */
- @SaCheckPermission("demo:demo:edit")
- @Log(title = "测试单表", businessType = BusinessType.UPDATE)
- @RepeatSubmit
- @PutMapping()
- public R<Void> edit(@Validated(EditGroup.class) @RequestBody TestDemoBo bo) {
- return toAjax(iTestDemoService.updateByBo(bo) ? 1 : 0);
- }
- /**
- * 删除测试单表
- */
- @SaCheckPermission("demo:demo:remove")
- @Log(title = "测试单表", businessType = BusinessType.DELETE)
- @DeleteMapping("/{ids}")
- public R<Void> remove(@Parameter(name = "测试ID串")
- @NotEmpty(message = "主键不能为空")
- @PathVariable Long[] ids) {
- return toAjax(iTestDemoService.deleteWithValidByIds(Arrays.asList(ids), true) ? 1 : 0);
- }
- }
|