-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathOpenTelemetryLoggerConfigurationService.cs
More file actions
47 lines (40 loc) · 1.61 KB
/
OpenTelemetryLoggerConfigurationService.cs
File metadata and controls
47 lines (40 loc) · 1.61 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
using System.Collections.Generic;
using Microsoft.Extensions.Configuration;
using Serilog;
using Serilog.Sinks.OpenTelemetry;
using VirtoCommerce.Platform.Core.Logger;
namespace VirtoCommerce.OpenTelemetry.Web;
/// <summary>
/// Configures Serilog to send logs to OpenTelemetry via OTLP.
/// Integrates with the platform's Serilog configuration pipeline.
/// </summary>
public class OpenTelemetryLoggerConfigurationService : ILoggerConfigurationService
{
private readonly IConfiguration _configuration;
public OpenTelemetryLoggerConfigurationService(IConfiguration configuration)
{
_configuration = configuration;
}
public void Configure(LoggerConfiguration loggerConfiguration)
{
var otlpEndpoint = _configuration["OpenTelemetry:Endpoint"];
if (string.IsNullOrWhiteSpace(otlpEndpoint))
{
return;
}
loggerConfiguration.WriteTo.OpenTelemetry(options =>
{
options.Endpoint = otlpEndpoint;
options.Protocol = OtlpProtocol.Grpc;
// Include trace context for correlation with distributed traces
options.IncludedData = IncludedData.TraceIdField | IncludedData.SpanIdField |
IncludedData.MessageTemplateTextAttribute |
IncludedData.MessageTemplateMD5HashAttribute;
var serviceName = _configuration["OpenTelemetry:ServiceName"] ?? "VirtoCommerce.Platform";
options.ResourceAttributes = new Dictionary<string, object>
{
["service.name"] = serviceName,
};
});
}
}