CCSWE.nanoFramework.Mediator
1.1.127
dotnet add package CCSWE.nanoFramework.Mediator --version 1.1.127
NuGet\Install-Package CCSWE.nanoFramework.Mediator -Version 1.1.127
<PackageReference Include="CCSWE.nanoFramework.Mediator" Version="1.1.127" />
<PackageVersion Include="CCSWE.nanoFramework.Mediator" Version="1.1.127" />
<PackageReference Include="CCSWE.nanoFramework.Mediator" />
paket add CCSWE.nanoFramework.Mediator --version 1.1.127
#r "nuget: CCSWE.nanoFramework.Mediator, 1.1.127"
#:package CCSWE.nanoFramework.Mediator@1.1.127
#addin nuget:?package=CCSWE.nanoFramework.Mediator&version=1.1.127
#tool nuget:?package=CCSWE.nanoFramework.Mediator&version=1.1.127
CCSWE.nanoFramework.Mediator
A simple asynchronous mediator implementation for nanoFramework. Provides in-process publisher-subscriber communication while keeping all parties decoupled.
Based on Mako-IoT.Device.Services.Mediator
Usage
Create classes for your events
public class Event1 : IMediatorEvent
{
public string Data { get; set; }
}
public class Event2 : IMediatorEvent
{
public string Text { get; set; }
}
Your event subscriber must implement IMediatorEventHandler interface
public class EventHandlerService : IMediatorEventHandler
{
public void HandleEvent(IMediatorEvent mediatorEvent)
{
switch (mediatorEvent)
{
case Event1 event1:
Debug.WriteLine($"[{nameof(EventHandlerService)}] Event1 received. The data is: {event1.Data}");
break;
case Event2 event2:
Debug.WriteLine($"[{nameof(EventHandlerService)}] Event2 received The text is: {event2.Text}");
break;
}
}
}
Use IMediator to publish events
public class EventPublisherService : IEventPublisherService
{
private readonly IMediator _mediator;
public EventPublisherService(IMediator mediator)
{
_mediator = mediator;
}
public void DoSomething()
{
_mediator.Publish(new Event2 { Text = "Hello from EventPublisherService" });
}
}
Register AsyncMediator and singleton subscribers to an IHostBuilder ...
var hostBuilder = new HostBuilder();
hostBuilder.UseMediator(options =>
{
options.AddSubscriber(typeof(Event1), typeof(Service2));
options.AddSubscriber(typeof(Event2), typeof(Service2));
});
... or directly to an IServiceCollection
var serviceCollection = new ServiceCollection();
serviceCollection.AddMediator(options =>
{
options.AddSubscriber(typeof(Event1), typeof(Service2));
options.AddSubscriber(typeof(Event2), typeof(Service2));
});
For transient and scoped services you can use the Subscribe and Unsubscribe overloads that take a specific instance.
public class TransientService : IDisposable
{
private readonly IMediator _mediator;
public TransientService(IMediator mediator)
{
_mediator = mediator;
_mediator.Subscribe(typeof(Event1), this);
_mediator.Subscribe(typeof(Event2), this);
}
public void Dispose()
{
_mediator.Unsubscribe(typeof(Event1), this);
_mediator.Unsubscribe(typeof(Event2), this);
}
}
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NETnanoFramework | netnano1.0 is compatible. |
-
.NETnanoFramework 1.0
- CCSWE.nanoFramework.Core (>= 1.1.127)
- CCSWE.nanoFramework.Threading (>= 1.1.127)
- nanoFramework.CoreLibrary (>= 1.17.11)
- nanoFramework.DependencyInjection (>= 1.1.32)
- nanoFramework.Logging (>= 1.1.161)
- nanoFramework.System.Collections (>= 1.5.67)
- nanoFramework.System.Text (>= 1.3.42)
- nanoFramework.System.Threading (>= 1.1.52)
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.127 | 44 | 4/15/2026 |
| 1.1.124 | 45 | 4/15/2026 |
| 1.1.123 | 46 | 4/14/2026 |
| 1.1.122 | 91 | 4/13/2026 |
| 1.1.117 | 82 | 4/13/2026 |
| 1.1.114 | 91 | 4/10/2026 |
| 1.1.113 | 83 | 4/10/2026 |
| 1.1.112 | 92 | 4/9/2026 |
| 1.1.104 | 90 | 4/8/2026 |
| 1.1.103 | 82 | 4/8/2026 |
| 1.1.101 | 83 | 4/7/2026 |
| 1.1.100 | 77 | 4/7/2026 |
| 1.1.99 | 79 | 4/7/2026 |
| 1.1.97 | 113 | 4/2/2026 |