| package com.dy.pipIrrRemote.common; | 
|   | 
| 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.PrIntakeMapper; | 
| import com.dy.pipIrrGlobal.daoPr.PrIntakeVcMapper; | 
| import com.dy.pipIrrGlobal.daoPr.PrWaterPriceMapper; | 
| import com.dy.pipIrrGlobal.daoRm.RmCommandHistoryMapper; | 
| 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.VoUnclosedParam; | 
| import com.dy.pipIrrGlobal.voRm.VoUnclosedValve; | 
| import com.dy.pipIrrGlobal.voSe.VoVirtualCard; | 
| import com.dy.pipIrrRemote.common.qo.QoCommand; | 
| import lombok.RequiredArgsConstructor; | 
| import lombok.extern.slf4j.Slf4j; | 
| import org.apache.dubbo.common.utils.PojoUtils; | 
| 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 | 
|  * @date 2024-05-21 17:14 | 
|  * @LastEditTime 2024-05-21 17:14 | 
|  * @Description 命令日志服务类 | 
|  */ | 
|   | 
| @Slf4j | 
| @Service | 
| @RequiredArgsConstructor | 
| public class CommandSv extends ComSupport { | 
|     private final RmCommandHistoryMapper rmCommandHistoryMapper; | 
|     private final SeVirtualCardMapper seVirtualCardMapper; | 
|     private final PrIntakeMapper prIntakeMapper; | 
|     private final PrWaterPriceMapper prWaterPriceMapper; | 
|     private final PrIntakeVcMapper prIntakeVcMapper; | 
|     private final SeClientCardMapper seClientCardMapper; | 
|   | 
|     /** | 
|      * 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, SeVirtualCardMapper seVirtualCardMapper, PrIntakeMapper prIntakeMapper, PrWaterPriceMapper prWaterPriceMapper, PrIntakeVcMapper prIntakeVcMapper, SeClientCardMapper seClientCardMapper, Environment env) { | 
|         this.rmCommandHistoryMapper = rmCommandHistoryMapper; | 
|         this.seVirtualCardMapper = seVirtualCardMapper; | 
|         this.prIntakeMapper = prIntakeMapper; | 
|         this.prWaterPriceMapper = prWaterPriceMapper; | 
|         this.prIntakeVcMapper = prIntakeVcMapper; | 
|         this.seClientCardMapper = seClientCardMapper; | 
|         this.env = env; | 
|     } | 
|   | 
|     /** | 
|      * 虚拟卡ID换虚拟卡对象 | 
|      * @param vcId | 
|      * @return | 
|      */ | 
|     public VoVirtualCard getVcById(Long vcId) { | 
|         return seVirtualCardMapper.getVcById(vcId); | 
|     } | 
|   | 
|     /** | 
|      * 获取水价 | 
|      * @return | 
|      */ | 
|     public Double getPrice() { | 
|         return prWaterPriceMapper.getPrice(); | 
|     } | 
|   | 
|     /** | 
|      * 添加命令日志 | 
|      * @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 operator | 
|      * @return | 
|      */ | 
|     public List<VoUnclosedValve> getUnclosedValves(Long operator) { | 
|         Command com = new Command() ; | 
|         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)); | 
|         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); | 
|             } | 
|   | 
|             System.out.println(jsonArray); | 
|             List<VoUnclosedValve> res = rmCommandHistoryMapper.getUnclosedValves(jsonArray.toJSONString(), operator); | 
|             if(res != null) { | 
|                 return res; | 
|             } else { | 
|                 return new ArrayList<>(); | 
|             } | 
|         } else { | 
|             QueryResultVo<List<VoOnLineIntake>> rsVo = new QueryResultVo<>(); | 
|             return new ArrayList<>(); | 
|         } | 
|     } | 
|   | 
|     /** | 
|      * 修改命令日志记录,回调报错时将命令记录的执行结果改为失败 | 
|      * @param po | 
|      * @return | 
|      */ | 
|     public Integer updateCommandResult(RmCommandHistory po) { | 
|         return rmCommandHistoryMapper.updateByPrimaryKeySelective(po); | 
|     } | 
|   | 
|     /** | 
|      * 根据取水口ID获取与之绑定虚拟卡ID | 
|      * @param intakeId | 
|      * @return | 
|      */ | 
|     public Long getVcIdByIntakeId(Long intakeId) { | 
|         return prIntakeVcMapper.getVcIdByIntakeId(intakeId); | 
|     } | 
|   | 
|     /** | 
|      * 根据取水口ID获取该取水口未关阀参数,平台选择取水口关阀使用 | 
|      * @param intakeId | 
|      * @return | 
|      */ | 
|     public VoUnclosedParam getUncloseParam(Long intakeId) { | 
|         Command com = new Command() ; | 
|         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)); | 
|         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); | 
|             } | 
|             System.out.println(jsonArray); | 
|             return rmCommandHistoryMapper.getUncloseParam(jsonArray.toJSONString(), intakeId); | 
|         } else { | 
|             QueryResultVo<List<VoOnLineIntake>> rsVo = new QueryResultVo<>(); | 
|             VoUnclosedParam voUnclosedParam = new VoUnclosedParam(); | 
|             return voUnclosedParam; | 
|         } | 
|   | 
|     } | 
|   | 
|     /** | 
|      * 根据水卡编号获取水卡对象,远程充值使用 | 
|      * @param cardId | 
|      * @return | 
|      */ | 
|     public SeClientCard geClientCardByCardId(Long cardId) { | 
|         return seClientCardMapper.selectByPrimaryKey(cardId); | 
|     } | 
|   | 
|     /** | 
|      * 根据指定条件获取命令日志历史记录 | 
|      * @param query | 
|      * @return | 
|      */ | 
|     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); | 
|         } | 
|   | 
|         Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(query); | 
|   | 
|         Long itemTotal = rmCommandHistoryMapper.getCommandHistoriesCount(params); | 
|   | 
|         QueryResultVo<List<VoCommand>> rsVo = new QueryResultVo<>() ; | 
|         rsVo.pageSize = query.pageSize ; | 
|         rsVo.pageCurr = query.pageCurr ; | 
|   | 
|         rsVo.calculateAndSet(itemTotal, params); | 
|         rsVo.obj = rmCommandHistoryMapper.getCommandHistories(params); | 
|         return rsVo ; | 
|     } | 
| } |