get-author-by-id-fix-3
Some checks failed
deploy / deploy (push) Failing after 1m7s

This commit is contained in:
Untone 2023-11-14 21:20:45 +03:00
parent 1d44b2e336
commit 4f3a0dc788
2 changed files with 44 additions and 74 deletions

View File

@ -3,7 +3,7 @@ import json
from typing import Any, Dict, List, Optional, Union from typing import Any, Dict, List, Optional, Union
from services.auth import login_required from services.auth import login_required
from services.core import get_author, get_network from services.core import get_my_followings, members
from services.rediscache import redis from services.rediscache import redis
from services.schema import query from services.schema import query
from validators.chat import Message, ChatPayload from validators.chat import Message, ChatPayload
@ -73,7 +73,7 @@ async def load_chats(_, info, limit: int = 50, offset: int = 0) -> Dict[str, Uni
member_ids = c["members"].copy() member_ids = c["members"].copy()
c["members"] = [] c["members"] = []
for member_id in member_ids: for member_id in member_ids:
for a in (await get_network(member_id, 1)): for a in (await get_my_followings()):
a["online"] = a.get("id") in members_online a["online"] = a.get("id") in members_online
c["members"].append(a) c["members"].append(a)
chats.append(c) chats.append(c)
@ -111,14 +111,17 @@ async def load_messages_by(_, info, by, limit: int = 10, offset: int = 0):
async def load_recipients(_, _info, limit=50, offset=0): async def load_recipients(_, _info, limit=50, offset=0):
"""load possible chat participants""" """load possible chat participants"""
onliners = (await redis.execute("SMEMBERS", "authors-online")) or [] onliners = (await redis.execute("SMEMBERS", "authors-online")) or []
members = [] r = []
all_authors: List[ChatMember] = await get_network(limit, offset) all_authors: List[ChatMember] = members
for a in all_authors: my_followings = await get_my_followings()
if len(my_followings) < limit:
my_followings = my_followings + all_authors[0:limit-len(my_followings)]
for a in my_followings:
a["online"] = a["id"] in onliners a["online"] = a["id"] in onliners
members.append(a) r.append(a)
# NOTE: maybe sort members here # NOTE: maybe sort members here
print(f"[resolvers.load] loadRecipients found {len(members)} members") print(f"[resolvers.load] loadRecipients found {len(r)} members")
return {"members": members, "error": None} return {"members": r, "error": None}

View File

@ -1,26 +1,20 @@
from datetime import datetime
from httpx import AsyncClient from httpx import AsyncClient
from settings import API_BASE from settings import API_BASE
from validators.member import ChatMember
headers = {"Content-Type": "application/json"} headers = {"Content-Type": "application/json"}
INTERNAL_AUTH_SERVER = 'v2.' in API_BASE INTERNAL_AUTH_SERVER = 'v2.' in API_BASE
async def get_author(author_id): async def get_all_authors():
query_name = "getAuthorById" if INTERNAL_AUTH_SERVER else "GetAuthorById" query_name = "authorsAll"
query_type = "query" query_type = "query"
operation = "GetAuthorById" operation = "AuthorsAll"
query_fields = "id slug userpic name lastSeen" if INTERNAL_AUTH_SERVER else "id slug userpic name last_seen" query_fields = "id slug userpic name"
headers = {"Content-Type": "application/json"} # "Bearer " + removed headers = {"Content-Type": "application/json"} # "Bearer " + removed
gql = { gql = {
"query": query_type + " " + operation + " { " + query_name + " { " + query_fields + " } " + " }", "query": query_type + " " + operation + " { " + query_name + " { " + query_fields + " } " + " }",
"operationName": operation, "operationName": operation,
"variables": { "variables": None,
"author_id": author_id
},
} }
async with AsyncClient() as client: async with AsyncClient() as client:
try: try:
@ -28,66 +22,39 @@ async def get_author(author_id):
except Exception: except Exception:
import traceback import traceback
traceback.print_exc() traceback.print_exc()
print(f"[services.core] get_author: {response.status_code} {response.text}") print(f"[services.core] {query_name}: {response.status_code} {response.text}")
if response.status_code != 200: if response.status_code != 200:
return None return None
r = response.json() r = response.json()
a = r.get("data", {}).get("getAuthorById") return r.get("data", {}).get(query_name)
if a:
ts_value = a.get("lastSeen", a.get("last_seen"))
dt = datetime.strptime(ts_value, "%Y-%m-%dT%H:%M:%S.%f")
timestamp = int(dt.timestamp())
a["last_seen"] = timestamp
author: ChatMember = a
return author
async def get_network(author_id: int, limit: int = 50, offset: int = 0) -> list: async def get_my_followings():
query_name = "loadMySubscriptions"
query_type = "query"
operation = "LoadMySubscriptions"
query_fields = "id slug userpic name"
headers = {"Content-Type": "application/json"} # "Bearer " + removed
gql = { gql = {
"query": """query LoadAuthors($author_id: Int!, $limit: Int, $offset: Int) { "query": query_type + " " + operation + " { " + query_name + " { authors {" + query_fields + "} } " + " }",
authorFollowings(author_id: $author_id, limit: $limit, offset: $offset) { "operationName": operation,
id slug userpic name "variables": None,
}
}""",
"operation": "LoadAuthors",
"variables": {"author_id": author_id, "limit": limit, "offset": offset},
} }
async with AsyncClient() as client:
followings = [] try:
try:
async with AsyncClient() as client:
response = await client.post(API_BASE, headers=headers, json=gql) response = await client.post(API_BASE, headers=headers, json=gql)
if response.status_code != 200: except Exception:
return [] import traceback
r = response.json() traceback.print_exc()
followings = r.get("data", {}).get("authorFollowings", []) print(f"[services.core] {query_name}: {response.status_code} {response.text}")
more_amount = limit - len(followings) if response.status_code != 200:
if more_amount > 0: return None
followers = await get_followers(author_id, more_amount) r = response.json()
followings.extend(followers) authors = r.get("data", {}).get(query_name).get("authors", [])
except Exception as e: return authors
print(e)
return followings members = get_all_authors() # [ { id slug name userpic }, ..]
print(f"[services.core] cache members amount: {len(members)}")
members_by_slug = {member['slug']: member for member in members}
async def get_followers(author_id, amount): members_by_id = {member['id']: member for member in members}
gql = {
"query": """query LoadAuthors($author_id: Int!, $limit: Int, $offset: Int) {
authorFollowers(author_id: $author_id, limit: $limit) {
id slug userpic name
}
}""",
"operation": "LoadAuthors",
"variables": {"author_id": author_id, "limit": amount},
}
try:
async with AsyncClient() as client:
response = await client.post(API_BASE, headers=headers, json=gql)
if response.status_code != 200:
return []
r = response.json()
return r.get("data", {}).get("authorFollowers", [])
except Exception as e:
print(e)
return []