|  |  | 
 |  |  | import com.alibaba.fastjson2.JSON; | 
 |  |  | import com.alibaba.fastjson2.JSONArray; | 
 |  |  | import com.alibaba.fastjson2.JSONObject; | 
 |  |  | import com.dy.common.multiDataSource.DataSourceContext; | 
 |  |  | import com.dy.common.mw.protocol.Command; | 
 |  |  | import com.dy.common.webUtil.QueryResultVo; | 
 |  |  | import com.dy.pipIrrGlobal.command.ComSupport; | 
 |  |  | 
 |  |  | import com.dy.pipIrrGlobal.daoPr.PrIntakeVcMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoPr.PrWaterPriceMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoRm.RmCommandHistoryMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoRm.RmIrrigateProfileMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoRm.RmOpenCloseValveLastMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoSe.SeClientCardMapper; | 
 |  |  | import com.dy.pipIrrGlobal.daoSe.SeVirtualCardMapper; | 
 |  |  | 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.VoUnclosedValve; | 
 |  |  | import com.dy.pipIrrGlobal.voSe.VoVirtualCard; | 
 |  |  | import lombok.RequiredArgsConstructor; | 
 |  |  | import lombok.extern.slf4j.Slf4j; | 
 |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
 |  |  | 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; | 
 |  |  |  | 
 |  |  | /** | 
 |  |  |  * @author ZhuBaoMin | 
 |  |  | 
 |  |  |     private final PrWaterPriceMapper prWaterPriceMapper; | 
 |  |  |     private final PrIntakeVcMapper prIntakeVcMapper; | 
 |  |  |     private final SeClientCardMapper seClientCardMapper; | 
 |  |  |     private final RmIrrigateProfileMapper rmIrrigateProfileMapper; | 
 |  |  |     private final RmOpenCloseValveLastMapper rmOpenCloseValveLastMapper; | 
 |  |  |     //private final PrCommonIntakesMapper prCommonIntakesMapper; | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * pro_mw:属性 | 
 |  |  |      * tag从控制器中获取 | 
 |  |  |      * key_mw:url的key | 
 |  |  |      */ | 
 |  |  |     private Environment env = null; | 
 |  |  |     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) { | 
 |  |  |         this.rmCommandHistoryMapper = rmCommandHistoryMapper; | 
 |  |  |         this.rmOpenCloseValveLastMapper = rmOpenCloseValveLastMapper; | 
 |  |  |         //this.prCommonIntakesMapper = prCommonIntakesMapper; | 
 |  |  |         this.seVirtualCardMapper = seVirtualCardMapper; | 
 |  |  |         this.prIntakeMapper = prIntakeMapper; | 
 |  |  |         this.prWaterPriceMapper = prWaterPriceMapper; | 
 |  |  |         this.prIntakeVcMapper = prIntakeVcMapper; | 
 |  |  |         this.seClientCardMapper = seClientCardMapper; | 
 |  |  |         this.rmIrrigateProfileMapper = rmIrrigateProfileMapper; | 
 |  |  |         this.env = env; | 
 |  |  |     } | 
 |  |  |     /** | 
 |  |  |      * 虚拟卡ID换虚拟卡对象 | 
 |  |  |      * @param vcId | 
 |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 添加命令日志 | 
 |  |  |      * @param po 命令日志对象 | 
 |  |  |      * @return 字符串类型的主键 | 
 |  |  |      */ | 
 |  |  |     public Long insert(RmCommandHistory po) { | 
 |  |  |         rmCommandHistoryMapper.insert(po); | 
 |  |  |         return po.getId(); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 修改命令日志信息 | 
 |  |  |      * @param po 命令日志对象 | 
 |  |  |      * @return 影响记录数量 | 
 |  |  |      */ | 
 |  |  |     public Integer update(RmCommandHistory po) { | 
 |  |  |         return rmCommandHistoryMapper.updateByPrimaryKeySelective(po); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 根据操作员ID获取未关阀记录(包含在线情况) | 
 |  |  |      * @param operator | 
 |  |  |      * @return | 
 |  |  | 
 |  |  |         com.id = Command.defaultId; | 
 |  |  |         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); | 
 |  |  |             List<VoUnclosedValve> res = rmCommandHistoryMapper.getUnclosedValves(jsonArray.toJSONString(), operator); | 
 |  |  |             if(res != null) { | 
 |  |  |                 return res; | 
 |  |  |             } else { | 
 |  |  |                 return new ArrayList<>(); | 
 |  |  |             } | 
 |  |  |         List<VoUnclosedValve> res = rmCommandHistoryMapper.getUnclosedValves(jsonArray.toJSONString(), operator); | 
 |  |  |         if(res != null) { | 
 |  |  |             return res; | 
 |  |  |         } else { | 
 |  |  |             QueryResultVo<List<VoOnLineIntake>> rsVo = new QueryResultVo<>(); | 
 |  |  |             return new ArrayList<>(); | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 为指定(阀控器地址、水卡编号、无关阀记录)开关阀最新记录添加关阀时间,使之不在未关阀记录中显示 | 
 |  |  |      * @param rtuAddr | 
 |  |  |      * @param icCardNo | 
 |  |  |      * @return | 
 |  |  |      */ | 
 |  |  |     public Integer addClostTime(String rtuAddr, String icCardNo) { | 
 |  |  |         return rmOpenCloseValveLastMapper.addCloseTime(rtuAddr, icCardNo); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  | 
 |  |  |     public SeClientCard geClientCardByCardId(Long cardId) { | 
 |  |  |         return seClientCardMapper.selectByPrimaryKey(cardId); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 添加命令日志 | 
 |  |  |      * @param po 命令日志对象 | 
 |  |  |      * @return 字符串类型的主键 | 
 |  |  |      */ | 
 |  |  |     public Long insert(RmCommandHistory po) { | 
 |  |  |         rmCommandHistoryMapper.insert(po); | 
 |  |  |         return po.getComId(); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 修改命令日志信息 | 
 |  |  |      * @param po 命令日志对象 | 
 |  |  |      * @return 影响记录数量 | 
 |  |  |      */ | 
 |  |  |     public Integer update(RmCommandHistory po) { | 
 |  |  |         return rmCommandHistoryMapper.updateByPrimaryKeySelective(po); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 取水口名称换取水口ID,扫码开阀使用 | 
 |  |  |      * @param intakeName | 
 |  |  |      * @return | 
 |  |  |      */ | 
 |  |  |     public Long getIntakeIdByName(String intakeName) { | 
 |  |  |         return prIntakeMapper.getIntakeIdByName(intakeName); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 根据配置类型获取配置值 | 
 |  |  |      * @param type | 
 |  |  |      * @return | 
 |  |  |      */ | 
 |  |  |     QueryResultVo<List<VoIrrigaterProfile>> getIrrPro(Integer type) { | 
 |  |  |         QueryResultVo<List<VoIrrigaterProfile>> rsVo = new QueryResultVo<>() ; | 
 |  |  |         rsVo.obj = rmIrrigateProfileMapper.getIrrPro(type); | 
 |  |  |         return rsVo ; | 
 |  |  |     } | 
 |  |  | } |