潘志宝
2024-11-14 afa8fc57084c423218c6816b710dfb2f0b87ea89
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
package com.iailab.module.data.job.task;
 
import com.iailab.framework.tenant.core.context.TenantContextHolder;
import com.iailab.module.data.video.controller.admin.camera.vo.CameraPageReqVO;
import com.iailab.module.data.video.dahua.DHCapturePictureClient;
import com.iailab.module.data.video.dahua.DHClientFactory;
import com.iailab.module.data.video.dto.CameraDTO;
import com.iailab.module.data.video.enums.CaptureTypeEnum;
import com.iailab.module.data.video.service.CameraService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.util.CollectionUtils;
 
import javax.annotation.Resource;
import java.time.LocalDateTime;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
 
/**
 * 大华摄像头截图定时任务
 *
 * @author Houzhongjian
 * @Description
 * @createTime 2024年10月30日
 */
@Component("devCameraDahuaTask")
public class DevCameraDahuaTask implements ITask {
    private Logger logger = LoggerFactory.getLogger(getClass());
 
    @Resource
    private CameraService cameraService;
 
    @Autowired
    private DHClientFactory dhClientFactory;
 
    @Override
    public void run(String params) {
        logger.info("devCameraDahuaTask定时任务正在执行,参数为:{}", params);
        //传递租户id
        System.out.println(TenantContextHolder.getTenantId());
        String tenantId = String.valueOf(TenantContextHolder.getTenantId());
        try {
            CameraPageReqVO cameraPageReqVO = new CameraPageReqVO();
            cameraPageReqVO.setType("2");
            List<CameraDTO> list = cameraService.list(cameraPageReqVO);
            if (CollectionUtils.isEmpty(list)) {
                logger.info("Alarm List 为空");
                return;
            }
            Map<String, List<CameraDTO>> alarmGroup = list.stream().collect(Collectors.groupingBy(CameraDTO::getNvrId));
            for  (Map.Entry<String, List<CameraDTO>> nvr : alarmGroup.entrySet()) {
                DHCapturePictureClient client = dhClientFactory.getClient(nvr.getKey());
                try {
                    if(!client.isLogin()) {
                        dhClientFactory.reLogin(client, nvr.getKey());
                    }
                    if(!client.isLogin()) {
                        continue;
                    }
                    List<CameraDTO> cameraList = nvr.getValue();
                    for (int i = 0; i < cameraList.size(); i++) {
                        CameraDTO camera = cameraList.get(i);
                        boolean captureResult = false;
                        if (CaptureTypeEnum.LOCAL.getCode().equals(camera.getCaptureType())) {
                            captureResult = client.localCapturePicture(camera.getChannel(), camera.getCode());
                        } else {
                            captureResult = client.remoteCapturePicture(camera.getChannel(), camera.getCode());
                        }
                        logger.info(camera.getCode() + ":captureResult = " + captureResult);
                        Thread.sleep(100);
                    }
                } catch (Exception ex) {
                    logger.info("item:" + ex.getMessage());
                }
            }
            logger.info("devCameraDahuaTask定时任务执行完成:" + LocalDateTime.now());
 
        } catch (Exception ex) {
            ex.printStackTrace();
            logger.info("devCameraDahuaTask定时任务失败时间:" + LocalDateTime.now());
        }
    }
}