CrestApps.Queues
1.0.1
See the version list below for details.
dotnet add package CrestApps.Queues --version 1.0.1
NuGet\Install-Package CrestApps.Queues -Version 1.0.1
<PackageReference Include="CrestApps.Queues" Version="1.0.1" />
paket add CrestApps.Queues --version 1.0.1
#r "nuget: CrestApps.Queues, 1.0.1"
// Install CrestApps.Queues as a Cake Addin #addin nuget:?package=CrestApps.Queues&version=1.0.1 // Install CrestApps.Queues as a Cake Tool #tool nuget:?package=CrestApps.Queues&version=1.0.1
Queues
This module offers essential services for queuing elements and processing them in the background. It proves particularly useful when there is a need to queue tasks such as notifications or emails for background processing.
Since this module focuses solely on providing core services, it is marked with the EnabledByDependencyOnly
flag, making it available on demand.
To utilize this module, you can create an OrchardCore module and add a dependency on CrestApps.Queues
feature. Additionally, to handle your queue items, you need to implement the IQueueElementProcessor
, which is responsible for processing the queued elements.
For queuing elements, utilize the IQueueStore
interface.
Example of implementing an Email
Queue Processor
In this example, we employ a retry logic of 5 attempts in this instance to enable the processing of the queue element before considering it abandoned.
public class EmailQueueProcessor : IQueueElementProcessor
{
/// <summary>
/// Sets the max attempts to send the email before abandon the element.
/// </summary>
private const int _maxAttempts = 5;
private readonly ISmtpService _smtpService;
private IEnumerable<User> _users;
public EmailQueueProcessor(ISmtpService smtpService)
{
_smtpService = smtpService;
}
public bool CanHandle(string queueName)
{
return queueName == "Email";
}
public Task<bool> IsProcessableAsync(QueueElement element)
{
return Task.FromResult(element.FailedCounter < _maxAttempts);
}
public async Task ProcessAsync(QueueElementProcessingContext context)
{
foreach (var item in context.Elements)
{
var message = item.As<MailMessage>();
if(message == null)
{
// No message was found on the queue element.
item.IsRemovable = true;
continue;
}
var result = await _smtpService.SendAsync(message);
item.IsProcessed = result.Succeeded;
}
}
}
Example of creating Email
Queue elements using a Content Type Handler.
In this particular scenario, we make the assumption that there exists a content type called ContactFormEntry
which is completed by a site visitor. Our objective is to enqueue an email for sending it to the site owner.
public class ContactFormContentType : ContentHandlerBase
{
private const string _contentType = "ContactFormEntry";
private readonly IQueueStore _queueStore;
public ContactFormContentType(IQueueStore queueStore)
{
_queueStore = queueStore;
}
public override Task PublishedAsync(PublishContentContext context)
{
if(context.PublishingItem.ContentType != _contentType)
{
return Task.CompletedTask;
}
return AddOrUpdateNotificationQueueAsync(context.PublishingItem);
}
public override Task UnpublishedAsync(PublishContentContext context)
{
if (context.PublishingItem.ContentType != _contentType)
{
return Task.CompletedTask;
}
return RemoveNotificationQueueAsync(context.PublishingItem);
}
public override Task RemovedAsync(RemoveContentContext context)
{
if (context.ContentItem.ContentType != _contentType)
{
return Task.CompletedTask;
}
return RemoveNotificationQueueAsync(context.ContentItem);
}
private async Task AddOrUpdateNotificationQueueAsync(ContentItem contentItem)
{
var queueItems = await _queueStore.GetCorrelationAsync(contentItem.ContentItemId);
// Get event date and add minuts to it.
var queueItem = queueItems.FirstOrDefault(x => x.QueueName == "Email")
?? new QueueElement()
{
CorrelationId = contentItem.ContentItemId,
QueueName = "Email",
};
// The Mail info will come from the contact form entry or other sources.
var message = new MailMessage()
{
Subject = contentItem.Content.ContactFormEntry.Subject.Text,
Body = contentItem.Content.ContactFormEntry.Message.Text,
To = "owner@example.com",
};
queueItem.Put(message);
await _queueStore.SaveAsync(queueItem);
await _queueStore.SaveChangesAsync();
}
private async Task RemoveNotificationQueueAsync(ContentItem contentItem)
{
var queueItems = await _queueStore.GetCorrelationAsync(contentItem.ContentItemId);
foreach (var queueItem in queueItems)
{
if (queueItem.QueueName != "Email")
{
continue;
}
await _queueStore.DeleteAsync(queueItem);
}
await _queueStore.SaveChangesAsync();
}
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net7.0
- CrestApps.Queues.Core (>= 1.0.1)
- ncrontab (>= 3.3.1)
- OrchardCore.ContentManagement (>= 1.7.0-preview-17499)
- OrchardCore.ContentTypes.Abstractions (>= 1.7.0-preview-17499)
- OrchardCore.DisplayManagement (>= 1.7.0-preview-17499)
- OrchardCore.Module.Targets (>= 1.7.0-preview-17499)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.10.0-preview-0027 | 74 | 1/9/2025 |
1.10.0-preview-0026 | 40 | 1/9/2025 |
1.10.0-preview-0025 | 120 | 1/3/2025 |
1.10.0-preview-0024 | 105 | 1/2/2025 |
1.10.0-preview-0023 | 662 | 9/9/2024 |
1.10.0-preview-0022 | 146 | 8/26/2024 |
1.10.0-preview-0021 | 88 | 8/26/2024 |
1.10.0-preview-0020 | 129 | 8/7/2024 |
1.10.0-preview-0007 | 118 | 7/22/2024 |
1.10.0-preview-0006 | 154 | 6/10/2024 |
1.10.0-preview-0005 | 118 | 6/6/2024 |
1.10.0-preview-0004 | 103 | 6/5/2024 |
1.10.0-preview-0003 | 224 | 5/7/2024 |
1.10.0-preview-0002 | 152 | 3/8/2024 |
1.10.0-preview-0001 | 104 | 3/7/2024 |
1.9.0 | 535 | 1/17/2024 |
1.1.0 | 130 | 1/17/2024 |
1.0.8 | 385 | 9/19/2023 |
1.0.7 | 304 | 8/16/2023 |
1.0.6 | 188 | 8/14/2023 |
1.0.5 | 200 | 8/4/2023 |
1.0.4 | 199 | 8/1/2023 |
1.0.3 | 172 | 8/1/2023 |
1.0.2 | 158 | 8/1/2023 |
1.0.1 | 243 | 7/12/2023 |
1.0.0 | 193 | 7/12/2023 |