search-messages
This commit is contained in:
parent
058fdcc64f
commit
35f540b26a
|
@ -31,9 +31,11 @@ class RedisCache:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
async def lrange(self, key, start, stop):
|
async def lrange(self, key, start, stop):
|
||||||
|
print(f"[redis] LRANGE {key} {start} {stop}")
|
||||||
return await self._instance.lrange(key, start, stop)
|
return await self._instance.lrange(key, start, stop)
|
||||||
|
|
||||||
async def mget(self, key, *keys):
|
async def mget(self, key, *keys):
|
||||||
|
print(f"[redis] MGET {key} {keys}")
|
||||||
return await self._instance.mget(key, *keys)
|
return await self._instance.mget(key, *keys)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -76,36 +76,6 @@ async def load_chats(_, info, limit: int = 50, offset: int = 0):
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
async def search_user_chats(by, messages, user_id: int, limit, offset):
|
|
||||||
cids = set([])
|
|
||||||
by_author = by.get('author')
|
|
||||||
body_like = by.get('body')
|
|
||||||
cids.union(set(await redis.execute("SMEMBERS", "chats_by_user/" + str(user_id))))
|
|
||||||
# messages_by_chat = []
|
|
||||||
if by_author:
|
|
||||||
# all author's messages
|
|
||||||
cids.union(set(await redis.execute("SMEMBERS", f"chats_by_user/{by_author}")))
|
|
||||||
# author's messages in filtered chat
|
|
||||||
messages.union(set(filter(lambda m: m["author"] == by_author, list(messages))))
|
|
||||||
for c in cids:
|
|
||||||
c = c.decode('utf-8')
|
|
||||||
# messages_by_chat = await load_messages(c, limit, offset)
|
|
||||||
|
|
||||||
if body_like:
|
|
||||||
# search in all messages in all user's chats
|
|
||||||
for c in cids:
|
|
||||||
# FIXME: use redis scan here
|
|
||||||
c = c.decode('utf-8')
|
|
||||||
mmm = set(await load_messages(c, limit, offset))
|
|
||||||
for m in mmm:
|
|
||||||
if body_like in m["body"]:
|
|
||||||
messages.add(m)
|
|
||||||
else:
|
|
||||||
# search in chat's messages
|
|
||||||
messages.union(set(filter(lambda m: body_like in m["body"], list(messages))))
|
|
||||||
return messages
|
|
||||||
|
|
||||||
|
|
||||||
@query.field("loadMessagesBy")
|
@query.field("loadMessagesBy")
|
||||||
@login_required
|
@login_required
|
||||||
async def load_messages_by(_, info, by, limit: int = 10, offset: int = 0):
|
async def load_messages_by(_, info, by, limit: int = 10, offset: int = 0):
|
||||||
|
@ -129,18 +99,6 @@ async def load_messages_by(_, info, by, limit: int = 10, offset: int = 0):
|
||||||
}
|
}
|
||||||
# everyone's messages in filtered chat
|
# everyone's messages in filtered chat
|
||||||
messages = await load_messages(by_chat, limit, offset)
|
messages = await load_messages(by_chat, limit, offset)
|
||||||
|
|
||||||
# if len(messages) == 0:
|
|
||||||
# messages.union(set(await search_user_chats(by, messages, auth.user_id, limit, offset)))
|
|
||||||
|
|
||||||
# days = by.get("days")
|
|
||||||
# if days:
|
|
||||||
# messages.union(set(filter(
|
|
||||||
# list(messages),
|
|
||||||
# key=lambda m: (
|
|
||||||
# datetime.now(tz=timezone.utc) - int(m["createdAt"]) < timedelta(days=by["days"])
|
|
||||||
# )
|
|
||||||
# )))
|
|
||||||
return {
|
return {
|
||||||
"messages": sorted(
|
"messages": sorted(
|
||||||
list(messages),
|
list(messages),
|
||||||
|
@ -161,6 +119,7 @@ async def load_recipients(_, info, limit=50, offset=0):
|
||||||
|
|
||||||
try:
|
try:
|
||||||
chat_users += await followed_authors(auth.user_id)
|
chat_users += await followed_authors(auth.user_id)
|
||||||
|
print("[resolvers.inbox] ")
|
||||||
limit = limit - len(chat_users)
|
limit = limit - len(chat_users)
|
||||||
except Exception:
|
except Exception:
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -1,11 +1,12 @@
|
||||||
import json
|
import json
|
||||||
|
from datetime import datetime, timezone, timedelta
|
||||||
from auth.authenticate import login_required
|
from auth.authenticate import login_required
|
||||||
from auth.credentials import AuthCredentials
|
from auth.credentials import AuthCredentials
|
||||||
from base.redis import redis
|
from base.redis import redis
|
||||||
from base.resolvers import query
|
from base.resolvers import query
|
||||||
from base.orm import local_session
|
from base.orm import local_session
|
||||||
from orm.user import AuthorFollower, User
|
from orm.user import AuthorFollower, User
|
||||||
|
from resolvers.inbox.load import load_messages
|
||||||
|
|
||||||
|
|
||||||
@query.field("searchRecipients")
|
@query.field("searchRecipients")
|
||||||
|
@ -47,3 +48,48 @@ async def search_recipients(_, info, query: str, limit: int = 50, offset: int =
|
||||||
"members": list(result),
|
"members": list(result),
|
||||||
"error": None
|
"error": None
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@query.field("searchMessages")
|
||||||
|
@login_required
|
||||||
|
async def search_user_chats(by, messages, user_id: int, limit, offset):
|
||||||
|
cids = set([])
|
||||||
|
cids.union(set(await redis.execute("SMEMBERS", "chats_by_user/" + str(user_id))))
|
||||||
|
messages = []
|
||||||
|
|
||||||
|
by_author = by.get('author')
|
||||||
|
if by_author:
|
||||||
|
# all author's messages
|
||||||
|
cids.union(set(await redis.execute("SMEMBERS", f"chats_by_user/{by_author}")))
|
||||||
|
# author's messages in filtered chat
|
||||||
|
messages.union(set(filter(lambda m: m["author"] == by_author, list(messages))))
|
||||||
|
for c in cids:
|
||||||
|
c = c.decode('utf-8')
|
||||||
|
messages = await load_messages(c, limit, offset)
|
||||||
|
|
||||||
|
body_like = by.get('body')
|
||||||
|
if body_like:
|
||||||
|
# search in all messages in all user's chats
|
||||||
|
for c in cids:
|
||||||
|
# FIXME: use redis scan here
|
||||||
|
c = c.decode('utf-8')
|
||||||
|
mmm = await load_messages(c, limit, offset)
|
||||||
|
for m in mmm:
|
||||||
|
if body_like in m["body"]:
|
||||||
|
messages.add(m)
|
||||||
|
else:
|
||||||
|
# search in chat's messages
|
||||||
|
messages.extend(filter(lambda m: body_like in m["body"], list(messages)))
|
||||||
|
|
||||||
|
days = by.get("days")
|
||||||
|
if days:
|
||||||
|
messages.extend(filter(
|
||||||
|
list(messages),
|
||||||
|
key=lambda m: (
|
||||||
|
datetime.now(tz=timezone.utc) - int(m["createdAt"]) < timedelta(days=by["days"])
|
||||||
|
)
|
||||||
|
))
|
||||||
|
return {
|
||||||
|
"messages": messages,
|
||||||
|
"error": None
|
||||||
|
}
|
||||||
|
|
|
@ -270,6 +270,7 @@ type Query {
|
||||||
loadMessagesBy(by: MessagesBy!, limit: Int, offset: Int): Result!
|
loadMessagesBy(by: MessagesBy!, limit: Int, offset: Int): Result!
|
||||||
loadRecipients(limit: Int, offset: Int): Result!
|
loadRecipients(limit: Int, offset: Int): Result!
|
||||||
searchRecipients(query: String!, limit: Int, offset: Int): Result!
|
searchRecipients(query: String!, limit: Int, offset: Int): Result!
|
||||||
|
searchMessages(by: MessagesBy!, limit: Int, offset: Int): Result!
|
||||||
|
|
||||||
# auth
|
# auth
|
||||||
isEmailUsed(email: String!): Boolean!
|
isEmailUsed(email: String!): Boolean!
|
||||||
|
|
Loading…
Reference in New Issue
Block a user