cached-storage-authors
All checks were successful
deploy / deploy (push) Successful in 1m3s

This commit is contained in:
2023-12-23 09:11:04 +03:00
parent e81eabd0d0
commit ce02ce0130
5 changed files with 141 additions and 85 deletions

View File

@@ -1,6 +1,8 @@
from typing import List
import asyncio
import requests
from datetime import datetime, timezone, timedelta
from models.member import ChatMember
from settings import API_BASE
@@ -8,7 +10,7 @@ from settings import API_BASE
def _request_endpoint(query_name, body) -> dict:
print(f"[services.core] requesting {query_name}...")
response = requests.post(API_BASE, headers={"Content-Type": "application/json"}, json=body)
print(f"[services.core] {query_name} response: <{response.status_code}> {response.text[:65]}..")
print(f"[services.core] {query_name} response: <{response.status_code}> {response.text}..")
if response.status_code == 200:
try:
@@ -55,3 +57,61 @@ def get_my_followed() -> List[ChatMember]:
result = _request_endpoint(query_name, gql)
return result.get("authors", [])
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())
print(task)
@staticmethod
async def update_authors():
self = CacheStorage
async with self.lock:
result = get_all_authors()
print(f"[services.core] loaded {len(result)}")
if result:
CacheStorage.authors = result
for a in result:
self.authors_by_user[a.user] = a
self.authors_by_id[a.id] = a
@staticmethod
async def worker():
"""async task worker"""
failed = 0
self = CacheStorage
while True:
try:
print("[services.core] - updating views...")
await self.update_authors()
failed = 0
except Exception:
failed += 1
print("[services.core] - update failed #%d, wait 10 seconds" % failed)
if failed > 3:
print("[services.core] - not trying to update anymore")
break
if failed == 0:
when = datetime.now(timezone.utc) + timedelta(seconds=self.period)
t = format(when.astimezone().isoformat())
print(
"[services.core] ⎩ next update: %s"
% (t.split("T")[0] + " " + t.split("T")[1].split(".")[0])
)
await asyncio.sleep(self.period)
else:
await asyncio.sleep(10)
print("[services.core] - trying to update data again")