2023-10-04 17:14:06 +00:00
|
|
|
import json
|
2023-10-14 12:59:43 +00:00
|
|
|
|
2024-04-18 10:47:01 +00:00
|
|
|
from servies.logger import root_logger as logger
|
|
|
|
|
2023-12-17 17:13:17 +00:00
|
|
|
from models.chat import ChatUpdate, Message
|
2023-10-14 14:55:51 +00:00
|
|
|
from services.rediscache import redis
|
2023-10-04 17:14:06 +00:00
|
|
|
|
|
|
|
|
2024-04-08 06:30:57 +00:00
|
|
|
async def notify_message(message: Message, action="create"):
|
2023-11-22 12:09:24 +00:00
|
|
|
channel_name = f"message:{message['chat_id']}"
|
2024-04-08 06:30:57 +00:00
|
|
|
data = {"payload": message, "action": action}
|
2023-10-04 17:14:06 +00:00
|
|
|
try:
|
2023-10-04 21:20:43 +00:00
|
|
|
await redis.publish(channel_name, json.dumps(data))
|
2024-04-18 10:47:01 +00:00
|
|
|
logger.info(f"ok {data}")
|
2023-10-04 17:14:06 +00:00
|
|
|
except Exception as e:
|
2024-04-18 10:47:01 +00:00
|
|
|
logger.error(f"Failed to publish to channel {channel_name}: {e}")
|
2023-11-16 14:52:39 +00:00
|
|
|
|
|
|
|
|
2024-04-08 06:30:57 +00:00
|
|
|
async def notify_chat(chat: ChatUpdate, member_id: int, action="create"):
|
|
|
|
channel_name = f"chat:{member_id}"
|
|
|
|
data = {"payload": chat, "action": action}
|
2023-11-16 14:52:39 +00:00
|
|
|
try:
|
|
|
|
await redis.publish(channel_name, json.dumps(data))
|
2024-04-18 10:47:01 +00:00
|
|
|
logger.info(f"ok {data}")
|
2023-11-16 14:52:39 +00:00
|
|
|
except Exception as e:
|
2024-04-18 10:47:01 +00:00
|
|
|
logger.error(f"Failed to publish to channel {channel_name}: {e}")
|