package com.doumee.cloud.admin; import com.doumee.api.BaseController; import com.doumee.config.annotation.CloudRequiredPermission; import com.doumee.core.annotation.excel.ExcelExporter; import com.doumee.core.annotation.pr.PreventRepeat; import com.doumee.core.constants.ResponseStatus; import com.doumee.core.exception.BusinessException; import com.doumee.dao.business.vo.HiddenDangerDataVO; import com.doumee.service.business.third.model.ApiResponse; import com.doumee.service.business.third.model.LoginUserInfo; import com.doumee.service.business.third.model.PageData; import com.doumee.service.business.third.model.PageWrap; import com.doumee.core.utils.Constants; import com.doumee.dao.business.model.HiddenDanger; import com.doumee.service.business.HiddenDangerService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import java.util.List; import java.util.Objects; /** * @author 江蹄蹄 * @since 2024/04/28 16:06 */ @Api(tags = "隐患信息表") @RestController @RequestMapping(Constants.CLOUD_SERVICE_URL_INDEX+"/business/hiddenDanger") public class HiddenDangerCloudController extends BaseController { @Autowired private HiddenDangerService hiddenDangerService; @PreventRepeat @ApiOperation("新建") @PostMapping("/create") @CloudRequiredPermission("business:hiddendanger:create") public ApiResponse create(@RequestBody HiddenDanger hiddenDanger,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ LoginUserInfo loginUserInfo = this.getLoginUser(token); if(Objects.isNull(loginUserInfo.getMemberId())||Objects.isNull(loginUserInfo)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"当前账户无法进行该操作"); } hiddenDanger.setLoginUserInfo(loginUserInfo); return ApiResponse.success(hiddenDangerService.create(hiddenDanger)); } @ApiOperation("根据ID删除") @GetMapping("/delete/{id}") @CloudRequiredPermission("business:hiddendanger:delete") public ApiResponse deleteById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ hiddenDangerService.deleteById(id,this.getLoginUser(token)); return ApiResponse.success(null); } @ApiOperation("批量删除") @GetMapping("/delete/batch") @CloudRequiredPermission("business:hiddendanger:delete") public ApiResponse deleteByIdInBatch(@RequestParam String ids,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ hiddenDangerService.deleteByIdInBatch(this.getIdList(ids)); return ApiResponse.success(null); } @ApiOperation("根据ID修改") @PostMapping("/updateById") @CloudRequiredPermission("business:hiddendanger:update") public ApiResponse updateById(@RequestBody HiddenDanger hiddenDanger,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ LoginUserInfo loginUserInfo = this.getLoginUser(token); if(Objects.isNull(loginUserInfo.getMemberId())||Objects.isNull(loginUserInfo)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"当前账户无法进行该操作"); } hiddenDanger.setLoginUserInfo(loginUserInfo); hiddenDangerService.updateById(hiddenDanger); return ApiResponse.success(null); } @ApiOperation("分页查询") @PostMapping("/page") @CloudRequiredPermission("business:hiddendanger:query") public ApiResponse> findPage (@RequestBody PageWrap pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ pageWrap.getModel().setLoginUserInfo(this.getLoginUser(token)); return ApiResponse.success(hiddenDangerService.findPage(pageWrap)); } @ApiOperation("导出Excel") @PostMapping("/exportExcel") @CloudRequiredPermission("business:hiddendanger:exportExcel") public void exportExcel (@RequestBody PageWrap pageWrap, HttpServletResponse response,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ pageWrap.getModel().setLoginUserInfo(this.getLoginUser(token)); List list = hiddenDangerService.findPage(pageWrap).getRecords(); ExcelExporter.build(HiddenDanger.class).export(list, "隐患信息表", response); } @ApiOperation("根据ID查询") @GetMapping("/{id}") @CloudRequiredPermission("business:hiddendanger:query") public ApiResponse findById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ return ApiResponse.success(hiddenDangerService.findById(id)); } @ApiOperation("隐患处理") @PostMapping("/dealHiddenDanger") public ApiResponse dealHiddenDanger (@RequestBody HiddenDanger hiddenDanger,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ hiddenDanger.setLoginUserInfo(getLoginUser(token)); hiddenDangerService.dealHiddenDanger(hiddenDanger); return ApiResponse.success("操作成功"); } @ApiOperation("隐患转交") @PostMapping("/transferHiddenDanger") public ApiResponse transferHiddenDanger (@RequestBody HiddenDanger hiddenDanger,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ hiddenDanger.setLoginUserInfo(getLoginUser(token)); hiddenDangerService.transferHiddenDanger(hiddenDanger); return ApiResponse.success("操作成功"); } @ApiOperation("隐患数据统计") @PostMapping("/hiddenDangerData") public ApiResponse hiddenDangerData (@RequestBody HiddenDanger hiddenDanger, @RequestHeader(Constants.HEADER_USER_TOKEN) String token){ hiddenDanger.setLoginUserInfo(getLoginUser(token)); return ApiResponse.success("操作成功",hiddenDangerService.hiddenDangerData(hiddenDanger)); } }