package com.ruoyi.data.controller; import java.util.List; import java.util.Arrays; import java.util.concurrent.TimeUnit; import com.ruoyi.data.domain.MqttObj; import lombok.RequiredArgsConstructor; import javax.servlet.http.HttpServletResponse; import javax.validation.constraints.*; import cn.dev33.satoken.annotation.SaCheckPermission; import org.springframework.web.bind.annotation.*; import org.springframework.validation.annotation.Validated; import com.ruoyi.common.annotation.RepeatSubmit; import com.ruoyi.common.annotation.Log; 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.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.utils.poi.ExcelUtil; import com.ruoyi.data.domain.vo.TblEquipmentMqttVo; import com.ruoyi.data.domain.bo.TblEquipmentMqttBo; import com.ruoyi.data.service.ITblEquipmentMqttService; import com.ruoyi.common.core.page.TableDataInfo; /** * 【请填写功能名称】 * * @author ruoyi * @date 2023-12-14 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/data/equipmentMqtt") public class TblEquipmentMqttController extends BaseController { private final ITblEquipmentMqttService iTblEquipmentMqttService; /** * 查询【请填写功能名称】列表 */ @SaCheckPermission("data:equipmentMqtt:list") @GetMapping("/list") public TableDataInfo list(TblEquipmentMqttBo bo, PageQuery pageQuery) { return iTblEquipmentMqttService.queryPageList(bo, pageQuery); } /** * 导出【请填写功能名称】列表 */ @SaCheckPermission("data:equipmentMqtt:export") @Log(title = "【请填写功能名称】", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(TblEquipmentMqttBo bo, HttpServletResponse response) { List list = iTblEquipmentMqttService.queryList(bo); ExcelUtil.exportExcel(list, "【请填写功能名称】", TblEquipmentMqttVo.class, response); } /** * 获取【请填写功能名称】详细信息 * * @param id 主键 */ @SaCheckPermission("data:equipmentMqtt:query") @GetMapping("/{id}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable Long id) { return R.ok(iTblEquipmentMqttService.queryById(id)); } /** * 新增【请填写功能名称】 */ @SaCheckPermission("data:equipmentMqtt:add") @Log(title = "【请填写功能名称】", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R add(@Validated(AddGroup.class) @RequestBody TblEquipmentMqttBo bo) { return toAjax(iTblEquipmentMqttService.insertByBo(bo)); } /** * 修改【请填写功能名称】 */ @SaCheckPermission("data:equipmentMqtt:edit") @Log(title = "【请填写功能名称】", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody TblEquipmentMqttBo bo) { return toAjax(iTblEquipmentMqttService.updateByBo(bo)); } /** * 删除【请填写功能名称】 * * @param ids 主键串 */ @SaCheckPermission("data:equipmentMqtt:remove") @Log(title = "【请填写功能名称】", businessType = BusinessType.DELETE) @DeleteMapping("/{ids}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable Long[] ids) { return toAjax(iTblEquipmentMqttService.deleteWithValidByIds(Arrays.asList(ids), true)); } @GetMapping("/listByDeviceId") public R> listByDeviceId(MqttObj mqttObj) { return R.ok(iTblEquipmentMqttService.getMqttListByDeviceId(mqttObj)); } @GetMapping("/noListByDeviceId") public R> noListByDeviceId(MqttObj mqttObj) { return R.ok(iTblEquipmentMqttService.selectNoMqttListByDeviceId(mqttObj)); } }