@smithers-orchestrator/observability 0.16.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (202) hide show
  1. package/LICENSE +21 -0
  2. package/package.json +44 -0
  3. package/src/MetricName.ts +1 -0
  4. package/src/MetricsServiceLive.js +9 -0
  5. package/src/ResolvedSmithersObservabilityOptions.ts +10 -0
  6. package/src/SmithersEvent.ts +603 -0
  7. package/src/SmithersLogFormat.ts +1 -0
  8. package/src/SmithersMetricDefinition.ts +15 -0
  9. package/src/SmithersMetricType.ts +1 -0
  10. package/src/SmithersMetricUnit.ts +8 -0
  11. package/src/SmithersObservability.js +6 -0
  12. package/src/SmithersObservabilityOptions.ts +10 -0
  13. package/src/SmithersObservabilityService.ts +15 -0
  14. package/src/_coreCorrelation/CorrelationContext.ts +10 -0
  15. package/src/_coreCorrelation/CorrelationContextLive.js +11 -0
  16. package/src/_coreCorrelation/CorrelationContextService.js +6 -0
  17. package/src/_coreCorrelation/CorrelationContextServiceShape.ts +14 -0
  18. package/src/_coreCorrelation/CorrelationPatch.ts +3 -0
  19. package/src/_coreCorrelation/_correlationStorage.js +4 -0
  20. package/src/_coreCorrelation/correlationContextFiberRef.js +2 -0
  21. package/src/_coreCorrelation/correlationContextToLogAnnotations.js +28 -0
  22. package/src/_coreCorrelation/getCurrentCorrelationContext.js +9 -0
  23. package/src/_coreCorrelation/getCurrentCorrelationContextEffect.js +11 -0
  24. package/src/_coreCorrelation/index.js +14 -0
  25. package/src/_coreCorrelation/mergeCorrelationContext.js +61 -0
  26. package/src/_coreCorrelation/runWithCorrelationContext.js +14 -0
  27. package/src/_coreCorrelation/updateCurrentCorrelationContext.js +19 -0
  28. package/src/_coreCorrelation/withCorrelationContext.js +15 -0
  29. package/src/_coreCorrelation/withCurrentCorrelationContext.js +13 -0
  30. package/src/_coreMetrics.js +510 -0
  31. package/src/_coreMetricsShape.ts +55 -0
  32. package/src/_corePrometheus.js +93 -0
  33. package/src/_corePrometheusShape.ts +11 -0
  34. package/src/_coreTracing.js +142 -0
  35. package/src/_coreTracingShape.ts +17 -0
  36. package/src/_smithersSpanAttributeAliases.js +19 -0
  37. package/src/_smithersTraceSpanStorage.js +3 -0
  38. package/src/annotateSmithersTrace.js +11 -0
  39. package/src/correlation.js +20 -0
  40. package/src/createSmithersObservabilityLayer.js +49 -0
  41. package/src/createSmithersOtelLayer.js +21 -0
  42. package/src/createSmithersRuntimeLayer.js +2 -0
  43. package/src/getCurrentSmithersTraceAnnotations.js +14 -0
  44. package/src/getCurrentSmithersTraceSpan.js +7 -0
  45. package/src/index.d.ts +1032 -0
  46. package/src/index.js +35 -0
  47. package/src/logging.js +91 -0
  48. package/src/makeSmithersSpanAttributes.js +20 -0
  49. package/src/metrics/SmithersMetricDefinition.ts +17 -0
  50. package/src/metrics/SmithersMetricType.ts +1 -0
  51. package/src/metrics/SmithersMetricUnit.ts +8 -0
  52. package/src/metrics/_asyncExternalWaitCounts.js +4 -0
  53. package/src/metrics/_buckets.js +43 -0
  54. package/src/metrics/_processStartMs.js +1 -0
  55. package/src/metrics/activeNodes.js +2 -0
  56. package/src/metrics/activeRuns.js +2 -0
  57. package/src/metrics/agentActionsTotal.js +2 -0
  58. package/src/metrics/agentDurationMs.js +3 -0
  59. package/src/metrics/agentErrorsTotal.js +2 -0
  60. package/src/metrics/agentEventsTotal.js +2 -0
  61. package/src/metrics/agentInvocationsTotal.js +2 -0
  62. package/src/metrics/agentRetriesTotal.js +2 -0
  63. package/src/metrics/agentSessionsTotal.js +2 -0
  64. package/src/metrics/agentTokensTotal.js +2 -0
  65. package/src/metrics/alertDeliveriesAttempted.js +2 -0
  66. package/src/metrics/alertDeliveriesSuppressed.js +2 -0
  67. package/src/metrics/alertsAcknowledgedTotal.js +2 -0
  68. package/src/metrics/alertsActive.js +2 -0
  69. package/src/metrics/alertsEscalatedTotal.js +2 -0
  70. package/src/metrics/alertsFiredTotal.js +2 -0
  71. package/src/metrics/alertsReopenedTotal.js +2 -0
  72. package/src/metrics/alertsResolvedTotal.js +2 -0
  73. package/src/metrics/alertsSilencedTotal.js +2 -0
  74. package/src/metrics/approvalPending.js +2 -0
  75. package/src/metrics/approvalWaitDuration.js +3 -0
  76. package/src/metrics/approvalsDenied.js +2 -0
  77. package/src/metrics/approvalsGranted.js +2 -0
  78. package/src/metrics/approvalsRequested.js +2 -0
  79. package/src/metrics/attemptDuration.js +3 -0
  80. package/src/metrics/attentionBacklog.js +2 -0
  81. package/src/metrics/cacheHits.js +2 -0
  82. package/src/metrics/cacheMisses.js +2 -0
  83. package/src/metrics/dbQueryDuration.js +3 -0
  84. package/src/metrics/dbRetries.js +2 -0
  85. package/src/metrics/dbTransactionDuration.js +3 -0
  86. package/src/metrics/dbTransactionRetries.js +2 -0
  87. package/src/metrics/dbTransactionRollbacks.js +2 -0
  88. package/src/metrics/devtoolsActiveSubscribers.js +2 -0
  89. package/src/metrics/devtoolsBackpressureDisconnectTotal.js +2 -0
  90. package/src/metrics/devtoolsDeltaBuildMs.js +3 -0
  91. package/src/metrics/devtoolsEventBytes.js +3 -0
  92. package/src/metrics/devtoolsEventTotal.js +2 -0
  93. package/src/metrics/devtoolsSnapshotBuildMs.js +3 -0
  94. package/src/metrics/devtoolsSubscribeTotal.js +2 -0
  95. package/src/metrics/errorsTotal.js +2 -0
  96. package/src/metrics/eventsEmittedTotal.js +2 -0
  97. package/src/metrics/externalWaitAsyncPending.js +2 -0
  98. package/src/metrics/gatewayApprovalDecisionsTotal.js +2 -0
  99. package/src/metrics/gatewayAuthEventsTotal.js +2 -0
  100. package/src/metrics/gatewayConnectionsActive.js +2 -0
  101. package/src/metrics/gatewayConnectionsClosedTotal.js +2 -0
  102. package/src/metrics/gatewayConnectionsTotal.js +2 -0
  103. package/src/metrics/gatewayCronTriggersTotal.js +2 -0
  104. package/src/metrics/gatewayErrorsTotal.js +2 -0
  105. package/src/metrics/gatewayHeartbeatTicksTotal.js +2 -0
  106. package/src/metrics/gatewayMessagesReceivedTotal.js +2 -0
  107. package/src/metrics/gatewayMessagesSentTotal.js +2 -0
  108. package/src/metrics/gatewayRpcCallsTotal.js +2 -0
  109. package/src/metrics/gatewayRpcDuration.js +3 -0
  110. package/src/metrics/gatewayRunsCompletedTotal.js +2 -0
  111. package/src/metrics/gatewayRunsStartedTotal.js +2 -0
  112. package/src/metrics/gatewaySignalsTotal.js +2 -0
  113. package/src/metrics/gatewayWebhooksReceivedTotal.js +2 -0
  114. package/src/metrics/gatewayWebhooksRejectedTotal.js +2 -0
  115. package/src/metrics/gatewayWebhooksVerifiedTotal.js +2 -0
  116. package/src/metrics/heartbeatDataSizeBytes.js +3 -0
  117. package/src/metrics/heartbeatIntervalMs.js +3 -0
  118. package/src/metrics/hotReloadDuration.js +3 -0
  119. package/src/metrics/hotReloadFailures.js +2 -0
  120. package/src/metrics/hotReloads.js +2 -0
  121. package/src/metrics/httpRequestDuration.js +3 -0
  122. package/src/metrics/httpRequests.js +2 -0
  123. package/src/metrics/index.js +151 -0
  124. package/src/metrics/metricsServiceAdapter.js +188 -0
  125. package/src/metrics/nodeDuration.js +3 -0
  126. package/src/metrics/nodeRetriesTotal.js +2 -0
  127. package/src/metrics/nodesFailed.js +2 -0
  128. package/src/metrics/nodesFinished.js +2 -0
  129. package/src/metrics/nodesStarted.js +2 -0
  130. package/src/metrics/processHeapUsedBytes.js +2 -0
  131. package/src/metrics/processMemoryRssBytes.js +2 -0
  132. package/src/metrics/processUptimeSeconds.js +2 -0
  133. package/src/metrics/promptSizeBytes.js +3 -0
  134. package/src/metrics/responseSizeBytes.js +3 -0
  135. package/src/metrics/rewindDurationMs.js +3 -0
  136. package/src/metrics/rewindFramesDeleted.js +3 -0
  137. package/src/metrics/rewindRollbackTotal.js +2 -0
  138. package/src/metrics/rewindSandboxesReverted.js +3 -0
  139. package/src/metrics/rewindTotal.js +2 -0
  140. package/src/metrics/runDuration.js +3 -0
  141. package/src/metrics/runsAncestryDepth.js +3 -0
  142. package/src/metrics/runsCancelledTotal.js +2 -0
  143. package/src/metrics/runsCarriedStateBytes.js +3 -0
  144. package/src/metrics/runsContinuedTotal.js +2 -0
  145. package/src/metrics/runsFailedTotal.js +2 -0
  146. package/src/metrics/runsFinishedTotal.js +2 -0
  147. package/src/metrics/runsResumedTotal.js +2 -0
  148. package/src/metrics/runsTotal.js +2 -0
  149. package/src/metrics/sandboxActive.js +2 -0
  150. package/src/metrics/sandboxBundleSizeBytes.js +3 -0
  151. package/src/metrics/sandboxCompletedTotal.js +2 -0
  152. package/src/metrics/sandboxCreatedTotal.js +2 -0
  153. package/src/metrics/sandboxDurationMs.js +3 -0
  154. package/src/metrics/sandboxPatchCount.js +3 -0
  155. package/src/metrics/sandboxTransportDurationMs.js +3 -0
  156. package/src/metrics/schedulerConcurrencyUtilization.js +2 -0
  157. package/src/metrics/schedulerQueueDepth.js +2 -0
  158. package/src/metrics/schedulerWaitDuration.js +3 -0
  159. package/src/metrics/scorerEventsFailed.js +2 -0
  160. package/src/metrics/scorerEventsFinished.js +2 -0
  161. package/src/metrics/scorerEventsStarted.js +2 -0
  162. package/src/metrics/smithersMetricCatalog.js +484 -0
  163. package/src/metrics/smithersMetricCatalogByKey.js +2 -0
  164. package/src/metrics/smithersMetricCatalogByName.js +2 -0
  165. package/src/metrics/smithersMetricCatalogByPrometheusName.js +2 -0
  166. package/src/metrics/supervisorPollDuration.js +3 -0
  167. package/src/metrics/supervisorPollsTotal.js +2 -0
  168. package/src/metrics/supervisorResumeLag.js +3 -0
  169. package/src/metrics/supervisorResumedTotal.js +2 -0
  170. package/src/metrics/supervisorSkippedTotal.js +2 -0
  171. package/src/metrics/supervisorStaleDetected.js +2 -0
  172. package/src/metrics/taskHeartbeatTimeoutTotal.js +2 -0
  173. package/src/metrics/taskHeartbeatsTotal.js +2 -0
  174. package/src/metrics/timerDelayDuration.js +3 -0
  175. package/src/metrics/timersCancelled.js +2 -0
  176. package/src/metrics/timersCreated.js +2 -0
  177. package/src/metrics/timersFired.js +2 -0
  178. package/src/metrics/timersPending.js +2 -0
  179. package/src/metrics/toPrometheusMetricName.js +8 -0
  180. package/src/metrics/tokensCacheReadTotal.js +2 -0
  181. package/src/metrics/tokensCacheWriteTotal.js +2 -0
  182. package/src/metrics/tokensContextWindowBucketTotal.js +2 -0
  183. package/src/metrics/tokensContextWindowPerCall.js +3 -0
  184. package/src/metrics/tokensInputPerCall.js +3 -0
  185. package/src/metrics/tokensInputTotal.js +2 -0
  186. package/src/metrics/tokensOutputPerCall.js +3 -0
  187. package/src/metrics/tokensOutputTotal.js +2 -0
  188. package/src/metrics/tokensReasoningTotal.js +2 -0
  189. package/src/metrics/toolCallErrorsTotal.js +2 -0
  190. package/src/metrics/toolCallsTotal.js +2 -0
  191. package/src/metrics/toolDuration.js +3 -0
  192. package/src/metrics/toolOutputTruncatedTotal.js +2 -0
  193. package/src/metrics/trackEvent.js +604 -0
  194. package/src/metrics/updateAsyncExternalWaitPending.js +14 -0
  195. package/src/metrics/updateProcessMetrics.js +17 -0
  196. package/src/metrics/vcsDuration.js +3 -0
  197. package/src/prometheusContentType.js +1 -0
  198. package/src/renderPrometheusMetrics.js +205 -0
  199. package/src/resolveSmithersObservabilityOptions.js +79 -0
  200. package/src/smithersMetrics.js +2 -0
  201. package/src/smithersSpanNames.js +6 -0
  202. package/src/withSmithersSpan.js +15 -0
