Lidarr/NzbDrone.Common/Eventing/EventAggregator.cs

30 lines
859 B
C#
Raw Normal View History

using System;
using System.Collections.Generic;
using System.Linq;
2013-02-23 20:09:44 +00:00
using NLog;
namespace NzbDrone.Common.Eventing
{
public class EventAggregator : IEventAggregator
{
2013-02-23 20:09:44 +00:00
private readonly Logger _logger;
private readonly Func<IEnumerable<IHandle>> _handlers;
public EventAggregator(Logger logger, Func<IEnumerable<IHandle>> handlers)
{
2013-02-23 20:09:44 +00:00
_logger = logger;
_handlers = handlers;
}
public void Publish<TEvent>(TEvent message) where TEvent : IEvent
{
2013-02-23 20:09:44 +00:00
_logger.Trace("Publishing {0}", message.GetType().Name);
foreach (var handler in _handlers().OfType<IHandle<TEvent>>())
{
2013-02-23 20:09:44 +00:00
_logger.Trace("{0} => {1}", message.GetType().Name, handler.GetType().Name);
handler.Handle(message);
}
}
}
}