MediatorX 1.0.2.1

dotnet add package MediatorX --version 1.0.2.1
                    
NuGet\Install-Package MediatorX -Version 1.0.2.1
                    
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="MediatorX" Version="1.0.2.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="MediatorX" Version="1.0.2.1" />
                    
Directory.Packages.props
<PackageReference Include="MediatorX" />
                    
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 MediatorX --version 1.0.2.1
                    
#r "nuget: MediatorX, 1.0.2.1"
                    
#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 MediatorX@1.0.2.1
                    
#: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=MediatorX&version=1.0.2.1
                    
Install as a Cake Addin
#tool nuget:?package=MediatorX&version=1.0.2.1
                    
Install as a Cake Tool

MediatorX

MediatorX es una biblioteca liviana para .NET que implementa el patrón CQRS (Command Query Responsibility Segregation), actuando como una alternativa simple, sin dependencias externas, a MediatR.

Está diseñada para desarrolladores que buscan una solución minimalista pero poderosa para enviar comandos y consultas dentro de proyectos con arquitectura limpia (Clean Architecture).


🚀 Características

  • ✔️ Alternativa ligera a MediatR
  • 🔌 Sin dependencias externas
  • 📦 Fácil de integrar en proyectos existentes
  • ⚙️ Compatible con .NET 6, 7, 8, 9
  • 🧪 Fácil de testear y mantener
  • 🧱 Ideal para Clean Architecture y CQRS

📦 Instalación

Instala MediatorX desde NuGet:

dotnet add package MediatorX

🧱 Ejemplo de uso

  1. Definir un Command
using MediatorX.Interfaces;

public class CrearUsuarioCommand : IRequest<string>
{
    public string Nombre { get; set; } = string.Empty;
    public string Email { get; set; } = string.Empty;
}
  1. Crear el Handler del Command
using MediatorX.Interfaces;

public class CrearUsuarioHandler : IRequestHandler<CrearUsuarioCommand, string>
{
    public Task<string> Handle(CrearUsuarioCommand request, CancellationToken cancellationToken = default)
    {
        return Task.FromResult($"Usuario '{request.Nombre}' creado exitosamente.");
    }
}
  1. Usar el Dispatcher en un controlador
using MediatorX.Interfaces;
using Microsoft.AspNetCore.Mvc;

[ApiController]
[Route("api/[controller]")]
public class UsuariosController : ControllerBase
{
    private readonly IMediator _mediator;

    public UsuariosController(IMediator mediator)
    {
        _mediator = mediator;
    }

    [HttpPost("crear")]
    public async Task<IActionResult> CrearUsuario([FromBody] CrearUsuarioCommand command)
    {
        var resultado = await _mediator.Send(command);
        return Ok(new { mensaje = resultado });
    }
}
  1. Definir una Query
using MediatorX.Interfaces;

public class ObtenerUsuarioQuery : IRequest<UsuarioDto>
{
    public int Id { get; set; }
}
  1. Usar la Query en un controlador
[HttpGet("{id}")]
public async Task<IActionResult> ObtenerUsuario(int id)
{
    var query = new ObtenerUsuarioQuery { Id = id };
    var usuario = await _mediator.Send(query);
    return Ok(usuario);
}

⚙️ Configuración en Program.cs

using MediatorX;
using MediatorX.Interfaces;
using MediatorX.DependencyInjection;

builder.Services.AddScoped<IMediator, Mediator>();
builder.Services.AddScoped<IPublisher, Mediator>();

// Registra automáticamente todos los handlers del ensamblado donde están definidos
builder.Services.AddMediatorX(typeof(CrearUsuarioCommand).Assembly);

✅ Ventajas

  • 🔌 Sin dependencias externas
  • 🧠 Pensado para arquitectura limpia
  • ⚡ Registro automático de handlers
  • 🔁 Compatible con CQRS
  • 🧪 Fácil de testear

📄 Requisitos

  • .NET 6.0 o superior
  • Compatible con .NET 6, 7, 8, 9
  • Requiere Microsoft.Extensions.DependencyInjection (incluido en ASP.NET Core)

📘 Licencia

  • MIT © 2025 Ramon Castillo
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  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 was computed.  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.  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. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos 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.0.2.1 143 7/17/2025
1.0.2.1-beta 301 7/17/2025
1.0.2-beta 134 7/17/2025
1.0.1 145 7/15/2025
1.0.0 141 7/15/2025