public async Task Invoke(MessageContext messageContext) { var pipelineStartedAt = DateTime.UtcNow; using (var childBuilder = builder.CreateChildBuilder()) { var message = new IncomingMessage(messageContext.MessageId, messageContext.Headers, messageContext.Body); var rootContext = pipelineComponent.CreateRootContext(childBuilder, messageContext.Extensions); var transportReceiveContext = new TransportReceiveContext(message, messageContext.TransportTransaction, messageContext.ReceiveCancellationTokenSource, rootContext); try { await transportReceiveContext.InvokePipeline <ITransportReceiveContext>().ConfigureAwait(false); } catch (Exception e) { e.Data.Add("Message ID", message.MessageId); if (message.NativeMessageId != message.MessageId) { e.Data.Add("Transport message ID", message.NativeMessageId); } throw; } await transportReceiveContext.RaiseNotification(new ReceivePipelineCompleted(message, pipelineStartedAt, DateTime.UtcNow)).ConfigureAwait(false); } }
public async Task Invoke(MessageContext messageContext) { var pipelineStartedAt = DateTime.UtcNow; using (var childBuilder = builder.CreateChildBuilder()) { var rootContext = new RootContext(childBuilder, pipelineCache, eventAggregator); var message = new IncomingMessage(messageContext.MessageId, messageContext.Headers, messageContext.Body); var context = new TransportReceiveContext(message, messageContext.TransportTransaction, messageContext.ReceiveCancellationTokenSource, rootContext); context.Extensions.Merge(messageContext.Extensions); await mainPipeline.Invoke(context).ConfigureAwait(false); await context.RaiseNotification(new ReceivePipelineCompleted(message, pipelineStartedAt, DateTime.UtcNow)).ConfigureAwait(false); } }
public async Task Invoke(MessageContext messageContext) { var pipelineStartedAt = DateTime.UtcNow; using (var childBuilder = builder.CreateChildBuilder()) { var rootContext = new RootContext(childBuilder, pipelineCache, eventAggregator); var message = new IncomingMessage(messageContext.MessageId, messageContext.Headers, messageContext.Body); var context = new TransportReceiveContext(message, messageContext.TransportTransaction, messageContext.ReceiveCancellationTokenSource, rootContext); context.Extensions.Merge(messageContext.Context); await mainPipeline.Invoke(context).ConfigureAwait(false); await context.RaiseNotification(new ReceivePipelineCompleted(message, pipelineStartedAt, DateTime.UtcNow)).ConfigureAwait(false); } }