|  |  |  | 
|---|
|  |  |  | package com.dy.pipIrrRemote.valve; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSON; | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSONObject; | 
|---|
|  |  |  | import com.dy.common.aop.SsoAop; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.Command; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.Data; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V1_0_0.CodeV1_0_1; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V1_0_0.downVos.Com97Vo; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V1_0_0.downVos.Com98Vo; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V202404.CodeV202404; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V202404.downVos.ComCd92_A2Vo; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V202404.downVos.ComCd93_A3Vo; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V202404.downVos.*; | 
|---|
|  |  |  | import com.dy.common.util.IDLongGenerator; | 
|---|
|  |  |  | import com.dy.common.webUtil.BaseResponse; | 
|---|
|  |  |  | import com.dy.common.webUtil.BaseResponseUtils; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.command.ComSupport; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.command.dto.Param; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoSe.SeVirtualCardMapper; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmCommandHistory; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoSe.SeVirtualCard; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoSe.SeClientCard; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voRm.VoUnclosedParam; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voRm.VoUnclosedValve; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voSe.VoVirtualCard; | 
|---|
|  |  |  | import com.dy.pipIrrRemote.common.CommandSv; | 
|---|
|  |  |  | import com.dy.pipIrrRemote.common.dto.DtoBase; | 
|---|
|  |  |  | import com.dy.pipIrrRemote.common.dto.ValveClose; | 
|---|
|  |  |  | import com.dy.pipIrrRemote.common.dto.ValveOpen; | 
|---|
|  |  |  | import com.dy.pipIrrRemote.common.enums.LastOperateENUM; | 
|---|
|  |  |  | import com.dy.pipIrrRemote.common.dto.*; | 
|---|
|  |  |  | import com.dy.pipIrrRemote.result.RemoteResultCode; | 
|---|
|  |  |  | import io.swagger.v3.oas.annotations.tags.Tag; | 
|---|
|  |  |  | import jakarta.validation.Valid; | 
|---|
|  |  |  | import lombok.RequiredArgsConstructor; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.apache.commons.lang3.RandomStringUtils; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Value; | 
|---|
|  |  |  | import org.springframework.http.MediaType; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  | import org.springframework.validation.BindingResult; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.time.format.DateTimeFormatter; | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Objects; | 
|---|
|  |  |  | import java.util.Optional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @author ZhuBaoMin | 
|---|
|  |  |  | 
|---|
|  |  |  | private final CommandSv commandSv; | 
|---|
|  |  |  | private final SeVirtualCardMapper seVirtualCardMapper; | 
|---|
|  |  |  | private final IDLongGenerator idLongGenerator; | 
|---|
|  |  |  | private String rtuResultSendWebUrl = "http://127.0.0.1:8081/remote/comRes/receive" ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Value("${mw.rtuCallbackUrl_rm}") | 
|---|
|  |  |  | private String rtuCallbackUrl_rm; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 平台远程开阀 | 
|---|
|  |  |  | 
|---|
|  |  |  | public BaseResponse<Boolean> open(@RequestBody @Valid ValveOpen valve, BindingResult bindingResult) { | 
|---|
|  |  |  | DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyMMddHHmmss"); | 
|---|
|  |  |  | if(bindingResult != null && bindingResult.hasErrors()){ | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long intakeId = valve.getIntakeId(); | 
|---|
|  |  |  | 
|---|
|  |  |  | if(vcId == null) { | 
|---|
|  |  |  | vcId = commandSv.getVcIdByIntakeId(intakeId); | 
|---|
|  |  |  | if(vcId == null) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(RemoteResultCode.PLEASE_SELECT_A_VC.getMessage()); | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.PLEASE_SELECT_A_VC.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | // 虚拟卡ID换虚拟卡对象 | 
|---|
|  |  |  | VoVirtualCard vc = commandSv.getVcById(vcId); | 
|---|
|  |  |  | if(vc == null) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(RemoteResultCode.PLEASE_SELECT_A_VC.getMessage()); | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.PLEASE_SELECT_A_VC.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(vc.getInUse() == 1) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(RemoteResultCode.IN_USE_VC_CANNOT_OPEN_VALVE.getMessage()); | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.IN_USE_VC_CANNOT_OPEN_VALVE.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取水价 | 
|---|
|  |  |  | 
|---|
|  |  |  | param.elePrice = 0.0; | 
|---|
|  |  |  | param.orderNo = orderNo; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 构造命令 | 
|---|
|  |  |  | Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送命令 | 
|---|
|  |  |  | JSONObject response_SendCom= (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | if(response_SendCom != null && response_SendCom.getString("code").equals("0001")) { | 
|---|
|  |  |  | //if(1 > 0) { | 
|---|
|  |  |  | // 请求成功 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建命令日志对象并添加到数据库中 | 
|---|
|  |  |  | String commandName = CodeV202404.getCodeName(commandCode); | 
|---|
|  |  |  | RmCommandHistory rmCommandHistory = getComHistory(comId, commandCode, commandName, intakeId, rtuAddr, protocol, param, operator); | 
|---|
|  |  |  | commandSv.insert(rmCommandHistory); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 处理回调 | 
|---|
|  |  |  | BaseResponse response_CallBack = dealWithCallBack(comId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调失败 | 
|---|
|  |  |  | if(!response_CallBack.getCode().equals("0001")) { | 
|---|
|  |  |  | // 命令日志执行结果改为失败 | 
|---|
|  |  |  | //rmCommandHistory = new RmCommandHistory(); | 
|---|
|  |  |  | //rmCommandHistory.setId(comId); | 
|---|
|  |  |  | //rmCommandHistory.setResult((byte)0); | 
|---|
|  |  |  | //commandSv.updateCommandResult(rmCommandHistory); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getMsg()); | 
|---|
|  |  |  | //return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调成功,再判断执行是否成功 | 
|---|
|  |  |  | JSONObject job_content = (JSONObject)JSON.toJSON(response_CallBack.getContent()); | 
|---|
|  |  |  | System.out.println(job_content); | 
|---|
|  |  |  | JSONObject job_subData = (JSONObject) job_content.getJSONObject("subData").getJSONObject("subData"); | 
|---|
|  |  |  | System.out.println(job_subData); | 
|---|
|  |  |  | Boolean dealResult = job_subData.getBoolean("success"); | 
|---|
|  |  |  | if(!dealResult) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 执行成功 | 
|---|
|  |  |  | * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | //                SeVirtualCard virtualCard = new SeVirtualCard(); | 
|---|
|  |  |  | //                virtualCard.setId(vcId); | 
|---|
|  |  |  | //                virtualCard.setInUse((byte) 1); | 
|---|
|  |  |  | //                virtualCard.setIntakeId(intakeId); | 
|---|
|  |  |  | //                virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
|---|
|  |  |  | //                virtualCard.setLastOperateTime(new Date()); | 
|---|
|  |  |  | //                seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调返回的内容 | 
|---|
|  |  |  | //Data myData = (Data)response_CallBack.getContent(); | 
|---|
|  |  |  | //return BaseResponseUtils.buildSuccess(myData); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject job_response = new JSONObject(); | 
|---|
|  |  |  | job_response.put("rtuAddr", rtuAddr); | 
|---|
|  |  |  | job_response.put("vcNum", vc.getVcNum()); | 
|---|
|  |  |  | job_response.put("orderNo", orderNo); | 
|---|
|  |  |  | //job_response.put("operator", operator); | 
|---|
|  |  |  | return BaseResponseUtils.buildSuccess(job_response); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 请求失败 | 
|---|
|  |  |  | JSONObject job_param = response_SendCom.getJSONObject("content").getJSONObject("param"); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(job_param.getString("message")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 构造命令、发送命令并处理请求结果及执行结果 | 
|---|
|  |  |  | * 1 准备参数 | 
|---|
|  |  |  | * 2 调用公共方法 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Param myParam = new Param(); | 
|---|
|  |  |  | myParam.setComId(comId); | 
|---|
|  |  |  | myParam.setComType((byte)1); | 
|---|
|  |  |  | myParam.setCommandCode(commandCode); | 
|---|
|  |  |  | myParam.setCommandName(CodeV202404.getCodeName(commandCode)); | 
|---|
|  |  |  | myParam.setIntakeId(intakeId); | 
|---|
|  |  |  | myParam.setRtuAddr(rtuAddr); | 
|---|
|  |  |  | myParam.setProtocol(protocol); | 
|---|
|  |  |  | myParam.setVcId(vcId); | 
|---|
|  |  |  | myParam.setParam(param); | 
|---|
|  |  |  | myParam.setRtuResultSendWebUrl(rtuCallbackUrl_rm); | 
|---|
|  |  |  | myParam.setOperator(operator); | 
|---|
|  |  |  | return dealWithCommandResult(myParam); | 
|---|
|  |  |  | } else if(protocol.equals("p206V1_0_1")) { | 
|---|
|  |  |  | // 获取功能码 | 
|---|
|  |  |  | commandCode = CodeV1_0_1.cd_92; | 
|---|
|  |  |  | 
|---|
|  |  |  | param.waterPrice = waterPrice; | 
|---|
|  |  |  | param.orderNo = orderNo; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 构造命令 | 
|---|
|  |  |  | Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送命令 | 
|---|
|  |  |  | JSONObject response_SendCom= (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | if(response_SendCom != null && response_SendCom.getString("code").equals("0001")) { | 
|---|
|  |  |  | //if(1 > 0) { | 
|---|
|  |  |  | // 请求成功 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建命令日志对象并添加到数据库中 | 
|---|
|  |  |  | String commandName = CodeV1_0_1.getCodeName(commandCode); | 
|---|
|  |  |  | RmCommandHistory rmCommandHistory = getComHistory(comId, commandCode, commandName, intakeId, rtuAddr, protocol, param, operator); | 
|---|
|  |  |  | commandSv.insert(rmCommandHistory); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 处理回调 | 
|---|
|  |  |  | BaseResponse response_CallBack = dealWithCallBack(comId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //回调异常 | 
|---|
|  |  |  | if(!response_CallBack.getCode().equals("0001")) { | 
|---|
|  |  |  | // 命令日志执行结果改为失败 | 
|---|
|  |  |  | rmCommandHistory = new RmCommandHistory(); | 
|---|
|  |  |  | rmCommandHistory.setId(comId); | 
|---|
|  |  |  | rmCommandHistory.setResult((byte)0); | 
|---|
|  |  |  | commandSv.updateCommandResult(rmCommandHistory); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调超时 | 
|---|
|  |  |  | if(response_CallBack.getContent().toString().equals(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage())) { | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 回调超时,暂时认为执行失败 | 
|---|
|  |  |  | * 命令置为失败 | 
|---|
|  |  |  | * 虚拟卡依旧保持使用中的状态 | 
|---|
|  |  |  | * 不返回关阀参数 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rmCommandHistory = new RmCommandHistory(); | 
|---|
|  |  |  | rmCommandHistory.setId(comId); | 
|---|
|  |  |  | rmCommandHistory.setResult((byte)0); | 
|---|
|  |  |  | commandSv.updateCommandResult(rmCommandHistory); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //SeVirtualCard virtualCard = new SeVirtualCard(); | 
|---|
|  |  |  | //virtualCard.setId(vcId); | 
|---|
|  |  |  | //virtualCard.setInUse((byte) 1); | 
|---|
|  |  |  | //virtualCard.setIntakeId(intakeId); | 
|---|
|  |  |  | //virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
|---|
|  |  |  | //virtualCard.setLastOperateTime(new Date()); | 
|---|
|  |  |  | //seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //JSONObject job_response = new JSONObject(); | 
|---|
|  |  |  | //job_response.put("message", RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage()); | 
|---|
|  |  |  | //job_response.put("rtuAddr", rtuAddr); | 
|---|
|  |  |  | //job_response.put("vcNum", vc.getVcNum()); | 
|---|
|  |  |  | //job_response.put("orderNo", orderNo); | 
|---|
|  |  |  | //return BaseResponseUtils.buildSuccess(job_response); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调成功,再判断执行是否成功 | 
|---|
|  |  |  | JSONObject job_content = (JSONObject)JSON.toJSON(response_CallBack.getContent()); | 
|---|
|  |  |  | System.out.println(job_content); | 
|---|
|  |  |  | JSONObject job_subData = (JSONObject) job_content.getJSONObject("subData").getJSONObject("subData"); | 
|---|
|  |  |  | System.out.println(job_subData); | 
|---|
|  |  |  | Boolean dealResult = job_subData.getBoolean("success"); | 
|---|
|  |  |  | if(!dealResult) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 执行成功 | 
|---|
|  |  |  | * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | SeVirtualCard virtualCard = new SeVirtualCard(); | 
|---|
|  |  |  | virtualCard.setId(vcId); | 
|---|
|  |  |  | virtualCard.setInUse((byte) 1); | 
|---|
|  |  |  | virtualCard.setIntakeId(intakeId); | 
|---|
|  |  |  | virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
|---|
|  |  |  | virtualCard.setLastOperateTime(new Date()); | 
|---|
|  |  |  | seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调返回的内容 | 
|---|
|  |  |  | //Data myData = (Data)response_CallBack.getContent(); | 
|---|
|  |  |  | //return BaseResponseUtils.buildSuccess(myData) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject job_response = new JSONObject(); | 
|---|
|  |  |  | job_response.put("message", "ok"); | 
|---|
|  |  |  | job_response.put("rtuAddr", rtuAddr); | 
|---|
|  |  |  | job_response.put("vcNum", vc.getVcNum()); | 
|---|
|  |  |  | job_response.put("orderNo", orderNo); | 
|---|
|  |  |  | //job_response.put("operator", operator); | 
|---|
|  |  |  | return BaseResponseUtils.buildSuccess(job_response); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 请求失败 | 
|---|
|  |  |  | JSONObject job_param = response_SendCom.getJSONObject("content").getJSONObject("param"); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(job_param.getString("message")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 构造命令、发送命令并处理请求结果及执行结果 | 
|---|
|  |  |  | * 1 准备参数 | 
|---|
|  |  |  | * 2 调用公共方法 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Param myParam = new Param(); | 
|---|
|  |  |  | myParam.setComId(comId); | 
|---|
|  |  |  | myParam.setComType((byte)1); | 
|---|
|  |  |  | myParam.setCommandCode(commandCode); | 
|---|
|  |  |  | myParam.setCommandName(CodeV202404.getCodeName(commandCode)); | 
|---|
|  |  |  | myParam.setIntakeId(intakeId); | 
|---|
|  |  |  | myParam.setRtuAddr(rtuAddr); | 
|---|
|  |  |  | myParam.setProtocol(protocol); | 
|---|
|  |  |  | myParam.setVcId(vcId); | 
|---|
|  |  |  | myParam.setParam(param); | 
|---|
|  |  |  | myParam.setRtuResultSendWebUrl(rtuCallbackUrl_rm); | 
|---|
|  |  |  | myParam.setOperator(operator); | 
|---|
|  |  |  | return dealWithCommandResult(myParam); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail("系统暂不支持该协议"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 平台远程关阀_参数模式 | 
|---|
|  |  |  | * @param valve | 
|---|
|  |  |  | * @param bindingResult | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @PostMapping(path = "close", consumes = MediaType.APPLICATION_JSON_VALUE) | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | @SsoAop() | 
|---|
|  |  |  | public BaseResponse<Boolean> close(@RequestBody @Valid ValveClose valve, BindingResult bindingResult) { | 
|---|
|  |  |  | DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyMMddHHmmss"); | 
|---|
|  |  |  | if(bindingResult != null && bindingResult.hasErrors()){ | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String rtuAddr = valve.getRtuAddr(); | 
|---|
|  |  |  | String vcNum = valve.getVcNum(); | 
|---|
|  |  |  | String orderNo = valve.getOrderNo(); | 
|---|
|  |  |  | Long operator = valve.getOperator(); | 
|---|
|  |  |  | Long comId = idLongGenerator.generate(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取系统参数 | 
|---|
|  |  |  | if(!setuped) { | 
|---|
|  |  |  | setUp(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 阀控器地址换取水口ID和通讯协议 | 
|---|
|  |  |  | JSONObject job_rtu = getRtu(null, rtuAddr); | 
|---|
|  |  |  | if(job_rtu == null) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.RTU_NOT_EXIST.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Long intakeId = job_rtu.getLong("intakeId"); | 
|---|
|  |  |  | String protocol = job_rtu.getString("protocol"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String commandCode = null; | 
|---|
|  |  |  | if(protocol.equals("p206V202404")) { | 
|---|
|  |  |  | // 获取功能码 | 
|---|
|  |  |  | commandCode = CodeV202404.cd_93; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建视图 | 
|---|
|  |  |  | ComCd93_A3Vo param = new ComCd93_A3Vo(); | 
|---|
|  |  |  | param.controllerType = controllerType; | 
|---|
|  |  |  | param.projectNo = projectNo; | 
|---|
|  |  |  | param.icCardNo = vcNum; | 
|---|
|  |  |  | param.orderNo = orderNo; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 构造命令 | 
|---|
|  |  |  | Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送命令 | 
|---|
|  |  |  | JSONObject response_SendCom= (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | if(response_SendCom != null && response_SendCom.getString("code").equals("0001")) { | 
|---|
|  |  |  | // 请求成功 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建命令日志对象并添加到数据库中 | 
|---|
|  |  |  | String commandName = CodeV202404.getCodeName(commandCode); | 
|---|
|  |  |  | RmCommandHistory rmCommandHistory = getComHistory(comId, commandCode, commandName, intakeId, rtuAddr, protocol, param, operator); | 
|---|
|  |  |  | commandSv.insert(rmCommandHistory); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 处理回调 | 
|---|
|  |  |  | BaseResponse response_CallBack = dealWithCallBack(comId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调失败 | 
|---|
|  |  |  | if(!response_CallBack.getCode().equals("0001")) { | 
|---|
|  |  |  | // 命令日志执行结果改为失败 | 
|---|
|  |  |  | //rmCommandHistory = new RmCommandHistory(); | 
|---|
|  |  |  | //rmCommandHistory.setId(comId); | 
|---|
|  |  |  | //rmCommandHistory.setResult((byte)0); | 
|---|
|  |  |  | //commandSv.updateCommandResult(rmCommandHistory); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getMsg()); | 
|---|
|  |  |  | //return BaseResponseUtils.buildErrorMsgMsg(WechatResultCode.GET_RESULT_ERROR.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调成功,再判断执行是否成功 | 
|---|
|  |  |  | JSONObject job_content = (JSONObject)JSON.toJSON(response_CallBack.getContent()); | 
|---|
|  |  |  | System.out.println(job_content); | 
|---|
|  |  |  | JSONObject job_subData = (JSONObject) job_content.getJSONObject("subData").getJSONObject("subData"); | 
|---|
|  |  |  | System.out.println(job_subData); | 
|---|
|  |  |  | Boolean dealResult = job_subData.getBoolean("success"); | 
|---|
|  |  |  | if(!dealResult) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 执行成功 | 
|---|
|  |  |  | * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | //SeVirtualCard virtualCard = seVirtualCardMapper.getVcCardByNum(vcNum); | 
|---|
|  |  |  | //virtualCard.setInUse((byte) 0); | 
|---|
|  |  |  | //virtualCard.setIntakeId(null); | 
|---|
|  |  |  | //virtualCard.setLastOperate(LastOperateENUM.CLOSE_VALVE.getCode()); | 
|---|
|  |  |  | //virtualCard.setLastOperateTime(new Date()); | 
|---|
|  |  |  | //seVirtualCardMapper.updateByPrimaryKey(virtualCard); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调返回的内容 | 
|---|
|  |  |  | Data myData = (Data)response_CallBack.getContent(); | 
|---|
|  |  |  | return BaseResponseUtils.buildSuccess(myData) ; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 请求失败 | 
|---|
|  |  |  | JSONObject job_param = response_SendCom.getJSONObject("content").getJSONObject("param"); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(job_param.getString("message")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else if(protocol.equals("p206V1_0_1")) { | 
|---|
|  |  |  | // 获取功能码 | 
|---|
|  |  |  | commandCode = CodeV1_0_1.cd_93; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建视图 | 
|---|
|  |  |  | Com98Vo param = new Com98Vo() ; | 
|---|
|  |  |  | param.icCardNo = vcNum; | 
|---|
|  |  |  | param.orderNo = orderNo; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 构造命令 | 
|---|
|  |  |  | Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送命令 | 
|---|
|  |  |  | JSONObject response_SendCom= (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | if(response_SendCom != null && response_SendCom.getString("code").equals("0001")) { | 
|---|
|  |  |  | //if(1 > 0) { | 
|---|
|  |  |  | // 请求成功 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建命令日志对象并添加到数据库中 | 
|---|
|  |  |  | String commandName = CodeV1_0_1.getCodeName(commandCode); | 
|---|
|  |  |  | RmCommandHistory rmCommandHistory = getComHistory(comId, commandCode, commandName, intakeId, rtuAddr, protocol, param, operator); | 
|---|
|  |  |  | commandSv.insert(rmCommandHistory); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 处理回调 | 
|---|
|  |  |  | BaseResponse response_CallBack = dealWithCallBack(comId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调异常 | 
|---|
|  |  |  | if(!response_CallBack.getCode().equals("0001")) { | 
|---|
|  |  |  | // 命令日志执行结果改为失败 | 
|---|
|  |  |  | rmCommandHistory = new RmCommandHistory(); | 
|---|
|  |  |  | rmCommandHistory.setId(comId); | 
|---|
|  |  |  | rmCommandHistory.setResult((byte)0); | 
|---|
|  |  |  | commandSv.updateCommandResult(rmCommandHistory); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调超时 | 
|---|
|  |  |  | if(response_CallBack.getContent().toString().equals(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage())) { | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 回调超时,暂时认为执行失败 | 
|---|
|  |  |  | * 命令置为失败 | 
|---|
|  |  |  | * 虚拟卡依旧保持使用中的状态 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rmCommandHistory = new RmCommandHistory(); | 
|---|
|  |  |  | rmCommandHistory.setId(comId); | 
|---|
|  |  |  | rmCommandHistory.setResult((byte)0); | 
|---|
|  |  |  | commandSv.updateCommandResult(rmCommandHistory); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //SeVirtualCard virtualCard = seVirtualCardMapper.getVcCardByNum(vcNum); | 
|---|
|  |  |  | //virtualCard.setInUse((byte) 0); | 
|---|
|  |  |  | //virtualCard.setIntakeId(null); | 
|---|
|  |  |  | //virtualCard.setLastOperate(LastOperateENUM.CLOSE_VALVE.getCode()); | 
|---|
|  |  |  | //virtualCard.setLastOperateTime(new Date()); | 
|---|
|  |  |  | //seVirtualCardMapper.updateByPrimaryKey(virtualCard); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调成功,再判断执行是否成功 | 
|---|
|  |  |  | JSONObject job_content = (JSONObject)JSON.toJSON(response_CallBack.getContent()); | 
|---|
|  |  |  | System.out.println(job_content); | 
|---|
|  |  |  | JSONObject job_subData = (JSONObject) job_content.getJSONObject("subData").getJSONObject("subData"); | 
|---|
|  |  |  | System.out.println(job_subData); | 
|---|
|  |  |  | Boolean dealResult = job_subData.getBoolean("success"); | 
|---|
|  |  |  | if(!dealResult) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 执行成功 | 
|---|
|  |  |  | * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | SeVirtualCard virtualCard = seVirtualCardMapper.getVcCardByNum(vcNum); | 
|---|
|  |  |  | virtualCard.setInUse((byte) 0); | 
|---|
|  |  |  | virtualCard.setIntakeId(null); | 
|---|
|  |  |  | virtualCard.setLastOperate(LastOperateENUM.CLOSE_VALVE.getCode()); | 
|---|
|  |  |  | virtualCard.setLastOperateTime(new Date()); | 
|---|
|  |  |  | seVirtualCardMapper.updateByPrimaryKey(virtualCard); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调返回的内容 | 
|---|
|  |  |  | Data myData = (Data)response_CallBack.getContent(); | 
|---|
|  |  |  | return BaseResponseUtils.buildSuccess(myData) ; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 请求失败 | 
|---|
|  |  |  | JSONObject job_param = response_SendCom.getJSONObject("content").getJSONObject("param"); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(job_param.getString("message")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail("系统暂不支持该协议"); | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg("系统暂不支持该协议"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | @SsoAop() | 
|---|
|  |  |  | public BaseResponse<Boolean> closeByIntake(@RequestBody @Valid DtoBase dtoBase, BindingResult bindingResult) { | 
|---|
|  |  |  | DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyMMddHHmmss"); | 
|---|
|  |  |  | if(bindingResult != null && bindingResult.hasErrors()){ | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long intakeId = dtoBase.getIntakeId(); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String rtuAddr = voUnclosedParam.getRtuAddr(); | 
|---|
|  |  |  | String vcNum = voUnclosedParam.getVcNum(); | 
|---|
|  |  |  | Long vcId = Optional.ofNullable(seVirtualCardMapper.getVcIdByNum(vcNum)).orElse(0L); | 
|---|
|  |  |  | String orderNo = voUnclosedParam.getOrderNo(); | 
|---|
|  |  |  | Long comId = idLongGenerator.generate(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | param.icCardNo = vcNum; | 
|---|
|  |  |  | param.orderNo = orderNo; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 构造命令 | 
|---|
|  |  |  | Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送命令 | 
|---|
|  |  |  | JSONObject response_SendCom= (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | if(response_SendCom != null && response_SendCom.getString("code").equals("0001")) { | 
|---|
|  |  |  | // 请求成功 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建命令日志对象并添加到数据库中 | 
|---|
|  |  |  | String commandName = CodeV202404.getCodeName(commandCode); | 
|---|
|  |  |  | RmCommandHistory rmCommandHistory = getComHistory(comId, commandCode, commandName, intakeId, rtuAddr, protocol, param, operator); | 
|---|
|  |  |  | commandSv.insert(rmCommandHistory); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 处理回调 | 
|---|
|  |  |  | BaseResponse response_CallBack = dealWithCallBack(comId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调失败 | 
|---|
|  |  |  | if(!response_CallBack.getCode().equals("0001")) { | 
|---|
|  |  |  | // 命令日志执行结果改为失败 | 
|---|
|  |  |  | //rmCommandHistory = new RmCommandHistory(); | 
|---|
|  |  |  | //rmCommandHistory.setId(comId); | 
|---|
|  |  |  | //rmCommandHistory.setResult((byte)0); | 
|---|
|  |  |  | //commandSv.updateCommandResult(rmCommandHistory); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getMsg()); | 
|---|
|  |  |  | //return BaseResponseUtils.buildErrorMsgMsg(WechatResultCode.GET_RESULT_ERROR.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调成功,再判断执行是否成功 | 
|---|
|  |  |  | JSONObject job_content = (JSONObject)JSON.toJSON(response_CallBack.getContent()); | 
|---|
|  |  |  | System.out.println(job_content); | 
|---|
|  |  |  | JSONObject job_subData = (JSONObject) job_content.getJSONObject("subData").getJSONObject("subData"); | 
|---|
|  |  |  | System.out.println(job_subData); | 
|---|
|  |  |  | Boolean dealResult = job_subData.getBoolean("success"); | 
|---|
|  |  |  | if(!dealResult) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 执行成功 | 
|---|
|  |  |  | * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | //Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); | 
|---|
|  |  |  | //SeVirtualCard virtualCard = new SeVirtualCard(); | 
|---|
|  |  |  | //virtualCard.setId(vcId); | 
|---|
|  |  |  | //virtualCard.setInUse((byte) 0); | 
|---|
|  |  |  | //virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
|---|
|  |  |  | //virtualCard.setLastOperateTime(new Date()); | 
|---|
|  |  |  | //seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调返回的内容 | 
|---|
|  |  |  | Data myData = (Data)response_CallBack.getContent(); | 
|---|
|  |  |  | return BaseResponseUtils.buildSuccess(myData) ; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 请求失败 | 
|---|
|  |  |  | JSONObject job_param = response_SendCom.getJSONObject("content").getJSONObject("param"); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(job_param.getString("message")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 构造命令、发送命令并处理请求结果及执行结果 | 
|---|
|  |  |  | * 1 准备参数 | 
|---|
|  |  |  | * 2 调用公共方法 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Param myParam = new Param(); | 
|---|
|  |  |  | myParam.setComId(comId); | 
|---|
|  |  |  | myParam.setComType((byte)2); | 
|---|
|  |  |  | myParam.setCommandCode(commandCode); | 
|---|
|  |  |  | myParam.setCommandName(CodeV202404.getCodeName(commandCode)); | 
|---|
|  |  |  | myParam.setIntakeId(intakeId); | 
|---|
|  |  |  | myParam.setRtuAddr(rtuAddr); | 
|---|
|  |  |  | myParam.setProtocol(protocol); | 
|---|
|  |  |  | myParam.setVcId(vcId); | 
|---|
|  |  |  | myParam.setParam(param); | 
|---|
|  |  |  | myParam.setRtuResultSendWebUrl(rtuCallbackUrl_rm); | 
|---|
|  |  |  | myParam.setOperator(operator); | 
|---|
|  |  |  | return dealWithCommandResult(myParam); | 
|---|
|  |  |  | } else if(protocol.equals("p206V1_0_1")) { | 
|---|
|  |  |  | // 获取功能码 | 
|---|
|  |  |  | commandCode = CodeV1_0_1.cd_93; | 
|---|
|  |  |  | 
|---|
|  |  |  | param.icCardNo = vcNum; | 
|---|
|  |  |  | param.orderNo = orderNo; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 构造命令 | 
|---|
|  |  |  | Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送命令 | 
|---|
|  |  |  | JSONObject response_SendCom= (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | if(response_SendCom != null && response_SendCom.getString("code").equals("0001")) { | 
|---|
|  |  |  | //if(1 > 0) { | 
|---|
|  |  |  | // 请求成功 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建命令日志对象并添加到数据库中 | 
|---|
|  |  |  | String commandName = CodeV1_0_1.getCodeName(commandCode); | 
|---|
|  |  |  | RmCommandHistory rmCommandHistory = getComHistory(comId, commandCode, commandName, intakeId, rtuAddr, protocol, param, operator); | 
|---|
|  |  |  | commandSv.insert(rmCommandHistory); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 处理回调 | 
|---|
|  |  |  | BaseResponse response_CallBack = dealWithCallBack(comId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调异常 | 
|---|
|  |  |  | if(!response_CallBack.getCode().equals("0001")) { | 
|---|
|  |  |  | // 命令日志执行结果改为失败 | 
|---|
|  |  |  | rmCommandHistory = new RmCommandHistory(); | 
|---|
|  |  |  | rmCommandHistory.setId(comId); | 
|---|
|  |  |  | rmCommandHistory.setResult((byte)0); | 
|---|
|  |  |  | commandSv.updateCommandResult(rmCommandHistory); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调超时 | 
|---|
|  |  |  | if(response_CallBack.getContent().toString().equals(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage())) { | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 回调超时,暂时认为执行失败 | 
|---|
|  |  |  | * 命令置为失败 | 
|---|
|  |  |  | * 虚拟卡依旧保持使用中的状态 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rmCommandHistory = new RmCommandHistory(); | 
|---|
|  |  |  | rmCommandHistory.setId(comId); | 
|---|
|  |  |  | rmCommandHistory.setResult((byte)0); | 
|---|
|  |  |  | commandSv.updateCommandResult(rmCommandHistory); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); | 
|---|
|  |  |  | //SeVirtualCard virtualCard = new SeVirtualCard(); | 
|---|
|  |  |  | //virtualCard.setId(vcId); | 
|---|
|  |  |  | //virtualCard.setInUse((byte) 0); | 
|---|
|  |  |  | //virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
|---|
|  |  |  | //virtualCard.setLastOperateTime(new Date()); | 
|---|
|  |  |  | //seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调成功,再判断执行是否成功 | 
|---|
|  |  |  | JSONObject job_content = (JSONObject)JSON.toJSON(response_CallBack.getContent()); | 
|---|
|  |  |  | System.out.println(job_content); | 
|---|
|  |  |  | JSONObject job_subData = (JSONObject) job_content.getJSONObject("subData").getJSONObject("subData"); | 
|---|
|  |  |  | System.out.println(job_subData); | 
|---|
|  |  |  | Boolean dealResult = job_subData.getBoolean("success"); | 
|---|
|  |  |  | if(!dealResult) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 执行成功 | 
|---|
|  |  |  | * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); | 
|---|
|  |  |  | SeVirtualCard virtualCard = new SeVirtualCard(); | 
|---|
|  |  |  | virtualCard.setId(vcId); | 
|---|
|  |  |  | virtualCard.setInUse((byte) 0); | 
|---|
|  |  |  | virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
|---|
|  |  |  | virtualCard.setLastOperateTime(new Date()); | 
|---|
|  |  |  | seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 回调返回的内容 | 
|---|
|  |  |  | Data myData = (Data)response_CallBack.getContent(); | 
|---|
|  |  |  | return BaseResponseUtils.buildSuccess(myData) ; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 请求失败 | 
|---|
|  |  |  | JSONObject job_param = response_SendCom.getJSONObject("content").getJSONObject("param"); | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(job_param.getString("message")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 构造命令、发送命令并处理请求结果及执行结果 | 
|---|
|  |  |  | * 1 准备参数 | 
|---|
|  |  |  | * 2 调用公共方法 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Param myParam = new Param(); | 
|---|
|  |  |  | myParam.setComId(comId); | 
|---|
|  |  |  | myParam.setComType((byte)2); | 
|---|
|  |  |  | myParam.setCommandCode(commandCode); | 
|---|
|  |  |  | myParam.setCommandName(CodeV202404.getCodeName(commandCode)); | 
|---|
|  |  |  | myParam.setIntakeId(intakeId); | 
|---|
|  |  |  | myParam.setRtuAddr(rtuAddr); | 
|---|
|  |  |  | myParam.setProtocol(protocol); | 
|---|
|  |  |  | myParam.setVcId(vcId); | 
|---|
|  |  |  | myParam.setParam(param); | 
|---|
|  |  |  | myParam.setRtuResultSendWebUrl(rtuCallbackUrl_rm); | 
|---|
|  |  |  | myParam.setOperator(operator); | 
|---|
|  |  |  | return dealWithCommandResult(myParam); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail("系统暂不支持该协议"); | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg("系统暂不支持该协议"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | return BaseResponseUtils.buildException(e.getMessage()) ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 平台远程充值 | 
|---|
|  |  |  | * @param po | 
|---|
|  |  |  | * @param bindingResult | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @PostMapping(path = "recharge", consumes = MediaType.APPLICATION_JSON_VALUE) | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | @SsoAop() | 
|---|
|  |  |  | public BaseResponse<Boolean> recharge(@RequestBody @Valid Recharge po, BindingResult bindingResult) { | 
|---|
|  |  |  | if(bindingResult != null && bindingResult.hasErrors()){ | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long intakeId = po.getIntakeId(); | 
|---|
|  |  |  | Long cardId = po.getCardId(); | 
|---|
|  |  |  | Double chargeMoney = po.getChargeMoney(); | 
|---|
|  |  |  | Double chargeWater = po.getChargeWater(); | 
|---|
|  |  |  | Long operator = po.getOperator(); | 
|---|
|  |  |  | String flowNo = RandomStringUtils.randomNumeric(12); // 生成12位随机数 | 
|---|
|  |  |  | Long comId = idLongGenerator.generate(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取系统参数 | 
|---|
|  |  |  | if(!setuped) { | 
|---|
|  |  |  | setUp(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 取水口ID换阀控器地址及通讯协议 | 
|---|
|  |  |  | JSONObject job_rtu = getRtu(intakeId, null); | 
|---|
|  |  |  | if(job_rtu == null) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.RTU_NOT_EXIST.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String rtuAddr = job_rtu.getString("rtuAddr"); | 
|---|
|  |  |  | String protocol = job_rtu.getString("protocol"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 水卡ID换水卡地址及水卡编号 | 
|---|
|  |  |  | SeClientCard seClientCard = commandSv.geClientCardByCardId(cardId); | 
|---|
|  |  |  | if(seClientCard == null) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.CLIENT_CARD_NOT_EXIST.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String icCardAddr = seClientCard.getCardaddr(); | 
|---|
|  |  |  | String icCardNo = seClientCard.getCardnum(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String commandCode = null; | 
|---|
|  |  |  | if(protocol.equals("p206V202404")) { | 
|---|
|  |  |  | // 获取功能码 | 
|---|
|  |  |  | commandCode = CodeV202404.cd_15; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建视图 | 
|---|
|  |  |  | ComCd15Vo param = new ComCd15Vo(); | 
|---|
|  |  |  | param.controllerType = controllerType; | 
|---|
|  |  |  | param.projectNo = projectNo; | 
|---|
|  |  |  | param.icCardAddr = icCardAddr; | 
|---|
|  |  |  | param.icCardNo = icCardNo; | 
|---|
|  |  |  | param.chargeMoney = chargeMoney; | 
|---|
|  |  |  | param.chargeWater = chargeWater; | 
|---|
|  |  |  | param.flowNo = flowNo; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 构造命令、发送命令并处理请求结果及执行结果 | 
|---|
|  |  |  | * 1 准备参数 | 
|---|
|  |  |  | * 2 调用公共方法 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Param myParam = new Param(); | 
|---|
|  |  |  | myParam.setComId(comId); | 
|---|
|  |  |  | myParam.setCommandCode(commandCode); | 
|---|
|  |  |  | myParam.setCommandName(CodeV202404.getCodeName(commandCode)); | 
|---|
|  |  |  | myParam.setIntakeId(intakeId); | 
|---|
|  |  |  | myParam.setRtuAddr(rtuAddr); | 
|---|
|  |  |  | myParam.setProtocol(protocol); | 
|---|
|  |  |  | myParam.setParam(param); | 
|---|
|  |  |  | myParam.setRtuResultSendWebUrl(rtuCallbackUrl_rm); | 
|---|
|  |  |  | myParam.setOperator(operator); | 
|---|
|  |  |  | return dealWithCommandResult(myParam); | 
|---|
|  |  |  | } else if(protocol.equals("p206V1_0_1")) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.THE_DEVICE_DOES_NOT_HAVE_THIS_FUNCTION.getMessage()); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail("系统暂不支持该协议"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 强制关阀 | 
|---|
|  |  |  | * @param card | 
|---|
|  |  |  | * @param bindingResult | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @PostMapping(path = "forced_close", consumes = MediaType.APPLICATION_JSON_VALUE) | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | @SsoAop() | 
|---|
|  |  |  | public BaseResponse<Boolean> forcedClose(@RequestBody @Valid Card card, BindingResult bindingResult) { | 
|---|
|  |  |  | if(bindingResult != null && bindingResult.hasErrors()){ | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long intakeId = card.getIntakeId(); | 
|---|
|  |  |  | String cardAddr = card.getCardAddr(); | 
|---|
|  |  |  | Long operator = card.getOperator(); | 
|---|
|  |  |  | Long comId = idLongGenerator.generate(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取系统参数 | 
|---|
|  |  |  | if(!setuped) { | 
|---|
|  |  |  | setUp(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 取水口ID换阀控器地址及通讯协议 | 
|---|
|  |  |  | JSONObject job_rtu = getRtu(intakeId, null); | 
|---|
|  |  |  | if(job_rtu == null) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.RTU_NOT_EXIST.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String rtuAddr = job_rtu.getString("rtuAddr"); | 
|---|
|  |  |  | String protocol = job_rtu.getString("protocol"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String commandCode = null; | 
|---|
|  |  |  | if(protocol.equals("p206V202404")) { | 
|---|
|  |  |  | // 获取功能码 | 
|---|
|  |  |  | commandCode = CodeV202404.cd_9C; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建视图 | 
|---|
|  |  |  | ComCd9CVo param = new ComCd9CVo(); | 
|---|
|  |  |  | param.controllerType = controllerType; | 
|---|
|  |  |  | param.projectNo = projectNo; | 
|---|
|  |  |  | param.icCardAddr = cardAddr; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 构造命令、发送命令并处理请求结果及执行结果 | 
|---|
|  |  |  | * 1 准备参数 | 
|---|
|  |  |  | * 2 调用公共方法 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Param myParam = new Param(); | 
|---|
|  |  |  | myParam.setComId(comId); | 
|---|
|  |  |  | myParam.setCommandCode(commandCode); | 
|---|
|  |  |  | myParam.setCommandName(CodeV202404.getCodeName(commandCode)); | 
|---|
|  |  |  | myParam.setIntakeId(intakeId); | 
|---|
|  |  |  | myParam.setRtuAddr(rtuAddr); | 
|---|
|  |  |  | myParam.setProtocol(protocol); | 
|---|
|  |  |  | myParam.setParam(param); | 
|---|
|  |  |  | myParam.setRtuResultSendWebUrl(rtuCallbackUrl_rm); | 
|---|
|  |  |  | myParam.setOperator(operator); | 
|---|
|  |  |  | return dealWithCommandResult(myParam); | 
|---|
|  |  |  | } else if(protocol.equals("p206V1_0_1")) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.THE_DEVICE_DOES_NOT_HAVE_THIS_FUNCTION.getMessage()); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg("系统暂不支持该协议"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 设备终端用水控制 | 
|---|
|  |  |  | * @param usability | 
|---|
|  |  |  | * @param bindingResult | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @PostMapping(path = "usability", consumes = MediaType.APPLICATION_JSON_VALUE) | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | @SsoAop() | 
|---|
|  |  |  | public BaseResponse<Boolean> usability(@RequestBody @Valid Usability usability, BindingResult bindingResult) { | 
|---|
|  |  |  | if(bindingResult != null && bindingResult.hasErrors()){ | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long intakeId = usability.getIntakeId(); | 
|---|
|  |  |  | Boolean valid = usability.getValid(); | 
|---|
|  |  |  | Long operator = usability.getOperator(); | 
|---|
|  |  |  | Long comId = idLongGenerator.generate(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取系统参数 | 
|---|
|  |  |  | if(!setuped) { | 
|---|
|  |  |  | setUp(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 取水口ID换阀控器地址及通讯协议 | 
|---|
|  |  |  | JSONObject job_rtu = getRtu(intakeId, null); | 
|---|
|  |  |  | if(job_rtu == null) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.RTU_NOT_EXIST.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String rtuAddr = job_rtu.getString("rtuAddr"); | 
|---|
|  |  |  | String protocol = job_rtu.getString("protocol"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String commandCode = null; | 
|---|
|  |  |  | if(protocol.equals("p206V202404")) { | 
|---|
|  |  |  | if(valid) { | 
|---|
|  |  |  | // 获取功能码 | 
|---|
|  |  |  | commandCode = CodeV202404.cd_30; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建视图 | 
|---|
|  |  |  | ComCd31Vo param = new ComCd31Vo(); | 
|---|
|  |  |  | param.controllerType = controllerType; | 
|---|
|  |  |  | param.projectNo = projectNo; | 
|---|
|  |  |  | param.valid = true; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 构造命令、发送命令并处理请求结果及执行结果 | 
|---|
|  |  |  | * 1 准备参数 | 
|---|
|  |  |  | * 2 调用公共方法 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Param myParam = new Param(); | 
|---|
|  |  |  | myParam.setComId(comId); | 
|---|
|  |  |  | myParam.setCommandCode(commandCode); | 
|---|
|  |  |  | myParam.setCommandName(CodeV202404.getCodeName(commandCode)); | 
|---|
|  |  |  | myParam.setIntakeId(intakeId); | 
|---|
|  |  |  | myParam.setRtuAddr(rtuAddr); | 
|---|
|  |  |  | myParam.setProtocol(protocol); | 
|---|
|  |  |  | myParam.setParam(param); | 
|---|
|  |  |  | myParam.setRtuResultSendWebUrl(rtuCallbackUrl_rm); | 
|---|
|  |  |  | myParam.setOperator(operator); | 
|---|
|  |  |  | return dealWithCommandResult(myParam); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | // 获取功能码 | 
|---|
|  |  |  | commandCode = CodeV202404.cd_31; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建视图 | 
|---|
|  |  |  | ComCd31Vo param = new ComCd31Vo(); | 
|---|
|  |  |  | param.controllerType = controllerType; | 
|---|
|  |  |  | param.projectNo = projectNo; | 
|---|
|  |  |  | param.valid = false; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 构造命令、发送命令并处理请求结果及执行结果 | 
|---|
|  |  |  | * 1 准备参数 | 
|---|
|  |  |  | * 2 调用公共方法 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Param myParam = new Param(); | 
|---|
|  |  |  | myParam.setComId(comId); | 
|---|
|  |  |  | myParam.setCommandCode(commandCode); | 
|---|
|  |  |  | myParam.setCommandName(CodeV202404.getCodeName(commandCode)); | 
|---|
|  |  |  | myParam.setIntakeId(intakeId); | 
|---|
|  |  |  | myParam.setRtuAddr(rtuAddr); | 
|---|
|  |  |  | myParam.setProtocol(protocol); | 
|---|
|  |  |  | myParam.setParam(param); | 
|---|
|  |  |  | myParam.setRtuResultSendWebUrl(rtuCallbackUrl_rm); | 
|---|
|  |  |  | myParam.setOperator(operator); | 
|---|
|  |  |  | return dealWithCommandResult(myParam); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else if(protocol.equals("p206V1_0_1")) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(RemoteResultCode.THE_DEVICE_DOES_NOT_HAVE_THIS_FUNCTION.getMessage()); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg("系统暂不支持该协议"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|