mirror of
https://github.com/alex289/CleanArchitecture.git
synced 2025-06-30 02:31:08 +00:00
Add fanout event handler
This commit is contained in:
parent
4746bfbef1
commit
bff6fb47f2
6
CleanArchitecture.Domain/Constants/Messaging.cs
Normal file
6
CleanArchitecture.Domain/Constants/Messaging.cs
Normal file
@ -0,0 +1,6 @@
|
||||
namespace CleanArchitecture.Domain.Constants;
|
||||
|
||||
public sealed class Messaging
|
||||
{
|
||||
public const string ExchangeNameNotifications = "exchange-notifications";
|
||||
}
|
@ -3,6 +3,7 @@ using MediatR;
|
||||
|
||||
namespace CleanArchitecture.Domain.DomainEvents;
|
||||
|
||||
// Todo: Move this and all events to shared
|
||||
public abstract class DomainEvent : Message, INotification
|
||||
{
|
||||
public DateTime Timestamp { get; private set; }
|
||||
|
@ -0,0 +1,26 @@
|
||||
using System.Threading.Tasks;
|
||||
using CleanArchitecture.Domain.Constants;
|
||||
using CleanArchitecture.Domain.DomainEvents;
|
||||
using CleanArchitecture.Domain.Rabbitmq;
|
||||
|
||||
namespace CleanArchitecture.Domain.EventHandler.Fanout;
|
||||
|
||||
public sealed class FanoutEventHandler : IFanoutEventHandler
|
||||
{
|
||||
private readonly RabbitMqHandler _rabbitMqHandler;
|
||||
|
||||
public FanoutEventHandler(
|
||||
RabbitMqHandler rabbitMqHandler)
|
||||
{
|
||||
_rabbitMqHandler = rabbitMqHandler;
|
||||
}
|
||||
|
||||
public Task<DomainEvent> HandleDomainEventAsync(DomainEvent @event)
|
||||
{
|
||||
_rabbitMqHandler.EnqueueExchangeMessage(
|
||||
Messaging.ExchangeNameNotifications,
|
||||
@event);
|
||||
|
||||
return Task.FromResult(@event);
|
||||
}
|
||||
}
|
@ -0,0 +1,9 @@
|
||||
using System.Threading.Tasks;
|
||||
using CleanArchitecture.Domain.DomainEvents;
|
||||
|
||||
namespace CleanArchitecture.Domain.EventHandler.Fanout;
|
||||
|
||||
public interface IFanoutEventHandler
|
||||
{
|
||||
Task<DomainEvent> HandleDomainEventAsync(DomainEvent @event);
|
||||
}
|
@ -6,7 +6,9 @@ using CleanArchitecture.Domain.Commands.Users.CreateUser;
|
||||
using CleanArchitecture.Domain.Commands.Users.DeleteUser;
|
||||
using CleanArchitecture.Domain.Commands.Users.LoginUser;
|
||||
using CleanArchitecture.Domain.Commands.Users.UpdateUser;
|
||||
using CleanArchitecture.Domain.DomainEvents;
|
||||
using CleanArchitecture.Domain.EventHandler;
|
||||
using CleanArchitecture.Domain.EventHandler.Fanout;
|
||||
using CleanArchitecture.Domain.Events.Tenant;
|
||||
using CleanArchitecture.Domain.Events.User;
|
||||
using CleanArchitecture.Domain.Interfaces;
|
||||
@ -36,6 +38,9 @@ public static class ServiceCollectionExtension
|
||||
|
||||
public static IServiceCollection AddNotificationHandlers(this IServiceCollection services)
|
||||
{
|
||||
// Fanout
|
||||
services.AddScoped<IFanoutEventHandler, FanoutEventHandler>();
|
||||
|
||||
// User
|
||||
services.AddScoped<INotificationHandler<UserCreatedEvent>, UserEventHandler>();
|
||||
services.AddScoped<INotificationHandler<UserUpdatedEvent>, UserEventHandler>();
|
||||
|
@ -2,6 +2,7 @@ using System;
|
||||
using System.Threading.Tasks;
|
||||
using CleanArchitecture.Domain.Commands.Users.DeleteUser;
|
||||
using CleanArchitecture.Domain.DomainEvents;
|
||||
using CleanArchitecture.Domain.EventHandler.Fanout;
|
||||
using CleanArchitecture.Domain.Events.User;
|
||||
using CleanArchitecture.Domain.Notifications;
|
||||
using MediatR;
|
||||
@ -17,8 +18,9 @@ public sealed class InMemoryBusTests
|
||||
{
|
||||
var mediator = Substitute.For<IMediator>();
|
||||
var domainEventStore = Substitute.For<IDomainEventStore>();
|
||||
var fanoutEventHandler = Substitute.For<IFanoutEventHandler>();
|
||||
|
||||
var inMemoryBus = new InMemoryBus(mediator, domainEventStore);
|
||||
var inMemoryBus = new InMemoryBus(mediator, domainEventStore, fanoutEventHandler);
|
||||
|
||||
const string key = "Key";
|
||||
const string value = "Value";
|
||||
@ -36,8 +38,9 @@ public sealed class InMemoryBusTests
|
||||
{
|
||||
var mediator = Substitute.For<IMediator>();
|
||||
var domainEventStore = Substitute.For<IDomainEventStore>();
|
||||
var fanoutEventHandler = Substitute.For<IFanoutEventHandler>();
|
||||
|
||||
var inMemoryBus = new InMemoryBus(mediator, domainEventStore);
|
||||
var inMemoryBus = new InMemoryBus(mediator, domainEventStore, fanoutEventHandler);
|
||||
|
||||
var userDeletedEvent = new UserDeletedEvent(Guid.NewGuid(), Guid.NewGuid());
|
||||
|
||||
@ -51,8 +54,9 @@ public sealed class InMemoryBusTests
|
||||
{
|
||||
var mediator = Substitute.For<IMediator>();
|
||||
var domainEventStore = Substitute.For<IDomainEventStore>();
|
||||
var fanoutEventHandler = Substitute.For<IFanoutEventHandler>();
|
||||
|
||||
var inMemoryBus = new InMemoryBus(mediator, domainEventStore);
|
||||
var inMemoryBus = new InMemoryBus(mediator, domainEventStore, fanoutEventHandler);
|
||||
|
||||
var deleteUserCommand = new DeleteUserCommand(Guid.NewGuid());
|
||||
|
||||
|
@ -1,6 +1,7 @@
|
||||
using System.Threading.Tasks;
|
||||
using CleanArchitecture.Domain.Commands;
|
||||
using CleanArchitecture.Domain.DomainEvents;
|
||||
using CleanArchitecture.Domain.EventHandler.Fanout;
|
||||
using CleanArchitecture.Domain.Interfaces;
|
||||
using MediatR;
|
||||
|
||||
@ -10,13 +11,16 @@ public sealed class InMemoryBus : IMediatorHandler
|
||||
{
|
||||
private readonly IDomainEventStore _domainEventStore;
|
||||
private readonly IMediator _mediator;
|
||||
private readonly IFanoutEventHandler _fanoutEventHandler;
|
||||
|
||||
public InMemoryBus(
|
||||
IMediator mediator,
|
||||
IDomainEventStore domainEventStore)
|
||||
IDomainEventStore domainEventStore,
|
||||
IFanoutEventHandler fanoutEventHandler)
|
||||
{
|
||||
_mediator = mediator;
|
||||
_domainEventStore = domainEventStore;
|
||||
_fanoutEventHandler = fanoutEventHandler;
|
||||
}
|
||||
|
||||
public Task<TResponse> QueryAsync<TResponse>(IRequest<TResponse> query)
|
||||
@ -29,6 +33,8 @@ public sealed class InMemoryBus : IMediatorHandler
|
||||
await _domainEventStore.SaveAsync(@event);
|
||||
|
||||
await _mediator.Publish(@event);
|
||||
|
||||
await _fanoutEventHandler.HandleDomainEventAsync(@event);
|
||||
}
|
||||
|
||||
public Task SendCommandAsync<T>(T command) where T : CommandBase
|
||||
|
Loading…
Reference in New Issue
Block a user