| | |
| | | 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.util.IDLongGenerator; |
| | | import com.dy.common.webUtil.BaseResponse; |
| | | import com.dy.common.webUtil.BaseResponseUtils; |
| | | import com.dy.pipIrrGlobal.daoPr.PrWaterPriceMapper; |
| | | import com.dy.pipIrrGlobal.daoRm.RmCommandHistoryMapper; |
| | | import com.dy.pipIrrGlobal.command.ComSupport; |
| | | import com.dy.pipIrrGlobal.daoSe.SeVirtualCardMapper; |
| | | import com.dy.pipIrrGlobal.pojoRm.RmCommandHistory; |
| | | import com.dy.pipIrrGlobal.pojoSe.SeVirtualCard; |
| | | import com.dy.pipIrrGlobal.voRm.VoUnclosedParam; |
| | | import com.dy.pipIrrGlobal.voRm.VoUnclosedValve; |
| | | import com.dy.pipIrrGlobal.voSe.VoVirtualCard; |
| | | import com.dy.pipIrrRemote.common.ComSupport; |
| | | 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.result.RemoteResultCode; |
| | | import com.dy.pipIrrRemote.utils.RestTemplateUtils; |
| | | import com.dy.pipIrrSell.virtualCard.enums.LastOperateENUM; |
| | | import io.swagger.v3.oas.annotations.tags.Tag; |
| | | import jakarta.validation.Valid; |
| | | import lombok.RequiredArgsConstructor; |
| | |
| | | import org.springframework.validation.BindingResult; |
| | | import org.springframework.web.bind.annotation.*; |
| | | |
| | | import java.time.LocalDateTime; |
| | | import java.time.format.DateTimeFormatter; |
| | | import java.util.Date; |
| | | import java.util.List; |
| | | import java.util.Objects; |
| | | import java.util.Random; |
| | | |
| | | /** |
| | | * @author ZhuBaoMin |
| | |
| | | */ |
| | | |
| | | @Slf4j |
| | | @Tag(name = "分水房管理", description = "分水房操作") |
| | | @Tag(name = "平台阀控器控制", description = "平台阀控器控制") |
| | | @RestController |
| | | @RequestMapping(path="valve") |
| | | @RequiredArgsConstructor |
| | | public class ValveCtrl extends ComSupport { |
| | | private final RestTemplateUtils restTemplateUtils; |
| | | private final CommandSv commandSv; |
| | | private final SeVirtualCardMapper seVirtualCardMapper; |
| | | private final PrWaterPriceMapper prWaterPriceMapper; |
| | | private final RmCommandHistoryMapper rmCommandHistoryMapper; |
| | | private final IDLongGenerator idLongGenerator; |
| | | private String rtuResultSendWebUrl = "http://127.0.0.1:8081/remote/comRes/receive" ; |
| | | |
| | | /** |
| | | * 远程开阀(平台、APP) |
| | | * 平台远程开阀 |
| | | * @param valve |
| | | * @param bindingResult |
| | | * @return |
| | |
| | | |
| | | Long intakeId = valve.getIntakeId(); |
| | | Long vcId = valve.getVcId(); |
| | | Integer userType = valve.getUserType(); |
| | | Long operator = valve.getOperator(); |
| | | String comId = null; |
| | | Long comId = idLongGenerator.generate(); |
| | | |
| | | /** |
| | | * 如果农户选择了虚拟卡,则使用该虚拟卡 |
| | | * 如果农户未选择虚拟卡,则根据取水口ID获取与之绑定的虚拟卡 |
| | | * 如果取水口没有与之绑定的虚拟卡,则提示农户选择一张虚拟卡 |
| | | */ |
| | | if(vcId == null) { |
| | | vcId = commandSv.getVcIdByIntakeId(intakeId); |
| | | if(vcId == null) { |
| | | return BaseResponseUtils.buildFail(RemoteResultCode.PLEASE_SELECT_A_VC.getMessage()); |
| | | } |
| | | } |
| | | |
| | | // 获取系统参数 |
| | | if(!setuped) { |
| | |
| | | } |
| | | |
| | | // 虚拟卡ID换虚拟卡对象 |
| | | VoVirtualCard vc = seVirtualCardMapper.getVcById(vcId); |
| | | // 获取水价 |
| | | Double waterPrice = prWaterPriceMapper.getPrice(); |
| | | |
| | | // 取水口ID换阀控器地址 |
| | | String rtuAddr = commandSv.getRtuAddrByIntakeId(intakeId); |
| | | if(rtuAddr == null || rtuAddr.length() == 0) { |
| | | return BaseResponseUtils.buildError(RemoteResultCode.RTU_ADDR_CANNOT_BE_NULL.getMessage()); |
| | | VoVirtualCard vc = commandSv.getVcById(vcId); |
| | | if(vc == null) { |
| | | return BaseResponseUtils.buildFail(RemoteResultCode.PLEASE_SELECT_A_VC.getMessage()); |
| | | } |
| | | if(vc.getInUse() == 1) { |
| | | return BaseResponseUtils.buildFail(RemoteResultCode.IN_USE_VC_CANNOT_OPEN_VALVE.getMessage()); |
| | | } |
| | | |
| | | // 获取水价 |
| | | Double waterPrice = commandSv.getPrice(); |
| | | |
| | | // 取水口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"); |
| | | |
| | | // 生成订单号 |
| | | LocalDateTime dateTime = LocalDateTime.now(); |
| | | Random random = new Random(); |
| | | String CHARACTERS = "0123456789"; |
| | | StringBuilder sb = new StringBuilder(4); |
| | | for (int i = 0; i < 4; i++) { |
| | | int index = random.nextInt(CHARACTERS.length()); |
| | | sb.append(CHARACTERS.charAt(index)); |
| | | } |
| | | String orderNo = dtf.format(dateTime) + sb.toString(); |
| | | String orderNo = generateOrderNo(); |
| | | |
| | | String commandCode = null; |
| | | if(protocolName.equals("p206V202404")) { |
| | | if(protocol.equals("p206V202404")) { |
| | | // 获取功能码 |
| | | if(userType == 1) { |
| | | // 平台开阀 |
| | | commandCode = CodeV202404.cd_92; |
| | | }else { |
| | | // APP开阀 |
| | | commandCode = CodeV202404.cd_A2; |
| | | } |
| | | commandCode = CodeV202404.cd_92; |
| | | |
| | | // 创建视图 |
| | | ComCd92_A2Vo param = new ComCd92_A2Vo(); |
| | |
| | | param.elePrice = 0.0; |
| | | param.orderNo = orderNo; |
| | | |
| | | // 创建命令日志对象并添加到数据库中 |
| | | RmCommandHistory rmCommandHistory = getComHistory(commandCode, rtuAddr, param, operator); |
| | | comId = commandSv.insert(rmCommandHistory); |
| | | // 构造命令 |
| | | Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); |
| | | |
| | | // 构造并发送命令 |
| | | Command com = command(comId, commandCode, rtuAddr, param); |
| | | sendCom2Mw(com); |
| | | } else { |
| | | // 获取功能码 |
| | | if(userType == 1) { |
| | | // 平台开阀 |
| | | commandCode = "92"; |
| | | }else { |
| | | // APP开阀 |
| | | commandCode = "97"; |
| | | // 发送命令 |
| | | 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")); |
| | | } |
| | | } else if(protocol.equals("p206V1_0_1")) { |
| | | // 获取功能码 |
| | | commandCode = CodeV1_0_1.cd_92; |
| | | |
| | | // 创建视图 |
| | | ComCd92_A2Vo param = new ComCd92_A2Vo(); |
| | | Com97Vo param = new Com97Vo() ; |
| | | param.icCardNo = vc.getVcNum(); |
| | | param.moneyRemain = vc.getMoney(); |
| | | param.waterPrice = waterPrice; |
| | | param.orderNo = orderNo; |
| | | |
| | | // 创建命令日志对象并添加到数据库中 |
| | | RmCommandHistory rmCommandHistory = getComHistory(commandCode, rtuAddr, param, operator); |
| | | comId = commandSv.insert(rmCommandHistory); |
| | | // 构造命令 |
| | | Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); |
| | | |
| | | // 构造并发送命令 |
| | | Command com = command(comId, commandCode, rtuAddr, param); |
| | | sendCom2Mw(com); |
| | | // 发送命令 |
| | | 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")); |
| | | } |
| | | } else { |
| | | return BaseResponseUtils.buildFail("系统暂不支持该协议"); |
| | | } |
| | | |
| | | // 处理回调 |
| | | BaseResponse response = dealWithCallBack(comId); |
| | | if(!response.getCode().equals("0001")) { |
| | | return BaseResponseUtils.buildError(RemoteResultCode.GET_RESULT_ERROR.getMessage()); |
| | | } |
| | | |
| | | // 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 |
| | | SeVirtualCard virtualCard = new SeVirtualCard(); |
| | | virtualCard.setId(vcId); |
| | | virtualCard.setInUse((byte) 1); |
| | | virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); |
| | | virtualCard.setLastOperateTime(new Date()); |
| | | seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); |
| | | |
| | | Data myData = (Data)response.getContent(); |
| | | return BaseResponseUtils.buildSuccess(myData) ; |
| | | } |
| | | |
| | | /** |
| | | * 远程关阀(平台、APP) |
| | | * 平台远程关阀_参数模式 |
| | | * @param valve |
| | | * @param bindingResult |
| | | * @return |
| | |
| | | String rtuAddr = valve.getRtuAddr(); |
| | | String vcNum = valve.getVcNum(); |
| | | String orderNo = valve.getOrderNo(); |
| | | Integer userType = valve.getUserType(); |
| | | Long operator = valve.getOperator(); |
| | | String comId = null; |
| | | 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(protocolName.equals("p206V202404")) { |
| | | if(protocol.equals("p206V202404")) { |
| | | // 获取功能码 |
| | | if (userType == 1) { |
| | | // 平台关阀 |
| | | commandCode = CodeV202404.cd_93; |
| | | } else { |
| | | // APP关阀 |
| | | commandCode = CodeV202404.cd_A3; |
| | | } |
| | | commandCode = CodeV202404.cd_93; |
| | | |
| | | // 创建视图 |
| | | ComCd93_A3Vo param = new ComCd93_A3Vo(); |
| | |
| | | param.icCardNo = vcNum; |
| | | param.orderNo = orderNo; |
| | | |
| | | // 创建命令日志对象并添加到数据库中 |
| | | RmCommandHistory rmCommandHistory = getComHistory(commandCode, rtuAddr, param, operator); |
| | | comId = commandSv.insert(rmCommandHistory); |
| | | // 构造命令 |
| | | Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); |
| | | |
| | | // 构造并发送命令 |
| | | Command com = command(comId, commandCode, rtuAddr, param); |
| | | sendCom2Mw(com); |
| | | // 发送命令 |
| | | 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("系统暂不支持该协议"); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 平台远程关阀_取水口模式 |
| | | * @param dtoBase |
| | | * @param bindingResult |
| | | * @return |
| | | */ |
| | | @PostMapping(path = "close_intake", consumes = MediaType.APPLICATION_JSON_VALUE) |
| | | @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()); |
| | | } |
| | | |
| | | Long intakeId = dtoBase.getIntakeId(); |
| | | Long operator = dtoBase.getOperator(); |
| | | |
| | | VoUnclosedParam voUnclosedParam = null; |
| | | try { |
| | | voUnclosedParam = commandSv.getUncloseParam(intakeId); |
| | | }catch (Exception e) { |
| | | return BaseResponseUtils.buildErrorMsg("获取未关阀信息错误"); |
| | | } |
| | | |
| | | if(voUnclosedParam == null) { |
| | | return BaseResponseUtils.buildSuccess(RemoteResultCode.VALVE_CLOSED.getMessage()); |
| | | } |
| | | String rtuAddr = voUnclosedParam.getRtuAddr(); |
| | | String vcNum = voUnclosedParam.getVcNum(); |
| | | String orderNo = voUnclosedParam.getOrderNo(); |
| | | 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")) { |
| | | // 获取功能码 |
| | | if (userType == 1) { |
| | | // 平台关阀 |
| | | commandCode = "93"; |
| | | } else { |
| | | // APP关阀 |
| | | commandCode = "98"; |
| | | } |
| | | commandCode = CodeV202404.cd_93; |
| | | |
| | | // 创建视图 |
| | | ComCd93_A3Vo param = new ComCd93_A3Vo(); |
| | |
| | | param.icCardNo = vcNum; |
| | | param.orderNo = orderNo; |
| | | |
| | | // 创建命令日志对象并添加到数据库中 |
| | | RmCommandHistory rmCommandHistory = getComHistory(commandCode, rtuAddr, param, operator); |
| | | comId = commandSv.insert(rmCommandHistory); |
| | | // 构造命令 |
| | | Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); |
| | | |
| | | // 构造并发送命令 |
| | | Command com = command(comId, commandCode, rtuAddr, param); |
| | | sendCom2Mw(com); |
| | | // 发送命令 |
| | | 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")); |
| | | } |
| | | } 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); |
| | | |
| | | //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")); |
| | | } |
| | | } else { |
| | | return BaseResponseUtils.buildFail("系统暂不支持该协议"); |
| | | } |
| | | |
| | | // 处理回调 |
| | | BaseResponse response = dealWithCallBack(comId); |
| | | if(!response.getCode().equals("0001")) { |
| | | return BaseResponseUtils.buildError(RemoteResultCode.GET_RESULT_ERROR.getMessage()); |
| | | } |
| | | |
| | | // 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 |
| | | Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); |
| | | SeVirtualCard virtualCard = new SeVirtualCard(); |
| | | virtualCard.setId(vcId); |
| | | virtualCard.setInUse((byte) 0); |
| | | virtualCard.setLastOperate(LastOperateENUM.CLOSE_VALVE.getCode()); |
| | | virtualCard.setLastOperateTime(new Date()); |
| | | seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); |
| | | |
| | | Data myData = (Data)response.getContent(); |
| | | return BaseResponseUtils.buildSuccess(myData) ; |
| | | } |
| | | |
| | | /** |