package com.dy.pipIrrIrrigate.irrigateGroup; import com.dy.common.aop.SsoAop; import com.dy.common.webUtil.BaseResponse; import com.dy.common.webUtil.BaseResponseUtils; import com.dy.common.webUtil.QueryResultVo; import com.dy.common.webUtil.ResultCodeMsg; import com.dy.pipIrrGlobal.pojoIr.IrGroupClient; import com.dy.pipIrrGlobal.pojoIr.IrGroupUnit; import com.dy.pipIrrGlobal.pojoIr.IrIrrigateGroup; import com.dy.pipIrrGlobal.voIr.VoGroup; import com.dy.pipIrrGlobal.voIr.VoGroupDetail; import com.dy.pipIrrGlobal.voIr.VoGroupOne; import com.dy.pipIrrGlobal.voIr.VoGroupSimple; import com.dy.pipIrrGlobal.voSe.VoActiveCard; import com.dy.pipIrrIrrigate.irrigateGroup.dto.GroupClient; import com.dy.pipIrrIrrigate.irrigateGroup.dto.IrrigateGroup; import com.dy.pipIrrIrrigate.irrigateGroup.qo.QoGroup; import com.dy.pipIrrIrrigate.result.IrrigateResultCode; import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.media.Content; import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.responses.ApiResponse; import io.swagger.v3.oas.annotations.responses.ApiResponses; import io.swagger.v3.oas.annotations.tags.Tag; import jakarta.validation.Valid; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.MediaType; import org.springframework.transaction.annotation.Transactional; import org.springframework.validation.BindingResult; import org.springframework.web.bind.annotation.*; import java.util.*; /** * @author :WuZeYu * @Date :2024/5/21 16:19 * @LastEditTime :2024/5/21 16:19 * @Description */ @Slf4j @Tag(name = "轮灌组", description = "轮灌组") @RestController @RequestMapping(path = "group") @RequiredArgsConstructor public class IrrigateGroupCtrl { @Autowired private IrrigateGroupSv irrigateGroupSv; /** * 创建轮灌组 * * @param po 轮灌组实体对象 * @param bindingResult * @return 添加是否成功 */ @Operation(summary = "创建轮灌组记录", description = "创建轮灌组记录") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @PostMapping(path = "add", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse add(@RequestBody @Valid IrIrrigateGroup po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } try { Integer rec = Optional.ofNullable(irrigateGroupSv.addIrrigateGroup(po)).orElse(0); if (rec == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.ADD_GROUP_FAIL.getMessage()); } } catch (Exception e) { log.error("创建轮灌组异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } /** * 逻辑删除灌溉单元 * * @param * @return */ @Operation(summary = "逻辑删除轮灌组", description = "逻辑删除轮灌组") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @PostMapping(path = "delete") @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse delete(@RequestBody Map map) { if (map == null || map.size() <= 0) { BaseResponseUtils.buildFail(IrrigateResultCode.PLEASE_INPUT_GROUP_ID.getMessage()); } Long groupId = Long.parseLong(map.get("id").toString()); try { Integer rows = irrigateGroupSv.deleteIrrigateGroup(groupId); if (rows == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.DELETE_GROUP_FAIL.getMessage()); } } catch (Exception e) { log.error("删除轮灌组异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } /** * 批量删除 * * @param groupIds * @return */ @PostMapping(path = "delete_batch", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse delete_batch(@RequestBody Map groupIds) { if (groupIds == null || groupIds.size() <= 0) { BaseResponseUtils.buildFail(IrrigateResultCode.PLEASE_INPUT_PROJECT_ID.getMessage()); } List ids = groupIds.get("groupIds"); for (int i = 0; i < ids.size(); i++) { long groupId = Long.parseLong(ids.get(i).toString()); try { Integer rows = irrigateGroupSv.deleteIrrigateGroup(groupId); if (rows == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.DELETE_GROUP_FAIL.getMessage()); } } catch (Exception e) { log.error("删除轮灌组异常", e); return BaseResponseUtils.buildException(e.getMessage()); } } return BaseResponseUtils.buildSuccess(true); } /** * 修改灌溉单元 * * @param po * @param bindingResult * @return */ @Operation(summary = "修改轮灌组", description = "修改轮灌组") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @PostMapping(path = "update", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse update(@RequestBody @Valid IrIrrigateGroup po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } try { Integer rec = Optional.ofNullable(irrigateGroupSv.updateIrrigateGroup(po)).orElse(0); if (rec == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.UPDATE_GROUP_FAIL.getMessage()); } } catch (Exception e) { log.error("修改轮灌组异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } /** * 获取一个轮灌组 * * @return 获取一个轮灌组 */ @Operation(summary = "获取一个轮灌组", description = "获取一个轮灌组") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "获取一个轮灌组(BaseResponse.content:{})", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = IrIrrigateGroup.class))} ) }) @GetMapping(path = "one") @SsoAop() public BaseResponse one(@RequestParam Long id) { VoGroupOne irIrrigateGroup = this.irrigateGroupSv.selectById(id); return BaseResponseUtils.buildSuccess(irIrrigateGroup); } /** * 分页查询 * * @param vo * @return */ @Operation(summary = "获得一页轮灌组记录", description = "获得一页轮灌组记录") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "获得一页灌溉单元记录(BaseResponse.content:QueryResultVo[{}])", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = VoActiveCard.class))} ) }) @GetMapping(path = "some") @SsoAop() public BaseResponse>> getIrrigateGroups(QueryVo vo) { try { QueryResultVo> res = irrigateGroupSv.getIrrigateGroups(vo); return BaseResponseUtils.buildSuccess(res); } catch (Exception e) { log.error("获取轮灌组记录异常", e); return BaseResponseUtils.buildException(e.getMessage()); } } /** * 轮灌组添加灌溉单元 * * @param po 轮灌组灌溉单元中间表 * @param bindingResult * @return 添加是否成功 */ @Operation(summary = "轮灌组添加灌溉单元", description = "轮灌组添加灌溉单元") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @PostMapping(path = "add_unit", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse addGroupUnit(@RequestBody @Valid Map po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } Long groupId = Long.parseLong(po.get("groupId").toString()); Long operator = Long.parseLong(po.get("operator").toString()); List unitIds = (List) po.get("unitIds"); try { for (int i = 0; i < unitIds.size(); i++) { Long unitId = unitIds.get(i); IrGroupUnit irGroupUnit = new IrGroupUnit(); irGroupUnit.setGroupId(groupId); irGroupUnit.setUnitId(unitId); irGroupUnit.setOperator(operator); Integer rec = Optional.ofNullable(irrigateGroupSv.addGroupUnit(irGroupUnit)).orElse(0); if (rec == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.GROUP_ADD_UNIT_FAIL.getMessage()); } } } catch (Exception e) { log.error("轮灌组添加灌溉单元异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } /** * 轮灌组移除灌溉单元 * * @param * @return */ @Operation(summary = "轮灌组移除灌溉单元", description = "轮灌组移除灌溉单元") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @PostMapping(path = "remove_unit") @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse deleteGroupUnit(@RequestBody @Valid Map po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } Long groupId = Long.parseLong(po.get("groupId").toString()); Long operator = Long.parseLong(po.get("operator").toString()); List unitIds = (List) po.get("unitIds"); try { for (int i = 0; i < unitIds.size(); i++) { Long unitId = unitIds.get(i); IrGroupUnit irGroupUnit = new IrGroupUnit(); irGroupUnit.setGroupId(groupId); irGroupUnit.setUnitId(unitId); irGroupUnit.setOperator(operator); Integer rec = Optional.ofNullable(irrigateGroupSv.deleteGroupUnit(irGroupUnit)).orElse(0); if (rec == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.DELETE_PROJECT_FAIL.getMessage()); } } } catch (Exception e) { log.error("轮灌组移除灌溉单元异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } @GetMapping(path = "bind_units") @SsoAop() public BaseResponse> getGroupBindUnits(Long id) { try { List res = irrigateGroupSv.getGroupBindUnits(id); ArrayList list = new ArrayList<>(); for (int i = 0; i < res.size(); i++) { String aLong = res.get(i).toString(); list.add(aLong); } return BaseResponseUtils.buildSuccess(list); } catch (Exception e) { log.error("获取一个轮灌组绑定灌溉单元记录异常", e); return BaseResponseUtils.buildException(e.getMessage()); } } @GetMapping(path = "notBind_units") @SsoAop() public BaseResponse> getNotBindUnits() { try { List res = irrigateGroupSv.getNotBindUnits(); ArrayList list = new ArrayList<>(); for (int i = 0; i < res.size(); i++) { String aLong = res.get(i).toString(); list.add(aLong); } return BaseResponseUtils.buildSuccess(list); } catch (Exception e) { log.error("获取未绑定轮灌组的灌溉单元id记录异常", e); return BaseResponseUtils.buildException(e.getMessage()); } } /** * 修改轮灌组绑定的灌溉单元 * * @param po 轮灌组灌溉单元中间表 * @param bindingResult * @return 添加是否成功 */ @Operation(summary = "修改轮灌组绑定的灌溉单元", description = "修改轮灌组绑定的灌溉单元") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @PostMapping(path = "updateBindUnits", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse updateBindUnits(@RequestBody @Valid Map po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } Long groupId = Long.parseLong(po.get("groupId").toString()); Long operator = Long.parseLong(po.get("operator").toString()); List newUnitIds = (List) po.get("unitIds"); List oldUnitIds = irrigateGroupSv.getGroupBindUnits(groupId); IrGroupUnit irGroupUnit = new IrGroupUnit(); irGroupUnit.setGroupId(groupId); irGroupUnit.setOperator(operator); try { for (int j = 0; j < oldUnitIds.size(); j++) { Long oldUnitId = oldUnitIds.get(j); if (!newUnitIds.toString().contains(oldUnitId.toString())) { irGroupUnit.setUnitId(oldUnitId); Integer rec = Optional.ofNullable(irrigateGroupSv.deleteGroupUnit(irGroupUnit)).orElse(0); if (rec == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.ADD_PROJECT_FAIL.getMessage()); } } } for (int i = 0; i < newUnitIds.size(); i++) { Long newUnitId = Long.parseLong(newUnitIds.get(i)); if (!oldUnitIds.toString().contains(newUnitId.toString())) { irGroupUnit.setUnitId(newUnitId); Integer rec = Optional.ofNullable(irrigateGroupSv.addGroupUnit(irGroupUnit)).orElse(0); if (rec == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.ADD_PROJECT_FAIL.getMessage()); } } } } catch (Exception e) { log.error("修改轮灌组绑定的灌溉单元异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } /** * 轮灌组关联农户 * @param po * @param bindingResult * @return */ @PostMapping(path = "add_group_client", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse addGroupClient(@RequestBody @Valid GroupClient po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } IrGroupClient irGroupClient = new IrGroupClient(); irGroupClient.setGroupId(po.getGroupId()); irGroupClient.setClientId(po.getClientId()); irGroupClient.setOperator(po.getOperator()); irGroupClient.setOperateTime(new Date()); try { Long rec = Optional.ofNullable(irrigateGroupSv.addGroupClient(irGroupClient)).orElse(0L); if (rec == 0) { return BaseResponseUtils.buildErrorMsg(IrrigateResultCode.GRPUP_ASSOCIATE_CLIENT_FAIL.getMessage()); } } catch (Exception e) { return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } /** * 新增轮灌组,新代码 * @param po * @param bindingResult * @return */ @PostMapping(path = "addIrrigateGroup", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse addIrrigateGroup(@RequestBody @Valid IrrigateGroup po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } // 先判断表内是否存在相同的 groupCode if (irrigateGroupSv.existsByGroupCode(po.getGroupCode())) { return BaseResponseUtils.buildFail(IrrigateResultCode.GROUP_CODE_ALREADY_EXISTS.getMessage()); } Map map_result = irrigateGroupSv.addIrrigateGroup(po); if(map_result.get("success").equals(false)) { return BaseResponseUtils.buildErrorMsg(map_result.get("msg").toString()); } return BaseResponseUtils.buildSuccess() ; } /** * 删除轮灌组,新代码 * @param groupId * @return */ @PostMapping(path = "deleteIrrigateGroup") @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse deleteIrrigateGroup(@RequestParam(required = false) Long groupId) { if(groupId == null) { return BaseResponseUtils.buildErrorMsg("轮灌组ID不能为空"); } Map map_result = irrigateGroupSv.deleteGroup(groupId); if(map_result.get("success").equals(false)) { return BaseResponseUtils.buildErrorMsg(map_result.get("msg").toString()); } return BaseResponseUtils.buildSuccess() ; } /** * 修改轮灌组,新代码 * @param po * @param bindingResult * @return */ @PostMapping(path = "updateIrrigateGroup", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse updateIrrigateGroup(@RequestBody @Valid IrrigateGroup po, BindingResult bindingResult){ if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } if(po.getGroupId() == null) { return BaseResponseUtils.buildErrorMsg("轮灌组ID不能为空"); } // 先判断表内是否存在相同的 groupCode(排除当前正在修改的记录) if (irrigateGroupSv.existsByGroupCodeExcludeId(po.getGroupCode(), po.getGroupId())) { return BaseResponseUtils.buildFail(IrrigateResultCode.GROUP_CODE_ALREADY_EXISTS.getMessage()); } Map map_result = irrigateGroupSv.updateIrrigateGroup(po); if(map_result.get("success").equals(false)) { return BaseResponseUtils.buildErrorMsg(map_result.get("msg").toString()); } return BaseResponseUtils.buildSuccess() ; } /** * 获取轮灌组列表,新代码 * @param qo * @return */ @GetMapping(path = "/getSimpleGroups") @SsoAop() public BaseResponse>> getSimpleGroups(QoGroup qo) { try { QueryResultVo> res = irrigateGroupSv.getSimpleGroups(qo); return BaseResponseUtils.buildSuccess(res); } catch (Exception e) { log.error("获取项目记录异常", e); return BaseResponseUtils.buildException(e.getMessage()); } } /** * 获取全部轮灌组,新代码 * @return */ @GetMapping(path = "/getAllGroups") @SsoAop() public BaseResponse> getAllGroups() { try { return BaseResponseUtils.buildSuccess(irrigateGroupSv.getAllGroups()); } catch (Exception e) { log.error("获取项目记录异常", e); return BaseResponseUtils.buildException(e.getMessage()); } } /** * 获取轮灌组详情,新代码 * @param groupId * @return */ @GetMapping(path = "getGroupDetail") @SsoAop() public BaseResponse getGroupDetail(@RequestParam Long groupId) { if(groupId == null) { return BaseResponseUtils.buildErrorMsg("轮灌组ID不能为空"); } Map map_result = irrigateGroupSv.getGroupDetail(groupId); if(map_result.get("success").equals(false)) { return BaseResponseUtils.buildErrorMsg(map_result.get("msg").toString()); } return BaseResponseUtils.buildSuccess(map_result.get("content")) ; } }