From 335916f1f15eb9d0b34dea38cacee2300eac0606 Mon Sep 17 00:00:00 2001
From: 李防 <liguofang0703@126.com>
Date: 星期一, 07 三月 2022 14:20:27 +0800
Subject: [PATCH] InviteRequestProcessor类中,channelid从invite消息的header subject获取,不再从第一行request line获取。原因是和第三方平台对接时,发送的invite消息第一行为国标平台编码而不是设备通道编码,导致报错通道不存在,返回404。

---
 src/main/java/com/genersoft/iot/vmp/conf/SipPlatformRunner.java |   19 ++++++++++++++++---
 1 files changed, 16 insertions(+), 3 deletions(-)

diff --git a/src/main/java/com/genersoft/iot/vmp/conf/SipPlatformRunner.java b/src/main/java/com/genersoft/iot/vmp/conf/SipPlatformRunner.java
index eae4547..b69bf68 100644
--- a/src/main/java/com/genersoft/iot/vmp/conf/SipPlatformRunner.java
+++ b/src/main/java/com/genersoft/iot/vmp/conf/SipPlatformRunner.java
@@ -4,6 +4,7 @@
 import com.genersoft.iot.vmp.gb28181.bean.ParentPlatformCatch;
 import com.genersoft.iot.vmp.gb28181.event.EventPublisher;
 import com.genersoft.iot.vmp.gb28181.transmit.cmd.ISIPCommanderForPlatform;
+import com.genersoft.iot.vmp.media.zlm.ZLMRTPServerFactory;
 import com.genersoft.iot.vmp.storager.IRedisCatchStorage;
 import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -29,15 +30,24 @@
     @Autowired
     private EventPublisher publisher;
 
+    @Autowired
+    private ISIPCommanderForPlatform sipCommanderForPlatform;
+
+
     @Override
     public void run(String... args) throws Exception {
         // 璁剧疆鎵�鏈夊钩鍙扮绾�
         storager.outlineForAllParentPlatform();
 
+        // 娓呯悊鎵�鏈夊钩鍙版敞鍐岀紦瀛�
+        redisCatchStorage.cleanPlatformRegisterInfos();
+
+        // 鍋滄鎵�鏈夋帹娴�
+//        zlmrtpServerFactory.closeAllSendRtpStream();
+
         List<ParentPlatform> parentPlatforms = storager.queryEnableParentPlatformList(true);
 
         for (ParentPlatform parentPlatform : parentPlatforms) {
-
             redisCatchStorage.updatePlatformRegister(parentPlatform);
 
             redisCatchStorage.updatePlatformKeepalive(parentPlatform);
@@ -45,11 +55,14 @@
             ParentPlatformCatch parentPlatformCatch = new ParentPlatformCatch();
 
             parentPlatformCatch.setParentPlatform(parentPlatform);
-            parentPlatformCatch.setId(parentPlatform.getDeviceGBId());
+            parentPlatformCatch.setId(parentPlatform.getServerGBId());
             redisCatchStorage.updatePlatformCatchInfo(parentPlatformCatch);
 
+            // 鍙栨秷璁㈤槄
+            sipCommanderForPlatform.unregister(parentPlatform, null, null);
+            Thread.sleep(500);
             // 鍙戦�佸钩鍙版湭娉ㄥ唽娑堟伅
-            publisher.platformNotRegisterEventPublish(parentPlatform.getDeviceGBId());
+            publisher.platformNotRegisterEventPublish(parentPlatform.getServerGBId());
         }
     }
 }

--
Gitblit v1.8.0