@@ -0,0 +1,8 @@
1
+ export type SmithersMetricUnit =
2
+ | "count"
3
+ | "milliseconds"
4
+ | "seconds"
5
+ | "bytes"
6
+ | "tokens"
7
+ | "ratio"
8
+ | "depth";
@@ -0,0 +1,6 @@
1
+ import { Context } from "effect";
2
+ /** @typedef {import("./SmithersObservabilityService.ts").SmithersObservabilityService} SmithersObservabilityService */
3
+
4
+ const _SmithersObservabilityBase = /** @type {Context.TagClass<SmithersObservability, "SmithersObservability", SmithersObservabilityService>} */ (/** @type {unknown} */ (Context.Tag("SmithersObservability")()));
5
+ export class SmithersObservability extends _SmithersObservabilityBase {
6
+ }
@@ -0,0 +1,10 @@
1
+ import type { LogLevel } from "effect";
2
+ import type { SmithersLogFormat } from "./SmithersLogFormat";
3
+
4
+ export type SmithersObservabilityOptions = {
5
+ readonly enabled?: boolean;
6
+ readonly endpoint?: string;
7
+ readonly serviceName?: string;
8
+ readonly logFormat?: SmithersLogFormat;
9
+ readonly logLevel?: LogLevel.LogLevel | string;
10
+ };
@@ -0,0 +1,15 @@
1
+ import type { Effect } from "effect";
2
+ import type * as Tracer from "effect/Tracer";
3
+ import type { ResolvedSmithersObservabilityOptions } from "./ResolvedSmithersObservabilityOptions";
4
+
5
+ export type SmithersObservabilityService = {
6
+ readonly options: ResolvedSmithersObservabilityOptions;
7
+ readonly annotate: (
8
+ attributes: Readonly<Record<string, unknown>>,
9
+ ) => Effect.Effect<void>;
10
+ readonly withSpan: <A, E, R>(
11
+ name: string,
12
+ effect: Effect.Effect<A, E, R>,
13
+ attributes?: Readonly<Record<string, unknown>>,
14
+ ) => Effect.Effect<A, E, Exclude<R, Tracer.ParentSpan>>;
15
+ };
@@ -0,0 +1,10 @@
1
+ export type CorrelationContext = {
2
+ runId: string;
3
+ nodeId?: string;
4
+ iteration?: number;
5
+ attempt?: number;
6
+ workflowName?: string;
7
+ parentRunId?: string;
8
+ traceId?: string;
9
+ spanId?: string;
10
+ };
@@ -0,0 +1,11 @@
1
+ import { Layer } from "effect";
2
+ import { CorrelationContextService } from "./CorrelationContextService.js";
3
+ import { correlationContextToLogAnnotations } from "./correlationContextToLogAnnotations.js";
4
+ import { getCurrentCorrelationContextEffect } from "./getCurrentCorrelationContextEffect.js";
5
+ import { withCorrelationContext } from "./withCorrelationContext.js";
6
+ /** @type {Layer.Layer<CorrelationContextService, never, never>} */
7
+ export const CorrelationContextLive = Layer.succeed(CorrelationContextService, {
8
+ current: () => getCurrentCorrelationContextEffect(),
9
+ withCorrelation: (patch, effect) => withCorrelationContext(effect, patch),
10
+ toLogAnnotations: correlationContextToLogAnnotations,
11
+ });
@@ -0,0 +1,6 @@
1
+ import { Context } from "effect";
2
+ /** @typedef {import("./CorrelationContextServiceShape.ts").CorrelationContextServiceShape} CorrelationContextServiceShape */
3
+
4
+ const _CorrelationContextServiceBase = /** @type {Context.TagClass<CorrelationContextService, "CorrelationContextService", CorrelationContextServiceShape>} */ (/** @type {unknown} */ (Context.Tag("CorrelationContextService")()));
5
+ export class CorrelationContextService extends _CorrelationContextServiceBase {
6
+ }
@@ -0,0 +1,14 @@
1
+ import type { Effect } from "effect";
2
+ import type { CorrelationContext } from "./CorrelationContext.ts";
3
+ import type { CorrelationPatch } from "./CorrelationPatch.ts";
4
+
5
+ export type CorrelationContextServiceShape = {
6
+ readonly current: () => Effect.Effect<CorrelationContext | undefined>;
7
+ readonly withCorrelation: <A, E, R>(
8
+ patch: CorrelationPatch,
9
+ effect: Effect.Effect<A, E, R>,
10
+ ) => Effect.Effect<A, E, R>;
11
+ readonly toLogAnnotations: (
12
+ context?: CorrelationContext | null,
13
+ ) => Record<string, unknown> | undefined;
14
+ };
@@ -0,0 +1,3 @@
1
+ import type { CorrelationContext } from "./CorrelationContext.ts";
2
+
3
+ export type CorrelationPatch = Partial<CorrelationContext> | undefined | null;
@@ -0,0 +1,4 @@
1
+ import { AsyncLocalStorage } from "node:async_hooks";
2
+ /** @typedef {import("./CorrelationContext.ts").CorrelationContext} CorrelationContext */
3
+ /** @type {AsyncLocalStorage<CorrelationContext>} */
4
+ export const correlationStorage = new AsyncLocalStorage();
@@ -0,0 +1,2 @@
1
+ import { FiberRef } from "effect";
2
+ export const correlationContextFiberRef = FiberRef.unsafeMake(undefined);
@@ -0,0 +1,28 @@
1
+
2
+ /** @typedef {import("./CorrelationContext.ts").CorrelationContext} CorrelationContext */
3
+ /**
4
+ * @param {CorrelationContext | null} [context]
5
+ * @returns {Record<string, unknown> | undefined}
6
+ */
7
+ export function correlationContextToLogAnnotations(context) {
8
+ if (!context)
9
+ return undefined;
10
+ const annotations = {};
11
+ if (context.runId)
12
+ annotations.runId = context.runId;
13
+ if (context.nodeId)
14
+ annotations.nodeId = context.nodeId;
15
+ if (context.workflowName)
16
+ annotations.workflowName = context.workflowName;
17
+ if (context.parentRunId)
18
+ annotations.parentRunId = context.parentRunId;
19
+ if (context.traceId)
20
+ annotations.traceId = context.traceId;
21
+ if (context.spanId)
22
+ annotations.spanId = context.spanId;
23
+ if (typeof context.iteration === "number")
24
+ annotations.iteration = context.iteration;
25
+ if (typeof context.attempt === "number")
26
+ annotations.attempt = context.attempt;
27
+ return Object.keys(annotations).length > 0 ? annotations : undefined;
28
+ }
@@ -0,0 +1,9 @@
1
+ import { correlationStorage } from "./_correlationStorage.js";
2
+ /** @typedef {import("./CorrelationContext.ts").CorrelationContext} CorrelationContext */
3
+
4
+ /**
5
+ * @returns {CorrelationContext | undefined}
6
+ */
7
+ export function getCurrentCorrelationContext() {
8
+ return correlationStorage.getStore();
9
+ }
@@ -0,0 +1,11 @@
1
+ import { Effect, FiberRef } from "effect";
2
+ import { correlationContextFiberRef } from "./correlationContextFiberRef.js";
3
+ import { correlationStorage } from "./_correlationStorage.js";
4
+ /** @typedef {import("./CorrelationContext.ts").CorrelationContext} CorrelationContext */
5
+
6
+ /**
7
+ * @returns {Effect.Effect< CorrelationContext | undefined >}
8
+ */
9
+ export function getCurrentCorrelationContextEffect() {
10
+ return FiberRef.get(correlationContextFiberRef).pipe(Effect.map((fiberContext) => fiberContext ?? correlationStorage.getStore()));
11
+ }
@@ -0,0 +1,14 @@
1
+ /** @typedef {import("./CorrelationContext.ts").CorrelationContext} CorrelationContext */
2
+ /** @typedef {import("./CorrelationPatch.ts").CorrelationPatch} CorrelationPatch */
3
+
4
+ export { correlationContextFiberRef } from "./correlationContextFiberRef.js";
5
+ export { CorrelationContextService } from "./CorrelationContextService.js";
6
+ export { CorrelationContextLive } from "./CorrelationContextLive.js";
7
+ export { mergeCorrelationContext } from "./mergeCorrelationContext.js";
8
+ export { getCurrentCorrelationContext } from "./getCurrentCorrelationContext.js";
9
+ export { getCurrentCorrelationContextEffect } from "./getCurrentCorrelationContextEffect.js";
10
+ export { updateCurrentCorrelationContext } from "./updateCurrentCorrelationContext.js";
11
+ export { runWithCorrelationContext } from "./runWithCorrelationContext.js";
12
+ export { withCorrelationContext } from "./withCorrelationContext.js";
13
+ export { withCurrentCorrelationContext } from "./withCurrentCorrelationContext.js";
14
+ export { correlationContextToLogAnnotations } from "./correlationContextToLogAnnotations.js";
@@ -0,0 +1,61 @@
1
+
2
+ /** @typedef {import("./CorrelationContext.ts").CorrelationContext} CorrelationContext */
3
+ /** @typedef {import("./CorrelationPatch.ts").CorrelationPatch} CorrelationPatch */
4
+ /**
5
+ * @param {unknown} value
6
+ * @returns {string | undefined}
7
+ */
8
+ function cleanString(value) {
9
+ return typeof value === "string" && value.length > 0 ? value : undefined;
10
+ }
11
+ /**
12
+ * @param {unknown} value
13
+ * @returns {number | undefined}
14
+ */
15
+ function cleanNumber(value) {
16
+ return typeof value === "number" && Number.isFinite(value) ? value : undefined;
17
+ }
18
+ /**
19
+ * @param {CorrelationPatch} patch
20
+ * @returns {Partial<CorrelationContext> | undefined}
21
+ */
22
+ function normalizePatch(patch) {
23
+ if (!patch)
24
+ return undefined;
25
+ const normalized = {};
26
+ const runId = cleanString(patch.runId);
27
+ const nodeId = cleanString(patch.nodeId);
28
+ const workflowName = cleanString(patch.workflowName);
29
+ const parentRunId = cleanString(patch.parentRunId);
30
+ const traceId = cleanString(patch.traceId);
31
+ const spanId = cleanString(patch.spanId);
32
+ const iteration = cleanNumber(patch.iteration);
33
+ const attempt = cleanNumber(patch.attempt);
34
+ if (runId)
35
+ normalized.runId = runId;
36
+ if (nodeId)
37
+ normalized.nodeId = nodeId;
38
+ if (workflowName)
39
+ normalized.workflowName = workflowName;
40
+ if (parentRunId)
41
+ normalized.parentRunId = parentRunId;
42
+ if (traceId)
43
+ normalized.traceId = traceId;
44
+ if (spanId)
45
+ normalized.spanId = spanId;
46
+ if (iteration !== undefined)
47
+ normalized.iteration = iteration;
48
+ if (attempt !== undefined)
49
+ normalized.attempt = attempt;
50
+ return Object.keys(normalized).length > 0 ? normalized : undefined;
51
+ }
52
+ /**
53
+ * @param {CorrelationContext | null} [base]
54
+ * @param {CorrelationPatch} [patch]
55
+ * @returns {CorrelationContext | undefined}
56
+ */
57
+ export function mergeCorrelationContext(base, patch) {
58
+ const normalizedPatch = normalizePatch(patch);
59
+ const merged = { ...base, ...normalizedPatch };
60
+ return merged.runId ? merged : undefined;
61
+ }
@@ -0,0 +1,14 @@
1
+ import { correlationStorage } from "./_correlationStorage.js";
2
+ import { mergeCorrelationContext } from "./mergeCorrelationContext.js";
3
+ /** @typedef {import("./CorrelationPatch.ts").CorrelationPatch} CorrelationPatch */
4
+
5
+ /**
6
+ * @template T
7
+ * @param {CorrelationPatch} patch
8
+ * @param {() => T} fn
9
+ * @returns {T}
10
+ */
11
+ export function runWithCorrelationContext(patch, fn) {
12
+ const next = mergeCorrelationContext(correlationStorage.getStore(), patch);
13
+ return next ? correlationStorage.run(next, fn) : fn();
14
+ }
@@ -0,0 +1,19 @@
1
+ import { Effect, FiberRef } from "effect";
2
+ import { correlationContextFiberRef } from "./correlationContextFiberRef.js";
3
+ import { getCurrentCorrelationContextEffect } from "./getCurrentCorrelationContextEffect.js";
4
+ import { mergeCorrelationContext } from "./mergeCorrelationContext.js";
5
+ /** @typedef {import("./CorrelationContext.ts").CorrelationContext} CorrelationContext */
6
+ /** @typedef {import("./CorrelationPatch.ts").CorrelationPatch} CorrelationPatch */
7
+
8
+ /**
9
+ * @param {CorrelationPatch} patch
10
+ * @returns {Effect.Effect<CorrelationContext | undefined>}
11
+ */
12
+ export function updateCurrentCorrelationContext(patch) {
13
+ return Effect.gen(function* () {
14
+ const current = yield* getCurrentCorrelationContextEffect();
15
+ const next = mergeCorrelationContext(current, patch);
16
+ yield* FiberRef.set(correlationContextFiberRef, next);
17
+ return next;
18
+ });
19
+ }
@@ -0,0 +1,15 @@
1
+ import { Effect } from "effect";
2
+ import { correlationContextFiberRef } from "./correlationContextFiberRef.js";
3
+ import { correlationStorage } from "./_correlationStorage.js";
4
+ import { mergeCorrelationContext } from "./mergeCorrelationContext.js";
5
+ /** @typedef {import("./CorrelationPatch.ts").CorrelationPatch} CorrelationPatch */
6
+
7
+ /**
8
+ * @template A, E, R
9
+ * @param {Effect.Effect<A, E, R>} effect
10
+ * @param {CorrelationPatch} patch
11
+ */
12
+ export function withCorrelationContext(effect, patch) {
13
+ const next = mergeCorrelationContext(correlationStorage.getStore(), patch);
14
+ return next ? effect.pipe(Effect.locally(correlationContextFiberRef, next)) : effect;
15
+ }
@@ -0,0 +1,13 @@
1
+ import { Effect } from "effect";
2
+ import { correlationContextFiberRef } from "./correlationContextFiberRef.js";
3
+ import { correlationStorage } from "./_correlationStorage.js";
4
+ /**
5
+ * @template A, E, R
6
+ * @param {Effect.Effect<A, E, R>} effect
7
+ */
8
+ export function withCurrentCorrelationContext(effect) {
9
+ const current = correlationStorage.getStore();
10
+ return current
11
+ ? effect.pipe(Effect.locally(correlationContextFiberRef, current))
12
+ : effect;
13
+ }