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) ;
|
}
|
|
}
|