sync: ensure monographs sync for first time ever on an existing device (#44)

This commit is contained in:
01zulfi
2025-09-06 09:33:18 +05:00
committed by GitHub
parent 34a09ad15d
commit 6e8fb81ade
2 changed files with 14 additions and 1 deletions
+4 -1
View File
@@ -263,14 +263,17 @@ namespace Notesnook.API.Hubs
if (includeMonographs)
{
var isSyncingMonographsForFirstTime = !device.HasInitialMonographsSync;
var unsyncedMonographs = ids.Where((id) => id.EndsWith(":monograph")).ToHashSet();
var unsyncedMonographIds = unsyncedMonographs.Select((id) => id.Split(":")[0]).ToArray();
var userMonographs = isResetSync
var userMonographs = isResetSync || isSyncingMonographsForFirstTime
? await Repositories.Monographs.FindAsync(m => m.UserId == userId)
: await Repositories.Monographs.FindAsync(m => m.UserId == userId && unsyncedMonographIds.Contains(m.ItemId));
if (userMonographs.Any() && !await Clients.Caller.SendMonographs(userMonographs).WaitAsync(TimeSpan.FromMinutes(10)))
throw new HubException("Client rejected monographs.");
device.HasInitialMonographsSync = true;
}
deviceService.Reset();