2023-10-05 18:46:18 +00:00
|
|
|
import json
|
2023-12-17 20:30:20 +00:00
|
|
|
|
2024-03-04 07:35:33 +00:00
|
|
|
from orm.notification import Notification
|
|
|
|
from services.db import local_session
|
2024-08-07 05:57:56 +00:00
|
|
|
from utils.logger import root_logger as logger
|
|
|
|
from cache.rediscache import redis
|
2023-10-05 18:46:18 +00:00
|
|
|
|
2024-04-17 15:32:23 +00:00
|
|
|
|
2024-03-04 07:35:33 +00:00
|
|
|
def save_notification(action: str, entity: str, payload):
|
|
|
|
with local_session() as session:
|
|
|
|
n = Notification(action=action, entity=entity, payload=payload)
|
|
|
|
session.add(n)
|
|
|
|
session.commit()
|
|
|
|
|
|
|
|
|
2024-04-17 15:32:23 +00:00
|
|
|
async def notify_reaction(reaction, action: str = "create"):
|
|
|
|
channel_name = "reaction"
|
|
|
|
data = {"payload": reaction, "action": action}
|
2023-10-05 18:46:18 +00:00
|
|
|
try:
|
2024-04-17 15:32:23 +00:00
|
|
|
save_notification(action, channel_name, data.get("payload"))
|
2023-10-05 18:46:18 +00:00
|
|
|
await redis.publish(channel_name, json.dumps(data))
|
|
|
|
except Exception as e:
|
2024-04-17 15:32:23 +00:00
|
|
|
logger.error(f"Failed to publish to channel {channel_name}: {e}")
|
2023-10-05 18:46:18 +00:00
|
|
|
|
|
|
|
|
2024-04-17 15:32:23 +00:00
|
|
|
async def notify_shout(shout, action: str = "update"):
|
|
|
|
channel_name = "shout"
|
|
|
|
data = {"payload": shout, "action": action}
|
2023-10-05 18:46:18 +00:00
|
|
|
try:
|
2024-04-17 15:32:23 +00:00
|
|
|
save_notification(action, channel_name, data.get("payload"))
|
2023-10-05 18:46:18 +00:00
|
|
|
await redis.publish(channel_name, json.dumps(data))
|
|
|
|
except Exception as e:
|
2024-04-17 15:32:23 +00:00
|
|
|
logger.error(f"Failed to publish to channel {channel_name}: {e}")
|
2023-10-05 18:46:18 +00:00
|
|
|
|
|
|
|
|
2024-04-17 15:32:23 +00:00
|
|
|
async def notify_follower(follower: dict, author_id: int, action: str = "follow"):
|
|
|
|
channel_name = f"follower:{author_id}"
|
2023-10-05 18:46:18 +00:00
|
|
|
try:
|
2024-01-22 23:47:23 +00:00
|
|
|
# Simplify dictionary before publishing
|
2024-04-17 15:32:23 +00:00
|
|
|
simplified_follower = {k: follower[k] for k in ["id", "name", "slug", "pic"]}
|
|
|
|
data = {"payload": simplified_follower, "action": action}
|
2024-04-09 10:46:27 +00:00
|
|
|
# save in channel
|
2024-04-17 15:32:23 +00:00
|
|
|
save_notification(action, channel_name, data.get("payload"))
|
2024-01-22 23:47:23 +00:00
|
|
|
|
|
|
|
# Convert data to JSON string
|
|
|
|
json_data = json.dumps(data)
|
|
|
|
|
|
|
|
# Ensure the data is not empty before publishing
|
2024-04-17 15:32:23 +00:00
|
|
|
if json_data:
|
2024-04-09 10:46:27 +00:00
|
|
|
# Use the 'await' keyword when publishing
|
|
|
|
await redis.publish(channel_name, json_data)
|
2024-03-04 07:35:33 +00:00
|
|
|
|
2023-10-05 18:46:18 +00:00
|
|
|
except Exception as e:
|
2024-01-22 23:47:23 +00:00
|
|
|
# Log the error and re-raise it
|
2024-04-17 15:32:23 +00:00
|
|
|
logger.error(f"Failed to publish to channel {channel_name}: {e}")
|