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:
parent
4f013cc7af
commit
c791163136
|
@ -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)
|
||||||
|
|
|
@ -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]
|
||||||
|
|
|
@ -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))
|
||||||
|
|
|
@ -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}]`,
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
Loading…
Reference in New Issue