feat: backup display name improvements

- Display name is now backed up only as a part of `protobuf.BackedUpProfile` message,
it is not backed up via `protobuf.SyncSetting` any more (this refers only to backing up to
and fetching data from waku, regular syncing (among devices) remains unchanged)

- When saving the display name fetched from waku, before a clock was set to the current
time when that operation is made, which was incorrect, now we're using the clock from
backed up message (`SaveSyncDisplayName` function)
This commit is contained in:
Sale Djenic 2023-03-30 12:18:13 +02:00 committed by saledjenic
parent 4f013cc7af
commit c791163136
7 changed files with 38 additions and 29 deletions

View File

@ -557,7 +557,7 @@ func (s *MessengerCommunitiesSuite) TestCommunityContactCodeAdvertisement() {
s.joinCommunity(community, s.alice) s.joinCommunity(community, s.alice)
// Trigger ContactCodeAdvertisement // Trigger ContactCodeAdvertisement
err := s.bob.SetDisplayName("bobby", true) err := s.bob.SetDisplayName("bobby")
s.Require().NoError(err) s.Require().NoError(err)
err = s.bob.SetBio("I like P2P chats") err = s.bob.SetBio("I like P2P chats")
s.Require().NoError(err) s.Require().NoError(err)

View File

@ -89,7 +89,7 @@ func (m *Messenger) BackupData(ctx context.Context) (uint64, error) {
if err != nil { if err != nil {
return 0, err return 0, err
} }
_, settings, errors := m.prepareSyncSettingsMessages(clock) _, settings, errors := m.prepareSyncSettingsMessages(clock, true)
if len(errors) != 0 { if len(errors) != 0 {
// return just the first error, the others have been logged // return just the first error, the others have been logged
return 0, errors[0] return 0, errors[0]

View File

@ -6,7 +6,6 @@ import (
"go.uber.org/zap" "go.uber.org/zap"
"github.com/status-im/status-go/images" "github.com/status-im/status-go/images"
"github.com/status-im/status-go/multiaccounts/settings"
"github.com/status-im/status-go/protocol/protobuf" "github.com/status-im/status-go/protocol/protobuf"
"github.com/status-im/status-go/protocol/wakusync" "github.com/status-im/status-go/protocol/wakusync"
) )
@ -73,25 +72,19 @@ func (m *Messenger) handleBackedUpProfile(message *protobuf.BackedUpProfile, bac
return nil return nil
} }
dbDisplayNameClock, err := m.settings.GetSettingLastSynced(settings.DisplayName)
if err != nil {
return err
}
contentSet := false contentSet := false
response := wakusync.WakuBackedUpDataResponse{ response := wakusync.WakuBackedUpDataResponse{
Profile: &wakusync.BackedUpProfile{}, Profile: &wakusync.BackedUpProfile{},
} }
if dbDisplayNameClock < message.DisplayNameClock { err := m.SaveSyncDisplayName(message.DisplayName, message.DisplayNameClock)
err = m.SetDisplayName(message.DisplayName, false) if err != nil {
if err != nil { return err
return err
}
contentSet = true
response.AddDisplayName(message.DisplayName)
} }
contentSet = true
response.AddDisplayName(message.DisplayName)
syncWithBackedUpImages := false syncWithBackedUpImages := false
dbImages, err := m.multiAccounts.GetIdentityImages(message.KeyUid) dbImages, err := m.multiAccounts.GetIdentityImages(message.KeyUid)
if err != nil { if err != nil {
@ -155,6 +148,11 @@ func (m *Messenger) handleBackedUpSettings(message *protobuf.SyncSetting) error
return nil return nil
} }
// DisplayName is recovered via `protobuf.BackedUpProfile` message
if message.GetType() == protobuf.SyncSetting_DISPLAY_NAME {
return nil
}
settingField, err := m.extractAndSaveSyncSetting(message) settingField, err := m.extractAndSaveSyncSetting(message)
if err != nil { if err != nil {
m.logger.Warn("failed to handle SyncSetting from backed up message", zap.Error(err)) m.logger.Warn("failed to handle SyncSetting from backed up message", zap.Error(err))

View File

@ -143,7 +143,7 @@ func (s *MessengerBackupSuite) TestBackupProfile() {
// Create bob1 // Create bob1
bob1 := s.m bob1 := s.m
err := bob1.SetDisplayName(bob1DisplayName, true) err := bob1.SetDisplayName(bob1DisplayName)
s.Require().NoError(err) s.Require().NoError(err)
bob1KeyUID := bob1.account.KeyUID bob1KeyUID := bob1.account.KeyUID
imagesExpected := fmt.Sprintf(`[{"keyUid":"%s","type":"large","uri":"","width":240,"height":300,"fileSize":1024,"resizeTarget":240,"clock":0},{"keyUid":"%s","type":"thumbnail","uri":"","width":80,"height":80,"fileSize":256,"resizeTarget":80,"clock":0}]`, imagesExpected := fmt.Sprintf(`[{"keyUid":"%s","type":"large","uri":"","width":240,"height":300,"fileSize":1024,"resizeTarget":240,"clock":0},{"keyUid":"%s","type":"thumbnail","uri":"","width":80,"height":80,"fileSize":256,"resizeTarget":80,"clock":0}]`,

View File

@ -50,7 +50,7 @@ func ValidateDisplayName(displayName *string) error {
return nil return nil
} }
func (m *Messenger) SetDisplayName(displayName string, publishChange bool) error { func (m *Messenger) SetDisplayName(displayName string) error {
currDisplayName, err := m.settings.DisplayName() currDisplayName, err := m.settings.DisplayName()
if err != nil { if err != nil {
return err return err
@ -64,7 +64,7 @@ func (m *Messenger) SetDisplayName(displayName string, publishChange bool) error
return err return err
} }
m.account.Name = displayName // We might need to do the same when syncing settings? m.account.Name = displayName
err = m.multiAccounts.SaveAccount(*m.account) err = m.multiAccounts.SaveAccount(*m.account)
if err != nil { if err != nil {
return err return err
@ -75,16 +75,22 @@ func (m *Messenger) SetDisplayName(displayName string, publishChange bool) error
return err return err
} }
if publishChange { err = m.resetLastPublishedTimeForChatIdentity()
err = m.resetLastPublishedTimeForChatIdentity() if err != nil {
if err != nil { return err
return err
}
return m.publishContactCode()
} }
return nil return m.publishContactCode()
}
func (m *Messenger) SaveSyncDisplayName(displayName string, clock uint64) error {
err := m.settings.SaveSyncSetting(settings.DisplayName, displayName, clock)
if err != nil {
return err
}
m.account.Name = displayName
return m.multiAccounts.SaveAccount(*m.account)
} }
func ValidateBio(bio *string) error { func ValidateBio(bio *string) error {

View File

@ -13,7 +13,7 @@ import (
) )
// syncSettings syncs all settings that are syncable // syncSettings syncs all settings that are syncable
func (m *Messenger) prepareSyncSettingsMessages(currentClock uint64) (resultRaw []*common.RawMessage, resultSync []*protobuf.SyncSetting, errors []error) { func (m *Messenger) prepareSyncSettingsMessages(currentClock uint64, prepareForBackup bool) (resultRaw []*common.RawMessage, resultSync []*protobuf.SyncSetting, errors []error) {
s, err := m.settings.GetSettings() s, err := m.settings.GetSettings()
if err != nil { if err != nil {
errors = append(errors, err) errors = append(errors, err)
@ -26,6 +26,11 @@ func (m *Messenger) prepareSyncSettingsMessages(currentClock uint64) (resultRaw
for _, sf := range settings.SettingFieldRegister { for _, sf := range settings.SettingFieldRegister {
if sf.CanSync(settings.FromStruct) { if sf.CanSync(settings.FromStruct) {
// DisplayName is backed up via `protobuf.BackedUpProfile` message.
if prepareForBackup && sf.SyncProtobufFactory().SyncSettingProtobufType() == protobuf.SyncSetting_DISPLAY_NAME {
continue
}
// Pull clock from the db // Pull clock from the db
clock, err := m.settings.GetSettingLastSynced(sf) clock, err := m.settings.GetSettingLastSynced(sf)
if err != nil { if err != nil {
@ -56,7 +61,7 @@ func (m *Messenger) syncSettings(rawMessageHandler RawMessageHandler) error {
logger := m.logger.Named("syncSettings") logger := m.logger.Named("syncSettings")
clock, _ := m.getLastClockWithRelatedChat() clock, _ := m.getLastClockWithRelatedChat()
rawMessages, _, errors := m.prepareSyncSettingsMessages(clock) rawMessages, _, errors := m.prepareSyncSettingsMessages(clock, false)
if len(errors) != 0 { if len(errors) != 0 {
// return just the first error, the others have been logged // return just the first error, the others have been logged

View File

@ -833,7 +833,7 @@ func (api *PublicAPI) SendContactUpdate(ctx context.Context, contactID, name, pi
} }
func (api *PublicAPI) SetDisplayName(ctx context.Context, displayName string) error { func (api *PublicAPI) SetDisplayName(ctx context.Context, displayName string) error {
return api.service.messenger.SetDisplayName(displayName, true) return api.service.messenger.SetDisplayName(displayName)
} }
func (api *PublicAPI) MarkAsTrusted(ctx context.Context, contactID string) error { func (api *PublicAPI) MarkAsTrusted(ctx context.Context, contactID string) error {