648540858
2021-01-21 ff7ecd270c7d0b2cd1dd2ec078df0dbe62aad08d
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
package com.genersoft.iot.vmp.gb28181.event.alarm;
 
import org.springframework.context.ApplicationListener;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.mvc.method.annotation.SseEmitter;
import java.io.IOException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
 
/**
 * @description: 报警事件监听
 * @author: lawrencehj
 * @data: 2021-01-20
 */
 
@Component
public class AlarmEventListener implements ApplicationListener<AlarmEvent> {
 
    private final static Logger logger = LoggerFactory.getLogger(AlarmEventListener.class);
 
    private static SseEmitter emitter = new SseEmitter();
 
    public void addSseEmitters(SseEmitter sseEmitter) {
        emitter = sseEmitter;
    }
 
    @Override
    public void onApplicationEvent(AlarmEvent event) {
        if (logger.isDebugEnabled()) {
            logger.debug("设备报警事件触发,deviceId:" + event.getAlarmInfo().getDeviceId() + ", "
                    + event.getAlarmInfo().getAlarmDescription());
        }
        try {
            String msg = "<strong>设备编码:</strong> <i>" + event.getAlarmInfo().getDeviceId() + "</i>"
                        + "<br><strong>报警描述:</strong> <i>" + event.getAlarmInfo().getAlarmDescription() + "</i>"
                        + "<br><strong>报警时间:</strong> <i>" + event.getAlarmInfo().getAlarmTime() + "</i>"
                        + "<br><strong>定位经度:</strong> <i>" + event.getAlarmInfo().getLongitude() + "</i>"
                        + "<br><strong>定位纬度:</strong> <i>" + event.getAlarmInfo().getLatitude() + "</i>";
            emitter.send(msg);
        } catch (IOException e) {
            if (logger.isDebugEnabled()) {
                logger.debug("SSE 通道已关闭");
            }
            // e.printStackTrace();
        }
    }
}