From cecb1450801fc364fe2d6981ef6909f3b6eeb538 Mon Sep 17 00:00:00 2001 From: Joe Schmitt <1146681+schmittjoseph@users.noreply.github.com> Date: Thu, 25 Apr 2024 11:25:08 -0700 Subject: [PATCH] Add wrapper for `EventSourcePipeline` with increased visibility (#6502) --- .../EventSourcePipelineProxy.cs | 57 +++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 src/Tools/dotnet-monitor/EventSourcePipelineProxy.cs diff --git a/src/Tools/dotnet-monitor/EventSourcePipelineProxy.cs b/src/Tools/dotnet-monitor/EventSourcePipelineProxy.cs new file mode 100644 index 00000000000..df8725c6b31 --- /dev/null +++ b/src/Tools/dotnet-monitor/EventSourcePipelineProxy.cs @@ -0,0 +1,57 @@ +// Licensed to the .NET Foundation under one or more agreements. +// The .NET Foundation licenses this file to you under the MIT license. + +using Microsoft.Diagnostics.Monitoring.WebApi; +using Microsoft.Diagnostics.Monitoring.EventPipe; +using System; +using Microsoft.Diagnostics.NETCore.Client; +using Microsoft.Diagnostics.Tracing; +using System.Threading.Tasks; +using System.Threading; + +namespace Microsoft.Diagnostics.Tools.Monitor +{ + public abstract class EventSourcePipelineProxy : IAsyncDisposable + { + private sealed class PipelineSettings : EventSourcePipelineSettings { } + + private sealed class EventSourcePipelineWrapper : EventSourcePipeline + { + private readonly Func _createConfiguration; + private readonly Func, CancellationToken, Task> _onEventSourceAvailable; + + public EventSourcePipelineWrapper(IpcEndpoint endpoint, Func createConfiguration, Func, CancellationToken, Task> onEventSourceAvailable, PipelineSettings settings) + : base(new DiagnosticsClient(endpoint), settings) + { + _createConfiguration = createConfiguration; + _onEventSourceAvailable = onEventSourceAvailable; + } + + protected override MonitoringSourceConfiguration CreateConfiguration() + => _createConfiguration(); + + protected override Task OnEventSourceAvailable(EventPipeEventSource eventSource, Func stopSessionAsync, CancellationToken token) + => _onEventSourceAvailable(eventSource, stopSessionAsync, token); + } + + private readonly EventSourcePipelineWrapper _pipeline; + + public EventSourcePipelineProxy(IEndpointInfo endpointInfo, TimeSpan duration) + { + _pipeline = new EventSourcePipelineWrapper(endpointInfo.Endpoint, CreateConfiguration, OnEventSourceAvailable, new PipelineSettings() + { + Duration = duration + }); + } + + protected abstract MonitoringSourceConfiguration CreateConfiguration(); + protected abstract Task OnEventSourceAvailable(EventPipeEventSource eventSource, Func stopSessionAsync, CancellationToken token); + + public Task StartAsync(CancellationToken token) + => _pipeline.StartAsync(token); + public Task StopAsync(CancellationToken token) + => _pipeline.StopAsync(token); + public ValueTask DisposeAsync() + => _pipeline.DisposeAsync(); + } +}