|  |  |  | 
|---|
|  |  |  | 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.List; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @author ZhuBaoMin | 
|---|
|  |  |  | 
|---|
|  |  |  | private final RmIrrigateProfileMapper rmIrrigateProfileMapper; | 
|---|
|  |  |  | 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.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"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONArray jsonArray = new JSONArray(); | 
|---|
|  |  |  | 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<>(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | rsVo.obj = rmIrrigateProfileMapper.getIrrPro(type); | 
|---|
|  |  |  | 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, Long planId, 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 != null && openType == 1) { | 
|---|
|  |  |  | IrIntakeOperate irIntakeOperate = new IrIntakeOperate(); | 
|---|
|  |  |  | irIntakeOperate.setPlanId(planId); | 
|---|
|  |  |  | irIntakeOperate.setOperateType((byte)1); | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|