-
Notifications
You must be signed in to change notification settings - Fork 25
Expand file tree
/
Copy pathCorrelationIdEnricher.cs
More file actions
77 lines (65 loc) · 2.77 KB
/
CorrelationIdEnricher.cs
File metadata and controls
77 lines (65 loc) · 2.77 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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
using Microsoft.AspNetCore.Http;
using Serilog.Core;
using Serilog.Events;
using Serilog.Preparers.CorrelationIds;
#nullable enable
namespace Serilog.Enrichers;
/// <inheritdoc />
public class CorrelationIdEnricher : ILogEventEnricher
{
private const string CorrelationIdItemKey = "Serilog_CorrelationId";
private const string PropertyName = "CorrelationId";
private readonly IHttpContextAccessor _contextAccessor;
private readonly CorrelationIdPreparerOptions _options;
/// <summary>
/// Initializes a new instance of the <see cref="CorrelationIdEnricher" /> class.
/// </summary>
/// <param name="headerKey">
/// The header key used to retrieve the correlation ID from the HTTP request or response headers.
/// </param>
/// <param name="addValueIfHeaderAbsence">
/// Determines whether to add a new correlation ID value if the header is absent.
/// </param>
public CorrelationIdEnricher(
string headerKey,
bool addValueIfHeaderAbsence)
: this(
headerKey,
addValueIfHeaderAbsence,
new HttpContextAccessor())
{
}
internal CorrelationIdEnricher(
string headerKey,
bool addValueIfHeaderAbsence,
IHttpContextAccessor contextAccessor)
{
_options = new CorrelationIdPreparerOptions(addValueIfHeaderAbsence, headerKey);
_contextAccessor = contextAccessor;
}
/// <inheritdoc />
public void Enrich(LogEvent logEvent, ILogEventPropertyFactory propertyFactory)
{
HttpContext httpContext = _contextAccessor.HttpContext;
if (httpContext == null) return;
if (httpContext.Items.TryGetValue(CorrelationIdItemKey, out object? value) &&
value is LogEventProperty logEventProperty)
{
logEvent.AddPropertyIfAbsent(logEventProperty);
// Ensure the string value is also available if not already stored
if (!httpContext.Items.ContainsKey(Constants.CorrelationIdValueKey))
{
string? correlationIdValue = ((ScalarValue)logEventProperty.Value).Value as string;
httpContext.Items.Add(Constants.CorrelationIdValueKey, correlationIdValue);
}
return;
}
ICorrelationIdPreparer correlationIdPreparer = httpContext.GetCorrelationIdPreparer();
string? correlationId = correlationIdPreparer.PrepareCorrelationId(httpContext, _options);
LogEventProperty correlationIdProperty = new(PropertyName, new ScalarValue(correlationId));
logEvent.AddOrUpdateProperty(correlationIdProperty);
httpContext.Items.Add(CorrelationIdItemKey, correlationIdProperty);
httpContext.Items.Add(Constants.CorrelationIdValueKey, correlationId);
}
}
#nullable disable