-
-
Notifications
You must be signed in to change notification settings - Fork 545
Expand file tree
/
Copy pathEventStoreDBEventMetadataJsonConverter.cs
More file actions
75 lines (62 loc) · 2.46 KB
/
EventStoreDBEventMetadataJsonConverter.cs
File metadata and controls
75 lines (62 loc) · 2.46 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
using Core.OpenTelemetry;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using OpenTelemetry.Context.Propagation;
namespace Core.EventStoreDB.Events;
public class EventStoreDBEventMetadataJsonConverter: JsonConverter
{
private const string CorrelationIdPropertyName = "$correlationId";
private const string CausationIdPropertyName = "$causationId";
private const string TraceParentPropertyName = "traceparent";
private const string TraceStatePropertyName = "tracestate";
public override bool CanConvert(Type objectType) =>
objectType == typeof(PropagationContext) || objectType == typeof(PropagationContext?);
public override void WriteJson(JsonWriter writer, object? value, JsonSerializer serializer)
{
if (value is not PropagationContext propagationContext)
{
writer.WriteNull();
return;
}
writer.WriteStartObject();
writer.WritePropertyName(CorrelationIdPropertyName);
writer.WriteValue(propagationContext.ActivityContext.TraceId.ToHexString());
writer.WritePropertyName(CausationIdPropertyName);
writer.WriteValue(propagationContext.ActivityContext.SpanId.ToHexString());
propagationContext.Inject(writer, SerializePropagationContext);
}
private static void SerializePropagationContext(JsonWriter writer, string key, string value)
{
writer.WritePropertyName(key);
writer.WriteValue(value);
}
public override object ReadJson(JsonReader reader, Type objectType, object? existingValue,
JsonSerializer serializer)
{
var jObject = JObject.Load(reader);
var parentContext = TelemetryPropagator.Extract(
new Dictionary<string, string?>
{
{ TraceParentPropertyName, jObject[TraceParentPropertyName]?.Value<string>() },
{ TraceStatePropertyName, jObject[TraceStatePropertyName]?.Value<string>() }
},
ExtractTraceContextFromEventMetadata
);
return parentContext;
}
private static IEnumerable<string> ExtractTraceContextFromEventMetadata(Dictionary<string, string?> headers,
string key)
{
try
{
return headers.TryGetValue(key, out var value) && value != null
? [value]
: [];
}
catch (Exception ex)
{
Console.WriteLine($"Failed to extract trace context: {ex}");
return [];
}
}
}