RODY/app/utils/websocket_tool.py

64 lines
1.9 KiB
Python
Raw Normal View History

2022-11-04 17:37:08 +08:00
"""
@Time 2022/10/12 17:55
@Auth
@MottoABC(Always Be Coding)
@Desc
"""
import json
from typing import Union, List, Dict
from app.core.common_utils import logger
from app.utils.JSONEncodeTools import MyEncoder
2022-11-24 10:45:05 +08:00
from configs.global_var import *
2022-11-04 17:37:08 +08:00
class WebsocketUtil:
def connect(self, ws, id: str):
# 等待连接
msg = ws.receive()
# 存储ws连接对象
2022-11-24 10:56:11 +08:00
# global active_connections
2022-11-24 10:45:05 +08:00
# active_connections = get_active_connections()
active_connections.append(ws)
2022-11-24 10:56:11 +08:00
# global active_connections_dist
2022-11-24 10:45:05 +08:00
# active_connections_dist = get_active_connections_dist()
if id in active_connections_dist:
active_connections_dist[id].append(ws)
2022-11-04 17:37:08 +08:00
else:
ws_list = [ws, ]
2022-11-24 10:45:05 +08:00
active_connections_dist[id] = ws_list
2022-11-04 17:37:08 +08:00
def disconnect(self, ws, id):
# ws关闭时 移除ws对象
if ws.closed:
2022-11-24 10:45:05 +08:00
if ws in active_connections_dist.values():
2022-11-24 10:56:11 +08:00
# global active_connections
2022-11-24 10:45:05 +08:00
active_connections.remove(ws)
2022-11-24 10:56:11 +08:00
# global active_connections_dist
2022-11-24 10:45:05 +08:00
active_connections_dist[id].pop(ws)
2022-11-04 17:37:08 +08:00
@staticmethod
async def send_personal_message(message: str, ws):
# 发送个人消息
await ws.send(message)
def broadcast(self, message: str):
# 广播消息
2022-11-24 10:56:11 +08:00
# global active_connections
2022-11-24 10:45:05 +08:00
for connection in active_connections:
2022-11-04 17:37:08 +08:00
connection.send(message)
def send_message_proj_json(self, message: Union[str, int, List, Dict], id: str):
# 广播该项目的消息
2022-11-24 10:56:11 +08:00
# global active_connections_dist
2022-11-24 10:45:05 +08:00
for connection in active_connections_dist[id]:
2022-11-04 17:37:08 +08:00
try:
connection.send(json.dumps(message, cls=MyEncoder, indent=4), )
except Exception as e:
logger.error("websocket异常断开{}", e)
self.disconnect(ws=connection, id=id)
2022-11-08 10:02:42 +08:00
manager = WebsocketUtil()