inbox/services/core.py

106 lines
2.9 KiB
Python
Raw Normal View History

2023-12-23 06:11:04 +00:00
import asyncio
2024-01-25 09:25:52 +00:00
import logging
from datetime import datetime, timedelta, timezone
2024-04-19 07:47:16 +00:00
import json
2023-12-23 06:11:04 +00:00
2024-04-18 10:47:01 +00:00
from services.logger import root_logger as logger
2024-04-19 07:47:16 +00:00
from services.rediscache import redis
2023-10-04 20:42:39 +00:00
2024-01-23 20:13:49 +00:00
logger.setLevel(logging.DEBUG)
2023-10-04 20:42:39 +00:00
2024-04-19 08:22:57 +00:00
async def get_all_authors():
2024-04-19 07:47:16 +00:00
authors = []
redis_key = "user:*"
2023-11-06 16:25:28 +00:00
2024-04-19 08:22:57 +00:00
result = await redis.execute("GET", redis_key)
2024-04-19 07:47:16 +00:00
if isinstance(result, str):
authors = json.loads(result)
2023-12-19 08:25:06 +00:00
2024-04-19 07:47:16 +00:00
return authors
2023-12-19 17:19:16 +00:00
2023-11-22 12:09:24 +00:00
2024-04-19 08:22:57 +00:00
async def get_author_by_user(user: str):
2024-04-19 07:47:16 +00:00
author = None
redis_key = f"user:{user}"
2024-04-19 08:22:57 +00:00
result = await redis.execute("GET", redis_key)
2024-04-19 07:47:16 +00:00
if isinstance(result, str):
author = json.loads(result)
2023-12-19 08:25:06 +00:00
2024-04-19 07:47:16 +00:00
return author
2023-10-04 20:42:39 +00:00
2023-10-11 19:12:55 +00:00
2024-04-19 08:22:57 +00:00
async def get_author_followed(author_id: int):
2024-04-19 07:47:16 +00:00
authors = []
redis_key = f"author:{author_id}:follows-authors"
2023-10-11 19:12:55 +00:00
2024-04-19 08:22:57 +00:00
result = await redis.execute("GET", redis_key)
2024-04-19 07:47:16 +00:00
if isinstance(result, str):
authors = json.loads(result)
2023-11-22 12:09:24 +00:00
2024-04-19 07:47:16 +00:00
return authors
2023-12-23 06:11:04 +00:00
class CacheStorage:
lock = asyncio.Lock()
period = 5 * 60 # every 5 mins
client = None
authors = []
authors_by_user = {}
authors_by_id = {}
@staticmethod
async def init():
"""graphql client connection using permanent token"""
self = CacheStorage
async with self.lock:
task = asyncio.create_task(self.worker())
2024-01-23 20:13:49 +00:00
logger.info(task)
2023-12-23 06:11:04 +00:00
@staticmethod
async def update_authors():
self = CacheStorage
async with self.lock:
result = get_all_authors()
2024-04-08 06:30:57 +00:00
logger.info(f"cache loaded {len(result)}")
2023-12-23 06:11:04 +00:00
if result:
CacheStorage.authors = result
for a in result:
2024-04-08 06:30:57 +00:00
user_id = a.get("user")
author_id = str(a.get("id"))
2024-01-24 09:22:05 +00:00
self.authors_by_user[user_id] = a
self.authors_by_id[author_id] = a
2023-12-23 06:11:04 +00:00
@staticmethod
async def worker():
"""async task worker"""
failed = 0
self = CacheStorage
while True:
try:
2024-04-08 06:30:57 +00:00
logger.info(" - updating profiles data...")
2023-12-23 06:11:04 +00:00
await self.update_authors()
failed = 0
2024-01-11 07:11:23 +00:00
except Exception as er:
2023-12-23 06:11:04 +00:00
failed += 1
2024-04-08 06:30:57 +00:00
logger.error(f"{er} - update failed #{failed}, wait 10 seconds")
2023-12-23 06:11:04 +00:00
if failed > 3:
2024-04-08 06:30:57 +00:00
logger.error(" - not trying to update anymore")
2024-01-24 07:47:34 +00:00
import traceback
2024-01-25 09:25:52 +00:00
2024-01-24 07:47:34 +00:00
traceback.print_exc()
2023-12-23 06:11:04 +00:00
break
if failed == 0:
when = datetime.now(timezone.utc) + timedelta(seconds=self.period)
t = format(when.astimezone().isoformat())
2024-04-08 06:30:57 +00:00
logger.info(
" ⎩ next update: %s"
% (t.split("T")[0] + " " + t.split("T")[1].split(".")[0])
)
2023-12-23 06:11:04 +00:00
await asyncio.sleep(self.period)
else:
await asyncio.sleep(10)
2024-04-08 06:30:57 +00:00
logger.info(" - trying to update data again")