From 16fed342914874759626ac5dcbcb3b69abce5a76 Mon Sep 17 00:00:00 2001
From: guoshilong <123456>
Date: Fri, 22 Sep 2023 16:41:41 +0800
Subject: [PATCH] 修改视频查询接口

---
 src/main/java/com/dji/sample/component/websocket/service/impl/SendMessageServiceImpl.java |   34 +++++++++++++++++++++++++++++++---
 1 files changed, 31 insertions(+), 3 deletions(-)

diff --git a/src/main/java/com/dji/sample/component/websocket/service/impl/SendMessageServiceImpl.java b/src/main/java/com/dji/sample/component/websocket/service/impl/SendMessageServiceImpl.java
index 8ee6131..b605cf9 100644
--- a/src/main/java/com/dji/sample/component/websocket/service/impl/SendMessageServiceImpl.java
+++ b/src/main/java/com/dji/sample/component/websocket/service/impl/SendMessageServiceImpl.java
@@ -3,13 +3,17 @@
 import com.dji.sample.component.websocket.config.ConcurrentWebSocketSession;
 import com.dji.sample.component.websocket.model.CustomWebSocketMessage;
 import com.dji.sample.component.websocket.service.ISendMessageService;
+import com.dji.sample.component.websocket.service.IWebSocketManageService;
 import com.fasterxml.jackson.databind.ObjectMapper;
 import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.util.StringUtils;
 import org.springframework.web.socket.TextMessage;
 
 import java.io.IOException;
 import java.util.Collection;
+import java.util.Objects;
 
 /**
  * @author sean.zhou
@@ -19,6 +23,12 @@
 @Service
 @Slf4j
 public class SendMessageServiceImpl implements ISendMessageService {
+
+    @Autowired
+    private ObjectMapper mapper;
+
+    @Autowired
+    private IWebSocketManageService webSocketManageService;
 
     @Override
     public void sendMessage(ConcurrentWebSocketSession session, CustomWebSocketMessage message) {
@@ -33,7 +43,6 @@
                 return;
             }
 
-            ObjectMapper mapper = new ObjectMapper();
 
             session.sendMessage(new TextMessage(mapper.writeValueAsBytes(message)));
         } catch (IOException e) {
@@ -50,7 +59,6 @@
 
         try {
 
-            ObjectMapper mapper = new ObjectMapper();
             TextMessage data = new TextMessage(mapper.writeValueAsBytes(message));
 
             for (ConcurrentWebSocketSession session : sessions) {
@@ -60,7 +68,6 @@
                     return;
                 }
                 session.sendMessage(data);
-
             }
 
         } catch (IOException e) {
@@ -69,4 +76,25 @@
             e.printStackTrace();
         }
     }
+
+    @Override
+    public void sendBatch(String workspaceId, Integer userType, String bizCode, Object data) {
+        if (!StringUtils.hasText(workspaceId)) {
+            throw new RuntimeException("Workspace ID does not exist.");
+        }
+        Collection<ConcurrentWebSocketSession> sessions = Objects.isNull(userType) ?
+                webSocketManageService.getValueWithWorkspace(workspaceId) :
+                webSocketManageService.getValueWithWorkspaceAndUserType(workspaceId, userType);
+
+        this.sendBatch(sessions, CustomWebSocketMessage.builder()
+                        .data(data)
+                        .timestamp(System.currentTimeMillis())
+                        .bizCode(bizCode)
+                        .build());
+    }
+
+    @Override
+    public void sendBatch(String workspaceId, String bizCode, Object data) {
+        this.sendBatch(workspaceId, null, bizCode, data);
+    }
 }
\ No newline at end of file

--
Gitblit v1.9.3