package com.dy.pipIrrProject.intakeController; 
 | 
  
 | 
  
 | 
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.pojoBa.BaClient; 
 | 
import com.dy.pipIrrGlobal.pojoPr.PrController; 
 | 
import com.dy.pipIrrGlobal.pojoPr.PrControllerTramp; 
 | 
import com.dy.pipIrrGlobal.pojoPr.PrIntakeController; 
 | 
import com.dy.pipIrrProject.controller.ControllerSv; 
 | 
import com.dy.pipIrrProject.intake.IntakeSv; 
 | 
import com.dy.pipIrrProject.result.ProjectResultCode; 
 | 
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.http.MediaType; 
 | 
import org.springframework.transaction.annotation.Transactional; 
 | 
import org.springframework.validation.BindingResult; 
 | 
import org.springframework.web.bind.annotation.*; 
 | 
  
 | 
import java.text.ParseException; 
 | 
import java.text.SimpleDateFormat; 
 | 
import java.util.*; 
 | 
  
 | 
/** 
 | 
 * @author ZhuBaoMin 
 | 
 * @date 2024-01-02 9:18 
 | 
 * @LastEditTime 2024-01-02 9:18 
 | 
 * @Description 
 | 
 */ 
 | 
  
 | 
@Slf4j 
 | 
@Tag(name = "取水口/控制器关联管理", description = "取水口/控制器关联操作") 
 | 
@RestController 
 | 
@RequestMapping(path = "intake_controller") 
 | 
@RequiredArgsConstructor 
 | 
public class IntakeControllerCtrl { 
 | 
    private final IntakeControllerSv intakeControllerSv; 
 | 
    private final IntakeSv intakeSv; 
 | 
    private final ControllerSv controllerSv; 
 | 
  
