Pelican.Mediator
1.1.2
dotnet add package Pelican.Mediator --version 1.1.2
NuGet\Install-Package Pelican.Mediator -Version 1.1.2
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Pelican.Mediator" Version="1.1.2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Pelican.Mediator" Version="1.1.2" />
<PackageReference Include="Pelican.Mediator" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Pelican.Mediator --version 1.1.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Pelican.Mediator, 1.1.2"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Pelican.Mediator@1.1.2
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Pelican.Mediator&version=1.1.2
#tool nuget:?package=Pelican.Mediator&version=1.1.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
🦤 Pelican.Mediator
Simple. Fast. Reliable message delivery for .NET.
Pelican.Mediator
is a lightweight and high-performance Mediator pattern implementation for .NET.
Designed with pipelines, request handlers, and clean architecture in mind.
✨ Features
- ⚡ Fast: delegate-based
- 🧩 Supports pipelines (
IPipelineBehavior<TRequest, TResponse>
) - 🔌 DI-friendly: plug it into any
IServiceProvider
- 🧼 Zero dependencies (except DI abstractions)
- 🧪 Battle-tested with xUnit & NSubstitute
📦 Installation
dotnet add package Pelican.Mediator
🚀 Quick Start
public record Ping(string Message) : IRequest<string>;
public class PingHandler : IRequestHandler<Ping, string>
{
public Task<string> Handle(Ping request, CancellationToken cancellationToken = default)
=> Task.FromResult($"Pong: {request.Message}");
}
public record MyNotification(string Message) : INotification;
public class Subscriber1 : INotificationHandler<MyNotification>
{
public Task Handle(MyNotification notification, CancellationToken = default)
{
Console.WriteLine($"Subscriber1: {notification.Message}");
return Task.CompletedTask;
}
}
public class Subscriber2 : INotificationHandler<MyNotification>
{
public Task Handle(MyNotification notification, CancellationToken = default)
{
Console.WriteLine($"Subscriber2: {notification.Message}");
return Task.CompletedTask;
}
}
public class Generator
{
private readonly IMediator _mediator;
public Generator(IMediator mediator)
{
_mediator = mediator;
}
public async Task Invoke()
{
var ping = new PingRequest("Ping");
var response = await _mediator.Send(ping);
Console.WriteLine(response);
// Output ->
// Pong: Ping
var notification = new MyNotification("Hello world!");
await _mediator.Publish(notification);
// Output ->
// Subscriber1: HelloWorld!
// Subscriber2: HelloWorld!
}
}
Add Pelican to the service container.
services.AddPelican(Assembly.Load("YourProject"));
⚙️ Pipelines
Create reusable middleware by implementing:
public class LoggingBehavior<TRequest, TResponse> : IPipelineBehavior<TRequest, TResponse>
{
// Support DependencyInjection
public async Task<TResponse> Handle(TRequest request, Handler<TResponse> next, CancellationToken ct)
{
Console.WriteLine($"Handling {typeof(TRequest).Name}");
var response = await next();
Console.WriteLine($"Handled {typeof(TResponse).Name}");
return response;
}
}
Register your pre-processors and post-processors:
services.AddTransient(typeof(IPipelineBehavior<,>), typeof(LoggingBehavior<,>));
⚙️ Pre-Processors and Post-Processors
public class LoggingPreProcessor<TRequest> : IPreProcessor<TRequest>
{
// Support DependencyInjection
public Task Handle(TRequest request, CancellationToken ct)
{
Console.WriteLine($"This is a pre-processor!");
return Task.CompletedTask;
}
}
public class LoggingPostProcessor<TRequest, TResponse> : IPostProcessor<TRequest, TResponse>
{
// Support DependencyInjection
public Task Handle(TRequest request, TResponse CancellationToken ct)
{
Console.WriteLine($"This is a post-processor!");
return Task.CompletedTask;
}
}
Register your pre-processors and post-processors:
services.AddTransient(typeof(IPreProcessor<>), typeof(LoggingPreProcessor<>));
services.AddTransient(typeof(IPostProcessor<,>), typeof(LoggingPostProcessor<,>));
🛠️ Upcoming Features
- Extended Base Handlers for Commands and Queries Add abstract classes with basic CRUD operations with Entity Framework Core.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. 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 is compatible. 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 is compatible. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net6.0
-
net7.0
-
net8.0
-
net9.0
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.