From 1b74e131111650d28b5d67b7e6c1b62db57736ad Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期日, 01 九月 2024 14:52:39 +0800 Subject: [PATCH] 定时任务工单生成优化 --- ycl-server/src/main/java/com/ycl/task/VideoTask.java | 85 ++++++++++++++++++++++++++++++++---------- 1 files changed, 64 insertions(+), 21 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 1d212aa..b8f8a53 100644 --- a/ycl-server/src/main/java/com/ycl/task/VideoTask.java +++ b/ycl-server/src/main/java/com/ycl/task/VideoTask.java @@ -4,36 +4,33 @@ 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.MonitorQualifyResult; -import com.ycl.platform.domain.result.UY.PyOsdResult; -import com.ycl.platform.domain.result.UY.QueryVqdResult; -import com.ycl.platform.domain.result.UY.VideoOnlineResult; +import com.ycl.platform.domain.entity.ImageResourceSecurity; +import com.ycl.platform.domain.entity.ImageResourceSecurityDetail; +import com.ycl.platform.domain.result.UY.*; import com.ycl.platform.domain.vo.PlatformOnlineVO; import com.ycl.platform.domain.vo.TMonitorVO; import com.ycl.platform.mapper.CheckIndexVideoMapper; +import com.ycl.platform.mapper.ImageResourceSecurityDetailMapper; import com.ycl.platform.mapper.PlatformOnlineMapper; import com.ycl.platform.mapper.TMonitorMapper; -import com.ycl.platform.service.PlatformOnlineService; -import com.ycl.system.mapper.SysDeptMapper; +import com.ycl.platform.service.IImageResourceSecurityService; import com.ycl.utils.DateUtils; -import constant.ApiConstants; +import com.ycl.utils.DictUtils; import constant.CalculationStrategyConstants; -import constant.CheckConstants; -import enumeration.general.AreaDeptEnum; +import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; 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.util.ArrayList; import java.util.Date; -import java.util.HashMap; import java.util.List; -import java.util.Map; +import java.util.Objects; /** * 瑙嗛璁$畻鑰冩牳鎸囨爣浠诲姟 @@ -41,6 +38,7 @@ */ @Slf4j @Component("videoTask") +@RequiredArgsConstructor public class VideoTask { @Autowired private MongoTemplate mongoTemplate; @@ -48,6 +46,11 @@ private PlatformOnlineMapper platformOnlineMapper; @Autowired private TMonitorMapper monitorMapper; + + private final IImageResourceSecurityService imageResourceSecurityService; + private final CheckIndexVideoMapper checkIndexVideoMapper; + private final ImageResourceSecurityDetailMapper imageResourceSecurityDetailMapper; + private static final BigDecimal NUM = new BigDecimal("0.15"); public void siteOnlineTask() { Date yesterday = DateUtils.addDays(new Date(), -1); @@ -68,7 +71,7 @@ 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); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_Usability); calculator.calculate(results); } @@ -76,17 +79,15 @@ public void oneMonitorFileTask() { //璁$畻涓�鏈轰竴妗f敞鍐岀巼銆佹。妗堣�冩牳姣� List<TMonitorVO> tMonitorVOS = monitorMapper.selectMonitorVOList(); - CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_Usability); + CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_MonitorRegis_ArchiveRate); calculator.calculate(tMonitorVOS); } - //TODO:鏃堕棿鍐欐浜� public void oneMonitorQualifyTask(){ //璁$畻涓�鏈轰竴妗e悎鏍肩巼 -// Date yesterday = DateUtils.addDays(new Date(), -1); - Date date = DateUtils.getDay(2024,7,13); + Date yesterday = DateUtils.addDays(new Date(), -1); Query query = new Query(); query.addCriteria(Criteria - .where("mongoCreateTime").gte(DateUtils.getDayStart(date)).lt(DateUtils.getDayEnd(date))); + .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); @@ -103,9 +104,51 @@ Query query = new Query(); query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); - List<PyOsdResult> results = mongoTemplate.find(query, PyOsdResult.class); + List<OsdCheckResult> results = mongoTemplate.find(query, OsdCheckResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_OsdTime); calculator.calculate(results); } + /** + * 瑙嗛鍥惧儚璧勬簮瀹夊叏锛岄渶瑕佹帓鍦ㄥ钩鍙板湪绾跨巼鍚庨潰銆� + */ + @Transactional + 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)); + // 鑾峰彇瀛楀吀鍊�-鎬绘暟 + int onlineAssetsTotal = Integer.parseInt(DictUtils.getDictValue("online_assets_total", checkIndexVideo.getDeptName())); + imageResourceSecurity.setRiskProperty(BigDecimal.valueOf(count / onlineAssetsTotal)); + imageResourceSecurity.setCreateTime(DateUtils.getNowDate()); + imageResourceSecurities.add(imageResourceSecurity); + // 鏇存柊鎸囨爣鏁版嵁 + checkIndexVideo.setImageResourceSecurity(imageResourceSecurity.getPlatformOnline().add(imageResourceSecurity.getPropertyAccuracy().add(imageResourceSecurity.getWeakPassword().add(imageResourceSecurity.getRiskProperty()))).multiply(NUM)); + checkIndexVideoMapper.updateById(checkIndexVideo); + } + imageResourceSecurityService.saveBatch(imageResourceSecurities); + + } } -- Gitblit v1.8.0