Page MenuHomePhabricator

[keyserver] Fix message creation when some (but not all) messages already exist
ClosedPublic

Authored by ashoat on Feb 18 2023, 12:24 PM.
Tags
None
Referenced Files
F3873463: D6768.diff
Thu, Jan 23, 8:00 AM
Unknown Object (File)
Tue, Jan 21, 2:49 AM
Unknown Object (File)
Sun, Jan 19, 10:26 AM
Unknown Object (File)
Sun, Jan 19, 10:26 AM
Unknown Object (File)
Sun, Jan 19, 9:20 AM
Unknown Object (File)
Thu, Jan 9, 5:40 PM
Unknown Object (File)
Thu, Jan 9, 5:37 PM
Unknown Object (File)
Thu, Jan 9, 12:19 PM
Subscribers
None

Details

Summary

threadsToMessageIndices can have the wrong index if some existingMessages get added to messageInfos before the new messages start being created. The existing code basically assumes messageInfos is empty at the start the message creation loop.

This scenario never occurs for us since an "already existing message" only occurs in the case of a client-composable message, and those messages only ever get passed to createMessages one-at-a-time. But it's still better to have this code fixed up than to have this bug.

Test Plan
  1. I created a message "first" on web that generated a notif on iOS
  2. I checked its localID in the database, and then I applied this patch to my local keyserver
  3. I create a second message "second" and saw that the notif was (incorrectly) referring to "first" before this diff, but fixed to be "second" after this diff

Diff Detail

Repository
rCOMM Comm
Lint
Lint Not Applicable
Unit
Tests Not Applicable