Esempio n. 1
0
        private static async Task <IResponseUnit <TResult> > HandleResponseHandler <TRequest, TResult>(IExecutionContextReader context, IResponseHandlerAsync <TRequest, TResult> h, TRequest request, ILogger logger)
        {
#if DEBUG
            var timer = Timer.Start(logger, h);
#endif
            IResponse <TResult> rsp;
            if (h.ExecutionHint != ExecutionHintType.Main)
            {
                rsp = await h.Handle(context, request);
            }
            else
            {
                try
                {
                    rsp = await h.Handle(context, request);
                }
                catch (Exception e)
                {
                    rsp = Response.Failed <TResult>();

                    logger.LogError(0, e, $"ResponseHandler {h.GetType().FullName} failed with message {e.Message}");
                }
            }
#if DEBUG
            timer.Completed();
#endif
            return(Convert(rsp, h.ExecutionHint));
        }
Esempio n. 2
0
        private async Task <Response <TResult> > ExecuteResponseHandler <TRequest, TResult>(IRequestBusContext context,
                                                                                            IResponseHandlerAsync <TRequest, TResult> handler,
                                                                                            TRequest request)
        {
            if (handler.ExecutionHint == ExecutionHint.Main)
            {
                return(await handler.Handle(context, request));
            }

            try
            {
                return(await handler.Handle(context, request));
            }
            catch (Exception e)
            {
                _logger.LogError(e, $"Handler {handler.GetType().FullName} failed with message {e.Message}");
            }

            return(null);
        }