mirror of
https://github.com/streetwriters/notesnook-sync-server.git
synced 2026-02-12 11:12:44 +00:00
inbox: sync inbox items
This commit is contained in:
@@ -44,7 +44,7 @@ namespace Notesnook.API.Accessors
|
|||||||
public Repository<UserSettings> UsersSettings { get; }
|
public Repository<UserSettings> UsersSettings { get; }
|
||||||
public Repository<Monograph> Monographs { get; }
|
public Repository<Monograph> Monographs { get; }
|
||||||
public Repository<InboxApiKey> InboxApiKey { get; }
|
public Repository<InboxApiKey> InboxApiKey { get; }
|
||||||
public SyncItemsRepository InboxItems { get; }
|
public Repository<InboxSyncItem> InboxItems { get; }
|
||||||
|
|
||||||
public SyncItemsRepositoryAccessor(IDbContext dbContext,
|
public SyncItemsRepositoryAccessor(IDbContext dbContext,
|
||||||
|
|
||||||
@@ -72,15 +72,14 @@ namespace Notesnook.API.Accessors
|
|||||||
IMongoCollection<SyncItem> vaults,
|
IMongoCollection<SyncItem> vaults,
|
||||||
[FromKeyedServices(Collections.TagsKey)]
|
[FromKeyedServices(Collections.TagsKey)]
|
||||||
IMongoCollection<SyncItem> tags,
|
IMongoCollection<SyncItem> tags,
|
||||||
[FromKeyedServices(Collections.InboxItems)]
|
|
||||||
IMongoCollection<SyncItem> inboxItems,
|
|
||||||
|
|
||||||
Repository<UserSettings> usersSettings, Repository<Monograph> monographs,
|
Repository<UserSettings> usersSettings, Repository<Monograph> monographs,
|
||||||
Repository<InboxApiKey> inboxApiKey)
|
Repository<InboxApiKey> inboxApiKey, Repository<InboxSyncItem> inboxItems)
|
||||||
{
|
{
|
||||||
UsersSettings = usersSettings;
|
UsersSettings = usersSettings;
|
||||||
Monographs = monographs;
|
Monographs = monographs;
|
||||||
InboxApiKey = inboxApiKey;
|
InboxApiKey = inboxApiKey;
|
||||||
|
InboxItems = inboxItems;
|
||||||
Notebooks = new SyncItemsRepository(dbContext, notebooks);
|
Notebooks = new SyncItemsRepository(dbContext, notebooks);
|
||||||
Notes = new SyncItemsRepository(dbContext, notes);
|
Notes = new SyncItemsRepository(dbContext, notes);
|
||||||
Contents = new SyncItemsRepository(dbContext, content);
|
Contents = new SyncItemsRepository(dbContext, content);
|
||||||
@@ -93,7 +92,6 @@ namespace Notesnook.API.Accessors
|
|||||||
Colors = new SyncItemsRepository(dbContext, colors);
|
Colors = new SyncItemsRepository(dbContext, colors);
|
||||||
Vaults = new SyncItemsRepository(dbContext, vaults);
|
Vaults = new SyncItemsRepository(dbContext, vaults);
|
||||||
Tags = new SyncItemsRepository(dbContext, tags);
|
Tags = new SyncItemsRepository(dbContext, tags);
|
||||||
InboxItems = new SyncItemsRepository(dbContext, inboxItems);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -19,15 +19,16 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Security.Claims;
|
using System.Security.Claims;
|
||||||
|
using System.Text.Json;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Microsoft.AspNetCore.Authorization;
|
using Microsoft.AspNetCore.Authorization;
|
||||||
using Microsoft.AspNetCore.Mvc;
|
using Microsoft.AspNetCore.Mvc;
|
||||||
using MongoDB.Bson;
|
using MongoDB.Bson;
|
||||||
using Notesnook.API.Authorization;
|
using Notesnook.API.Authorization;
|
||||||
using Notesnook.API.Interfaces;
|
|
||||||
using Notesnook.API.Models;
|
using Notesnook.API.Models;
|
||||||
using Notesnook.API.Repositories;
|
using Notesnook.API.Services;
|
||||||
using Streetwriters.Common;
|
using Streetwriters.Common;
|
||||||
|
using Streetwriters.Common.Messages;
|
||||||
using Streetwriters.Data.Repositories;
|
using Streetwriters.Data.Repositories;
|
||||||
|
|
||||||
namespace Notesnook.API.Controllers
|
namespace Notesnook.API.Controllers
|
||||||
@@ -38,16 +39,16 @@ namespace Notesnook.API.Controllers
|
|||||||
{
|
{
|
||||||
private readonly Repository<InboxApiKey> InboxApiKey;
|
private readonly Repository<InboxApiKey> InboxApiKey;
|
||||||
private readonly Repository<UserSettings> UserSetting;
|
private readonly Repository<UserSettings> UserSetting;
|
||||||
private SyncItemsRepository InboxItems;
|
private Repository<InboxSyncItem> InboxItems;
|
||||||
|
|
||||||
public InboxController(
|
public InboxController(
|
||||||
Repository<InboxApiKey> inboxApiKeysRepository,
|
Repository<InboxApiKey> inboxApiKeysRepository,
|
||||||
Repository<UserSettings> userSettingsRepository,
|
Repository<UserSettings> userSettingsRepository,
|
||||||
ISyncItemsRepositoryAccessor syncItemsRepositoryAccessor)
|
Repository<InboxSyncItem> inboxItemsRepository)
|
||||||
{
|
{
|
||||||
InboxApiKey = inboxApiKeysRepository;
|
InboxApiKey = inboxApiKeysRepository;
|
||||||
UserSetting = userSettingsRepository;
|
UserSetting = userSettingsRepository;
|
||||||
InboxItems = syncItemsRepositoryAccessor.InboxItems;
|
InboxItems = inboxItemsRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
[HttpGet("api-keys")]
|
[HttpGet("api-keys")]
|
||||||
@@ -189,6 +190,18 @@ namespace Notesnook.API.Controllers
|
|||||||
request.UserId = userId;
|
request.UserId = userId;
|
||||||
request.ItemId = ObjectId.GenerateNewId().ToString();
|
request.ItemId = ObjectId.GenerateNewId().ToString();
|
||||||
await InboxItems.InsertAsync(request);
|
await InboxItems.InsertAsync(request);
|
||||||
|
new SyncDeviceService(new SyncDevice(userId, string.Empty))
|
||||||
|
.AddIdsToAllDevices([$"{request.ItemId}:inboxItems"]);
|
||||||
|
await WampServers.MessengerServer.PublishMessageAsync(MessengerServerTopics.SendSSETopic, new SendSSEMessage
|
||||||
|
{
|
||||||
|
OriginTokenId = null,
|
||||||
|
UserId = userId,
|
||||||
|
Message = new Message
|
||||||
|
{
|
||||||
|
Type = "triggerSync",
|
||||||
|
Data = JsonSerializer.Serialize(new { reason = "Inbox items updated." })
|
||||||
|
}
|
||||||
|
});
|
||||||
return Ok();
|
return Ok();
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
|
|||||||
@@ -43,6 +43,7 @@ namespace Notesnook.API.Hubs
|
|||||||
Task<bool> SendItems(SyncTransferItemV2 transferItem);
|
Task<bool> SendItems(SyncTransferItemV2 transferItem);
|
||||||
Task<bool> SendVaultKey(EncryptedData vaultKey);
|
Task<bool> SendVaultKey(EncryptedData vaultKey);
|
||||||
Task<bool> SendMonographs(IEnumerable<MonographMetadata> monographs);
|
Task<bool> SendMonographs(IEnumerable<MonographMetadata> monographs);
|
||||||
|
Task<bool> SendInboxItems(IEnumerable<InboxSyncItem> inboxItems);
|
||||||
Task PushCompleted();
|
Task PushCompleted();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -197,15 +198,20 @@ namespace Notesnook.API.Hubs
|
|||||||
|
|
||||||
public async Task<SyncV2Metadata> RequestFetch(string deviceId)
|
public async Task<SyncV2Metadata> RequestFetch(string deviceId)
|
||||||
{
|
{
|
||||||
return await HandleRequestFetch(deviceId, false);
|
return await HandleRequestFetch(deviceId, false, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<SyncV2Metadata> RequestFetchV2(string deviceId)
|
public async Task<SyncV2Metadata> RequestFetchV2(string deviceId)
|
||||||
{
|
{
|
||||||
return await HandleRequestFetch(deviceId, true);
|
return await HandleRequestFetch(deviceId, true, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task<SyncV2Metadata> HandleRequestFetch(string deviceId, bool includeMonographs)
|
public async Task<SyncV2Metadata> RequestFetchV3(string deviceId)
|
||||||
|
{
|
||||||
|
return await HandleRequestFetch(deviceId, true, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task<SyncV2Metadata> HandleRequestFetch(string deviceId, bool includeMonographs, bool includeInboxItems)
|
||||||
{
|
{
|
||||||
var userId = Context.User?.FindFirstValue("sub") ?? throw new HubException("Please login to sync.");
|
var userId = Context.User?.FindFirstValue("sub") ?? throw new HubException("Please login to sync.");
|
||||||
|
|
||||||
@@ -285,6 +291,19 @@ namespace Notesnook.API.Hubs
|
|||||||
device.HasInitialMonographsSync = true;
|
device.HasInitialMonographsSync = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (includeInboxItems)
|
||||||
|
{
|
||||||
|
var unsyncedInboxItems = ids.Where((id) => id.EndsWith(":inboxItems")).ToHashSet();
|
||||||
|
var unsyncedInboxItemIds = unsyncedInboxItems.Select((id) => id.Split(":")[0]).ToArray();
|
||||||
|
var userInboxItems = isResetSync
|
||||||
|
? await Repositories.InboxItems.FindAsync(m => m.UserId == userId)
|
||||||
|
: await Repositories.InboxItems.FindAsync(m => m.UserId == userId && unsyncedInboxItemIds.Contains(m.ItemId));
|
||||||
|
if (userInboxItems.Any() && !await Clients.Caller.SendInboxItems(userInboxItems).WaitAsync(TimeSpan.FromMinutes(10)))
|
||||||
|
{
|
||||||
|
throw new HubException("Client rejected inbox items.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
deviceService.Reset();
|
deviceService.Reset();
|
||||||
|
|
||||||
return new SyncV2Metadata
|
return new SyncV2Metadata
|
||||||
|
|||||||
@@ -38,9 +38,9 @@ namespace Notesnook.API.Interfaces
|
|||||||
SyncItemsRepository Colors { get; }
|
SyncItemsRepository Colors { get; }
|
||||||
SyncItemsRepository Vaults { get; }
|
SyncItemsRepository Vaults { get; }
|
||||||
SyncItemsRepository Tags { get; }
|
SyncItemsRepository Tags { get; }
|
||||||
SyncItemsRepository InboxItems { get; }
|
|
||||||
Repository<UserSettings> UsersSettings { get; }
|
Repository<UserSettings> UsersSettings { get; }
|
||||||
Repository<Monograph> Monographs { get; }
|
Repository<Monograph> Monographs { get; }
|
||||||
Repository<InboxApiKey> InboxApiKey { get; }
|
Repository<InboxApiKey> InboxApiKey { get; }
|
||||||
|
Repository<InboxSyncItem> InboxItems { get; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -44,7 +44,7 @@ namespace Notesnook.API.Models
|
|||||||
[DataMember(Name = "userId")]
|
[DataMember(Name = "userId")]
|
||||||
[JsonPropertyName("userId")]
|
[JsonPropertyName("userId")]
|
||||||
[MessagePack.Key("userId")]
|
[MessagePack.Key("userId")]
|
||||||
public string UserId
|
public string? UserId
|
||||||
{
|
{
|
||||||
get; set;
|
get; set;
|
||||||
}
|
}
|
||||||
@@ -71,7 +71,7 @@ namespace Notesnook.API.Models
|
|||||||
[DataMember(Name = "id")]
|
[DataMember(Name = "id")]
|
||||||
[JsonPropertyName("id")]
|
[JsonPropertyName("id")]
|
||||||
[MessagePack.Key("id")]
|
[MessagePack.Key("id")]
|
||||||
public string ItemId
|
public string? ItemId
|
||||||
{
|
{
|
||||||
get; set;
|
get; set;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -173,7 +173,8 @@ namespace Notesnook.API
|
|||||||
services.AddRepository<UserSettings>("user_settings", "notesnook")
|
services.AddRepository<UserSettings>("user_settings", "notesnook")
|
||||||
.AddRepository<Monograph>("monographs", "notesnook")
|
.AddRepository<Monograph>("monographs", "notesnook")
|
||||||
.AddRepository<Announcement>("announcements", "notesnook")
|
.AddRepository<Announcement>("announcements", "notesnook")
|
||||||
.AddRepository<InboxApiKey>(Collections.InboxApiKeysKey, "notesnook");
|
.AddRepository<InboxApiKey>(Collections.InboxApiKeysKey, "notesnook")
|
||||||
|
.AddRepository<InboxSyncItem>(Collections.InboxItems, "notesnook");
|
||||||
|
|
||||||
services.AddMongoCollection(Collections.SettingsKey)
|
services.AddMongoCollection(Collections.SettingsKey)
|
||||||
.AddMongoCollection(Collections.AttachmentsKey)
|
.AddMongoCollection(Collections.AttachmentsKey)
|
||||||
|
|||||||
Reference in New Issue
Block a user