use redis for storing messages - next

This commit is contained in:
knst-kotov 2022-01-24 14:56:55 +03:00
parent c7639f38ae
commit ca9c3e0cee
3 changed files with 54 additions and 38 deletions

View File

@ -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():

View File

@ -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 {}

View File

@ -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!