This commit is contained in:
xyj 2024-01-06 15:15:52 +08:00
parent 800e881985
commit c663cdad31
1 changed files with 43 additions and 14 deletions

View File

@ -7,6 +7,17 @@ from pydantic import BaseModel
broker = 'mqtt.lihaink.cn' broker = 'mqtt.lihaink.cn'
port = 1883 port = 1883
APP = "app"
SCREEN = "screen"
WEB = "web"
SCENE_NAME = "scene"
user_sched = {}
user_msg = {}
user_scene = {
SCREEN: False,
APP: False,
WEB: False
}
class BaseResponse(BaseModel): class BaseResponse(BaseModel):
@ -41,9 +52,6 @@ class MQTTClient:
self.client.connect(self.broker, self.port) self.client.connect(self.broker, self.port)
user_sched = {}
async def close(username, device): async def close(username, device):
# 倒计时600秒 # 倒计时600秒
await asyncio.sleep(30) await asyncio.sleep(30)
@ -115,25 +123,46 @@ async def function_B(client, data):
await stop(username, device) await stop(username, device)
user_msg = {}
user_scene = [False, False, False]
# 创建WebSocket连接的处理函数 # 创建WebSocket连接的处理函数
async def handler(websocket, path): async def handler(websocket, path):
scene = None
try: try:
# 在循环中等待客户端的消息 # 在循环中等待客户端的消息
async for message in websocket: async for message in websocket:
user_msg[websocket] = message user_msg[websocket] = message
data = json.loads(message)
scene = data[SCENE_NAME]
# 如果该场景已经开启,那么不在开启了
if user_scene[scene] is True:
await websocket.send(json.dumps({"code": 200, "msg": scene + "该场景已经开启了,不要再请求我了!"}, ensure_ascii=False))
continue
if user_scene[APP] is True or user_scene[WEB] is True or user_scene[SCREEN] is True:
user_scene[scene] = True
await websocket.send(json.dumps({"code": 200, "msg": "已经有其他场景开启了,不需要再推流了!"}, ensure_ascii=False))
continue
# 如果该场景没有开启,那么进行开启
user_scene[scene] = True
# 当接收到消息时调用函数A # 当接收到消息时调用函数A
response = await function_A(websocket, message) response = await function_A(websocket, message)
await websocket.send(response) await websocket.send(response)
# 本地情况 # 没有消息了,则首先关闭该场景
await function_B(websocket, message) if scene is not None:
user_scene[scene] = False
# 查看所有场景是否在线,只有都不在线就关闭推流
if user_scene[APP] is False and user_scene[WEB] is False and user_scene[SCREEN] is False:
await websocket.send(json.dumps({"code": 200, "msg": "开始关闭场景" + scene}, ensure_ascii=False))
await function_B(websocket, user_msg[websocket])
except Exception as e: except Exception as e:
msg = user_msg[websocket] data = json.loads(user_msg[websocket])
await function_B(websocket, msg) scene = data[SCENE_NAME]
if scene is not None:
user_scene[scene] = False
# 查看所有场景是否在线,只有都不在线就关闭推流
if user_scene[APP] is False and user_scene[WEB] is False and user_scene[SCREEN] is False:
await function_B(websocket, user_msg[websocket])
if __name__ == '__main__':
# 启动WebSocket服务器 # 启动WebSocket服务器
start_server = websockets.serve(handler, "0.0.0.0", 8765) start_server = websockets.serve(handler, "0.0.0.0", 8765)