mirror of
https://github.com/signalapp/Signal-Server
synced 2026-04-21 11:18:03 +01:00
Multi-recipient message views
This adds support for storing multi-recipient message payloads and recipient views in Redis, and only fanning out on delivery or persistence. Phase 1: confirm storage and retrieval correctness.
This commit is contained in:
@@ -1,9 +1,12 @@
|
||||
local queueKey = KEYS[1]
|
||||
local queueMetadataKey = KEYS[2]
|
||||
local queueTotalIndexKey = KEYS[3]
|
||||
local message = ARGV[1]
|
||||
local currentTime = ARGV[2]
|
||||
local guid = ARGV[3]
|
||||
-- inserts a message into a device's queue, and updates relevant associated data
|
||||
-- returns a number, the queue-local message ID (useful for testing)
|
||||
|
||||
local queueKey = KEYS[1] -- sorted set of Envelopes for a device, by queue-local ID
|
||||
local queueMetadataKey = KEYS[2] -- hash of message GUID to queue-local IDs
|
||||
local queueTotalIndexKey = KEYS[3] -- sorted set of all queues in the shard, by timestamp of oldest message
|
||||
local message = ARGV[1] -- [bytes] the Envelope to insert
|
||||
local currentTime = ARGV[2] -- [number] the message timestamp, to sort the queue in the queueTotalIndex
|
||||
local guid = ARGV[3] -- [string] the message GUID
|
||||
|
||||
if redis.call("HEXISTS", queueMetadataKey, guid) == 1 then
|
||||
return tonumber(redis.call("HGET", queueMetadataKey, guid))
|
||||
@@ -14,9 +17,8 @@ local messageId = redis.call("HINCRBY", queueMetadataKey, "counter", 1)
|
||||
redis.call("ZADD", queueKey, "NX", messageId, message)
|
||||
|
||||
redis.call("HSET", queueMetadataKey, guid, messageId)
|
||||
|
||||
redis.call("EXPIRE", queueKey, 7776000) -- 90 days
|
||||
redis.call("EXPIRE", queueMetadataKey, 7776000) -- 90 days
|
||||
redis.call("EXPIRE", queueKey, 2678400) -- 31 days
|
||||
redis.call("EXPIRE", queueMetadataKey, 2678400) -- 31 days
|
||||
|
||||
redis.call("ZADD", queueTotalIndexKey, "NX", currentTime, queueKey)
|
||||
return messageId
|
||||
|
||||
Reference in New Issue
Block a user