MakoIoT.Device.Services.Mediator 1.0.68.59455

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

Mako-IoT.Device.Services.Mediator

Mediator pattern implementation. Provides in-process publisher-subscriber communication while keeping all parties decoupled.

Usage

See Mediator sample

Create classes for your events

public class Event1 : IEvent
{
    public string Data { get; set; }
}

public class Event2 : IEvent
{
    public string Text { get; set; }
}

Your event subscriber must implement IEventHandler interface

public class Service2 : IEventHandler
{
    public void Handle(IEvent @event)
    {
        switch (@event)
        {
            case Event1 event1:
                Debug.WriteLine($"[{nameof(Service2)}] Event1 received. The data is: {event1.Data}");
                break;
            case Event2 event2:
                Debug.WriteLine($"[{nameof(Service2)}] Event2 received The text is: {event2.Text}");
                break;
        }
    }
}

Use IMediator to publish events

public class Service1 : IService1
{
    private readonly IMediator _mediator;

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

    public void DoSomething()
    {
        _mediator.Publish(new Event2 { Text = "Hello from Service1 !" });
    }
}

Register Mediator and singleton subscribers in DeviceBuilder

DeviceBuilder.Create()
  .AddMediator(options =>
  {
      options.AddSubscriber(typeof(Event1), typeof(Service2));
      options.AddSubscriber(typeof(Event2), typeof(Service2));
  })
  .Build()
  .Start()

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 Compatible and additional computed target framework versions.
.NET Framework net is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (4)

Showing the top 4 NuGet packages that depend on MakoIoT.Device.Services.Mediator:

Package Downloads
MakoIoT.Device.Services.ConfigurationManager

Configuration mode manager for MAKO-IoT

MakoIoT.Device.Services.ConfigurationApi

REST API for configuration with MAKO-IoT

MakoIoT.Device.Platform.LocalConfig

MAKO-IoT Platform local configuration library. On-device web server, WiFi AP

MakoIoT.Device.Services.Logging.Storage

Logging to flash storage and logs upload to Elasticsearch for MAKO-IoT

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.0.68.59455 135 7/16/2025
1.0.67.23572 1,026 4/17/2025
1.0.66.46860 367 4/3/2025
1.0.65.25699 248 4/2/2025
1.0.64.60024 597 3/20/2025
1.0.63.14171 353 3/11/2025
1.0.61.19880 657 2/27/2025
1.0.60.10419 198 2/26/2025
1.0.59.42289 444 2/20/2025
1.0.58.36645 400 2/18/2025
1.0.57.42352 436 11/28/2024
1.0.56.4697 191 11/27/2024
1.0.55.2648 196 11/26/2024
1.0.54.41107 209 11/25/2024
1.0.53.51021 396 11/19/2024
1.0.52.56154 874 10/18/2024
1.0.51.44660 272 10/16/2024
1.0.50.63396 533 9/26/2024
1.0.49.59837 427 9/20/2024
1.0.48.59964 456 9/12/2024
1.0.47.39935 539 8/27/2024
1.0.46.45075 477 8/10/2024
1.0.45.63754 254 8/5/2024
1.0.44.7886 725 6/12/2024
1.0.43.57607 1,185 5/17/2024
1.0.42.48945 1,372 4/8/2024
1.0.41.33870 821 3/22/2024
1.0.40.12180 275 3/21/2024
1.0.39.38843 2,128 1/6/2024
1.0.38.6937 471 12/30/2023
1.0.37.22301 488 12/19/2023
1.0.36.36218 867 12/1/2023
1.0.35.38046 247 12/1/2023
1.0.34.61610 629 11/17/2023
1.0.33.12388 310 11/16/2023
1.0.32.35604 656 11/11/2023
1.0.31.54540 1,162 10/12/2023
1.0.30.24296 932 10/6/2023
1.0.28.51374 337 10/6/2023
1.0.26.61682 2,023 5/24/2023
1.0.25.54621 249 5/24/2023
1.0.23.37503 332 5/23/2023
1.0.21.48055 203 5/22/2023
1.0.20.12163 426 5/22/2023