From 1af77ab5f7c11a4b3d59c1989b51b9fca29679ce Mon Sep 17 00:00:00 2001
From: 648540858 <648540858@qq.com>
Date: 星期二, 18 十月 2022 22:18:49 +0800
Subject: [PATCH] Merge pull request #645 from IKangXu/wvp-28181-2.0

---
 src/main/java/com/genersoft/iot/vmp/storager/IRedisCatchStorage.java |   79 +++++++++++++++++++++++++--------------
 1 files changed, 51 insertions(+), 28 deletions(-)

diff --git a/src/main/java/com/genersoft/iot/vmp/storager/IRedisCatchStorage.java b/src/main/java/com/genersoft/iot/vmp/storager/IRedisCatchStorage.java
index c6b7e64..ab9a831 100644
--- a/src/main/java/com/genersoft/iot/vmp/storager/IRedisCatchStorage.java
+++ b/src/main/java/com/genersoft/iot/vmp/storager/IRedisCatchStorage.java
@@ -3,13 +3,12 @@
 import com.alibaba.fastjson.JSONObject;
 import com.genersoft.iot.vmp.common.StreamInfo;
 import com.genersoft.iot.vmp.gb28181.bean.*;
-import com.genersoft.iot.vmp.media.zlm.dto.MediaItem;
-import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem;
-import com.genersoft.iot.vmp.media.zlm.dto.StreamPushItem;
+import com.genersoft.iot.vmp.media.zlm.dto.*;
 import com.genersoft.iot.vmp.service.bean.GPSMsgInfo;
 import com.genersoft.iot.vmp.service.bean.MessageForPushChannel;
 import com.genersoft.iot.vmp.service.bean.SSRCInfo;
 import com.genersoft.iot.vmp.service.bean.ThirdPartyGB;
+import com.genersoft.iot.vmp.storager.dao.dto.PlatformRegisterInfo;
 
 import java.util.List;
 import java.util.Map;
@@ -19,10 +18,9 @@
     /**
      * 璁℃暟鍣ㄣ�備负cseq杩涜璁℃暟
      *
-     * @param method sip 鏂规硶
      * @return
      */
-    Long getCSEQ(String method);
+    Long getCSEQ();
 
     /**
      * 寮�濮嬫挱鏀炬椂灏嗘祦瀛樺叆
@@ -58,23 +56,21 @@
 
     StreamInfo queryPlayback(String deviceId, String channelID, String stream, String callId);
 
+    String queryPlaybackForKey(String deviceId, String channelId, String stream, String callId);
+
     void updatePlatformCatchInfo(ParentPlatformCatch parentPlatformCatch);
 
     ParentPlatformCatch queryPlatformCatchInfo(String platformGbId);
 
     void delPlatformCatchInfo(String platformGbId);
 
-    void updatePlatformKeepalive(ParentPlatform parentPlatform);
-
     void delPlatformKeepalive(String platformGbId);
-
-    void updatePlatformRegister(ParentPlatform parentPlatform);
 
     void delPlatformRegister(String platformGbId);
 
-    void updatePlatformRegisterInfo(String callId, String platformGbId);
+    void updatePlatformRegisterInfo(String callId, PlatformRegisterInfo platformRegisterInfo);
 
-    String queryPlatformRegisterInfo(String callId);
+    PlatformRegisterInfo queryPlatformRegisterInfo(String callId);
 
     void delPlatformRegisterInfo(String callId);
 
@@ -112,23 +108,6 @@
     void clearCatchByDeviceId(String deviceId);
 
     /**
-     * 鑾峰彇mediaServer鑺傜偣
-     * @param mediaServerId
-     * @return
-     */
-//    MediaServerItem getMediaInfo(String mediaServerId);
-
-    /**
-     * 璁剧疆鎵�鏈夎澶囩绾�
-     */
-    void outlineForAll();
-
-    /**
-     * 鑾峰彇鎵�鏈夊湪绾跨殑
-     */
-    List<String> getOnlineForAll();
-
-    /**
      * 鍦╮edis娣诲姞wvp鐨勪俊鎭�
      */
     void updateWVPInfo(JSONObject jsonObject, int time);
@@ -138,6 +117,12 @@
      * @param jsonObject 娑堟伅鍐呭
      */
     void sendStreamChangeMsg(String type, JSONObject jsonObject);
+
+    /**
+     * 鍙戦�佹姤璀︽秷鎭�
+     * @param msg 娑堟伅鍐呭
+     */
+    void sendAlarmMsg(AlarmChannelMessage msg);
 
     /**
      * 娣诲姞娴佷俊鎭埌redis
@@ -217,4 +202,42 @@
 
     void sendStreamPushRequestedMsg(MessageForPushChannel messageForPushChannel);
 
+    /**
+     * 鍒ゆ柇璁惧鐘舵��
+     * @param deviceId 璁惧ID
+     * @return
+     */
+    public boolean deviceIsOnline(String deviceId);
+
+    /**
+     * 瀛樺偍鎺ㄦ祦鐨勯壌鏉冧俊鎭�
+     * @param app 搴旂敤鍚�
+     * @param stream 娴�
+     * @param streamAuthorityInfo 閴存潈淇℃伅
+     */
+    void updateStreamAuthorityInfo(String app, String stream, StreamAuthorityInfo streamAuthorityInfo);
+
+    /**
+     * 绉婚櫎鎺ㄦ祦鐨勯壌鏉冧俊鎭�
+     * @param app 搴旂敤鍚�
+     * @param streamId 娴�
+     */
+    void removeStreamAuthorityInfo(String app, String streamId);
+
+    /**
+     * 鑾峰彇鎺ㄦ祦鐨勯壌鏉冧俊鎭�
+     * @param app 搴旂敤鍚�
+     * @param stream 娴�
+     * @return
+     */
+    StreamAuthorityInfo getStreamAuthorityInfo(String app, String stream);
+
+    /**
+     * 鍙戦�乺edis娑堟伅 鏌ヨ鎵�鏈夋帹娴佽澶囩殑鐘舵��
+     */
+    void sendStreamPushRequestedMsgForStatus();
+
+    List<SendRtpItem> querySendRTPServerByChnnelId(String channelId);
+
+    List<SendRtpItem> querySendRTPServerByStream(String stream);
 }

--
Gitblit v1.8.0