|  |  | 
 |  |  | import org.slf4j.Logger; | 
 |  |  | import org.slf4j.LoggerFactory; | 
 |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
 |  |  | import org.springframework.beans.factory.annotation.Qualifier; | 
 |  |  | import org.springframework.scheduling.annotation.Async; | 
 |  |  | import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; | 
 |  |  | import org.springframework.stereotype.Component; | 
 |  |  |  | 
 |  |  | import javax.sip.*; | 
 |  |  | 
 |  |  |  * @date:   2021年11月5日 下午15:32 | 
 |  |  |  */ | 
 |  |  | @Component | 
 |  |  | public class SIPProcessorObserver implements SipListener { | 
 |  |  | public class SIPProcessorObserver implements ISIPProcessorObserver { | 
 |  |  |  | 
 |  |  |     private final static Logger logger = LoggerFactory.getLogger(SIPProcessorObserver.class); | 
 |  |  |  | 
 |  |  | 
 |  |  |  | 
 |  |  |     @Autowired | 
 |  |  |     private SipSubscribe sipSubscribe; | 
 |  |  |  | 
 |  |  | //    @Autowired | 
 |  |  | //    @Qualifier(value = "taskExecutor") | 
 |  |  | //    private ThreadPoolTaskExecutor poolTaskExecutor; | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 添加 request订阅 | 
 |  |  | 
 |  |  |      * @param requestEvent RequestEvent事件 | 
 |  |  |      */ | 
 |  |  |     @Override | 
 |  |  |     @Async | 
 |  |  |     public void processRequest(RequestEvent requestEvent) { | 
 |  |  |         String method = requestEvent.getRequest().getMethod(); | 
 |  |  |         ISIPRequestProcessor sipRequestProcessor = requestProcessorMap.get(method); | 
 |  |  | 
 |  |  |             logger.warn("不支持方法{}的request", method); | 
 |  |  |             return; | 
 |  |  |         } | 
 |  |  |         requestProcessorMap.get(requestEvent.getRequest().getMethod()).process(requestEvent); | 
 |  |  |         requestProcessorMap.get(method).process(requestEvent); | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  | 
 |  |  |      * @param responseEvent responseEvent事件 | 
 |  |  |      */ | 
 |  |  |     @Override | 
 |  |  |     @Async | 
 |  |  |     public void processResponse(ResponseEvent responseEvent) { | 
 |  |  |         logger.debug(responseEvent.getResponse().toString()); | 
 |  |  | //        CSeqHeader cseqHeader = (CSeqHeader) responseEvent.getResponse().getHeader(CSeqHeader.NAME); | 
 |  |  | //        String method = cseqHeader.getMethod(); | 
 |  |  | //        ISIPResponseProcessor sipRequestProcessor = responseProcessorMap.get(method); | 
 |  |  | //        if (sipRequestProcessor == null) { | 
 |  |  | //            logger.warn("不支持方法{}的response", method); | 
 |  |  | //            return; | 
 |  |  | //        } | 
 |  |  | //        sipRequestProcessor.process(responseEvent); | 
 |  |  |  | 
 |  |  |  | 
 |  |  |         Response response = responseEvent.getResponse(); | 
 |  |  |         logger.debug(responseEvent.getResponse().toString()); | 
 |  |  |         int status = response.getStatusCode(); | 
 |  |  | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  | 
 |  |  |  | 
 |  |  |     @Override | 
 |  |  |     public void processIOException(IOExceptionEvent exceptionEvent) { | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     @Override | 
 |  |  |     public void processTransactionTerminated(TransactionTerminatedEvent transactionTerminatedEvent) { | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     @Override | 
 |  |  |     public void processDialogTerminated(DialogTerminatedEvent dialogTerminatedEvent) { | 
 |  |  |  | 
 |  |  |         CallIdHeader callId = dialogTerminatedEvent.getDialog().getCallId(); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |  |