|  |  | 
 |  |  | package com.genersoft.iot.vmp.gb28181.event; | 
 |  |  |  | 
 |  |  | import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander; | 
 |  |  | import com.genersoft.iot.vmp.gb28181.bean.DeviceNotFoundEvent; | 
 |  |  | import org.slf4j.Logger; | 
 |  |  | import org.slf4j.LoggerFactory; | 
 |  |  | import org.springframework.scheduling.annotation.Scheduled; | 
 |  |  | import org.springframework.stereotype.Component; | 
 |  |  |  | 
 |  |  | import javax.sip.*; | 
 |  |  | import javax.sip.header.CallIdHeader; | 
 |  |  | import javax.sip.message.Response; | 
 |  |  | import java.util.Calendar; | 
 |  |  | import java.util.Date; | 
 |  |  | import java.util.Map; | 
 |  |  | 
 |  |  |  | 
 |  |  |     private Map<String, SipSubscribe.Event> okSubscribes = new ConcurrentHashMap<>(); | 
 |  |  |  | 
 |  |  |     private Map<String, Date> timeSubscribes = new ConcurrentHashMap<>(); | 
 |  |  |     private Map<String, Date> okTimeSubscribes = new ConcurrentHashMap<>(); | 
 |  |  |     private Map<String, Date> errorTimeSubscribes = new ConcurrentHashMap<>(); | 
 |  |  |  | 
 |  |  | //    @Scheduled(cron="*/5 * * * * ?")   //每五秒执行一次 | 
 |  |  |     @Scheduled(cron="0 * */1 * * ?")   //每小时执行一次 | 
 |  |  |     //    @Scheduled(cron="*/5 * * * * ?")   //每五秒执行一次 | 
 |  |  | //    @Scheduled(fixedRate= 100 * 60 * 60 ) | 
 |  |  |     @Scheduled(cron="0 0/5 * * * ?")   //每5分钟执行一次 | 
 |  |  |     public void execute(){ | 
 |  |  |         logger.info("[定时任务] 清理过期的订阅信息"); | 
 |  |  |         Calendar calendar = Calendar.getInstance(); | 
 |  |  |         calendar.setTime(new Date()); | 
 |  |  |         calendar.set(Calendar.HOUR, calendar.get(Calendar.HOUR) - 1); | 
 |  |  |         for (String key : timeSubscribes.keySet()) { | 
 |  |  |             if (timeSubscribes.get(key).before(calendar.getTime())){ | 
 |  |  |                 logger.info("[定时任务] 清理过期的订阅信息: {}", key); | 
 |  |  |                 errorSubscribes.remove(key); | 
 |  |  |         calendar.set(Calendar.MINUTE, calendar.get(Calendar.MINUTE) - 5); | 
 |  |  |  | 
 |  |  |         for (String key : okTimeSubscribes.keySet()) { | 
 |  |  |             if (okTimeSubscribes.get(key).before(calendar.getTime())){ | 
 |  |  | //                logger.info("[定时任务] 清理过期的订阅信息: {}", key); | 
 |  |  |                 okSubscribes.remove(key); | 
 |  |  |                 timeSubscribes.remove(key); | 
 |  |  |                 okTimeSubscribes.remove(key); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |         for (String key : errorTimeSubscribes.keySet()) { | 
 |  |  |             if (errorTimeSubscribes.get(key).before(calendar.getTime())){ | 
 |  |  | //                logger.info("[定时任务] 清理过期的订阅信息: {}", key); | 
 |  |  |                 errorSubscribes.remove(key); | 
 |  |  |                 errorTimeSubscribes.remove(key); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |         logger.info("okTimeSubscribes.size:{}",okTimeSubscribes.size()); | 
 |  |  |         logger.info("okSubscribes.size:{}",okSubscribes.size()); | 
 |  |  |         logger.info("errorTimeSubscribes.size:{}",errorTimeSubscribes.size()); | 
 |  |  |         logger.info("errorSubscribes.size:{}",errorSubscribes.size()); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     public interface Event { | 
 |  |  | 
 |  |  |             this.event = event; | 
 |  |  |             if (event instanceof ResponseEvent) { | 
 |  |  |                 ResponseEvent responseEvent = (ResponseEvent)event; | 
 |  |  |                this.type = "response"; | 
 |  |  |                this.msg = responseEvent.getResponse().getReasonPhrase(); | 
 |  |  |                this.statusCode = responseEvent.getResponse().getStatusCode(); | 
 |  |  |                this.callId = responseEvent.getDialog().getCallId().getCallId(); | 
 |  |  |                this.dialog = responseEvent.getDialog(); | 
 |  |  |                 Response response = responseEvent.getResponse(); | 
 |  |  |                 this.dialog = responseEvent.getDialog(); | 
 |  |  |                 this.type = "response"; | 
 |  |  |                 if (response != null) { | 
 |  |  |                     this.msg = response.getReasonPhrase(); | 
 |  |  |                     this.statusCode = response.getStatusCode(); | 
 |  |  |                 } | 
 |  |  |                 this.callId = ((CallIdHeader)response.getHeader(CallIdHeader.NAME)).getCallId(); | 
 |  |  |  | 
 |  |  |             }else if (event instanceof TimeoutEvent) { | 
 |  |  |                 TimeoutEvent timeoutEvent = (TimeoutEvent)event; | 
 |  |  |                 this.type = "timeout"; | 
 |  |  | 
 |  |  |                 this.statusCode = -1024; | 
 |  |  |                 this.callId = dialogTerminatedEvent.getDialog().getCallId().getCallId(); | 
 |  |  |                 this.dialog = dialogTerminatedEvent.getDialog(); | 
 |  |  |             }else if (event instanceof DeviceNotFoundEvent) { | 
 |  |  |                 DeviceNotFoundEvent deviceNotFoundEvent = (DeviceNotFoundEvent)event; | 
 |  |  |                 this.type = "deviceNotFoundEvent"; | 
 |  |  |                 this.msg = "设备未找到"; | 
 |  |  |                 this.statusCode = -1024; | 
 |  |  |                 this.callId = deviceNotFoundEvent.getDialog().getCallId().getCallId(); | 
 |  |  |                 this.dialog = deviceNotFoundEvent.getDialog(); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     public void addErrorSubscribe(String key, SipSubscribe.Event event) { | 
 |  |  |         errorSubscribes.put(key, event); | 
 |  |  |         timeSubscribes.put(key, new Date()); | 
 |  |  |         errorTimeSubscribes.put(key, new Date()); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     public void addOkSubscribe(String key, SipSubscribe.Event event) { | 
 |  |  |         okSubscribes.put(key, event); | 
 |  |  |         timeSubscribes.put(key, new Date()); | 
 |  |  |         okTimeSubscribes.put(key, new Date()); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     public SipSubscribe.Event getErrorSubscribe(String key) { | 
 |  |  | 
 |  |  |  | 
 |  |  |     public void removeErrorSubscribe(String key) { | 
 |  |  |         errorSubscribes.remove(key); | 
 |  |  |         timeSubscribes.remove(key); | 
 |  |  |         errorTimeSubscribes.remove(key); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     public SipSubscribe.Event getOkSubscribe(String key) { | 
 |  |  | 
 |  |  |  | 
 |  |  |     public void removeOkSubscribe(String key) { | 
 |  |  |         okSubscribes.remove(key); | 
 |  |  |         timeSubscribes.remove(key); | 
 |  |  |         okTimeSubscribes.remove(key); | 
 |  |  |     } | 
 |  |  |     public int getErrorSubscribesSize(){ | 
 |  |  |         return errorSubscribes.size(); |