Add utilities for handling the traceparent header (see Trace Context W3C standard).

This commit is contained in:
2025-08-02 11:40:37 -05:00
parent c6d02d7db7
commit be60254227
2 changed files with 36 additions and 2 deletions

View File

@@ -1,6 +1,6 @@
# Package
version = "0.4.8"
version = "0.4.9"
author = "Jonathan Bernard"
description = "Jonathan's opinionated extensions and auth layer for Jester."
license = "MIT"

View File

@@ -1,5 +1,5 @@
import std/[json, jsonutils, options, sequtils, strtabs, strutils]
import mummy, webby
import mummy, webby, uuids
import std/httpcore except HttpHeaders
@@ -90,6 +90,40 @@ func origin*(req: Request): Option[string] =
else: none[string]()
func traceparent*(req: Request): Option[string] =
## Extract the traceparent from the request headers, if present.
if req.headers.contains("traceparent"):
return some(req.headers["traceparent"])
else:
return none[string]()
proc makeTraceContextHeaders*(req: Request, traceParentId: string): HttpHeaders =
var headers = HttpHeaders(@[])
if req.headers.contains("traceparent"):
# If the traceparent header is present, we should update it with our
# parent-id.
let traceparentParts = req.headers["traceparent"].split("-")
if traceparentParts.len != 4:
headers["traceparent"] = "00-$#-$#-00" % [
replace($genUUID(), "-", ""), # trace-id
traceParentId, # parent-id
]
else:
headers["traceparent"] = "00-$#-$#-$#" % [
traceparentParts[1], # trace-id
traceParentId, # parent-id
traceparentParts[3], # flags
]
if req.headers.contains("tracestate"):
headers["tracestate"] = req.headers["tracestate"]
return headers
proc respondWithRawJson*(
req: Request,
body: JsonNode,