From 002372c5cfd2c9b9881fda5e527c2b6c4ee4d599 Mon Sep 17 00:00:00 2001 From: zxl <763096477@qq.com> Date: 星期三, 19 二月 2025 09:26:40 +0800 Subject: [PATCH] 代码注释,运维监控报表接口统计sql重新编写 --- ycl-server/src/main/java/com/ycl/task/VideoTask.java | 173 +++++++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 135 insertions(+), 38 deletions(-) diff --git a/ycl-server/src/main/java/com/ycl/task/VideoTask.java b/ycl-server/src/main/java/com/ycl/task/VideoTask.java index 827d57a..615ddfa 100644 --- a/ycl-server/src/main/java/com/ycl/task/VideoTask.java +++ b/ycl-server/src/main/java/com/ycl/task/VideoTask.java @@ -4,31 +4,37 @@ import com.ycl.calculate.CalculationStrategy; import com.ycl.factory.IndexCalculationFactory; import com.ycl.platform.domain.entity.CheckIndexVideo; -import com.ycl.platform.domain.param.UY.RecordMetaDSumParam; -import com.ycl.platform.domain.result.HK.SnapshotDataMonitorResult; -import com.ycl.platform.domain.result.UY.QueryVqdResult; +import com.ycl.platform.domain.entity.ImageResourceSecurity; +import com.ycl.platform.domain.entity.ImageResourceSecurityDetail; +import com.ycl.platform.domain.form.VideoExportForm; +import com.ycl.platform.domain.result.SYS.TMonitorResult; +import com.ycl.platform.domain.result.UY.*; import com.ycl.platform.domain.vo.PlatformOnlineVO; -import com.ycl.platform.mapper.CheckIndexVideoMapper; -import com.ycl.platform.mapper.PlatformOnlineMapper; -import com.ycl.platform.service.PlatformOnlineService; -import com.ycl.system.mapper.SysDeptMapper; +import com.ycl.platform.domain.vo.TMonitorVO; +import com.ycl.platform.mapper.*; +import com.ycl.platform.service.IImageResourceSecurityService; import com.ycl.utils.DateUtils; +import com.ycl.utils.DictUtils; import constant.ApiConstants; import constant.CalculationStrategyConstants; import constant.CheckConstants; -import enumeration.general.AreaDeptEnum; +import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; +import org.apache.commons.collections4.CollectionUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.query.Criteria; import org.springframework.data.mongodb.core.query.Query; import org.springframework.stereotype.Component; -import org.springframework.util.CollectionUtils; +import org.springframework.transaction.annotation.Transactional; +import java.math.BigDecimal; +import java.math.RoundingMode; +import java.util.ArrayList; import java.util.Date; -import java.util.HashMap; import java.util.List; -import java.util.Map; +import java.util.Objects; +import java.util.stream.Collectors; /** * 瑙嗛璁$畻鑰冩牳鎸囨爣浠诲姟 @@ -36,66 +42,157 @@ */ @Slf4j @Component("videoTask") +@RequiredArgsConstructor public class VideoTask { @Autowired private MongoTemplate mongoTemplate; @Autowired private PlatformOnlineMapper platformOnlineMapper; @Autowired - private CheckIndexVideoMapper videoMapper; - @Autowired - private SysDeptMapper deptMapper; + private TMonitorMapper monitorMapper; + + private final IImageResourceSecurityService imageResourceSecurityService; + private final CheckIndexVideoMapper checkIndexVideoMapper; + private final ImageResourceSecurityDetailMapper imageResourceSecurityDetailMapper; + private final ImageResourceSecurityMapper imageResourceSecurityMapper; + + private static final BigDecimal NUM = new BigDecimal("0.15"); public void siteOnlineTask() { + log.info("寮�濮嬭绠楃偣浣嶅湪绾跨巼"); Date yesterday = DateUtils.addDays(new Date(), -1); - //璁$畻鐐逛綅鍦ㄧ嚎鐜囧拰閲嶇偣鐐逛綅鍦ㄧ嚎鐜� + //璁$畻鐐逛綅鍦ㄧ嚎鐜囧拰閲嶇偣鐐逛綅鍦ㄧ嚎鐜囧拰鎸囨尌鍥惧儚鍦ㄧ嚎鐜� Query query = new Query(); query.addCriteria(Criteria - .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); - - List<QueryVqdResult> results = mongoTemplate.find(query, QueryVqdResult.class); + .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday)));//<&== 鏄ㄥぉ鐨勫紑濮嬫椂闂� < 缁撴潫鏃堕棿 + List<VideoOnlineResult> results = mongoTemplate.find(query, VideoOnlineResult.class);// + //浼樹簯涓婃湁杞﹁締鍜屼汉鑴哥殑璁惧鏁版嵁锛岄渶瑕佽繃婊ゅ嚭瑙嗛璁惧 + List<String> videoIds = monitorMapper.getVideoIds(); + if(!CollectionUtils.isEmpty(results)){ + results = results.stream().filter(result -> videoIds.contains(result.getNo())).collect(Collectors.toList()); + } CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_SiteOnline); calculator.calculate(results); + log.info("缁撴潫璁$畻鐐逛綅鍦ㄧ嚎鐜�"); } public void videoUsabilityTask() { + log.info("寮�濮嬭绠楀綍鍍忓彲鐢ㄧ巼鍜岄噸鐐瑰綍鍍忓彲鐢ㄧ巼"); Date yesterday = DateUtils.addDays(new Date(), -1); //璁$畻褰曞儚鍙敤鐜囧拰閲嶇偣褰曞儚鍙敤鐜� Query query = new Query(); query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); - List<RecordMetaDSumParam> results = mongoTemplate.find(query, RecordMetaDSumParam.class); + List<RecordMetaDSumResult> results = mongoTemplate.find(query, RecordMetaDSumResult.class); + //浼樹簯涓婃湁杞﹁締鍜屼汉鑴哥殑璁惧鏁版嵁锛岄渶瑕佽繃婊ゅ嚭瑙嗛璁惧 + List<String> videoIds = monitorMapper.getVideoIds(); + if(!CollectionUtils.isEmpty(results)){ + results = results.stream().filter(result -> videoIds.contains(result.getNo())).collect(Collectors.toList()); + } CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_Usability); calculator.calculate(results); + log.info("缁撴潫璁$畻褰曞儚鍙敤鐜囧拰閲嶇偣褰曞儚鍙敤鐜�"); } public void oneMonitorFileTask() { - //璁$畻涓�鏈轰竴妗f敞鍐岀巼銆佷竴鏈轰竴妗e悎鏍肩巼銆佹。妗堣�冩牳姣� + log.info("寮�濮嬭绠椾竴鏈轰竴妗f敞鍐岀巼銆佹。妗堣�冩牳姣�"); + //璁$畻涓�鏈轰竴妗f敞鍐岀巼銆佹。妗堣�冩牳姣� + Date yesterday = DateUtils.addDays(new Date(), -1); + Query query = new Query(); + query.addCriteria(Criteria + .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); + List<MonitorQualifyResult> results = mongoTemplate.find(query, MonitorQualifyResult.class); + CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_MonitorRegis_ArchiveRate); + calculator.calculate(results); + log.info("缁撴潫璁$畻涓�鏈轰竴妗f敞鍐岀巼銆佹。妗堣�冩牳姣�"); + } + + public void oneMonitorQualifyTask() { + log.info("寮�濮嬭绠椾竴鏈轰竴妗e悎鏍肩巼"); + //璁$畻涓�鏈轰竴妗e悎鏍肩巼 + Date yesterday = DateUtils.addDays(new Date(), -1); + Query query = new Query(); + query.addCriteria(Criteria + .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); + List<MonitorQualifyResult> results = mongoTemplate.find(query, MonitorQualifyResult.class); + CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_MonitorQualify); + calculator.calculate(results); + log.info("缁撴潫璁$畻涓�鏈轰竴妗e悎鏍肩巼"); } public void platformOnlineTask() { + log.info("寮�濮嬭绠楀钩鍙板湪绾跨巼"); //璁$畻骞冲彴鍦ㄧ嚎鐜� - //鎷垮埌浠婃棩绂荤嚎鏃堕暱鏁版嵁 - List<PlatformOnlineVO> list = platformOnlineMapper.sumYesterday(DateUtils.getMouthStart(new Date()), DateUtils.getMouthEnd(new Date())); + List<PlatformOnlineVO> list = platformOnlineMapper.yesterdayData(DateUtils.getMouthStart(new Date()), DateUtils.getMouthEnd(new Date())); + CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_PlatformOnline); + calculator.calculate(list); + log.info("缁撴潫璁$畻骞冲彴鍦ㄧ嚎鐜�"); + } -// int num = (time / 60) % 30; -// double score = Math.max(1 - num * 0.1, 0); -// List<CheckIndexVideo> checkIndexVideos = videoMapper.selectToday(DateUtils.getDate()); -// List<Long> deptIds = deptMapper.selectByParentId(207L); -// Map<String, CheckIndexVideo> map = new HashMap<>(); -// for (Long deptId : deptIds) { -// CheckIndexVideo video = new CheckIndexVideo(); -// video.setExamineTag(CheckConstants.Examine_Tag_County); -// map.put(deptId + "", video); -// CheckIndexVideo provinceVideo = new CheckIndexVideo(); -// provinceVideo.setExamineTag(CheckConstants.Examine_Tag_Province); -// map.put("Province_" + deptId, new CheckIndexVideo()); -// } -// map.forEach((deptId, video) -> { -// -// }); + public void osdTask() { + log.info("寮�濮嬭绠桹sd鏍囨敞銆佹椂闂村噯纭巼"); + //璁$畻Osd鏍囨敞銆佹椂闂村噯纭巼 + Date yesterday = DateUtils.addDays(new Date(), -1); + Query query = new Query(); + query.addCriteria(Criteria + .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); + List<OsdCheckResult> results = mongoTemplate.find(query, OsdCheckResult.class); + CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_OsdTime); + calculator.calculate(results); + log.info("缁撴潫璁$畻Osd鏍囨敞銆佹椂闂村噯纭巼"); + } + + /** + * 瑙嗛鍥惧儚璧勬簮瀹夊叏锛岄渶瑕佹帓鍦ㄥ钩鍙板湪绾跨巼鍚庨潰銆� + */ + @Transactional(rollbackFor = Exception.class) + public void videoSecurity() { + ArrayList<ImageResourceSecurity> imageResourceSecurities = new ArrayList<>(); + List<CheckIndexVideo> list = checkIndexVideoMapper.selectAndDeptName(); + List<ImageResourceSecurityDetail> detail = imageResourceSecurityDetailMapper.getList(); + + // 姣忎釜閮ㄩ棬寰幆涓�娆¤绠楁暟鎹� + for (CheckIndexVideo checkIndexVideo : list) { + ImageResourceSecurity imageResourceSecurity = new ImageResourceSecurity(); + imageResourceSecurity.setDeptId(checkIndexVideo.getDeptId()); + // 鐩存帴鍙栨寚鏍� + imageResourceSecurity.setPlatformOnline(checkIndexVideo.getPlatformOnline()); + imageResourceSecurity.setPropertyAccuracy(checkIndexVideo.getMonitorQualification()); + // 鑾峰彇褰撳墠閮ㄩ棬鐨刣etail杩涜璁$畻 + List<ImageResourceSecurityDetail> detailList = detail.stream().filter(imageResourceSecurityDetail -> Objects.equals(imageResourceSecurityDetail.getDeptId(), checkIndexVideo.getDeptId())).toList(); + int score = 100; + int count = 0; + // 寰幆detail璁$畻 + for (ImageResourceSecurityDetail imageResourceSecurityDetail : detailList) { + // 鎵i櫎鍒嗘暟 + score -= imageResourceSecurityDetail.getAlarmCategory().getScore(); + // 缁熻鏁伴噺 + if (Integer.parseInt(imageResourceSecurityDetail.getAlarmLevel().getValue()) > 1) { + count++; + } + } + imageResourceSecurity.setWeakPassword(BigDecimal.valueOf(score).divide(new BigDecimal(100), 4, RoundingMode.HALF_UP)); + // 鑾峰彇瀛楀吀鍊�-鎬绘暟 + int onlineAssetsTotal = Integer.parseInt(DictUtils.getDictValue("online_assets_total", checkIndexVideo.getDeptName())); + imageResourceSecurity.setRiskProperty(BigDecimal.valueOf(count / onlineAssetsTotal)); + imageResourceSecurity.setCreateTime(DateUtils.getNowDate()); + imageResourceSecurities.add(imageResourceSecurity); + //鑾峰彇鏈�杩戜竴娆℃暟鎹墜鍔ㄦ墦鍒� + ImageResourceSecurity latest = imageResourceSecurityMapper.getLatest(checkIndexVideo.getDeptId(),new Date()); + imageResourceSecurity.setBoundaryIntegrity(latest ==null?BigDecimal.ONE:latest.getBoundaryIntegrity()); + // 鏇存柊鎸囨爣鏁版嵁 + checkIndexVideo.setImageResourceSecurity( + imageResourceSecurity.getPlatformOnline() + .add(imageResourceSecurity.getPropertyAccuracy() + .add(imageResourceSecurity.getWeakPassword() + .add(imageResourceSecurity.getRiskProperty()))).multiply(NUM) + .add(imageResourceSecurity.getBoundaryIntegrity()).multiply(new BigDecimal("0.45")) + ); + checkIndexVideoMapper.updateById(checkIndexVideo); + } + imageResourceSecurityService.saveBatch(imageResourceSecurities); } } -- Gitblit v1.8.0