mirror of https://github.com/Squidex/squidex.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
110 lines
3.5 KiB
110 lines
3.5 KiB
// ==========================================================================
|
|
// Squidex Headless CMS
|
|
// ==========================================================================
|
|
// Copyright (c) Squidex UG (haftungsbeschraenkt)
|
|
// All rights reserved. Licensed under the MIT license.
|
|
// ==========================================================================
|
|
|
|
using MongoDB.Bson.Serialization;
|
|
using MongoDB.Driver;
|
|
using Squidex.Domain.Apps.Core.Apps;
|
|
using Squidex.Domain.Apps.Core.Schemas;
|
|
using Squidex.Domain.Apps.Entities.Contents;
|
|
using Squidex.Domain.Apps.Entities.Contents.Repositories;
|
|
using Squidex.Domain.Apps.Entities.Contents.Text;
|
|
using Squidex.Domain.Apps.Entities.Contents.Text.State;
|
|
using Squidex.Infrastructure;
|
|
using Squidex.Infrastructure.MongoDb;
|
|
|
|
namespace Squidex.Domain.Apps.Entities.MongoDb.Text;
|
|
|
|
public sealed class MongoTextIndexerState(
|
|
IMongoDatabase database,
|
|
IContentRepository contentRepository)
|
|
: MongoRepositoryBase<TextContentState>(database), ITextIndexerState, IDeleter
|
|
{
|
|
static MongoTextIndexerState()
|
|
{
|
|
BsonUniqueContentIdSerializer.Register();
|
|
|
|
BsonClassMap.TryRegisterClassMap<TextContentState>(cm =>
|
|
{
|
|
cm.MapIdProperty(x => x.UniqueContentId);
|
|
|
|
cm.MapProperty(x => x.State)
|
|
.SetElementName("s");
|
|
});
|
|
}
|
|
|
|
int IDeleter.Order => -2000;
|
|
|
|
protected override string CollectionName()
|
|
{
|
|
return "TextIndexerState";
|
|
}
|
|
|
|
async Task IDeleter.DeleteAppAsync(App app,
|
|
CancellationToken ct)
|
|
{
|
|
var filter =
|
|
Filter.And(
|
|
Filter.Gte(x => x.UniqueContentId, new UniqueContentId(app.Id, DomainId.Empty)),
|
|
Filter.Lt(x => x.UniqueContentId, BsonUniqueContentIdSerializer.NextAppId(app.Id)));
|
|
|
|
await Collection.DeleteManyAsync(filter, ct);
|
|
}
|
|
|
|
async Task IDeleter.DeleteSchemaAsync(App app, Schema schema,
|
|
CancellationToken ct)
|
|
{
|
|
var ids = contentRepository.StreamIds(app.Id, schema.Id, SearchScope.All, ct).Batch(1000, ct);
|
|
|
|
await foreach (var batch in ids.WithCancellation(ct))
|
|
{
|
|
var filter =
|
|
Filter.In(x => x.UniqueContentId, batch.Select(x => new UniqueContentId(app.Id, x)));
|
|
|
|
await Collection.DeleteManyAsync(filter, ct);
|
|
}
|
|
}
|
|
|
|
public async Task<Dictionary<UniqueContentId, TextContentState>> GetAsync(HashSet<UniqueContentId> ids,
|
|
CancellationToken ct = default)
|
|
{
|
|
var entities = await Collection.Find(Filter.In(x => x.UniqueContentId, ids)).ToListAsync(ct);
|
|
|
|
return entities.ToDictionary(x => x.UniqueContentId);
|
|
}
|
|
|
|
public Task SetAsync(List<TextContentState> updates,
|
|
CancellationToken ct = default)
|
|
{
|
|
var writes = new List<WriteModel<TextContentState>>();
|
|
|
|
foreach (var update in updates)
|
|
{
|
|
if (update.State == TextState.Deleted)
|
|
{
|
|
writes.Add(
|
|
new DeleteOneModel<TextContentState>(
|
|
Filter.Eq(x => x.UniqueContentId, update.UniqueContentId)));
|
|
}
|
|
else
|
|
{
|
|
writes.Add(
|
|
new ReplaceOneModel<TextContentState>(
|
|
Filter.Eq(x => x.UniqueContentId, update.UniqueContentId), update)
|
|
{
|
|
IsUpsert = true
|
|
});
|
|
}
|
|
}
|
|
|
|
if (writes.Count == 0)
|
|
{
|
|
return Task.CompletedTask;
|
|
}
|
|
|
|
return Collection.BulkWriteAsync(writes, BulkUnordered, ct);
|
|
}
|
|
}
|
|
|