From 9bf87971e7dc6e0bccc0cf9a2301e9c89f9a0ba6 Mon Sep 17 00:00:00 2001
From: panlinlin <648540858@qq.com>
Date: 星期四, 07 一月 2021 14:56:10 +0800
Subject: [PATCH] 完成向上级联->启动时自动注册

---
 src/main/java/com/genersoft/iot/vmp/storager/IVideoManagerStorager.java         |   11 +++++
 src/main/java/com/genersoft/iot/vmp/vmanager/platform/PlatformController.java   |    1 
 src/main/java/com/genersoft/iot/vmp/conf/SipPlatformRunner.java                 |   55 +++++++++++++++++++++++++++
 src/main/java/com/genersoft/iot/vmp/storager/dao/ParentPlatformMapper.java      |    6 +++
 src/main/java/com/genersoft/iot/vmp/storager/impl/VideoManagerStoragerImpl.java |    9 ++++
 5 files changed, 82 insertions(+), 0 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
new file mode 100644
index 0000000..eae4547
--- /dev/null
+++ b/src/main/java/com/genersoft/iot/vmp/conf/SipPlatformRunner.java
@@ -0,0 +1,55 @@
+package com.genersoft.iot.vmp.conf;
+
+import com.genersoft.iot.vmp.gb28181.bean.ParentPlatform;
+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.storager.IRedisCatchStorage;
+import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.CommandLineRunner;
+import org.springframework.core.annotation.Order;
+import org.springframework.stereotype.Component;
+
+import java.util.List;
+
+/**
+ * 绯荤粺鍚姩鏃舵帶鍒朵笂绾у钩鍙伴噸鏂版敞鍐�
+ */
+@Component
+@Order(value=3)
+public class SipPlatformRunner implements CommandLineRunner {
+
+    @Autowired
+    private IVideoManagerStorager storager;
+
+    @Autowired
+    private IRedisCatchStorage redisCatchStorage;
+
+    @Autowired
+    private EventPublisher publisher;
+
+    @Override
+    public void run(String... args) throws Exception {
+        // 璁剧疆鎵�鏈夊钩鍙扮绾�
+        storager.outlineForAllParentPlatform();
+
+        List<ParentPlatform> parentPlatforms = storager.queryEnableParentPlatformList(true);
+
+        for (ParentPlatform parentPlatform : parentPlatforms) {
+
+            redisCatchStorage.updatePlatformRegister(parentPlatform);
+
+            redisCatchStorage.updatePlatformKeepalive(parentPlatform);
+
+            ParentPlatformCatch parentPlatformCatch = new ParentPlatformCatch();
+
+            parentPlatformCatch.setParentPlatform(parentPlatform);
+            parentPlatformCatch.setId(parentPlatform.getDeviceGBId());
+            redisCatchStorage.updatePlatformCatchInfo(parentPlatformCatch);
+
+            // 鍙戦�佸钩鍙版湭娉ㄥ唽娑堟伅
+            publisher.platformNotRegisterEventPublish(parentPlatform.getDeviceGBId());
+        }
+    }
+}
diff --git a/src/main/java/com/genersoft/iot/vmp/storager/IVideoManagerStorager.java b/src/main/java/com/genersoft/iot/vmp/storager/IVideoManagerStorager.java
index 0dad453..b868919 100644
--- a/src/main/java/com/genersoft/iot/vmp/storager/IVideoManagerStorager.java
+++ b/src/main/java/com/genersoft/iot/vmp/storager/IVideoManagerStorager.java
@@ -169,9 +169,20 @@
 	PageInfo<ParentPlatform> queryParentPlatformList(int page, int count);
 
 	/**
+	 * 鑾峰彇鎵�鏈夊凡鍚敤鐨勫钩鍙�
+	 * @return
+	 */
+	List<ParentPlatform> queryEnableParentPlatformList(boolean enable);
+
+	/**
 	 * 鑾峰彇涓婄骇骞冲彴
 	 * @param platformGbId
 	 * @return
 	 */
 	ParentPlatform queryParentPlatById(String platformGbId);
+
+	/**
+	 * 鎵�鏈夊钩鍙扮绾�
+	 */
+	void outlineForAllParentPlatform();
 }
diff --git a/src/main/java/com/genersoft/iot/vmp/storager/dao/ParentPlatformMapper.java b/src/main/java/com/genersoft/iot/vmp/storager/dao/ParentPlatformMapper.java
index 4e7cd45..efc7426 100644
--- a/src/main/java/com/genersoft/iot/vmp/storager/dao/ParentPlatformMapper.java
+++ b/src/main/java/com/genersoft/iot/vmp/storager/dao/ParentPlatformMapper.java
@@ -49,6 +49,12 @@
     @Select("SELECT * FROM parent_platform")
     List<ParentPlatform> getParentPlatformList();
 
+    @Select("SELECT * FROM parent_platform WHERE enable=#{enable}")
+    List<ParentPlatform> getEnableParentPlatformList(boolean enable);
+
     @Select("SELECT * FROM parent_platform WHERE deviceGBId=#{platformGbId}")
     ParentPlatform getParentPlatById(String platformGbId);
+
+    @Update("UPDATE parent_platform SET status=false" )
+    void outlineForAllParentPlatform();
 }
diff --git a/src/main/java/com/genersoft/iot/vmp/storager/impl/VideoManagerStoragerImpl.java b/src/main/java/com/genersoft/iot/vmp/storager/impl/VideoManagerStoragerImpl.java
index 92de14a..1513296 100644
--- a/src/main/java/com/genersoft/iot/vmp/storager/impl/VideoManagerStoragerImpl.java
+++ b/src/main/java/com/genersoft/iot/vmp/storager/impl/VideoManagerStoragerImpl.java
@@ -33,6 +33,7 @@
 
 	@Autowired
     private ParentPlatformMapper platformMapper;
+
 	@Autowired
     private IRedisCatchStorage redisCatchStorage;
 
@@ -252,5 +253,13 @@
 		return platformMapper.getParentPlatById(platformGbId);
 	}
 
+	@Override
+	public List<ParentPlatform> queryEnableParentPlatformList(boolean enable) {
+		return platformMapper.getEnableParentPlatformList(enable);
+	}
 
+	@Override
+	public void outlineForAllParentPlatform() {
+		platformMapper.outlineForAllParentPlatform();
+	}
 }
diff --git a/src/main/java/com/genersoft/iot/vmp/vmanager/platform/PlatformController.java b/src/main/java/com/genersoft/iot/vmp/vmanager/platform/PlatformController.java
index 950d8f5..ee77f01 100644
--- a/src/main/java/com/genersoft/iot/vmp/vmanager/platform/PlatformController.java
+++ b/src/main/java/com/genersoft/iot/vmp/vmanager/platform/PlatformController.java
@@ -25,6 +25,7 @@
 
     @Autowired
     private IVideoManagerStorager storager;
+
     @Autowired
     private IRedisCatchStorage redisCatchStorage;
 

--
Gitblit v1.8.0