lib/config, lib/model: Don't save on every pending folder/device update (fixes #5888) (#5890)

Wrapper methods generally don't save by themselves.
This commit is contained in:
Jakob Borg 2019-07-27 12:05:00 +02:00 committed by Audrius Butkevicius
parent 4e22a96602
commit 669bcb748f
2 changed files with 2 additions and 4 deletions

View File

@ -501,8 +501,6 @@ func (w *wrapper) MyName() string {
} }
func (w *wrapper) AddOrUpdatePendingDevice(device protocol.DeviceID, name, address string) { func (w *wrapper) AddOrUpdatePendingDevice(device protocol.DeviceID, name, address string) {
defer w.Save()
w.mut.Lock() w.mut.Lock()
defer w.mut.Unlock() defer w.mut.Unlock()
@ -524,8 +522,6 @@ func (w *wrapper) AddOrUpdatePendingDevice(device protocol.DeviceID, name, addre
} }
func (w *wrapper) AddOrUpdatePendingFolder(id, label string, device protocol.DeviceID) { func (w *wrapper) AddOrUpdatePendingFolder(id, label string, device protocol.DeviceID) {
defer w.Save()
w.mut.Lock() w.mut.Lock()
defer w.mut.Unlock() defer w.mut.Unlock()

View File

@ -1075,6 +1075,7 @@ func (m *model) ClusterConfig(deviceID protocol.DeviceID, cm protocol.ClusterCon
continue continue
} }
m.cfg.AddOrUpdatePendingFolder(folder.ID, folder.Label, deviceID) m.cfg.AddOrUpdatePendingFolder(folder.ID, folder.Label, deviceID)
changed = true
events.Default.Log(events.FolderRejected, map[string]string{ events.Default.Log(events.FolderRejected, map[string]string{
"folder": folder.ID, "folder": folder.ID,
"folderLabel": folder.Label, "folderLabel": folder.Label,
@ -1769,6 +1770,7 @@ func (m *model) OnHello(remoteID protocol.DeviceID, addr net.Addr, hello protoco
cfg, ok := m.cfg.Device(remoteID) cfg, ok := m.cfg.Device(remoteID)
if !ok { if !ok {
m.cfg.AddOrUpdatePendingDevice(remoteID, hello.DeviceName, addr.String()) m.cfg.AddOrUpdatePendingDevice(remoteID, hello.DeviceName, addr.String())
_ = m.cfg.Save() // best effort
events.Default.Log(events.DeviceRejected, map[string]string{ events.Default.Log(events.DeviceRejected, map[string]string{
"name": hello.DeviceName, "name": hello.DeviceName,
"device": remoteID.String(), "device": remoteID.String(),