mirror of
https://github.com/meysamhadeli/booking-microservices.git
synced 2026-04-19 10:22:10 +08:00
66 lines
2.0 KiB
C#
66 lines
2.0 KiB
C#
using System.Data;
|
|
using System.Text.Json;
|
|
using MediatR;
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
namespace BuildingBlocks.EFCore;
|
|
|
|
public class EfIdentityTxBehavior<TRequest, TResponse> : IPipelineBehavior<TRequest, TResponse>
|
|
where TRequest : notnull, IRequest<TResponse>
|
|
where TResponse : notnull
|
|
{
|
|
private readonly ILogger<EfTxBehavior<TRequest, TResponse>> _logger;
|
|
private readonly IDbContext _dbContextBase;
|
|
|
|
public EfIdentityTxBehavior(
|
|
ILogger<EfTxBehavior<TRequest, TResponse>> logger,
|
|
IDbContext dbContextBase)
|
|
{
|
|
_logger = logger;
|
|
_dbContextBase = dbContextBase;
|
|
}
|
|
|
|
public async Task<TResponse> Handle(
|
|
TRequest request,
|
|
CancellationToken cancellationToken,
|
|
RequestHandlerDelegate<TResponse> next)
|
|
{
|
|
_logger.LogInformation(
|
|
"{Prefix} Handled command {MediatrRequest}",
|
|
nameof(EfTxBehavior<TRequest, TResponse>),
|
|
typeof(TRequest).FullName);
|
|
|
|
_logger.LogDebug(
|
|
"{Prefix} Handled command {MediatrRequest} with content {RequestContent}",
|
|
nameof(EfTxBehavior<TRequest, TResponse>),
|
|
typeof(TRequest).FullName,
|
|
JsonSerializer.Serialize(request));
|
|
|
|
_logger.LogInformation(
|
|
"{Prefix} Open the transaction for {MediatrRequest}",
|
|
nameof(EfTxBehavior<TRequest, TResponse>),
|
|
typeof(TRequest).FullName);
|
|
|
|
await _dbContextBase.BeginTransactionAsync(cancellationToken);
|
|
|
|
try
|
|
{
|
|
var response = await next();
|
|
|
|
_logger.LogInformation(
|
|
"{Prefix} Executed the {MediatrRequest} request",
|
|
nameof(EfTxBehavior<TRequest, TResponse>),
|
|
typeof(TRequest).FullName);
|
|
|
|
await _dbContextBase.CommitTransactionAsync(cancellationToken);
|
|
|
|
return response;
|
|
}
|
|
catch
|
|
{
|
|
await _dbContextBase.RollbackTransactionAsync(cancellationToken);
|
|
throw;
|
|
}
|
|
}
|
|
}
|