This commit is contained in:
parent
1d44b2e336
commit
4f3a0dc788
|
@ -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}
|
||||||
|
|
|
@ -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 []
|
|
Loading…
Reference in New Issue
Block a user