Lawrence
2021-01-27 5d541e4ae6a5c635289d437366b20c9b2aefe741
src/main/java/com/genersoft/iot/vmp/gb28181/transmit/SIPProcessorFactory.java
@@ -7,7 +7,7 @@
import javax.sip.message.Request;
import javax.sip.message.Response;
import com.alibaba.fastjson.JSON;
import com.genersoft.iot.vmp.storager.IRedisCatchStorage;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
@@ -26,6 +26,7 @@
import com.genersoft.iot.vmp.gb28181.transmit.request.impl.CancelRequestProcessor;
import com.genersoft.iot.vmp.gb28181.transmit.request.impl.InviteRequestProcessor;
import com.genersoft.iot.vmp.gb28181.transmit.request.impl.MessageRequestProcessor;
import com.genersoft.iot.vmp.gb28181.transmit.request.impl.NotifyRequestProcessor;
import com.genersoft.iot.vmp.gb28181.transmit.request.impl.OtherRequestProcessor;
import com.genersoft.iot.vmp.gb28181.transmit.request.impl.RegisterRequestProcessor;
import com.genersoft.iot.vmp.gb28181.transmit.request.impl.SubscribeRequestProcessor;
@@ -56,6 +57,9 @@
   
   @Autowired
   private IVideoManagerStorager storager;
   @Autowired
   private IRedisCatchStorage redisCatchStorage;
   
   @Autowired
   private EventPublisher publisher;
@@ -83,7 +87,8 @@
   
   @Autowired
   private OtherResponseProcessor otherResponseProcessor;
   // 注:这里使用注解会导致循环依赖注入,暂用springBean
   private SipProvider tcpSipProvider;
      
@@ -94,6 +99,7 @@
      Request request = evt.getRequest();
      String method = request.getMethod();
//      logger.info("接收到消息:"+request.getMethod());
//      sipSubscribe.getSubscribe(evt.getServerTransaction().getBranchId()).response(evt);
      if (Request.INVITE.equals(method)) {
         InviteRequestProcessor processor = new InviteRequestProcessor();
         processor.setRequestEvent(evt);
@@ -127,7 +133,6 @@
         processor.setRequestEvent(evt);
         return processor;
      } else if (Request.MESSAGE.equals(method)) {
         MessageRequestProcessor processor = new MessageRequestProcessor();
         processor.setRequestEvent(evt);
         processor.setTcpSipProvider(getTcpSipProvider());
@@ -138,9 +143,25 @@
         processor.setOffLineDetector(offLineDetector);
         processor.setCmder(cmder);
         processor.setStorager(storager);
         processor.setRedisCatchStorage(redisCatchStorage);
         return processor;
      } else if (Request.NOTIFY.equalsIgnoreCase(method)) {
         NotifyRequestProcessor processor = new NotifyRequestProcessor();
         processor.setRequestEvent(evt);
         processor.setTcpSipProvider(getTcpSipProvider());
         processor.setUdpSipProvider(getUdpSipProvider());
         processor.setPublisher(publisher);
         processor.setRedis(redis);
         processor.setDeferredResultHolder(deferredResultHolder);
         processor.setOffLineDetector(offLineDetector);
         processor.setCmder(cmder);
         processor.setStorager(storager);
         processor.setRedisCatchStorage(redisCatchStorage);
         return processor;
      } else {
         return new OtherRequestProcessor();
         OtherRequestProcessor processor = new OtherRequestProcessor();
         processor.setRequestEvent(evt);
         return processor;
      }
   }