songww
2020-05-13 ca5139929b8b5853229ca3d63e2bca1ce82fa0ab
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
package com.genersoft.iot.vmp.gb28181.event.offline;
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationListener;
import org.springframework.stereotype.Component;
 
import com.genersoft.iot.vmp.common.VideoManagerConstants;
import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
import com.genersoft.iot.vmp.utils.redis.RedisUtil;
 
/**
 * @Description: 离线事件监听器,监听到离线后,修改设备离在线状态。 设备离线有两个来源:
 *               1、设备主动注销,发送注销指令,{@link com.genersoft.iot.vmp.gb28181.transmit.request.impl.RegisterRequestProcessor}
 *               2、设备未知原因离线,心跳超时,{@link com.genersoft.iot.vmp.gb28181.event.offline.OfflineEventListener}
 * @author: songww
 * @date: 2020年5月6日 下午1:51:23
 */
@Component
public class OfflineEventListener implements ApplicationListener<OfflineEvent> {
 
    private final static Logger logger = LoggerFactory.getLogger(OfflineEventListener.class);
    
    @Autowired
    private IVideoManagerStorager storager;
    
    @Autowired
    private RedisUtil redis;
 
    @Override
    public void onApplicationEvent(OfflineEvent event) {
        
        if (logger.isDebugEnabled()) {
            logger.debug("设备离线事件触发,deviceId:" + event.getDeviceId() + ",from:" + event.getFrom());
        }
 
        String key = VideoManagerConstants.KEEPLIVEKEY_PREFIX + event.getDeviceId();
 
        switch (event.getFrom()) {
        // 心跳超时触发的离线事件,说明redis中已删除,无需处理
        case VideoManagerConstants.EVENT_OUTLINE_TIMEOUT:
            break;
        // 设备主动注销触发的离线事件,需要删除redis中的超时监听
        case VideoManagerConstants.EVENT_OUTLINE_UNREGISTER:
            redis.del(key);
            break;
        default:
            boolean exist = redis.hasKey(key);
            if (exist) {
                redis.del(key);
            }
        }
 
        // 处理离线监听
        storager.outline(event.getDeviceId());
    }
}