old mode 100644
new mode 100755
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.DeviceNotFoundEvent; | 
|---|
|  |  |  | import gov.nist.javax.sip.message.SIPRequest; | 
|---|
|  |  |  | import gov.nist.javax.sip.message.SIPResponse; | 
|---|
|  |  |  | import org.apache.commons.lang3.ObjectUtils; | 
|---|
|  |  |  | 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 javax.sip.DialogTerminatedEvent; | 
|---|
|  |  |  | import javax.sip.ResponseEvent; | 
|---|
|  |  |  | import javax.sip.TimeoutEvent; | 
|---|
|  |  |  | import javax.sip.TransactionTerminatedEvent; | 
|---|
|  |  |  | import javax.sip.header.WarningHeader; | 
|---|
|  |  |  | import java.time.Instant; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  | import java.util.concurrent.ConcurrentHashMap; | 
|---|
|  |  |  | 
|---|
|  |  |  | private Map<String, SipSubscribe.Event> okSubscribes = new ConcurrentHashMap<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Map<String, Instant> okTimeSubscribes = new ConcurrentHashMap<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Map<String, Instant> errorTimeSubscribes = new ConcurrentHashMap<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    @Scheduled(cron="*/5 * * * * ?")   //每五秒执行一次 | 
|---|
|  |  |  | 
|---|
|  |  |  | logger.debug("errorSubscribes.size:{}",errorSubscribes.size()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public interface Event { | 
|---|
|  |  |  | void response(EventResult eventResult); | 
|---|
|  |  |  | public interface Event { void response(EventResult eventResult); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | // 会话已结束 | 
|---|
|  |  |  | dialogTerminated, | 
|---|
|  |  |  | // 设备未找到 | 
|---|
|  |  |  | deviceNotFoundEvent | 
|---|
|  |  |  | deviceNotFoundEvent, | 
|---|
|  |  |  | // 消息发送失败 | 
|---|
|  |  |  | cmdSendFailEvent, | 
|---|
|  |  |  | // 消息发送失败 | 
|---|
|  |  |  | failedToGetPort | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public static class EventResult<EventObject>{ | 
|---|
|  |  |  | 
|---|
|  |  |  | public EventResultType type; | 
|---|
|  |  |  | public String msg; | 
|---|
|  |  |  | public String callId; | 
|---|
|  |  |  | public Dialog dialog; | 
|---|
|  |  |  | public EventObject event; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public EventResult() { | 
|---|
|  |  |  | 
|---|
|  |  |  | this.event = event; | 
|---|
|  |  |  | if (event instanceof ResponseEvent) { | 
|---|
|  |  |  | ResponseEvent responseEvent = (ResponseEvent)event; | 
|---|
|  |  |  | Response response = responseEvent.getResponse(); | 
|---|
|  |  |  | this.dialog = responseEvent.getDialog(); | 
|---|
|  |  |  | SIPResponse response = (SIPResponse)responseEvent.getResponse(); | 
|---|
|  |  |  | this.type = EventResultType.response; | 
|---|
|  |  |  | if (response != null) { | 
|---|
|  |  |  | this.msg = response.getReasonPhrase(); | 
|---|
|  |  |  | WarningHeader warningHeader = (WarningHeader)response.getHeader(WarningHeader.NAME); | 
|---|
|  |  |  | if (warningHeader != null && !ObjectUtils.isEmpty(warningHeader.getText())) { | 
|---|
|  |  |  | this.msg = ""; | 
|---|
|  |  |  | if (warningHeader.getCode() > 0) { | 
|---|
|  |  |  | this.msg += warningHeader.getCode() + ":"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (warningHeader.getAgent() != null) { | 
|---|
|  |  |  | this.msg += warningHeader.getCode() + ":"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (warningHeader.getText() != null) { | 
|---|
|  |  |  | this.msg += warningHeader.getText(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | this.msg = response.getReasonPhrase(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.statusCode = response.getStatusCode(); | 
|---|
|  |  |  | this.callId = response.getCallIdHeader().getCallId(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.callId = ((CallIdHeader)response.getHeader(CallIdHeader.NAME)).getCallId(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }else if (event instanceof TimeoutEvent) { | 
|---|
|  |  |  | TimeoutEvent timeoutEvent = (TimeoutEvent)event; | 
|---|
|  |  |  | this.type = EventResultType.timeout; | 
|---|
|  |  |  | 
|---|
|  |  |  | this.statusCode = -1024; | 
|---|
|  |  |  | this.callId = dialogTerminatedEvent.getDialog().getCallId().getCallId(); | 
|---|
|  |  |  | }else if (event instanceof DeviceNotFoundEvent) { | 
|---|
|  |  |  | DeviceNotFoundEvent deviceNotFoundEvent = (DeviceNotFoundEvent)event; | 
|---|
|  |  |  | this.type = EventResultType.deviceNotFoundEvent; | 
|---|
|  |  |  | this.msg = "设备未找到"; | 
|---|
|  |  |  | this.statusCode = -1024; | 
|---|
|  |  |  | this.dialog = deviceNotFoundEvent.getDialog(); | 
|---|
|  |  |  | this.callId = this.dialog != null ?deviceNotFoundEvent.getDialog().getCallId().getCallId() : null; | 
|---|
|  |  |  | this.callId = ((DeviceNotFoundEvent) event).getCallId(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|