From 1625ef57d08599faf27ddd1c894ad55161cf8fe8 Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期五, 09 八月 2024 09:27:02 +0800
Subject: [PATCH] 视频在线率打通

---
 ycl-server/src/main/java/com/ycl/task/VideoTask.java |   85 ++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 84 insertions(+), 1 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 0746c25..827d57a 100644
--- a/ycl-server/src/main/java/com/ycl/task/VideoTask.java
+++ b/ycl-server/src/main/java/com/ycl/task/VideoTask.java
@@ -1,18 +1,101 @@
 package com.ycl.task;
 
 
+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.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.utils.DateUtils;
+import constant.ApiConstants;
+import constant.CalculationStrategyConstants;
+import constant.CheckConstants;
+import enumeration.general.AreaDeptEnum;
 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 java.util.Date;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
 
 /**
  * 瑙嗛璁$畻鑰冩牳鎸囨爣浠诲姟
  * 鍑屾櫒鎵ц璁$畻鏄ㄥぉ鏁版嵁
- * */
+ */
 @Slf4j
 @Component("videoTask")
 public class VideoTask {
     @Autowired
     private MongoTemplate mongoTemplate;
+    @Autowired
+    private PlatformOnlineMapper platformOnlineMapper;
+    @Autowired
+    private CheckIndexVideoMapper videoMapper;
+    @Autowired
+    private SysDeptMapper deptMapper;
+
+    public void siteOnlineTask() {
+        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);
+        CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_SiteOnline);
+        calculator.calculate(results);
+    }
+
+    public void videoUsabilityTask() {
+        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);
+        CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_Usability);
+        calculator.calculate(results);
+    }
+
+    public void oneMonitorFileTask() {
+        //璁$畻涓�鏈轰竴妗f敞鍐岀巼銆佷竴鏈轰竴妗e悎鏍肩巼銆佹。妗堣�冩牳姣�
+    }
+
+    public void platformOnlineTask() {
+        //璁$畻骞冲彴鍦ㄧ嚎鐜�
+        //鎷垮埌浠婃棩绂荤嚎鏃堕暱鏁版嵁
+        List<PlatformOnlineVO> list = platformOnlineMapper.sumYesterday(DateUtils.getMouthStart(new Date()), DateUtils.getMouthEnd(new Date()));
+
+//        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) -> {
+//
+//        });
+
+
+    }
 }

--
Gitblit v1.8.0