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" />
                    
Directory.Packages.props
<PackageReference Include="Pelican.Mediator" />
                    
Project file
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
                    
#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
                    
Install as a Cake Addin
#tool nuget:?package=Pelican.Mediator&version=1.1.2
                    
Install as a Cake Tool

🦤 Pelican.Mediator

Simple. Fast. Reliable message delivery for .NET.

Build NuGet License: MIT


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 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.

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.1.2 310 5/28/2025
1.1.1 107 5/24/2025
1.0.5 78 5/24/2025
1.0.4 138 5/23/2025