Add per-channel attachResume control to ARTRealtimeChannelOptions #2099
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR adds the ability to control attach resume behavior on a per-channel basis, allowing clients to disable automatic resume and rely solely on message history when channels reconnect within the 2-minute TTL.
Problem
Previously, attach resume behavior was managed automatically at the channel level based on state transitions. Clients had no way to override this behavior for specific channels, meaning they would always receive missed messages during reconnection within the TTL period. Some use cases require disabling this behavior to rely exclusively on message history.
Solution
Added a new
attachResumeproperty toARTRealtimeChannelOptions:@property (nonatomic, nullable) NSNumber *attachResume;The property behavior:
nil(default): Uses existing automatic behavior based on channel state@YES: Forces attach resume to be enabled@NO: Forces attach resume to be disabled, allowing sole reliance on message historyUsage Example
Message Differentiation
The existing
ARTChannelStateChange.resumedproperty can be used to differentiate between messages received during normal operation vs. after a resumed attachment:Implementation Details
ARTRealtimeChannelOptionswith proper getter/setter and copy supportshouldUseAttachResumehelper method that checks channel optionsFixes #2042.
💬 Share your feedback on Copilot coding agent for the chance to win a $200 gift card! Click here to start the survey.