use redis for storing messages - next
This commit is contained in:
parent
c7639f38ae
commit
ca9c3e0cee
|
@ -25,8 +25,11 @@ class Redis:
|
||||||
async def execute(self, command, *args, **kwargs):
|
async def execute(self, command, *args, **kwargs):
|
||||||
return await self._instance.execute_command(command, *args, **kwargs)
|
return await self._instance.execute_command(command, *args, **kwargs)
|
||||||
|
|
||||||
async def lrange(self, name, start, end):
|
async def lrange(self, key, start, stop):
|
||||||
return await self._instance.lrange(name, start, end)
|
return await self._instance.lrange(key, start, stop)
|
||||||
|
|
||||||
|
async def mget(self, key, *keys):
|
||||||
|
return await self._instance.mget(key, *keys)
|
||||||
|
|
||||||
|
|
||||||
async def test():
|
async def test():
|
||||||
|
|
|
@ -49,6 +49,7 @@ async def create_chat(_, info, description):
|
||||||
}
|
}
|
||||||
|
|
||||||
await redis.execute("SET", f"chats/{chat_id}", json.dumps(chat))
|
await redis.execute("SET", f"chats/{chat_id}", json.dumps(chat))
|
||||||
|
await redis.execute("SET", f"chats/{chat_id}/next_message_id", 0)
|
||||||
|
|
||||||
return { "chatId" : chat_id }
|
return { "chatId" : chat_id }
|
||||||
|
|
||||||
|
@ -60,7 +61,11 @@ async def enter_chat(_, info, chatId):
|
||||||
return { "error" : "chat not exist" }
|
return { "error" : "chat not exist" }
|
||||||
chat = json.loads(chat)
|
chat = json.loads(chat)
|
||||||
|
|
||||||
messages = await redis.lrange(f"chats/{chatId}/messages", 0, 10)
|
message_ids = await redis.lrange(f"chats/{chatId}/message_ids", 0, 10)
|
||||||
|
messages = []
|
||||||
|
if message_ids:
|
||||||
|
message_keys = [f"chats/{chatId}/messages/{id.decode('UTF-8')}" for id in message_ids]
|
||||||
|
messages = await redis.mget(*message_keys)
|
||||||
messages = [json.loads(msg) for msg in messages]
|
messages = [json.loads(msg) for msg in messages]
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
@ -77,15 +82,20 @@ async def create_message(_, info, chatId, body, replyTo = None):
|
||||||
if not chat:
|
if not chat:
|
||||||
return { "error" : "chat not exist" }
|
return { "error" : "chat not exist" }
|
||||||
|
|
||||||
|
message_id = await redis.execute("GET", f"chats/{chatId}/next_message_id")
|
||||||
|
message_id = int(message_id)
|
||||||
|
|
||||||
new_message = {
|
new_message = {
|
||||||
"chatId" : chatId,
|
"chatId" : chatId,
|
||||||
|
"id" : message_id,
|
||||||
"author" : user.slug,
|
"author" : user.slug,
|
||||||
"body" : body,
|
"body" : body,
|
||||||
"replyTo" : replyTo
|
"replyTo" : replyTo
|
||||||
}
|
}
|
||||||
|
|
||||||
message_id = await redis.execute("LPUSH", f"chats/{chatId}/messages", json.dumps(new_message))
|
await redis.execute("SET", f"chats/{chatId}/messages/{message_id}", json.dumps(new_message))
|
||||||
new_message["id"] = message_id
|
await redis.execute("LPUSH", f"chats/{chatId}/message_ids", str(message_id))
|
||||||
|
await redis.execute("SET", f"chats/{chatId}/next_message_id", str(message_id + 1))
|
||||||
|
|
||||||
return {"message" : new_message}
|
return {"message" : new_message}
|
||||||
|
|
||||||
|
@ -113,41 +123,44 @@ def check_and_get_message(message_id, user_id, session) :
|
||||||
|
|
||||||
@mutation.field("updateMessage")
|
@mutation.field("updateMessage")
|
||||||
@login_required
|
@login_required
|
||||||
async def update_message(_, info, id, body):
|
async def update_message(_, info, chatId, id, body):
|
||||||
auth = info.context["request"].auth
|
user = info.context["request"].user
|
||||||
user_id = auth.user_id
|
|
||||||
|
|
||||||
with local_session() as session:
|
chat = await redis.execute("GET", f"chats/{chatId}")
|
||||||
try:
|
if not chat:
|
||||||
message = check_and_get_message(id, user_id, session)
|
return { "error" : "chat not exist" }
|
||||||
except Exception as err:
|
|
||||||
return {"error" : err}
|
|
||||||
|
|
||||||
message.body = body
|
message = await redis.execute("GET", f"chats/{chatId}/messages/{id}")
|
||||||
session.commit()
|
if not message:
|
||||||
|
return { "error" : "message not exist" }
|
||||||
|
|
||||||
result = MessageResult("UPDATED", message)
|
message = json.loads(message)
|
||||||
await MessageSubscriptions.put(result)
|
message["body"] = body
|
||||||
|
|
||||||
|
await redis.execute("SET", f"chats/{chatId}/messages/{id}", json.dumps(message))
|
||||||
|
|
||||||
|
#result = MessageResult("UPDATED", message)
|
||||||
|
#await MessageSubscriptions.put(result)
|
||||||
|
|
||||||
return {"message" : message}
|
return {"message" : message}
|
||||||
|
|
||||||
@mutation.field("deleteMessage")
|
@mutation.field("deleteMessage")
|
||||||
@login_required
|
@login_required
|
||||||
async def delete_message(_, info, id):
|
async def delete_message(_, info, chatId, id):
|
||||||
auth = info.context["request"].auth
|
user = info.context["request"].user
|
||||||
user_id = auth.user_id
|
|
||||||
|
|
||||||
with local_session() as session:
|
chat = await redis.execute("GET", f"chats/{chatId}")
|
||||||
try:
|
if not chat:
|
||||||
message = check_and_get_message(id, user_id, session)
|
return { "error" : "chat not exist" }
|
||||||
except Exception as err:
|
|
||||||
return {"error" : err}
|
|
||||||
|
|
||||||
session.delete(message)
|
count = await redis.execute("LREM", f"chats/{chatId}/message_ids", 0, str(id))
|
||||||
session.commit()
|
if count == 0:
|
||||||
|
return { "error" : "message not exist" }
|
||||||
|
|
||||||
result = MessageResult("DELETED", message)
|
await redis.execute("DEL", f"chats/{chatId}/messages/{id}")
|
||||||
await MessageSubscriptions.put(result)
|
|
||||||
|
#result = MessageResult("DELETED", message)
|
||||||
|
#await MessageSubscriptions.put(result)
|
||||||
|
|
||||||
return {}
|
return {}
|
||||||
|
|
||||||
|
|
|
@ -101,7 +101,7 @@ type Mutation {
|
||||||
createChat(description: String): CreateChatResult!
|
createChat(description: String): CreateChatResult!
|
||||||
createMessage(chatId: String!, body: String!, replyTo: Int): MessageResult!
|
createMessage(chatId: String!, body: String!, replyTo: Int): MessageResult!
|
||||||
updateMessage(chatId: String!, id: Int!, body: String!): MessageResult!
|
updateMessage(chatId: String!, id: Int!, body: String!): MessageResult!
|
||||||
deleteMessage(chatId: String!, messageId: Int!): Result!
|
deleteMessage(chatId: String!, id: Int!): Result!
|
||||||
|
|
||||||
# auth
|
# auth
|
||||||
confirmEmail(token: String!): AuthResult!
|
confirmEmail(token: String!): AuthResult!
|
||||||
|
|
Loading…
Reference in New Issue
Block a user