예제 #1
0
        public async Task <TResponse> Handle(TRequest request, CancellationToken cancellationToken, RequestHandlerDelegate <TResponse> next)
        {
            if (request.ToString().EndsWith("Query"))
            {
                return(await next());
            }

            var response = default(TResponse);
            var typeName = request.GetType();

            for (int i = 0; i < 3; i++)
            {
                try
                {
                    if (_dbContext.HasActiveTransaction)
                    {
                        return(await next());
                    }

                    var strategy = _dbContext.Database.CreateExecutionStrategy();

                    await strategy.ExecuteAsync(async() =>
                    {
                        Guid transactionId;

                        using (var transaction = await _dbContext.BeginTransactionAsync())
                        {
                            response = await next();
                            //_logger.LogInformation("----- Commit transaction {TransactionId} for {CommandName}", transaction.TransactionId, typeName);

                            await _dbContext.CommitTransactionAsync(transaction);
                            transactionId = transaction.TransactionId;
                        }
                    });

                    return(response);
                }
                catch (Exception ex)
                {
                    //_logger.LogError(ex, "ERROR Handling transaction for {CommandName} ({@Command})", typeName, request);

                    if (i >= 3)
                    {
                        throw;
                    }
                }
            }

            return(response);
        }