Skip to content

feat(streams): Add the possibility to have per stream ids#3793

Open
ndyakov wants to merge 2 commits intomasterfrom
ndyakov/stream-ids
Open

feat(streams): Add the possibility to have per stream ids#3793
ndyakov wants to merge 2 commits intomasterfrom
ndyakov/stream-ids

Conversation

@ndyakov
Copy link
Copy Markdown
Member

@ndyakov ndyakov commented Apr 24, 2026

fixes #3694


Note

Medium Risk
Updates the XRead command builder and public XReadArgs API, which could affect downstream callers that construct XREAD arguments (especially around ID handling) despite being largely additive and covered by new tests.

Overview
Adds support for per-stream resume IDs in XRead by extending XReadArgs with an IDs []string field and updating argument construction to append those IDs (one per stream) when provided.

Clarifies semantics via comments and enforces precedence (IDs overrides ID), and adds new tests covering per-stream ID reads and the precedence behavior.

Reviewed by Cursor Bugbot for commit ce948f9. Bugbot is set up for automated code reviews on this repo. Configure here.

@jit-ci
Copy link
Copy Markdown

jit-ci Bot commented Apr 24, 2026

🛡️ Jit Security Scan Results

CRITICAL HIGH MEDIUM

✅ No security findings were detected in this PR


Security scan by Jit

Copy link
Copy Markdown
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull request overview

Adds per-stream resume IDs support for XREAD to address #3694, enabling callers to specify different IDs for each stream.

Changes:

  • Extends XReadArgs with IDs []string (per-stream IDs) and documents precedence over ID.
  • Updates XRead argument construction to append per-stream IDs when provided.
  • Adds tests for per-stream IDs and for IDs precedence over ID.

Reviewed changes

Copilot reviewed 2 out of 2 changed files in this pull request and generated 2 comments.

File Description
stream_commands.go Adds XReadArgs.IDs and updates XRead arg building logic to support per-stream IDs.
commands_test.go Adds test coverage for per-stream IDs and precedence behavior.

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment thread stream_commands.go
Comment on lines +196 to +205
Streams []string // list of streams, or streams and ids e.g. stream1 stream2 id1 id2
Count int64
Block time.Duration
ID string
// ID is a single ID applied to every stream in Streams.
// When reading from multiple streams that require different IDs,
// use IDs instead so each stream can be resumed from its own last ID.
ID string
// IDs is the per-stream list of IDs (one per entry in Streams).
// When non-empty, IDs takes precedence over ID.
IDs []string
Copy link

Copilot AI Apr 24, 2026

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The Streams field comment says it can contain both stream names and IDs, but IDs is documented as "one per entry in Streams" (which only makes sense if Streams contains stream names only). This is contradictory and will confuse callers, especially now that there are multiple supported input shapes. Please clarify the docs to explicitly describe the supported encodings (legacy Streams containing keys+ids vs Streams containing only keys when using ID/IDs) and how they interact/are mutually exclusive.

Copilot uses AI. Check for mistakes.
Comment thread stream_commands.go
Comment on lines +228 to +233
switch {
case len(a.IDs) > 0:
for _, id := range a.IDs {
args = append(args, id)
}
case a.ID != "":
Copy link

Copilot AI Apr 24, 2026

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

When IDs is non-empty, the code appends all IDs without checking that the count matches the number of stream keys being read. If these lengths differ, Redis will return a generic arity error that can be hard to diagnose. Consider validating len(a.IDs) == len(a.Streams) when IDs is used and returning a client-side error (e.g., via cmd.SetErr) with a clear message.

Copilot uses AI. Check for mistakes.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

XREAD accept multiple streams but only one id resulting multiple issues

2 participants