|  |  | 
 |  |  | import com.alibaba.fastjson2.JSONObject; | 
 |  |  | import com.dy.common.multiDataSource.DataSourceContext; | 
 |  |  | import com.dy.common.mw.protocol.Command; | 
 |  |  | import com.dy.common.mw.protocol.p206V1.CodeV1; | 
 |  |  | import com.dy.common.mw.protocol.p206V1.ProtocolConstantV206V1; | 
 |  |  | import com.dy.common.mw.protocol.p206V1.downVos.ComA1Vo; | 
 |  |  | import com.dy.common.mw.protocol.p206V2.ProtocolConstantV206V2; | 
 |  |  | import com.dy.common.mw.protocol.p206V202404.ProtocolConstantV206V202404; | 
 |  |  | import com.dy.common.util.IDLongGenerator; | 
 |  |  | import com.dy.common.webUtil.BaseResponse; | 
 |  |  | import com.dy.common.webUtil.QueryResultVo; | 
 |  |  | import com.dy.pipIrrGlobal.command.ComSupport; | 
 |  |  | import com.dy.pipIrrGlobal.command.dto.Param; | 
 |  |  | import com.dy.pipIrrGlobal.daoIr.IrIntakeOperateMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoPr.PrIntakeMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoPr.PrIntakeVcMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoPr.PrWaterPriceMapper; | 
 |  |  | 
 |  |  | import com.dy.pipIrrGlobal.daoRm.RmOpenCloseValveLastMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoSe.SeClientCardMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoSe.SeVirtualCardMapper; | 
 |  |  | import com.dy.pipIrrGlobal.pojoIr.IrIntakeOperate; | 
 |  |  | import com.dy.pipIrrGlobal.pojoRm.RmCommandHistory; | 
 |  |  | import com.dy.pipIrrGlobal.pojoSe.SeClientCard; | 
 |  |  | import com.dy.pipIrrGlobal.voPr.VoOnLineIntake; | 
 |  |  | import com.dy.pipIrrGlobal.voRm.VoIrrigaterProfile; | 
 |  |  | import com.dy.pipIrrGlobal.voRm.VoRtuAndVc; | 
 |  |  | import com.dy.pipIrrGlobal.voRm.VoUnclosedValve; | 
 |  |  | import com.dy.pipIrrGlobal.voSe.VoVirtualCard; | 
 |  |  | import com.dy.pipIrrWechat.command.dto.AutomaticClose; | 
 |  |  | import com.dy.pipIrrWechat.result.WechatResultCode; | 
 |  |  | import lombok.RequiredArgsConstructor; | 
 |  |  | import lombok.extern.slf4j.Slf4j; | 
 |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
 |  |  | import org.springframework.beans.factory.annotation.Value; | 
 |  |  | import org.springframework.core.env.Environment; | 
 |  |  | import org.springframework.stereotype.Service; | 
 |  |  |  | 
 |  |  | import java.util.ArrayList; | 
 |  |  | import java.util.HashMap; | 
 |  |  | import java.util.List; | 
 |  |  | import java.util.Map; | 
 |  |  | import java.util.*; | 
 |  |  |  | 
 |  |  | /** | 
 |  |  |  * @author ZhuBaoMin | 
 |  |  | 
 |  |  |     private final PrIntakeVcMapper prIntakeVcMapper; | 
 |  |  |     private final SeClientCardMapper seClientCardMapper; | 
 |  |  |     private final RmIrrigateProfileMapper rmIrrigateProfileMapper; | 
 |  |  |     private RmOpenCloseValveLastMapper rmOpenCloseValveLastMapper; | 
 |  |  |     private final RmOpenCloseValveLastMapper rmOpenCloseValveLastMapper; | 
 |  |  |     //private final PrCommonIntakesMapper prCommonIntakesMapper; | 
 |  |  |     private final IrIntakeOperateMapper irIntakeOperateMapper; | 
 |  |  |  | 
 |  |  |     @Value("${mw.rtuCallbackUrl_wx}") | 
 |  |  |     private String rtuCallbackUrl_wx; | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * pro_mw:属性 | 
 |  |  | 
 |  |  |     private String pro_mw = "mw"; | 
 |  |  |     private String key_mw = "comSendUrl"; | 
 |  |  |     @Autowired | 
 |  |  |     public CommandSv(RmCommandHistoryMapper rmCommandHistoryMapper,RmOpenCloseValveLastMapper rmOpenCloseValveLastMapper, SeVirtualCardMapper seVirtualCardMapper, PrIntakeMapper prIntakeMapper, PrWaterPriceMapper prWaterPriceMapper, PrIntakeVcMapper prIntakeVcMapper, SeClientCardMapper seClientCardMapper, RmIrrigateProfileMapper rmIrrigateProfileMapper, Environment env) { | 
 |  |  |     public CommandSv(RmCommandHistoryMapper rmCommandHistoryMapper,RmOpenCloseValveLastMapper rmOpenCloseValveLastMapper, SeVirtualCardMapper seVirtualCardMapper, PrIntakeMapper prIntakeMapper, PrWaterPriceMapper prWaterPriceMapper, PrIntakeVcMapper prIntakeVcMapper, SeClientCardMapper seClientCardMapper, RmIrrigateProfileMapper rmIrrigateProfileMapper, Environment env, IrIntakeOperateMapper irIntakeOperateMapper) { | 
 |  |  |         this.rmCommandHistoryMapper = rmCommandHistoryMapper; | 
 |  |  |         this.rmOpenCloseValveLastMapper = rmOpenCloseValveLastMapper; | 
 |  |  |         //this.prCommonIntakesMapper = prCommonIntakesMapper; | 
 |  |  |         this.seVirtualCardMapper = seVirtualCardMapper; | 
 |  |  |         this.prIntakeMapper = prIntakeMapper; | 
 |  |  |         this.prWaterPriceMapper = prWaterPriceMapper; | 
 |  |  | 
 |  |  |         this.seClientCardMapper = seClientCardMapper; | 
 |  |  |         this.rmIrrigateProfileMapper = rmIrrigateProfileMapper; | 
 |  |  |         this.env = env; | 
 |  |  |         this.irIntakeOperateMapper = irIntakeOperateMapper; | 
 |  |  |     } | 
 |  |  |     /** | 
 |  |  |      * 虚拟卡ID换虚拟卡对象 | 
 |  |  | 
 |  |  |         com.code = "LCD0001"; | 
 |  |  |         com.type = "innerCommand"; | 
 |  |  |         comSendUrl = env.getProperty(pro_mw + "." + DataSourceContext.get() + "." + key_mw); | 
 |  |  |  | 
 |  |  |         JSONObject response = (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
 |  |  |  | 
 |  |  |         JSONArray jsonArray = new JSONArray(); | 
 |  |  |         if(response != null && response.getString("code").equals("0001")) { | 
 |  |  |             JSONObject attachment = response.getJSONObject("content").getJSONObject("attachment").getJSONObject("onLineMap"); | 
 |  |  |             HashMap<String, Boolean> onLineMap = JSON.parseObject(attachment.toJSONString(), HashMap.class); | 
 |  |  |  | 
 |  |  |             JSONArray jsonArray = new JSONArray(); | 
 |  |  |             for (Map.Entry<String, Boolean> entry : onLineMap.entrySet()) { | 
 |  |  |                 JSONObject jsonObject = new JSONObject(); | 
 |  |  |                 jsonObject.put("rtuAddr", entry.getKey()); | 
 |  |  |                 jsonObject.put("isOnLine", entry.getValue()); | 
 |  |  |                 jsonArray.add(jsonObject); | 
 |  |  |             JSONObject attachment = response.getJSONObject("content").getJSONObject("attachment"); | 
 |  |  |             if(attachment != null) { | 
 |  |  |                 attachment.forEach((key, value) -> { | 
 |  |  |                     JSONObject jsonObject = new JSONObject(); | 
 |  |  |                     jsonObject.put("rtuAddr", key); | 
 |  |  |                     jsonObject.put("isOnLine", value); | 
 |  |  |                     jsonArray.add(jsonObject); | 
 |  |  |                 }); | 
 |  |  |             } | 
 |  |  |             //System.out.println(jsonArray.toJSONString()); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |             System.out.println(jsonArray.toJSONString()); | 
 |  |  |             List<VoUnclosedValve> res = rmCommandHistoryMapper.getUnclosedValves(jsonArray.toJSONString(), operator); | 
 |  |  |         /** | 
 |  |  |          * 获取未关阀的RTU地址和虚拟卡编号对数组 | 
 |  |  |          * 遍历数组获取最后命令日志ID集合 | 
 |  |  |          */ | 
 |  |  |         List<VoRtuAndVc> rtus = rmCommandHistoryMapper.getUnclosedRtus(operator); | 
 |  |  |         String comIds = ""; | 
 |  |  |         if(rtus != null && rtus.size() > 0) { | 
 |  |  |             for (int i = 0; i < rtus.size(); i++) { | 
 |  |  |                 Long comId = rmCommandHistoryMapper.getLastComId(rtus.get(i).getRtuAddr(), rtus.get(i).getVcNum()); | 
 |  |  |                 if(comId > 0) { | 
 |  |  |                     comIds = comIds + "\"" + comId + "\","; | 
 |  |  |                 } | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         if(comIds.length() > 0) { | 
 |  |  |             comIds = comIds.substring(0, comIds.length()-1); | 
 |  |  |             List<VoUnclosedValve> res = rmCommandHistoryMapper.getUnclosedValves(jsonArray.toJSONString(), comIds); | 
 |  |  |             if(res != null) { | 
 |  |  |                 return res; | 
 |  |  |             } else { | 
 |  |  |                 return new ArrayList<>(); | 
 |  |  |             } | 
 |  |  |         } else { | 
 |  |  |             QueryResultVo<List<VoOnLineIntake>> rsVo = new QueryResultVo<>(); | 
 |  |  |             return new ArrayList<>(); | 
 |  |  |         } | 
 |  |  |         return new ArrayList<>(); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  | 
 |  |  |         return rsVo ; | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 添加取水口操作记录,轮灌过程命令下发时使用 | 
 |  |  |      * @param po | 
 |  |  |      * @return | 
 |  |  |      */ | 
 |  |  |     public Long addIntakeOperate(IrIntakeOperate po) { | 
 |  |  |         irIntakeOperateMapper.insert(po); | 
 |  |  |         return po.getId(); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     ///** | 
 |  |  |     // * 根据命令ID更新取水口操作记录 | 
 |  |  |     // * @param commandId | 
 |  |  |     // * @param commandResult | 
 |  |  |     // * @return | 
 |  |  |     // */ | 
 |  |  |     //public Integer updateByCommandId(Long commandId, Byte commandResult) { | 
 |  |  |     //    return irIntakeOperateMapper.updateByCommandId(commandId, commandResult); | 
 |  |  |     //} | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 定时关阀式计划开阀 | 
 |  |  |      * @param automaticClose | 
 |  |  |      * @return | 
 |  |  |      */ | 
 |  |  |     public Map planedOpenTimedClose(AutomaticClose automaticClose, Date startTime, Integer duration) { | 
 |  |  |         Long intakeId = automaticClose.getIntakeId(); | 
 |  |  |         Long vcId = automaticClose.getVcId(); | 
 |  |  |         Date plannedOpenTime = automaticClose.getPlannedOpenTime(); | 
 |  |  |         Integer minutes = automaticClose.getMinutes(); | 
 |  |  |         Long operator = automaticClose.getOperator(); | 
 |  |  |         Byte openType = automaticClose.getOpenType(); | 
 |  |  |         Long comId = new IDLongGenerator().generate(); | 
 |  |  |  | 
 |  |  |         if(openType == 1) { | 
 |  |  |             IrIntakeOperate irIntakeOperate = new IrIntakeOperate(); | 
 |  |  |             irIntakeOperate.setCommandId(comId); | 
 |  |  |             irIntakeOperate.setIntakeId(intakeId); | 
 |  |  |             irIntakeOperate.setStartTime(startTime); | 
 |  |  |             irIntakeOperate.setDuration(duration); | 
 |  |  |  | 
 |  |  |             Long id = addIntakeOperate(irIntakeOperate); | 
 |  |  |             if(id == null) { | 
 |  |  |                 Map map = new HashMap<>(); | 
 |  |  |                 map.put("success", false); | 
 |  |  |                 map.put("msg", "添加取水口操作记录失败"); | 
 |  |  |                 map.put("content", null); | 
 |  |  |                 return map; | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         Integer year = Integer.parseInt(String.format("%tY", plannedOpenTime)); | 
 |  |  |         Integer month = Integer.parseInt(String.format("%tm", plannedOpenTime)); | 
 |  |  |         Integer day = Integer.parseInt(String.format("%td", plannedOpenTime)); | 
 |  |  |         Integer hour = Integer.parseInt(String.format("%tH", plannedOpenTime)); | 
 |  |  |         Integer minute = Integer.parseInt(String.format("%tM", plannedOpenTime)); | 
 |  |  |  | 
 |  |  |         /** | 
 |  |  |          * 如果农户选择了虚拟卡,则使用该虚拟卡 | 
 |  |  |          * 如果农户未选择虚拟卡,则根据取水口ID获取与之绑定的虚拟卡 | 
 |  |  |          * 如果取水口没有与之绑定的虚拟卡,则提示农户选择一张虚拟卡 | 
 |  |  |          */ | 
 |  |  |         if(vcId == null) { | 
 |  |  |             vcId = getVcIdByIntakeId(intakeId); | 
 |  |  |             if(vcId == null) { | 
 |  |  |                 irIntakeOperateMapper.updateByCommandId(comId, (byte)2, WechatResultCode.PLEASE_SELECT_A_VC.getMessage() + "(" + intakeId + ")"); | 
 |  |  |  | 
 |  |  |                 Map map = new HashMap<>(); | 
 |  |  |                 map.put("success", false); | 
 |  |  |                 map.put("msg", WechatResultCode.PLEASE_SELECT_A_VC.getMessage() + "(" + intakeId + ")"); | 
 |  |  |                 map.put("content", null); | 
 |  |  |                 return map; | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         // 虚拟卡ID换虚拟卡对象 | 
 |  |  |         VoVirtualCard vc = getVcById(vcId); | 
 |  |  |         if(vc == null) { | 
 |  |  |             irIntakeOperateMapper.updateByCommandId(comId, (byte)2, WechatResultCode.PLEASE_SELECT_A_VC.getMessage() + "(" + intakeId + ")"); | 
 |  |  |  | 
 |  |  |             Map map = new HashMap<>(); | 
 |  |  |             map.put("success", false); | 
 |  |  |             map.put("msg", WechatResultCode.PLEASE_SELECT_A_VC.getMessage() + "(" + intakeId + ")"); | 
 |  |  |             map.put("content", null); | 
 |  |  |             return map; | 
 |  |  |         } | 
 |  |  |         String vcNum = vc.getVcNum().toString(); | 
 |  |  |         Double moneyRemain = vc.getMoney(); | 
 |  |  |  | 
 |  |  |         // 获取水价 | 
 |  |  |         Double waterPrice = getPrice(); | 
 |  |  |         if(waterPrice == null) { | 
 |  |  |             Map map = new HashMap<>(); | 
 |  |  |             map.put("success", false); | 
 |  |  |             map.put("msg", WechatResultCode.NO_WATER_PRICE.getMessage()); | 
 |  |  |             map.put("content", null); | 
 |  |  |             return map; | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         // 取水口ID换阀控器地址及通讯协议 | 
 |  |  |         JSONObject job_rtu = getRtu(intakeId, null); | 
 |  |  |         if(job_rtu == null) { | 
 |  |  |             irIntakeOperateMapper.updateByCommandId(comId, (byte)2, WechatResultCode.RTU_NOT_EXIST.getMessage() + "(" + intakeId + ")"); | 
 |  |  |  | 
 |  |  |             Map map = new HashMap<>(); | 
 |  |  |             map.put("success", false); | 
 |  |  |             map.put("msg", WechatResultCode.RTU_NOT_EXIST.getMessage()); | 
 |  |  |             map.put("content", null); | 
 |  |  |             return map; | 
 |  |  |         } | 
 |  |  |         String rtuAddr = job_rtu.getString("rtuAddr"); | 
 |  |  |         String protocol = job_rtu.getString("protocol"); | 
 |  |  |  | 
 |  |  |         comSendUrl = env.getProperty(pro_mw + "." + DataSourceContext.get() + "." + key_mw); | 
 |  |  |  | 
 |  |  |         // 生成订单号 | 
 |  |  |         String orderNo = generateOrderNo(); | 
 |  |  |         if(orderNo == null) { | 
 |  |  |             irIntakeOperateMapper.updateByCommandId(comId, (byte)2, WechatResultCode.NO_ORDER_NUMBER.getMessage() + "(" + intakeId + ")"); | 
 |  |  |  | 
 |  |  |             Map map = new HashMap<>(); | 
 |  |  |             map.put("success", false); | 
 |  |  |             map.put("msg", WechatResultCode.NO_ORDER_NUMBER.getMessage()); | 
 |  |  |             map.put("content", null); | 
 |  |  |             return map; | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         String commandCode = null; | 
 |  |  |         if(protocol.equals(ProtocolConstantV206V202404.protocolName)) { | 
 |  |  |             Map map = new HashMap<>(); | 
 |  |  |             map.put("success", true); | 
 |  |  |             map.put("msg", "开阀成功"); | 
 |  |  |             map.put("content", null); | 
 |  |  |             return map; | 
 |  |  |         } else if(protocol.equals(ProtocolConstantV206V1.protocolName) || protocol.equals(ProtocolConstantV206V2.protocolName)) { | 
 |  |  |             // 获取功能码 | 
 |  |  |             commandCode = CodeV1.cd_A1; | 
 |  |  |  | 
 |  |  |             // 创建视图 | 
 |  |  |             ComA1Vo param = new ComA1Vo(); | 
 |  |  |             param.setIcCardNo(vcNum); | 
 |  |  |             param.setMoneyRemain(moneyRemain); | 
 |  |  |             param.setWaterPrice(waterPrice); | 
 |  |  |             param.setMinutes(minutes); | 
 |  |  |             param.setYear(year); | 
 |  |  |             param.setMonth(month); | 
 |  |  |             param.setDay(day); | 
 |  |  |             param.setHour(hour); | 
 |  |  |             param.setMinute(minute); | 
 |  |  |             param.setOrderNo(orderNo); | 
 |  |  |  | 
 |  |  |             /** | 
 |  |  |              * 构造命令、发送命令并处理请求结果及执行结果 | 
 |  |  |              * 1 准备参数 | 
 |  |  |              * 2 调用公共方法 | 
 |  |  |              */ | 
 |  |  |             Param myParam = new Param(); | 
 |  |  |             myParam.setComId(comId); | 
 |  |  |             myParam.setComType((byte)1); | 
 |  |  |             myParam.setCommandCode(commandCode); | 
 |  |  |             myParam.setCommandName(CodeV1.getCodeName(commandCode)); | 
 |  |  |             myParam.setIntakeId(intakeId); | 
 |  |  |             myParam.setRtuAddr(rtuAddr); | 
 |  |  |             myParam.setProtocol(protocol); | 
 |  |  |             myParam.setVcId(vcId); | 
 |  |  |             myParam.setParam(param); | 
 |  |  |             myParam.setRtuResultSendWebUrl(rtuCallbackUrl_wx); | 
 |  |  |             myParam.setOperator(operator); | 
 |  |  |             myParam.setOpenType(openType); | 
 |  |  |  | 
 |  |  |             BaseResponse<Boolean> result = dealWithCommandResult(myParam); | 
 |  |  |  | 
 |  |  |             Map map = new HashMap<>(); | 
 |  |  |             map.put("success", result.isSuccess()); | 
 |  |  |             map.put("msg", result.getMsg()); | 
 |  |  |             map.put("content", result.getContent()); | 
 |  |  |             return map; | 
 |  |  |         } else { | 
 |  |  |             irIntakeOperateMapper.updateByCommandId(comId, (byte)2, "系统暂不支持该协议" + "(" + intakeId + ")"); | 
 |  |  |  | 
 |  |  |             Map map = new HashMap<>(); | 
 |  |  |             map.put("success", false); | 
 |  |  |             map.put("msg", "系统暂不支持该协议"); | 
 |  |  |             map.put("content", null); | 
 |  |  |             return map; | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  | } |