Snowberry.Mediator.OpenTelemetry.Shared
2.0.0
dotnet add package Snowberry.Mediator.OpenTelemetry.Shared --version 2.0.0
NuGet\Install-Package Snowberry.Mediator.OpenTelemetry.Shared -Version 2.0.0
<PackageReference Include="Snowberry.Mediator.OpenTelemetry.Shared" Version="2.0.0" />
<PackageVersion Include="Snowberry.Mediator.OpenTelemetry.Shared" Version="2.0.0" />
<PackageReference Include="Snowberry.Mediator.OpenTelemetry.Shared" />
paket add Snowberry.Mediator.OpenTelemetry.Shared --version 2.0.0
#r "nuget: Snowberry.Mediator.OpenTelemetry.Shared, 2.0.0"
#:package Snowberry.Mediator.OpenTelemetry.Shared@2.0.0
#addin nuget:?package=Snowberry.Mediator.OpenTelemetry.Shared&version=2.0.0
#tool nuget:?package=Snowberry.Mediator.OpenTelemetry.Shared&version=2.0.0
Snowberry.Mediator.OpenTelemetry.Shared
Core, container-agnostic OpenTelemetry instrumentation for Snowberry.Mediator.
This package contains:
InstrumentedMediator: anIMediatordecorator that emits anActivityand metric measurements for everySendAsync,CreateStreamAsync, andPublishAsyncdispatch.MediatorInstrumentation: owns theActivitySource,Meter, and the six per-operationCounter<long>/Histogram<double>instruments.MediatorTelemetryOptions: configures the instrumentation (source name, tracing/metrics toggles, per-step span opt-ins, enrichment callbacks, filter).TracerProviderBuilderExtensions.AddSnowberryMediatorInstrumentationandMeterProviderBuilderExtensions.AddSnowberryMediatorInstrumentation: subscribe the OpenTelemetry SDK to the activity sources and the meter.
Consumers normally do not reference this package directly. Pick the DI integration package matching the container in use:
| Container | Package |
|---|---|
Microsoft.Extensions.DependencyInjection |
Snowberry.Mediator.Extensions.OpenTelemetry |
Snowberry.DependencyInjection |
Snowberry.Mediator.OpenTelemetry |
Emitted telemetry
Activities
| Source | Activity name | Tags |
|---|---|---|
Snowberry.Mediator |
Mediator.Send {RequestType} |
snowberry.mediator.request.type, snowberry.mediator.response.type, snowberry.mediator.operation = send |
Snowberry.Mediator |
Mediator.Stream {RequestType} |
snowberry.mediator.request.type, snowberry.mediator.response.type, snowberry.mediator.operation = stream |
Snowberry.Mediator |
Mediator.Publish {NotificationType} |
snowberry.mediator.notification.type, snowberry.mediator.operation = publish |
Snowberry.Mediator.Pipeline (opt-in) |
Mediator.Behavior {BehaviorType} |
snowberry.mediator.behavior.type, snowberry.mediator.request.type |
Snowberry.Mediator.Notification (opt-in) |
Mediator.Handler {HandlerType} |
snowberry.mediator.handler.type, snowberry.mediator.notification.type |
All activities use ActivityKind.Internal.
{RequestType} / {NotificationType} / {BehaviorType} / {HandlerType} and the corresponding
*.type tags use the fully-qualified type name (e.g. MyApp.Orders.PlaceOrder), so types that
share a simple name across namespaces are not conflated into the same span name or metric series.
Metrics
Meter name: Snowberry.Mediator (configurable via MediatorTelemetryOptions.SourceName).
| Instrument | Type | Unit | Tags |
|---|---|---|---|
snowberry.mediator.send.count |
Counter<long> |
type, status |
|
snowberry.mediator.send.duration |
Histogram<double> |
ms |
type, status |
snowberry.mediator.stream.count |
Counter<long> |
type, status |
|
snowberry.mediator.stream.duration |
Histogram<double> |
ms |
type, status |
snowberry.mediator.publish.count |
Counter<long> |
type, status |
|
snowberry.mediator.publish.duration |
Histogram<double> |
ms |
type, status |
status is "success" or "failure".
Per-step spans
Per-pipeline-behavior and per-notification-handler spans are opt-in. Enable them via MediatorTelemetryOptions:
o.EnablePipelineBehaviorSpans = true;
o.EnableNotificationHandlerSpans = true;
Subscribe the OpenTelemetry SDK to all three sources via the builder extensions:
using var tracerProvider = Sdk.CreateTracerProviderBuilder()
.AddSnowberryMediatorInstrumentation()
.AddConsoleExporter()
.Build();
using var meterProvider = Sdk.CreateMeterProviderBuilder()
.AddSnowberryMediatorInstrumentation()
.AddConsoleExporter()
.Build();
Enrichment and filtering
MediatorTelemetryOptions exposes enrichment callbacks (EnrichWithRequest, EnrichWithResponse, EnrichWithNotification, EnrichWithException) and a Filter that short-circuits instrumentation for a given dispatch. Exceptions thrown from enrichment callbacks are recorded as an Activity event named snowberry.mediator.enrichment.failed and do not propagate to the caller.
The Filter callback is the exception: it is evaluated before any Activity exists, so a throwing Filter is not swallowed and instead propagates out of the dispatch call. Keep Filter total (non-throwing). EnrichWithException fires for failed SendAsync, PublishAsync, and CreateStreamAsync dispatches; for a stream it does not fire when the consumer merely stops enumerating early (no exception occurred), though the span is still marked Error.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- OpenTelemetry.Api (>= 1.15.3)
- Snowberry.Mediator (>= 2.0.0)
- System.Diagnostics.DiagnosticSource (>= 10.0.6)
-
net10.0
- OpenTelemetry.Api (>= 1.15.3)
- Snowberry.Mediator (>= 2.0.0)
-
net9.0
- OpenTelemetry.Api (>= 1.15.3)
- Snowberry.Mediator (>= 2.0.0)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on Snowberry.Mediator.OpenTelemetry.Shared:
| Package | Downloads |
|---|---|
|
Snowberry.Mediator.OpenTelemetry
Snowberry.DependencyInjection integration for Snowberry.Mediator OpenTelemetry. |
|
|
Snowberry.Mediator.Extensions.OpenTelemetry
Microsoft.Extensions.DependencyInjection integration for Snowberry.Mediator OpenTelemetry. |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 2.0.0 | 151 | 6/1/2026 |