From 3b0516a2959e25576e4f3fda697a3b025d06c8c9 Mon Sep 17 00:00:00 2001 From: zxl <763096477@qq.com> Date: 星期二, 24 六月 2025 14:09:07 +0800 Subject: [PATCH] 每日录像可用指标添加日志,修改大屏为查看当前月平均 --- ycl-server/src/main/java/com/ycl/task/MonitorTask.java | 156 ++++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 114 insertions(+), 42 deletions(-) diff --git a/ycl-server/src/main/java/com/ycl/task/MonitorTask.java b/ycl-server/src/main/java/com/ycl/task/MonitorTask.java index bc08a68..c1a3fe2 100644 --- a/ycl-server/src/main/java/com/ycl/task/MonitorTask.java +++ b/ycl-server/src/main/java/com/ycl/task/MonitorTask.java @@ -4,10 +4,14 @@ import com.alibaba.druid.support.json.JSONUtils; import com.alibaba.fastjson2.JSONArray; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.mongodb.client.result.DeleteResult; import com.ycl.platform.domain.entity.TMonitor; import com.ycl.platform.domain.entity.YwPoint; +import com.ycl.platform.domain.result.HK.VehicleDeviceInspectionResult; +import com.ycl.platform.domain.result.SYS.TMonitorResult; import com.ycl.platform.domain.result.UY.MonitorQualifyResult; import com.ycl.platform.domain.result.UY.OneMachineFileResult; +import com.ycl.platform.domain.result.UY.OsdCheckResult; import com.ycl.platform.domain.vo.TMonitorVO; import com.ycl.platform.mapper.TMonitorMapper; import com.ycl.platform.mapper.YwPointMapper; @@ -17,11 +21,15 @@ import com.ycl.system.service.ISysDictDataService; import com.ycl.utils.DateUtils; import com.ycl.utils.StringUtils; +import constant.ApiConstants; +import constant.CheckConstants; import constant.RedisConstant; import enumeration.general.AreaDeptEnum; import enumeration.general.PointStatus; import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.query.Criteria; import org.springframework.data.mongodb.core.query.Query; @@ -54,70 +62,128 @@ private YwPointMapper ywPointMapper; @Autowired private RedisTemplate redisTemplate; + @Value("${DH.userName}") + public String userName; + @Value("${DH.password}") + public String password; + //鍚屾鐐逛綅鍦ㄧ嚎鐜囧埌mongo(寮冪敤) +// public void siteOnline() { +// log.info("寮�濮嬪悓姝ョ偣浣嶅湪绾跨巼鍒癿ongo"); +// List<TMonitorResult> tMonitorResults = monitorMapper.selectMonitorResult(null); +// if (!CollectionUtils.isEmpty(tMonitorResults)) { +// //濡傛灉瀛樺湪涔嬪墠鐨勬暟鎹厛鍒犻櫎 +// Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(new Date())).lt(DateUtils.getDayEnd(new Date()))); +// DeleteResult result = mongoTemplate.remove(query, TMonitorResult.class); +// //瀛樻斁鍦╩ongo涓� +// mongoTemplate.insertAll(tMonitorResults); +// log.info("缁撴潫鍚屾鐐逛綅鍦ㄧ嚎鐜囧埌mongo"); +// } +// } //鍚屾mongodb涓�鏈轰竴妗e埌鏁版嵁搴� @Transactional(rollbackFor = Exception.class) public void synchronize() { - Date date = DateUtils.getDay(2024,7,13); - Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(date)).lt(DateUtils.getDayEnd(date))); -// Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(new Date())).lt(DateUtils.getDayEnd(new Date()))); + log.info("寮�濮嬪悓姝ongodb涓�鏈轰竴妗e埌鏁版嵁搴�"); +// Date yesterday = DateUtils.addDays(new Date(), -1); + Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(new Date())).lt(DateUtils.getDayEnd(new Date()))); List<MonitorQualifyResult> oneMachineFileResults = mongoTemplate.find(query, MonitorQualifyResult.class); - //鏁版嵁搴搈onitor琛ㄦ暟鎹� - Map<String, TMonitorVO> monitorVOMap = monitorMapper.selectMonitorVOList().stream().collect(Collectors.toMap(TMonitorVO::getSerialNumber, Function.identity())); - //鍑嗗鎻掑叆璁惧琛ㄧ殑鏁版嵁 - List<TMonitor> monitorList = new ArrayList<>(); - //鍑嗗鎻掑叆鐐逛綅琛ㄧ殑鏁版嵁 - List<YwPoint> ywPointList = new ArrayList<>(); - //鏂扮殑鏁版嵁锛屽師鏁版嵁搴撲腑涓嶅瓨鍦ㄧ殑鏁版嵁 - Set<TMonitor> newMonitorList = new HashSet<>(); - //鐐逛綅鏁版嵁 - Map<String, YwPoint> pointMap = ywPointService.list(new QueryWrapper<YwPoint>()).stream().collect(Collectors.toMap(YwPoint::getSerialNumber, Function.identity())); - //閲嶇偣鐐逛綅闆嗗悎瀛楀吀(瑙f瀽SXJCJQY瀛楁) - SysDictData sysDictData = new SysDictData(); - sysDictData.setDictType("platform_important_site"); - List<SysDictData> DictDataList = dictDataService.selectDictDataList(sysDictData); - //閲囬泦鍖哄煙涓洪噸鐐圭偣浣嶇殑闆嗗悎 - List<String> importantSite = DictDataList.stream().map(SysDictData::getDictValue).collect(Collectors.toList()); + if(!CollectionUtils.isEmpty(oneMachineFileResults)) { + //mongo鍝佺墝鏁版嵁 + Query OSDQuery = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(new Date())).lt(DateUtils.getDayEnd(new Date()))); + Map<String, OsdCheckResult> osdMap = mongoTemplate.find(query, OsdCheckResult.class).stream().collect(Collectors.toMap(OsdCheckResult::getDeviceNo, Function.identity())); + //鏁版嵁搴搈onitor琛ㄦ暟鎹� + Map<String, TMonitorVO> monitorVOMap = monitorMapper.selectMonitorVOList().stream().collect(Collectors.toMap(TMonitorVO::getSerialNumber, Function.identity())); + //鐐逛綅鏁版嵁 + Map<String, YwPoint> pointMap = ywPointService.list(new QueryWrapper<YwPoint>()).stream().collect(Collectors.toMap(YwPoint::getSerialNumber, Function.identity())); - //鍏ㄥ勾鐣欏瓨 - for (MonitorQualifyResult result : oneMachineFileResults) { - TMonitor monitor = getMonitor(result, monitorVOMap); - YwPoint point = getPoint(result, pointMap, importantSite); - monitorList.add(monitor); - ywPointList.add(point); - //姣斿绛涢�夊嚭鏂扮殑鏁版嵁 - if (!CollectionUtils.isEmpty(monitorVOMap) && !monitorVOMap.containsKey(result.getSerialNumber().getValue())) { - newMonitorList.add(monitor); + //閲嶇偣鐐逛綅闆嗗悎瀛楀吀(瑙f瀽SXJCJQY瀛楁) + SysDictData sysDictData = new SysDictData(); + sysDictData.setDictType("platform_important_site"); + List<SysDictData> DictDataList = dictDataService.selectDictDataList(sysDictData); + //閲囬泦鍖哄煙涓洪噸鐐圭偣浣嶇殑闆嗗悎 + List<String> importantSite = DictDataList.stream().map(SysDictData::getDictValue).collect(Collectors.toList()); + + //鍑嗗鎻掑叆璁惧琛ㄧ殑鏁版嵁 + List<TMonitor> monitorList = new ArrayList<>(); + //鍑嗗鎻掑叆鐐逛綅琛ㄧ殑鏁版嵁 + List<YwPoint> ywPointList = new ArrayList<>(); + + //鍏ㄥ勾鐣欏瓨 + for (MonitorQualifyResult result : oneMachineFileResults) { + TMonitor monitor = getMonitor(result, monitorVOMap, osdMap); + YwPoint point = getPoint(result, pointMap, importantSite); + monitorList.add(monitor); + ywPointList.add(point); } + + //娣诲姞鑰佹暟鎹� + List<String> numbers = CollectionUtils.isEmpty(monitorList) ? new ArrayList<>() : monitorList.stream().map(TMonitor::getSerialNumber).collect(Collectors.toList()); + monitorVOMap.forEach((key, value) -> { + if (!numbers.contains(key)) { + TMonitor monitor = new TMonitor(); + BeanUtils.copyProperties(value, monitor); + //濉ˉ鍝佺墝 + OsdCheckResult osdCheckResult = osdMap.get(key); + if (osdCheckResult != null) { + monitor.setDeviceType(osdCheckResult.getDeviceBrand()); + } + monitorList.add(monitor); + } + }); + //杞崲 + List<String> points = CollectionUtils.isEmpty(ywPointList) ? new ArrayList<>() : ywPointList.stream().map(YwPoint::getSerialNumber).collect(Collectors.toList()); + //pointMap鐐逛綅鏃ф暟鎹� 璁惧鐮乵ap + pointMap.forEach((key, value) -> { + //鑰佽澶囩姸鎬佹敼涓轰笉鍙備笌鑰冩牳 + if (!points.contains(key)) { + value.setExamineStatus(Boolean.FALSE); + //鍗曚綅璁剧疆涓虹┖ + value.setUnitId(null); + ywPointList.add(value); + } + }); + + log.info("result闆嗗悎{},璁惧闆嗗悎{},鐐逛綅闆嗗悎{}", oneMachineFileResults.size(), monitorList.size(), ywPointList.size()); + //鎻掑叆鏁版嵁搴� + if (!CollectionUtils.isEmpty(monitorList)) { + monitorMapper.deleteAll(); + monitorService.saveBatch(monitorList); + } + if (!CollectionUtils.isEmpty(ywPointList)) { + ywPointMapper.deleteAll(); + ywPointService.saveBatch(ywPointList); + } + //鏂扮殑鏁版嵁鏀惧叆Redis涓瓑寰呰�冩牳鎸囨爣浠诲姟浣跨敤(寮冪敤锛屾敼涓烘爣绛惧舰寮�) +// redisTemplate.opsForValue().set(RedisConstant.New_Monitor_Set, JSONArray.toJSONString(newMonitorList)); } - log.info("result闆嗗悎{},璁惧闆嗗悎{},鐐逛綅闆嗗悎{}", oneMachineFileResults.size(), monitorList.size(), ywPointList.size()); - //鎻掑叆鏁版嵁搴� - if (!CollectionUtils.isEmpty(monitorList)) { - monitorMapper.deleteAll(); - monitorService.saveBatch(monitorList); - } - if (!CollectionUtils.isEmpty(ywPointList)) { - ywPointMapper.deleteAll(); - ywPointService.saveBatch(ywPointList); - } - //鏂扮殑鏁版嵁鏀惧叆Redis涓瓑寰呰�冩牳鎸囨爣浠诲姟浣跨敤 - redisTemplate.opsForValue().set(RedisConstant.New_Monitor_Set, JSONArray.toJSONString(newMonitorList)); + log.info("缁撴潫鍚屾mongodb涓�鏈轰竴妗e埌鏁版嵁搴�"); } private YwPoint getPoint(MonitorQualifyResult result, Map<String, YwPoint> pointMap, List<String> importantSite) { YwPoint ywPoint = new YwPoint(); if (pointMap.containsKey(result.getSerialNumber().getValue())) { ywPoint = pointMap.get(result.getSerialNumber().getValue()); + //鏇存柊瀹氫綅鍚� + if (ywPoint != null) { + ywPoint.setPointName(result.getName().getValue()); + } } else { ywPoint.setPointName(result.getName().getValue()); ywPoint.setStatus(PointStatus.WAIT.getDesc()); ywPoint.setSerialNumber(result.getSerialNumber().getValue()); ywPoint.setImportantTag(Boolean.FALSE); - ywPoint.setProvinceTag(Boolean.FALSE); + ywPoint.setProvinceTagVideo(Boolean.FALSE); + ywPoint.setProvinceTagCar(Boolean.FALSE); + ywPoint.setProvinceTagFace(Boolean.FALSE); ywPoint.setImportantCommandImageTag(Boolean.FALSE); ywPoint.setCreateTime(new Date()); ywPoint.setUpdateTime(new Date()); + ywPoint.setOnline(ApiConstants.UY_OnlineSite_Unknown); + ywPoint.setUsername(userName); + ywPoint.setPassword(password); } + //鐘舵�佽缃负鑰冩牳璁惧 + ywPoint.setExamineStatus(Boolean.TRUE); //姣斿鏄惁鏄噸鐐圭偣浣� if (importantSite.contains(result.getSxjcjqy().getValue())) { ywPoint.setImportantTag(Boolean.TRUE); @@ -138,11 +204,17 @@ return ywPoint; } - private TMonitor getMonitor(MonitorQualifyResult result, Map<String, TMonitorVO> monitorVOMap) { + private TMonitor getMonitor(MonitorQualifyResult result, Map<String, TMonitorVO> monitorVOMap, Map<String, OsdCheckResult> osdMap) { TMonitor monitor = new TMonitor(); if (monitorVOMap.containsKey(result.getSerialNumber().getValue())) { monitor.setId(monitorVOMap.get(result.getSerialNumber().getValue()).getId()); + //鏇存柊鍝佺墝 + OsdCheckResult osdCheckResult = osdMap.get(result.getSerialNumber().getValue()); + if (osdCheckResult != null) { + monitor.setDeviceType(osdCheckResult.getDeviceBrand()); + } } + monitor.setSerialNumber(result.getSerialNumber().getValue()); monitor.setName(result.getName().getValue()); String siteType = result.getJkdwlx().getValue(); -- Gitblit v1.8.0