MakoIoT.Device.Services.Mediator 1.0.42.48945

dotnet add package MakoIoT.Device.Services.Mediator --version 1.0.42.48945
NuGet\Install-Package MakoIoT.Device.Services.Mediator -Version 1.0.42.48945
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.42.48945" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add MakoIoT.Device.Services.Mediator --version 1.0.42.48945
#r "nuget: MakoIoT.Device.Services.Mediator, 1.0.42.48945"
#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.
// Install MakoIoT.Device.Services.Mediator as a Cake Addin
#addin nuget:?package=MakoIoT.Device.Services.Mediator&version=1.0.42.48945

// Install MakoIoT.Device.Services.Mediator as a Cake Tool
#tool nuget:?package=MakoIoT.Device.Services.Mediator&version=1.0.42.48945

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.42.48945 544 4/8/2024
1.0.41.33870 593 3/22/2024
1.0.40.12180 165 3/21/2024
1.0.39.38843 1,601 1/6/2024
1.0.38.6937 348 12/30/2023
1.0.37.22301 368 12/19/2023
1.0.36.36218 690 12/1/2023
1.0.35.38046 180 12/1/2023
1.0.34.61610 471 11/17/2023
1.0.33.12388 216 11/16/2023
1.0.32.35604 474 11/11/2023
1.0.31.54540 851 10/12/2023
1.0.30.24296 654 10/6/2023
1.0.28.51374 238 10/6/2023
1.0.26.61682 1,645 5/24/2023
1.0.25.54621 179 5/24/2023
1.0.23.37503 244 5/23/2023
1.0.21.48055 133 5/22/2023
1.0.20.12163 296 5/22/2023