92be035f51
- Add HrynCo.Common to Services project - TransactionBehavior now uses IProfiler.MeasureExecutionAsync: MeasureExecutionAsync -> ExecuteInTransactionAsync -> next() -> SaveChangesAsync - Profiler logs Start/End with duration + memory delta via Serilog PerformanceLog context - Register IProfiler as singleton in ServiceCollectionExtensions (uses Log.Logger) Ref: IT-628 Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
26 lines
845 B
C#
26 lines
845 B
C#
using HrynCo.NotificationService.DAL.Abstract;
|
|
using HrynCo.NotificationService.Services.Logging;
|
|
using MediatR;
|
|
using Serilog;
|
|
|
|
namespace HrynCo.NotificationService.Services.Core;
|
|
|
|
public abstract class RequestHandler<TRequest, TResponse> : IRequestHandler<TRequest, TResponse>
|
|
where TRequest : IRequest<TResponse>
|
|
{
|
|
protected RequestHandler(IContextualSerilogLogger<TRequest> logger, IUnitOfWork unitOfWork)
|
|
{
|
|
Logger = logger.Logger;
|
|
UnitOfWork = unitOfWork;
|
|
}
|
|
|
|
protected ILogger Logger { get; }
|
|
protected IUnitOfWork UnitOfWork { get; }
|
|
|
|
public Task<TResponse> Handle(TRequest request, CancellationToken cancellationToken)
|
|
{
|
|
return DoOnHandle(request, cancellationToken);
|
|
}
|
|
|
|
protected abstract Task<TResponse> DoOnHandle(TRequest request, CancellationToken cancellationToken);
|
|
} |