|  |  |  | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoPr.PrIntakeVcMapper; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoPr.PrWaterPriceMapper; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoRm.RmCommandHistoryMapper; | 
|---|
|  |  |  | 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.VoCommand; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voRm.VoRtuAndVc; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voRm.VoUnclosedParam; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voRm.VoUnclosedValve; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voSe.VoVirtualCard; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.HashMap; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | private final PrWaterPriceMapper prWaterPriceMapper; | 
|---|
|  |  |  | private final PrIntakeVcMapper prIntakeVcMapper; | 
|---|
|  |  |  | private final SeClientCardMapper seClientCardMapper; | 
|---|
|  |  |  | private RmOpenCloseValveLastMapper rmOpenCloseValveLastMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * pro_mw:属性 | 
|---|
|  |  |  | 
|---|
|  |  |  | private String pro_mw = "mw"; | 
|---|
|  |  |  | private String key_mw = "comSendUrl"; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | public CommandSv(RmCommandHistoryMapper rmCommandHistoryMapper, SeVirtualCardMapper seVirtualCardMapper, PrIntakeMapper prIntakeMapper, PrWaterPriceMapper prWaterPriceMapper, PrIntakeVcMapper prIntakeVcMapper, SeClientCardMapper seClientCardMapper, Environment env) { | 
|---|
|  |  |  | public CommandSv(RmCommandHistoryMapper rmCommandHistoryMapper,RmOpenCloseValveLastMapper rmOpenCloseValveLastMapper, SeVirtualCardMapper seVirtualCardMapper, PrIntakeMapper prIntakeMapper, PrWaterPriceMapper prWaterPriceMapper, PrIntakeVcMapper prIntakeVcMapper, SeClientCardMapper seClientCardMapper, Environment env) { | 
|---|
|  |  |  | this.rmCommandHistoryMapper = rmCommandHistoryMapper; | 
|---|
|  |  |  | this.rmOpenCloseValveLastMapper = rmOpenCloseValveLastMapper; | 
|---|
|  |  |  | this.seVirtualCardMapper = seVirtualCardMapper; | 
|---|
|  |  |  | this.prIntakeMapper = prIntakeMapper; | 
|---|
|  |  |  | this.prWaterPriceMapper = prWaterPriceMapper; | 
|---|
|  |  |  | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | System.out.println(jsonArray); | 
|---|
|  |  |  | 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<>(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 为指定(阀控器地址、水卡编号、无关阀记录)开关阀最新记录添加关阀时间,使之不在未关阀记录中显示 | 
|---|
|  |  |  | * @param rtuAddr | 
|---|
|  |  |  | * @param icCardNo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public Integer addClostTime(String rtuAddr, String icCardNo) { | 
|---|
|  |  |  | return rmOpenCloseValveLastMapper.addCloseTime(rtuAddr, icCardNo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | return rmCommandHistoryMapper.getUncloseParam(jsonArray.toJSONString(), intakeId); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | QueryResultVo<List<VoOnLineIntake>> rsVo = new QueryResultVo<>(); | 
|---|
|  |  |  | VoUnclosedParam voUnclosedParam = new VoUnclosedParam(); | 
|---|
|  |  |  | return voUnclosedParam; | 
|---|
|  |  |  | //    System.out.println(jsonArray); | 
|---|
|  |  |  | //} else { | 
|---|
|  |  |  | //    VoUnclosedParam voUnclosedParam = new VoUnclosedParam(); | 
|---|
|  |  |  | //    return voUnclosedParam; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return rmCommandHistoryMapper.getUncloseParam(jsonArray.toJSONString(), intakeId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public QueryResultVo<List<VoCommand>> getCommandHistories(QoCommand query) { | 
|---|
|  |  |  | // 完善查询起止时间 | 
|---|
|  |  |  | String timeStart = query.getTimeStart(); | 
|---|
|  |  |  | String timeStop = query.getTimeStop(); | 
|---|
|  |  |  | if(timeStart != null) { | 
|---|
|  |  |  | timeStart = timeStart + " 00:00:00"; | 
|---|
|  |  |  | query.setTimeStart(timeStart); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(timeStop != null) { | 
|---|
|  |  |  | timeStop = timeStop + " 23:59:59"; | 
|---|
|  |  |  | query.setTimeStop(timeStop); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | query.completionTime(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(query); | 
|---|
|  |  |  |  | 
|---|