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.6 KiB
110 lines
3.6 KiB
// ==========================================================================
|
|
// Squidex Headless CMS
|
|
// ==========================================================================
|
|
// Copyright (c) Squidex UG (haftungsbeschraenkt)
|
|
// All rights reserved. Licensed under the MIT license.
|
|
// ==========================================================================
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.Extensions.Caching.Memory;
|
|
using Squidex.Caching;
|
|
using Squidex.Domain.Apps.Core.HandleRules;
|
|
using Squidex.Domain.Apps.Core.Rules;
|
|
using Squidex.Domain.Apps.Entities.Rules.Repositories;
|
|
using Squidex.Domain.Apps.Events;
|
|
using Squidex.Infrastructure;
|
|
using Squidex.Infrastructure.EventSourcing;
|
|
|
|
namespace Squidex.Domain.Apps.Entities.Rules
|
|
{
|
|
public sealed class RuleEnqueuer : IEventConsumer, IRuleEnqueuer
|
|
{
|
|
private static readonly TimeSpan CacheDuration = TimeSpan.FromSeconds(10);
|
|
private readonly IMemoryCache cache;
|
|
private readonly IRuleEventRepository ruleEventRepository;
|
|
private readonly IRuleService ruleService;
|
|
private readonly IAppProvider appProvider;
|
|
private readonly ILocalCache localCache;
|
|
|
|
public string Name
|
|
{
|
|
get => GetType().Name;
|
|
}
|
|
|
|
public RuleEnqueuer(IAppProvider appProvider, IMemoryCache cache, ILocalCache localCache,
|
|
IRuleEventRepository ruleEventRepository,
|
|
IRuleService ruleService)
|
|
{
|
|
Guard.NotNull(appProvider, nameof(appProvider));
|
|
Guard.NotNull(cache, nameof(cache));
|
|
Guard.NotNull(localCache, nameof(localCache));
|
|
Guard.NotNull(ruleEventRepository, nameof(ruleEventRepository));
|
|
Guard.NotNull(ruleService, nameof(ruleService));
|
|
|
|
this.appProvider = appProvider;
|
|
|
|
this.cache = cache;
|
|
this.ruleEventRepository = ruleEventRepository;
|
|
this.ruleService = ruleService;
|
|
this.localCache = localCache;
|
|
}
|
|
|
|
public async Task EnqueueAsync(Rule rule, DomainId ruleId, Envelope<IEvent> @event)
|
|
{
|
|
Guard.NotNull(rule, nameof(rule));
|
|
Guard.NotNull(@event, nameof(@event));
|
|
|
|
var ruleContext = new RuleContext
|
|
{
|
|
Rule = rule,
|
|
RuleId = ruleId,
|
|
IgnoreStale = false
|
|
};
|
|
|
|
var jobs = ruleService.CreateJobsAsync(@event, ruleContext);
|
|
|
|
await foreach (var (job, ex, _) in jobs)
|
|
{
|
|
if (job != null)
|
|
{
|
|
await ruleEventRepository.EnqueueAsync(job, ex);
|
|
}
|
|
}
|
|
}
|
|
|
|
public async Task On(Envelope<IEvent> @event)
|
|
{
|
|
if (@event.Headers.Restored())
|
|
{
|
|
return;
|
|
}
|
|
|
|
if (@event.Payload is AppEvent appEvent)
|
|
{
|
|
using (localCache.StartContext())
|
|
{
|
|
var rules = await GetRulesAsync(appEvent.AppId.Id);
|
|
|
|
foreach (var ruleEntity in rules)
|
|
{
|
|
await EnqueueAsync(ruleEntity.RuleDef, ruleEntity.Id, @event);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
private Task<List<IRuleEntity>> GetRulesAsync(DomainId appId)
|
|
{
|
|
var cacheKey = $"{typeof(RuleEnqueuer)}_Rules_{appId}";
|
|
|
|
return cache.GetOrCreateAsync(cacheKey, entry =>
|
|
{
|
|
entry.AbsoluteExpirationRelativeToNow = CacheDuration;
|
|
|
|
return appProvider.GetRulesAsync(appId);
|
|
});
|
|
}
|
|
}
|
|
}
|