package org.dromara.analy.controller; import java.util.Date; import java.util.List; import lombok.RequiredArgsConstructor; import jakarta.servlet.http.HttpServletResponse; import jakarta.validation.constraints.*; import cn.dev33.satoken.annotation.SaCheckPermission; import org.springframework.web.bind.annotation.*; import org.springframework.validation.annotation.Validated; import org.dromara.common.idempotent.annotation.RepeatSubmit; import org.dromara.common.log.annotation.Log; import org.dromara.common.web.core.BaseController; import org.dromara.common.mybatis.core.page.PageQuery; import org.dromara.common.core.domain.R; import org.dromara.common.core.validate.AddGroup; import org.dromara.common.core.validate.EditGroup; import org.dromara.common.log.enums.BusinessType; import org.dromara.common.excel.utils.ExcelUtil; import org.dromara.analy.domain.vo.RollerTimeDataVo; import org.dromara.analy.domain.bo.RollerTimeDataBo; import org.dromara.analy.service.IRollerTimeDataService; import org.dromara.common.mybatis.core.page.TableDataInfo; /** * 卷接机分析 * * @author zhuguifei * @date 2026-01-28 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/analy/roller") public class RollerTimeDataController extends BaseController { private final IRollerTimeDataService rollerTimeDataService; /** * 查询卷接机分析列表 */ @SaCheckPermission("analy:rollerData:list") @GetMapping("/list") public TableDataInfo list(RollerTimeDataBo bo, PageQuery pageQuery) { return rollerTimeDataService.queryPageList(bo, pageQuery); } /** * 查询采样后的卷接机分析列表 (每小时每设备60条) */ @SaCheckPermission("analy:rollerData:list") @GetMapping("/sampleList") public R> sampleList(RollerTimeDataBo bo) { if (bo.getEquNo() == null) { return R.fail("设备号不能为空"); } List rollerTimeDataVos = rollerTimeDataService.querySampledList(bo); return R.ok(rollerTimeDataVos); } /** * 导出卷接机分析列表 */ @SaCheckPermission("analy:rollerData:export") @Log(title = "卷接机分析", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(RollerTimeDataBo bo, HttpServletResponse response) { List list = rollerTimeDataService.queryList(bo); ExcelUtil.exportExcel(list, "卷接机分析", RollerTimeDataVo.class, response); } /** * 获取卷接机分析详细信息 * * @param time 主键 */ @SaCheckPermission("analy:rollerData:query") @GetMapping("/{time}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable Date time) { return R.ok(rollerTimeDataService.queryById(time)); } /** * 新增卷接机分析 */ @SaCheckPermission("analy:rollerData:add") @Log(title = "卷接机分析", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R add(@Validated(AddGroup.class) @RequestBody RollerTimeDataBo bo) { return toAjax(rollerTimeDataService.insertByBo(bo)); } /** * 修改卷接机分析 */ @SaCheckPermission("analy:rollerData:edit") @Log(title = "卷接机分析", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody RollerTimeDataBo bo) { return toAjax(rollerTimeDataService.updateByBo(bo)); } /** * 删除卷接机分析 * * @param times 主键串 */ @SaCheckPermission("analy:rollerData:remove") @Log(title = "卷接机分析", businessType = BusinessType.DELETE) @DeleteMapping("/{times}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable Date[] times) { return toAjax(rollerTimeDataService.deleteWithValidByIds(List.of(times), true)); } }