| package com.dy.pipIrrStatistics.largeScreen; | 
|   | 
| import com.alibaba.fastjson2.JSON; | 
| import com.alibaba.fastjson2.JSONObject; | 
| import com.dy.common.mw.protocol.Command; | 
| import com.dy.common.mw.protocol.CommandBackParam; | 
| import com.dy.common.util.DateTime; | 
| import com.dy.common.util.IDLongGenerator; | 
| import com.dy.common.webUtil.BaseResponse; | 
| import com.dy.pipIrrGlobal.daoLargeScreen.Ls4StatisticsMapper; | 
| import com.dy.pipIrrGlobal.rtuMw.CodeLocal; | 
| import com.dy.pipIrrGlobal.rtuMw.Web2RtuMw; | 
| import com.dy.pipIrrGlobal.voLargeScreen.VoBaseInfo; | 
| import com.dy.pipIrrGlobal.voLargeScreen.VoCurrentInfo; | 
| import com.dy.pipIrrGlobal.voLargeScreen.VoMonitorInfo; | 
| import com.dy.pipIrrGlobal.voSpecial.VoTopXClient; | 
| import com.dy.pipIrrGlobal.voSpecial.VoTopXIntake; | 
| import lombok.extern.slf4j.Slf4j; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.core.env.Environment; | 
| import org.springframework.stereotype.Service; | 
| import org.springframework.web.client.RestTemplate; | 
|   | 
| import java.util.Date; | 
| import java.util.List; | 
|   | 
| /** | 
|  * @Author: liurunyu | 
|  * @Date: 2025/2/6 10:33 | 
|  * @Description | 
|  */ | 
| @Slf4j | 
| @Service | 
| public class Ls4StatisticsSv extends Web2RtuMw { | 
|     private Environment env; | 
|     private RestTemplate restTemplate; | 
|     private Ls4StatisticsMapper dao ; | 
|   | 
|     @Autowired | 
|     private void setEnvironment(Environment env){ | 
|         this.env = env; | 
|     } | 
|     @Autowired | 
|     private void setRestTemplate(RestTemplate restTemplate){ | 
|         this.restTemplate = restTemplate; | 
|     } | 
|     @Autowired | 
|     private void setDao(Ls4StatisticsMapper dao){ | 
|         this.dao = dao; | 
|     } | 
|   | 
|     /** | 
|      * 基本信息统计 | 
|      * @return | 
|      */ | 
|     public VoBaseInfo baseInfo(){ | 
|         VoBaseInfo vo = new VoBaseInfo() ; | 
|         vo.totalCountOfTown = this.dao.totalCountOfDistrict(3) ; | 
|         vo.totalCountOfVillage = this.dao.totalCountOfDistrict(4) ; | 
|         vo.totalCountOfBlock = this.dao.totalCountOfBlock() ; | 
|         vo.totalCountOfDivide = this.dao.totalCountOfDivide() ; | 
|         vo.totalCountOfIntake = this.dao.totalCountOfIntake() ; | 
|         vo.totalCountOfIntakeWithController = this.dao.totalCountOfIntakeWithController() ; | 
|         vo.totalCountOfIntakeWithoutController = this.dao.totalCountOfIntakeWithoutController() ; | 
|         vo.totalCountOfController = this.dao.totalCountOfController() ; | 
|         vo.totalCountOfControllerTramp = this.dao.totalCountOfControllerTramp() ; | 
|         return vo ; | 
|     } | 
|   | 
|     /** | 
|      * 当前信息统计 | 
|      * @return | 
|      */ | 
|     public VoCurrentInfo currentInfo() throws Exception{ | 
|         Integer totalCountOfIntake = this.dao.totalCountOfIntake() ; | 
|         Date dtAtXHourBefore = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(DateTime.lastXHour_yyyy_MM_dd_HH_mm_ss(24)) ;//X个小时前 | 
|         VoCurrentInfo vo = new VoCurrentInfo() ; | 
|         Integer[] result = this.queryMwOnAndOffLine() ; | 
|         vo.cTotalCountOfOnLine = result[0] ; | 
|         vo.cTotalCountOfOffLine = totalCountOfIntake - vo.cTotalCountOfOnLine; | 
|         vo.cTotalCountOfOffLine = vo.cTotalCountOfOffLine < 0 ? 0 : vo.cTotalCountOfOffLine ; | 
|   | 
|         vo.cTotalCountOfOpenValve = this.dao.totalCountOfOpenValve(dtAtXHourBefore) ; | 
|         vo.cTotalCountOfCloseValve = this.dao.totalCountOfCloseValve(dtAtXHourBefore) ; | 
|         vo.cTotalCountOfUnknownValve = totalCountOfIntake - vo.cTotalCountOfOpenValve - vo.cTotalCountOfCloseValve; | 
|         vo.cTotalCountOfUnknownValve = vo.cTotalCountOfUnknownValve < 0 ? 0 : vo.cTotalCountOfUnknownValve ; | 
|   | 
|         vo.cTotalCountOfAlarm = this.dao.totalCountOfAlarm(dtAtXHourBefore) ; | 
|         vo.cTotalCountOfNoAlarm = this.dao.totalCountOfNoAlarm(dtAtXHourBefore) ; | 
|         vo.cTotalCountOfUnknownAlarm = totalCountOfIntake - vo.cTotalCountOfAlarm - vo.cTotalCountOfNoAlarm; | 
|         vo.cTotalCountOfUnknownAlarm = vo.cTotalCountOfUnknownAlarm < 0 ? 0 : vo.cTotalCountOfUnknownAlarm ; | 
|         return vo ; | 
|     } | 
|   | 
|     /** | 
|      * 监测信息统计 | 
|      * @return | 
|      */ | 
|     public VoMonitorInfo monitorInfo(Date fromDt){ | 
|         VoMonitorInfo vo = new VoMonitorInfo() ; | 
|         vo.mTotalCountOfReport = this.dao.mTotalCountOfReport(fromDt) ; | 
|         vo.mTotalCountOfNoReport = this.dao.mTotalCountOfNoReport(fromDt) ; | 
|         vo.mTotalCountOfNeverReport = this.dao.mTotalCountOfNeverReport() ; | 
|   | 
|         vo.mTotalCountOfOpenValve = this.dao.mTotalCountOfOpenValve(fromDt) ; | 
|         vo.mTotalCountOfCloseValve = this.dao.mTotalCountOfCloseValve(fromDt) ; | 
|         vo.mTotalCountOfNeverOpenValve = this.dao.mTotalCountOfNeverOpenValve() ; | 
|   | 
|         vo.mTotalCountOfAlarm = this.dao.mTotalCountOfAlarm(fromDt) ; | 
|         vo.mTotalCountOfNoAlarm = this.dao.mTotalCountOfNoAlarm(fromDt) ; | 
|         vo.mTotalCountOfNeverAlarm = this.dao.mTotalCountOfNeverAlarm() ; | 
|   | 
|         return vo ; | 
|     } | 
|   | 
|     /** | 
|      * 查询取水口在线和离线统计 | 
|      * @return | 
|      */ | 
|     private Integer[] queryMwOnAndOffLine() { | 
|         Integer[] result = new Integer[]{0,0} ; | 
|         //向通信中间件发关命令,查询RTU在线统计情况 | 
|         Command com = this.createInnerCommand(CodeLocal.onLineStatistics); | 
|         String rqUrl = this.get2MwRequestUrl(this.env, ContextComSend) ; | 
|         BaseResponse res = this.sendPostRequest2Mw(restTemplate, rqUrl, com) ; | 
|         if(res != null){ | 
|             if(res.isSuccess()){ | 
|                 Command reCom = JSON.parseObject(res.getContent() == null ? null : JSON.toJSONString(res.getContent()), Command.class) ; | 
|                 CommandBackParam bakParam = JSON.parseObject((reCom== null || reCom.param == null) ? null : JSON.toJSONString(reCom.param), CommandBackParam.class) ; | 
|                 if(bakParam != null){ | 
|                     if(bakParam.getSuccess().booleanValue() && reCom.getAttachment() != null){ | 
|                         //通信中间件成功返回命令结果 | 
|                         JSONObject comRes = (JSONObject) JSON.toJSON(reCom.getAttachment()); | 
|                         result[0] = comRes.getInteger("onLineNum") ; | 
|                         result[1] = comRes.getInteger("offLineNum") ; | 
|                     } | 
|                 }else{ | 
|                     log.error("通信中间件返回内部命令结果中不包含CommandBackParam类型参数"); | 
|                 } | 
|             }else{ | 
|                 log.error("通信中间件返回内部命令执行失败" + (res.getMsg() == null? "" : ("," + res.getMsg()))) ; | 
|             } | 
|         }else{ | 
|             log.error("通信中间件返回内部命令结果为null"); | 
|         } | 
|         return result ; | 
|     } | 
|   | 
|   | 
|   | 
|     /** | 
|      * 昨日农户用水前5名统计 | 
|      * @return 数据集合 | 
|      */ | 
|     public List<VoTopXClient> top5ClientYesterday() { | 
|         int[] yesterday = DateTime.yyyy_MM_dd_2_ymdGroup(DateTime.lastXDay_yyyy_MM_dd(1)) ; | 
|         Long idStart = IDLongGenerator.generateOneDayStartId(yesterday[0], yesterday[1], yesterday[2]) ; | 
|         Long idEnd = IDLongGenerator.generateOneDayEndId(yesterday[0], yesterday[1], yesterday[2]) ; | 
|         return this.dao.topXClientAtCertainDay(idStart, idEnd, 5) ; | 
|     } | 
|   | 
|     /** | 
|      * 昨日取水口用水前5名统计 | 
|      * @return 数据集合 | 
|      */ | 
|     public List<VoTopXIntake> top5IntakeYesterday() { | 
|         int[] yesterday = DateTime.yyyy_MM_dd_2_ymdGroup(DateTime.lastXDay_yyyy_MM_dd(1)) ; | 
|         Long idStart = IDLongGenerator.generateOneDayStartId(yesterday[0], yesterday[1], yesterday[2]) ; | 
|         Long idEnd = IDLongGenerator.generateOneDayEndId(yesterday[0], yesterday[1], yesterday[2]) ; | 
|         return this.dao.topXIntakeAtCertainDay(idStart, idEnd, 5) ; | 
|     } | 
|   | 
| } |