Fix syncing of contact request local state

This commit is contained in:
Roman Volosovskyi 2023-02-17 11:02:03 +01:00
parent 7c7c3a1f13
commit 6cdc0ed5a1
No known key found for this signature in database
GPG Key ID: 0238A4B5ECEE70DE
4 changed files with 26 additions and 11 deletions

View File

@ -1 +1 @@
0.135.1 0.135.2

View File

@ -279,7 +279,7 @@ func (c *Contact) DismissContactRequest(clock uint64) ContactRequestProcessingRe
// Remote actions // Remote actions
func (c *Contact) contactRequestRetracted(clock uint64, r ContactRequestProcessingResponse) ContactRequestProcessingResponse { func (c *Contact) contactRequestRetracted(clock uint64, syncing bool, r ContactRequestProcessingResponse) ContactRequestProcessingResponse {
if clock <= c.ContactRequestRemoteClock { if clock <= c.ContactRequestRemoteClock {
return r return r
} }
@ -289,7 +289,7 @@ func (c *Contact) contactRequestRetracted(clock uint64, r ContactRequestProcessi
// the side it was sent from. The only exception is when the contact // the side it was sent from. The only exception is when the contact
// request has been explicitly dismissed, in which case we don't // request has been explicitly dismissed, in which case we don't
// change state // change state
if c.ContactRequestLocalState != ContactRequestStateDismissed { if c.ContactRequestLocalState != ContactRequestStateDismissed && !syncing {
c.ContactRequestLocalClock = clock c.ContactRequestLocalClock = clock
c.ContactRequestLocalState = ContactRequestStateNone c.ContactRequestLocalState = ContactRequestStateNone
} }
@ -299,8 +299,8 @@ func (c *Contact) contactRequestRetracted(clock uint64, r ContactRequestProcessi
return r return r
} }
func (c *Contact) ContactRequestRetracted(clock uint64) ContactRequestProcessingResponse { func (c *Contact) ContactRequestRetracted(clock uint64, syncing bool) ContactRequestProcessingResponse {
return c.contactRequestRetracted(clock, ContactRequestProcessingResponse{}) return c.contactRequestRetracted(clock, syncing, ContactRequestProcessingResponse{})
} }
func (c *Contact) contactRequestReceived(clock uint64, r ContactRequestProcessingResponse) ContactRequestProcessingResponse { func (c *Contact) contactRequestReceived(clock uint64, r ContactRequestProcessingResponse) ContactRequestProcessingResponse {
@ -379,7 +379,7 @@ func contactIDFromPublicKeyString(key string) (string, error) {
return contactIDFromPublicKey(pubKey), nil return contactIDFromPublicKey(pubKey), nil
} }
func (c *Contact) processSyncContactRequestState(remoteState ContactRequestState, remoteClock uint64, localState ContactRequestState, localClock uint64) { func (c *Contact) ProcessSyncContactRequestState(remoteState ContactRequestState, remoteClock uint64, localState ContactRequestState, localClock uint64) {
// We process the two separately, first local state // We process the two separately, first local state
switch localState { switch localState {
case ContactRequestStateDismissed: case ContactRequestStateDismissed:
@ -395,7 +395,7 @@ func (c *Contact) processSyncContactRequestState(remoteState ContactRequestState
case ContactRequestStateReceived: case ContactRequestStateReceived:
c.ContactRequestReceived(remoteClock) c.ContactRequestReceived(remoteClock)
case ContactRequestStateNone: case ContactRequestStateNone:
c.ContactRequestRetracted(remoteClock) c.ContactRequestRetracted(remoteClock, true)
} }
} }
@ -481,7 +481,7 @@ func (c *Contact) ContactRequestPropagatedStateReceived(state *protobuf.ContactR
if remoteState == ContactRequestStateSent { if remoteState == ContactRequestStateSent {
response = c.contactRequestReceived(remoteClock, response) response = c.contactRequestReceived(remoteClock, response)
} else if remoteState == ContactRequestStateNone { } else if remoteState == ContactRequestStateNone {
response = c.contactRequestRetracted(remoteClock, response) response = c.contactRequestRetracted(remoteClock, false, response)
} }
} }

View File

@ -402,7 +402,7 @@ func TestContactContactRequestRetracted(t *testing.T) {
for testNum, tc := range tests { for testNum, tc := range tests {
contact := tc.Contact() contact := tc.Contact()
contact.ContactRequestRetracted(clock) contact.ContactRequestRetracted(clock, false)
validateContactTest(t, contact, tc, testNum+1) validateContactTest(t, contact, tc, testNum+1)
} }
@ -765,3 +765,18 @@ func TestPrimaryName(t *testing.T) {
require.Equal(t, "nickname", contact.PrimaryName()) require.Equal(t, "nickname", contact.PrimaryName())
require.Equal(t, "alias", contact.SecondaryName()) require.Equal(t, "alias", contact.SecondaryName())
} }
func TestProcessSyncContactRequestState(t *testing.T) {
c := &Contact{}
c.ContactRequestLocalState = ContactRequestStateNone
c.ContactRequestLocalClock = 1
c.ContactRequestRemoteState = ContactRequestStateNone
c.ContactRequestRemoteClock = 1
c.ProcessSyncContactRequestState(ContactRequestStateNone, 2, ContactRequestStateSent, 2)
// Here we need to confirm that resulting Local/RemoteState is equal
// to what comes from the contact sync message, otherwise it will be inconsistent
require.Equal(t, ContactRequestStateSent, c.ContactRequestLocalState)
require.Equal(t, ContactRequestStateNone, c.ContactRequestRemoteState)
}

View File

@ -483,7 +483,7 @@ func (m *Messenger) HandleSyncInstallationContact(state *ReceivedMessageState, m
if message.ContactRequestRemoteClock != 0 || message.ContactRequestLocalClock != 0 { if message.ContactRequestRemoteClock != 0 || message.ContactRequestLocalClock != 0 {
// Some local action about contact requests were performed, // Some local action about contact requests were performed,
// process them // process them
contact.processSyncContactRequestState( contact.ProcessSyncContactRequestState(
ContactRequestState(message.ContactRequestRemoteState), ContactRequestState(message.ContactRequestRemoteState),
uint64(message.ContactRequestRemoteClock), uint64(message.ContactRequestRemoteClock),
ContactRequestState(message.ContactRequestLocalState), ContactRequestState(message.ContactRequestLocalState),
@ -888,7 +888,7 @@ func (m *Messenger) handleRetractContactRequest(contact *Contact, message protob
} }
m.logger.Debug("handling retracted contact request", zap.Uint64("clock", message.Clock)) m.logger.Debug("handling retracted contact request", zap.Uint64("clock", message.Clock))
r := contact.ContactRequestRetracted(message.Clock) r := contact.ContactRequestRetracted(message.Clock, false)
if !r.processed { if !r.processed {
m.logger.Debug("not handling retract since clock lower") m.logger.Debug("not handling retract since clock lower")
return nil return nil