 | 
    /** 
 | 
     * 取水口绑定控制器 
 | 
     * 1. 接收取水口ID及流浪控制器ID,并验证取水口和控制器是否存在 
 | 
     * 2. 判断该控制器是否存在未解绑记录,如果存在提示用户该控制器存在未解绑记录 
 | 
     * 3. 组装控制器对象插入控制器表中(及添加绑定记录) 
 | 
     * 4. 修改绑定记录设置备注 
 | 
     * 5. 删除流浪控制器(物理删除) 
 | 
     * 
 | 
     * @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 = "bind", consumes = MediaType.APPLICATION_JSON_VALUE) 
 | 
    @Transactional(rollbackFor = Exception.class) 
 | 
    @SsoAop() 
 | 
    public BaseResponse<Boolean> bind(@RequestBody @Valid DtoIntakeController po, BindingResult bindingResult) throws ParseException { 
 | 
        SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
 | 
        if (bindingResult != null && bindingResult.hasErrors()) { 
 | 
            return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); 
 | 
        } 
 | 
        // 接收参数 
 | 
        Long intakeId = po.getIntakeId(); 
 | 
        Long trampControllerId = po.getControllerId(); 
 | 
        String remarks = po.getRemarks(); 
 | 
        Long operator = po.getOperator(); 
 | 
  
 | 
        // 根据编号分别获取取水口记录数、流浪控制器信息,判断取水口及控制器是否存在 
 | 
        Integer recIntke = Optional.ofNullable(intakeSv.getRecordCountOfIntake(intakeId)).orElse(0); 
 | 
        PrControllerTramp prControllerTramp = intakeControllerSv.getTrampControllerInfo(trampControllerId); 
 | 
        //Map map_TrampController = Optional.ofNullable(intakeControllerSv.getTrampControllerInfo(controllerId)).orElse(new HashMap()); 
 | 
        if (recIntke == 0 || prControllerTramp == null) { 
 | 
            return BaseResponseUtils.buildFail(ProjectResultCode.INTAKE_OR_CONTROLLER_NO_EXIST.getMessage()); 
 | 
        } 
 | 
  
 | 
        // 根据控制器编号判断该控制器是否存在未解绑记录 
 | 
        Integer recBinded = Optional.ofNullable(controllerSv.getBindedCount(trampControllerId)).orElse(0); 
 | 
        if (recBinded > 0) { 
 | 
            return BaseResponseUtils.buildFail(ProjectResultCode.CONTROLLER_BINDED.getMessage()); 
 | 
        } 
 | 
  
 | 
        // 添加控制器记录 
 | 
        PrController prController = new PrController(); 
 | 
        prController.setIntakeId(intakeId); 
 | 
        prController.setRtuAddr(prControllerTramp.getRtuAddr()); 
 | 
        prController.setProtocol(prControllerTramp.getProtocol()); 
 | 
        prController.setProtocolVersion(prControllerTramp.getProtocolVersion()); 
 | 
        prController.setFindDt(prControllerTramp.getFindDt()); 
 | 
        prController.setOrgTag(prControllerTramp.getOrgTag()); 
 | 
        prController.setAddWays((byte) 1); 
 | 
        prController.setOperator(operator); 
 | 
        Date operateTime = new Date(); 
 | 
        prController.setOperateDt(operateTime); 
 | 
        prController.setDeleted((byte) 0); 
 | 
        Integer rec_addController = Optional.ofNullable(controllerSv.addController(prController)).orElse(0); 
 | 
        if (rec_addController == 0) { 
 | 
            return BaseResponseUtils.buildFail(ProjectResultCode.BIND_FAIL.getMessage()); 
 | 
        } 
 | 
//        if (remarks != null || remarks !=""){ 
 | 
//            // 修改绑定记录 
 | 
//            PrIntakeController prIntakeController = new PrIntakeController(); 
 | 
//            prIntakeController.setRemarks(remarks); 
 | 
//            prIntakeController.setIntakeid(intakeId); 
 | 
// 
 | 
//            Integer rec = Optional.ofNullable(intakeControllerSv.updateBindRecord(prIntakeController)).orElse(0); 
 | 
//            if (rec == 0) { 
 | 
//                return BaseResponseUtils.buildFail(ProjectResultCode.BIND_FAIL.getMessage()); 
 | 
//            } 
 | 
//        } 
 | 
  
 | 
  
 | 
        // 根据流浪控制器编号删除流浪控制器记录 
 | 
        intakeControllerSv.deleteTrampController(trampControllerId); 
 | 
  
 | 
        return BaseResponseUtils.buildSuccess(true); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 取水口解绑控制器 
 | 
     * 1. 接收取水口ID及流浪控制器ID,并验证取水口和控制器是否存在 
 | 
     * 2. 添加解绑记录 
 | 
     * 3. 删除控制器外键 
 | 
     * 
 | 
     * @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 = "unbind", consumes = MediaType.APPLICATION_JSON_VALUE) 
 | 
    @Transactional(rollbackFor = Exception.class) 
 | 
    @SsoAop() 
 | 
    public BaseResponse<Boolean> unbind(@RequestBody @Valid DtoIntakeController po, BindingResult bindingResult) { 
 | 
        if (bindingResult != null && bindingResult.hasErrors()) { 
 | 
            return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); 
 | 
        } 
 | 
  
 | 
        // 根据编号分别获取取水口、控制器未删除记录数 
 | 
        Integer recIntke = Optional.ofNullable(intakeSv.getRecordCountOfIntake(po.getIntakeId())).orElse(0); 
 | 
        Integer recController = Optional.ofNullable(controllerSv.getRecordCountOfController(po.getControllerId())).orElse(0); 
 | 
        if (recIntke == 0 || recController == 0) { 
 | 
            return BaseResponseUtils.buildFail(ProjectResultCode.INTAKE_OR_CONTROLLER_NO_EXIST.getMessage()); 
 | 
        } 
 | 
  
 | 
        // 判断最后操作记录是否为解绑记录 
 | 
        //Integer recordCount = Optional.ofNullable(intakeControllerSv.getBindRecordCount(po.getIntakeId(), po.getControllerId(), (byte)2)).orElse(0); 
 | 
        //if(recordCount > 0) { 
 | 
        //    return BaseResponseUtils.buildFail(ProjectResultCode.INTAKE_CONTROLLER_HAS_UNBOUND.getMessage()); 
 | 
        //} 
 | 
  
 | 
        // 添加解绑记录 
 | 
        PrIntakeController prIntakeController = DtoToPojo.INSTANCT.po2vo(po); 
 | 
        Date operateTime = new Date(); 
 | 
        prIntakeController.setOperatedt(operateTime); 
 | 
        prIntakeController.setOperatetype((byte) 2); 
 | 
        prIntakeController.setRemarks("解绑"); 
 | 
        Integer rec = Optional.ofNullable(intakeControllerSv.addRecord(prIntakeController)).orElse(0); 
 | 
        if (rec == 0) { 
 | 
            return BaseResponseUtils.buildFail(ProjectResultCode.BIND_FAIL.getMessage()); 
 | 
        } 
 | 
        //添加到流浪控制器 
 | 
        PrController ControllerList = controllerSv.getByControllerId(po.getControllerId()); 
 | 
        PrControllerTramp prControllerTramp = new PrControllerTramp(); 
 | 
        prControllerTramp.setRtuAddr(ControllerList.getRtuAddr()); 
 | 
        prControllerTramp.setProtocol(ControllerList.getProtocol()); 
 | 
        prControllerTramp.setFindDt(new Date()); 
 | 
        prControllerTramp.setOrgTag(ControllerList.getOrgTag()); 
 | 
        Integer rec_addControllerTramp = Optional.ofNullable(intakeControllerSv.addTrampController(prControllerTramp)).orElse(0); 
 | 
        if (rec_addControllerTramp == 0) { 
 | 
            return BaseResponseUtils.buildFail(ProjectResultCode.ADD_TRAMP_CONTROLLER_FAIL.getMessage()); 
 | 
        } 
 | 
        // 删除控制器 
 | 
        Integer rec_deleteIntakeId = Optional.ofNullable(controllerSv.deleteControllerByIdTwo(po.getControllerId())).orElse(0); 
 | 
        if (rec_deleteIntakeId == 0) { 
 | 
            return BaseResponseUtils.buildFail(ProjectResultCode.BIND_FAIL.getMessage()); 
 | 
        } 
 | 
  
 | 
        return BaseResponseUtils.buildSuccess(true); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 根据取水口编号获取绑定记录列表 
 | 
     * 
 | 
     * @param intakeId 取水口编号 
 | 
     * @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 = BaClient.class))} 
 | 
            ) 
 | 
    }) 
 | 
    @GetMapping(path = "intake_binds") 
 | 
    @SsoAop() 
 | 
    public BaseResponse<QueryResultVo<List<Map<String, Object>>>> getBindsByIntakeId(Long intakeId) { 
 | 
        try { 
 | 
            List<Map<String, Object>> list = Optional.ofNullable(intakeControllerSv.getBindsByIntakeId(intakeId)).orElse(new ArrayList<>()); 
 | 
            if (list.size() <= 0) { 
 | 
                //无绑定记录也返回成功 但数据为空 
 | 
                return BaseResponseUtils.buildSuccess(list); 
 | 
            }//成功返回绑定记录数据 
 | 
            return BaseResponseUtils.buildSuccess(list); 
 | 
        } catch (Exception e) { 
 | 
            log.error("查询异常", e); 
 | 
            return BaseResponseUtils.buildException(e.getMessage()); 
 | 
        } 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 根据控制器编号获取绑定记录列表 
 | 
     * 
 | 
     * @param controllerId 控制器编号 
 | 
     * @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 = BaClient.class))} 
 | 
            ) 
 | 
    }) 
 | 
    @GetMapping(path = "controller_binds") 
 | 
    @SsoAop() 
 | 
    public BaseResponse<QueryResultVo<List<Map<String, Object>>>> getBindsByControllerId(Long controllerId) { 
 | 
        try { 
 | 
            List<Map<String, Object>> list = Optional.ofNullable(intakeControllerSv.getBindsByControllerId(controllerId)).orElse(new ArrayList<>()); 
 | 
            if (list.size() <= 0) { 
 | 
                //无绑定记录也返回成功 但数据为空 
 | 
                return BaseResponseUtils.buildSuccess(list); 
 | 
            } 
 | 
            return BaseResponseUtils.buildSuccess(list); 
 | 
        } catch (Exception e) { 
 | 
            log.error("查询异常", e); 
 | 
            return BaseResponseUtils.buildException(e.getMessage()); 
 | 
        } 
 | 
    } 
 | 
  
 | 
  
 | 
    /** 
 | 
     * 根据指定条件获取流浪控制器列表 
 | 
     * 
 | 
     * @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 = PrControllerTramp.class))} 
 | 
            ) 
 | 
    }) 
 | 
    @GetMapping(path = "/getTrampControllers") 
 | 
    @SsoAop() 
 | 
    public BaseResponse<QueryResultVo<List<PrControllerTramp>>> getTrampControllers(TrampControllerQueryVo vo) { 
 | 
        try { 
 | 
            //QueryResultVo<List<PrControllerTramp>> res = intakeControllerSv.getTrampControllers(vo); 
 | 
            //if (res.itemTotal != null && res.itemTotal > 0) { 
 | 
            //    return BaseResponseUtils.buildSuccess(res); 
 | 
            //} else { 
 | 
            //    //请求成功但数据为空 
 | 
            //    return BaseResponseUtils.buildSuccess(res); 
 | 
            //} 
 | 
            return BaseResponseUtils.buildSuccess(intakeControllerSv.getTrampControllers(vo)); 
 | 
        } catch (Exception e) { 
 | 
            log.error("获取流浪控制器记录异常", e); 
 | 
            return BaseResponseUtils.buildException(e.getMessage()); 
 | 
        } 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 添加流浪控制器 
 | 
     * 
 | 
     * @param pct 
 | 
     * @return 
 | 
     */ 
 | 
    @PostMapping("addTrampController") 
 | 
    @Transactional(rollbackFor = Exception.class) 
 | 
    @SsoAop() 
 | 
    public BaseResponse<Boolean> addTrampController(@RequestBody PrControllerTramp pct) { 
 | 
        pct.setFindDt(new Date()); 
 | 
        Integer rows = intakeControllerSv.addTrampController(pct); 
 | 
        if (rows == 0) { 
 | 
            return BaseResponseUtils.buildErrorMsg(ProjectResultCode.ADD_TRAMP_CONTROLLER_FAIL.getMessage()); 
 | 
        } 
 | 
        return BaseResponseUtils.buildSuccess(true); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 删除流浪控制器 
 | 
     * 
 | 
     * @param id 
 | 
     * @return 
 | 
     */ 
 | 
    @PostMapping("deleteTrampController") 
 | 
    @Transactional(rollbackFor = Exception.class) 
 | 
    @SsoAop() 
 | 
    public BaseResponse<Boolean> deleteTrampController(Long id) { 
 | 
        PrControllerTramp controllerInfo = intakeControllerSv.getTrampControllerInfo(id); 
 | 
        if (controllerInfo == null) { 
 | 
            return BaseResponseUtils.buildErrorMsg(ProjectResultCode.NO_EXIST_TRAMP_CONTROLLER.getMessage()); 
 | 
        } 
 | 
  
 | 
        Integer rows = intakeControllerSv.deleteTrampController(id); 
 | 
//        if (rows == 0) { 
 | 
//            return BaseResponseUtils.buildErrorMsg(ProjectResultCode.DELETE_TRAMP_CONTROLLER_FAIL.getMessage()); 
 | 
//        } 
 | 
        return BaseResponseUtils.buildSuccess(true); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 清空流浪控制器 
 | 
     * 
 | 
     * @param 
 | 
     * @return 
 | 
     */ 
 | 
    @PostMapping("emptyTrampController") 
 | 
    @Transactional(rollbackFor = Exception.class) 
 | 
    @SsoAop() 
 | 
    public BaseResponse<Boolean> emptyTrampController() { 
 | 
  
 | 
        Integer rows = intakeControllerSv.emptyTrampController(); 
 | 
        if (rows == 0) { 
 | 
            return BaseResponseUtils.buildErrorMsg(ProjectResultCode.DELETE_TRAMP_CONTROLLER_FAIL.getMessage()); 
 | 
        } 
 | 
        return BaseResponseUtils.buildSuccess(true); 
 | 
    } 
 | 
} 
 |