@trigger.dev/core 0.0.0-v3-canary-20240325172431 → 0.0.0-v3-pnpm-fix-20240404110601

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.
@@ -32,6 +32,16 @@ var __privateMethod = (obj, member, method) => {
32
32
  return method;
33
33
  };
34
34
 
35
+ // src/v3/limits.ts
36
+ var OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT = 256;
37
+ var OTEL_LOG_ATTRIBUTE_COUNT_LIMIT = 256;
38
+ var OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT = 1028;
39
+ var OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT = 1028;
40
+ var OTEL_SPAN_EVENT_COUNT_LIMIT = 10;
41
+ var OTEL_LINK_COUNT_LIMIT = 2;
42
+ var OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT = 10;
43
+ var OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT = 10;
44
+
35
45
  // src/v3/semanticInternalAttributes.ts
36
46
  var SemanticInternalAttributes = {
37
47
  ENVIRONMENT_ID: "ctx.environment.id",
@@ -56,6 +66,7 @@ var SemanticInternalAttributes = {
56
66
  SPAN_PARTIAL: "$span.partial",
57
67
  SPAN_ID: "$span.span_id",
58
68
  OUTPUT: "$output",
69
+ OUTPUT_TYPE: "$mime_type_output",
59
70
  STYLE: "$style",
60
71
  STYLE_ICON: "$style.icon",
61
72
  STYLE_VARIANT: "$style.variant",
@@ -63,6 +74,7 @@ var SemanticInternalAttributes = {
63
74
  METADATA: "$metadata",
64
75
  TRIGGER: "$trigger",
65
76
  PAYLOAD: "$payload",
77
+ PAYLOAD_TYPE: "$mime_type_payload",
66
78
  SHOW: "$show",
67
79
  SHOW_ACTIONS: "$show.actions",
68
80
  WORKER_ID: "worker.id",
@@ -131,6 +143,8 @@ var _SafeAsyncLocalStorage = class _SafeAsyncLocalStorage {
131
143
  };
132
144
  __name(_SafeAsyncLocalStorage, "SafeAsyncLocalStorage");
133
145
  var SafeAsyncLocalStorage = _SafeAsyncLocalStorage;
146
+
147
+ // src/v3/tasks/taskContextManager.ts
134
148
  var _getStore, getStore_fn;
135
149
  var _TaskContextManager = class _TaskContextManager {
136
150
  constructor() {
@@ -144,10 +158,6 @@ var _TaskContextManager = class _TaskContextManager {
144
158
  const store = __privateMethod(this, _getStore, getStore_fn).call(this);
145
159
  return store?.ctx;
146
160
  }
147
- get payload() {
148
- const store = __privateMethod(this, _getStore, getStore_fn).call(this);
149
- return store?.payload;
150
- }
151
161
  get worker() {
152
162
  const store = __privateMethod(this, _getStore, getStore_fn).call(this);
153
163
  return store?.worker;
@@ -156,19 +166,11 @@ var _TaskContextManager = class _TaskContextManager {
156
166
  if (this.ctx) {
157
167
  return {
158
168
  ...this.contextAttributes,
159
- ...this.workerAttributes,
160
- ...this.payloadAttributes,
161
- [semanticConventions.SemanticResourceAttributes.SERVICE_NAME]: this.ctx.task.id
169
+ ...this.workerAttributes
162
170
  };
163
171
  }
164
172
  return {};
165
173
  }
166
- get payloadAttributes() {
167
- if (this.payload) {
168
- return flattenAttributes(this.payload, "payload");
169
- }
170
- return {};
171
- }
172
174
  get workerAttributes() {
173
175
  if (this.worker) {
174
176
  return {
@@ -315,19 +317,24 @@ var _TracingSDK = class _TracingSDK {
315
317
  forceFlushTimeoutMillis: config.forceFlushTimeoutMillis ?? 500,
316
318
  resource: commonResources,
317
319
  spanLimits: {
318
- attributeCountLimit: 1e3,
319
- attributeValueLengthLimit: 1e3,
320
- eventCountLimit: 100,
321
- attributePerEventCountLimit: 100,
322
- linkCountLimit: 10,
323
- attributePerLinkCountLimit: 100
320
+ attributeCountLimit: OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT,
321
+ attributeValueLengthLimit: OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT,
322
+ eventCountLimit: OTEL_SPAN_EVENT_COUNT_LIMIT,
323
+ attributePerEventCountLimit: OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT,
324
+ linkCountLimit: OTEL_LINK_COUNT_LIMIT,
325
+ attributePerLinkCountLimit: OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT
324
326
  }
325
327
  });
326
328
  const spanExporter = new exporterTraceOtlpHttp.OTLPTraceExporter({
327
329
  url: `${config.url}/v1/traces`,
328
330
  timeoutMillis: config.forceFlushTimeoutMillis ?? 1e3
329
331
  });
330
- traceProvider.addSpanProcessor(new TaskContextSpanProcessor(new sdkTraceNode.SimpleSpanProcessor(spanExporter)));
332
+ traceProvider.addSpanProcessor(new TaskContextSpanProcessor(getEnvVar("OTEL_BATCH_PROCESSING_ENABLED") === "1" ? new sdkTraceNode.BatchSpanProcessor(spanExporter, {
333
+ maxExportBatchSize: parseInt(getEnvVar("OTEL_SPAN_MAX_EXPORT_BATCH_SIZE") ?? "64"),
334
+ scheduledDelayMillis: parseInt(getEnvVar("OTEL_SPAN_SCHEDULED_DELAY_MILLIS") ?? "200"),
335
+ exportTimeoutMillis: parseInt(getEnvVar("OTEL_SPAN_EXPORT_TIMEOUT_MILLIS") ?? "30000"),
336
+ maxQueueSize: parseInt(getEnvVar("OTEL_SPAN_MAX_QUEUE_SIZE") ?? "512")
337
+ }) : new sdkTraceNode.SimpleSpanProcessor(spanExporter)));
331
338
  traceProvider.register();
332
339
  instrumentation.registerInstrumentations({
333
340
  instrumentations: config.instrumentations ?? [],
@@ -339,11 +346,16 @@ var _TracingSDK = class _TracingSDK {
339
346
  const loggerProvider = new sdkLogs.LoggerProvider({
340
347
  resource: commonResources,
341
348
  logRecordLimits: {
342
- attributeCountLimit: 1e3,
343
- attributeValueLengthLimit: 1e3
349
+ attributeCountLimit: OTEL_LOG_ATTRIBUTE_COUNT_LIMIT,
350
+ attributeValueLengthLimit: OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT
344
351
  }
345
352
  });
346
- loggerProvider.addLogRecordProcessor(new TaskContextLogProcessor(new sdkLogs.SimpleLogRecordProcessor(logExporter)));
353
+ loggerProvider.addLogRecordProcessor(new TaskContextLogProcessor(getEnvVar("OTEL_BATCH_PROCESSING_ENABLED") === "1" ? new sdkLogs.BatchLogRecordProcessor(logExporter, {
354
+ maxExportBatchSize: parseInt(getEnvVar("OTEL_LOG_MAX_EXPORT_BATCH_SIZE") ?? "64"),
355
+ scheduledDelayMillis: parseInt(getEnvVar("OTEL_LOG_SCHEDULED_DELAY_MILLIS") ?? "200"),
356
+ exportTimeoutMillis: parseInt(getEnvVar("OTEL_LOG_EXPORT_TIMEOUT_MILLIS") ?? "30000"),
357
+ maxQueueSize: parseInt(getEnvVar("OTEL_LOG_MAX_QUEUE_SIZE") ?? "512")
358
+ }) : new sdkLogs.SimpleLogRecordProcessor(logExporter)));
347
359
  this._logProvider = loggerProvider;
348
360
  this._spanExporter = spanExporter;
349
361
  this._traceProvider = traceProvider;
@@ -352,11 +364,11 @@ var _TracingSDK = class _TracingSDK {
352
364
  this.getTracer = traceProvider.getTracer.bind(traceProvider);
353
365
  }
354
366
  async flush() {
355
- await this._spanExporter.forceFlush?.();
367
+ await this._traceProvider.forceFlush();
356
368
  await this._logProvider.forceFlush();
357
369
  }
358
370
  async shutdown() {
359
- await this._spanExporter.shutdown();
371
+ await this._traceProvider.shutdown();
360
372
  await this._logProvider.shutdown();
361
373
  }
362
374
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/v3/otel/index.ts","../../../src/v3/otel/tracingSDK.ts","../../../src/v3/semanticInternalAttributes.ts","../../../src/v3/utils/flattenAttributes.ts","../../../src/v3/utils/safeAsyncLocalStorage.ts","../../../src/v3/tasks/taskContextManager.ts","../../../src/v3/utils/getEnv.ts"],"names":["SpanStatusCode","DiagConsoleLogger","DiagLogLevel","diag","logs","OTLPLogExporter","OTLPTraceExporter","registerInstrumentations","Resource","detectResourcesSync","processDetectorSync","LoggerProvider","SimpleLogRecordProcessor","NodeTracerProvider","SimpleSpanProcessor","SemanticResourceAttributes","SemanticInternalAttributes","ENVIRONMENT_ID","ENVIRONMENT_TYPE","ORGANIZATION_ID","ORGANIZATION_SLUG","ORGANIZATION_NAME","PROJECT_ID","PROJECT_REF","PROJECT_NAME","PROJECT_DIR","ATTEMPT_ID","ATTEMPT_NUMBER","RUN_ID","RUN_IS_TEST","BATCH_ID","TASK_SLUG","TASK_PATH","TASK_EXPORT_NAME","QUEUE_NAME","QUEUE_ID","SPAN_PARTIAL","SPAN_ID","OUTPUT","STYLE","STYLE_ICON","STYLE_VARIANT","STYLE_ACCESSORY","METADATA","TRIGGER","PAYLOAD","SHOW","SHOW_ACTIONS","WORKER_ID","WORKER_VERSION","CLI_VERSION","SDK_VERSION","SDK_LANGUAGE","RETRY_AT","RETRY_DELAY","RETRY_COUNT","flattenAttributes","obj","prefix","result","key","value","Object","entries","newPrefix","Array","isArray","i","length","assign","isRecord","AsyncLocalStorage","SafeAsyncLocalStorage","constructor","storage","runWith","context","fn","run","getStore","TaskContextManager","_storage","isInsideTask","undefined","ctx","store","payload","worker","attributes","contextAttributes","workerAttributes","payloadAttributes","SERVICE_NAME","task","id","version","attempt","number","filePath","exportName","queue","name","environment","type","organization","project","ref","isTest","slug","batch","taskContextManager","TaskContextSpanProcessor","innerProcessor","_innerProcessor","onStart","span","parentContext","setAttributes","onEnd","shutdown","forceFlush","TaskContextLogProcessor","onEmit","logRecord","getEnvVar","process","env","AsyncResourceDetector","_resolved","_promise","Promise","resolver","_resolver","detect","_config","resolveWithAttributes","Error","TracingSDK","config","asyncResourceDetector","setLogLevel","diagLogLevel","envResourceAttributesSerialized","envResourceAttributes","JSON","parse","commonResources","detectors","merge","CLOUD_PROVIDER","resource","traceProvider","forceFlushTimeoutMillis","spanLimits","attributeCountLimit","attributeValueLengthLimit","eventCountLimit","attributePerEventCountLimit","linkCountLimit","attributePerLinkCountLimit","spanExporter","url","timeoutMillis","addSpanProcessor","register","instrumentations","tracerProvider","logExporter","loggerProvider","logRecordLimits","addLogRecordProcessor","_logProvider","_spanExporter","_traceProvider","setGlobalLoggerProvider","getLogger","bind","getTracer","flush","level","NONE","ERROR","WARN","INFO","DEBUG","VERBOSE","ALL","setLogger","recordSpanException","error","recordException","stringify","setStatus","code"],"mappings":"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","sourcesContent":["import { Span, SpanStatusCode } from \"@opentelemetry/api\";\n\nexport { TracingSDK, type TracingSDKConfig, type TracingDiagnosticLogLevel } from \"./tracingSDK\";\n\nexport function recordSpanException(span: Span, error: unknown) {\n if (error instanceof Error) {\n span.recordException(error);\n } else if (typeof error === \"string\") {\n span.recordException(new Error(error));\n } else {\n span.recordException(new Error(JSON.stringify(error)));\n }\n\n span.setStatus({ code: SpanStatusCode.ERROR });\n}\n","import { DiagConsoleLogger, DiagLogLevel, TracerProvider, diag } from \"@opentelemetry/api\";\nimport { logs } from \"@opentelemetry/api-logs\";\nimport { OTLPLogExporter } from \"@opentelemetry/exporter-logs-otlp-http\";\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-http\";\nimport {\n registerInstrumentations,\n type InstrumentationOption,\n} from \"@opentelemetry/instrumentation\";\nimport {\n DetectorSync,\n IResource,\n Resource,\n ResourceAttributes,\n ResourceDetectionConfig,\n detectResourcesSync,\n processDetectorSync,\n} from \"@opentelemetry/resources\";\nimport { LoggerProvider, SimpleLogRecordProcessor } from \"@opentelemetry/sdk-logs\";\nimport {\n NodeTracerProvider,\n SimpleSpanProcessor,\n SpanExporter,\n} from \"@opentelemetry/sdk-trace-node\";\nimport { SemanticResourceAttributes } from \"@opentelemetry/semantic-conventions\";\nimport { SemanticInternalAttributes } from \"../semanticInternalAttributes\";\nimport { TaskContextLogProcessor, TaskContextSpanProcessor } from \"../tasks/taskContextManager\";\nimport { getEnvVar } from \"../utils/getEnv\";\n\nclass AsyncResourceDetector implements DetectorSync {\n private _promise: Promise<ResourceAttributes>;\n private _resolver?: (value: ResourceAttributes) => void;\n private _resolved: boolean = false;\n\n constructor() {\n this._promise = new Promise((resolver) => {\n this._resolver = resolver;\n });\n }\n\n detect(_config?: ResourceDetectionConfig): Resource {\n return new Resource({}, this._promise);\n }\n\n resolveWithAttributes(attributes: ResourceAttributes) {\n if (!this._resolver) {\n throw new Error(\"Resolver not available\");\n }\n\n if (this._resolved) {\n return;\n }\n\n this._resolved = true;\n this._resolver(attributes);\n }\n}\n\nexport type TracingDiagnosticLogLevel =\n | \"none\"\n | \"error\"\n | \"warn\"\n | \"info\"\n | \"debug\"\n | \"verbose\"\n | \"all\";\n\nexport type TracingSDKConfig = {\n url: string;\n forceFlushTimeoutMillis?: number;\n resource?: IResource;\n instrumentations?: InstrumentationOption[];\n diagLogLevel?: TracingDiagnosticLogLevel;\n};\n\nexport class TracingSDK {\n public readonly asyncResourceDetector = new AsyncResourceDetector();\n private readonly _logProvider: LoggerProvider;\n private readonly _spanExporter: SpanExporter;\n private readonly _traceProvider: TracerProvider;\n\n public readonly getLogger: LoggerProvider[\"getLogger\"];\n public readonly getTracer: TracerProvider[\"getTracer\"];\n\n constructor(private readonly config: TracingSDKConfig) {\n setLogLevel(config.diagLogLevel ?? \"none\");\n\n const envResourceAttributesSerialized = getEnvVar(\"OTEL_RESOURCE_ATTRIBUTES\");\n const envResourceAttributes = envResourceAttributesSerialized\n ? JSON.parse(envResourceAttributesSerialized)\n : {};\n\n const commonResources = detectResourcesSync({\n detectors: [this.asyncResourceDetector, processDetectorSync],\n })\n .merge(\n new Resource({\n [SemanticResourceAttributes.CLOUD_PROVIDER]: \"trigger.dev\",\n [SemanticInternalAttributes.TRIGGER]: true,\n })\n )\n .merge(config.resource ?? new Resource({}))\n .merge(new Resource(envResourceAttributes));\n\n const traceProvider = new NodeTracerProvider({\n forceFlushTimeoutMillis: config.forceFlushTimeoutMillis ?? 500,\n resource: commonResources,\n spanLimits: {\n attributeCountLimit: 1000,\n attributeValueLengthLimit: 1000,\n eventCountLimit: 100,\n attributePerEventCountLimit: 100,\n linkCountLimit: 10,\n attributePerLinkCountLimit: 100,\n },\n });\n\n const spanExporter = new OTLPTraceExporter({\n url: `${config.url}/v1/traces`,\n timeoutMillis: config.forceFlushTimeoutMillis ?? 1000,\n });\n\n traceProvider.addSpanProcessor(\n new TaskContextSpanProcessor(new SimpleSpanProcessor(spanExporter))\n );\n traceProvider.register();\n\n registerInstrumentations({\n instrumentations: config.instrumentations ?? [],\n tracerProvider: traceProvider,\n });\n\n const logExporter = new OTLPLogExporter({\n url: `${config.url}/v1/logs`,\n });\n\n // To start a logger, you first need to initialize the Logger provider.\n const loggerProvider = new LoggerProvider({\n resource: commonResources,\n logRecordLimits: {\n attributeCountLimit: 1000,\n attributeValueLengthLimit: 1000,\n },\n });\n\n loggerProvider.addLogRecordProcessor(\n new TaskContextLogProcessor(new SimpleLogRecordProcessor(logExporter))\n );\n\n this._logProvider = loggerProvider;\n this._spanExporter = spanExporter;\n this._traceProvider = traceProvider;\n\n logs.setGlobalLoggerProvider(loggerProvider);\n\n this.getLogger = loggerProvider.getLogger.bind(loggerProvider);\n this.getTracer = traceProvider.getTracer.bind(traceProvider);\n }\n\n public async flush() {\n await this._spanExporter.forceFlush?.();\n await this._logProvider.forceFlush();\n }\n\n public async shutdown() {\n await this._spanExporter.shutdown();\n await this._logProvider.shutdown();\n }\n}\n\nfunction setLogLevel(level: TracingDiagnosticLogLevel) {\n let diagLogLevel: DiagLogLevel;\n\n switch (level) {\n case \"none\":\n diagLogLevel = DiagLogLevel.NONE;\n break;\n case \"error\":\n diagLogLevel = DiagLogLevel.ERROR;\n break;\n case \"warn\":\n diagLogLevel = DiagLogLevel.WARN;\n break;\n case \"info\":\n diagLogLevel = DiagLogLevel.INFO;\n break;\n case \"debug\":\n diagLogLevel = DiagLogLevel.DEBUG;\n break;\n case \"verbose\":\n diagLogLevel = DiagLogLevel.VERBOSE;\n break;\n case \"all\":\n diagLogLevel = DiagLogLevel.ALL;\n break;\n default:\n diagLogLevel = DiagLogLevel.NONE;\n }\n\n diag.setLogger(new DiagConsoleLogger(), diagLogLevel);\n}\n","export const SemanticInternalAttributes = {\n ENVIRONMENT_ID: \"ctx.environment.id\",\n ENVIRONMENT_TYPE: \"ctx.environment.type\",\n ORGANIZATION_ID: \"ctx.organization.id\",\n ORGANIZATION_SLUG: \"ctx.organization.slug\",\n ORGANIZATION_NAME: \"ctx.organization.name\",\n PROJECT_ID: \"ctx.project.id\",\n PROJECT_REF: \"ctx.project.ref\",\n PROJECT_NAME: \"ctx.project.title\",\n PROJECT_DIR: \"project.dir\",\n ATTEMPT_ID: \"ctx.attempt.id\",\n ATTEMPT_NUMBER: \"ctx.attempt.number\",\n RUN_ID: \"ctx.run.id\",\n RUN_IS_TEST: \"ctx.run.isTest\",\n BATCH_ID: \"ctx.batch.id\",\n TASK_SLUG: \"ctx.task.id\",\n TASK_PATH: \"ctx.task.filePath\",\n TASK_EXPORT_NAME: \"ctx.task.exportName\",\n QUEUE_NAME: \"ctx.queue.name\",\n QUEUE_ID: \"ctx.queue.id\",\n SPAN_PARTIAL: \"$span.partial\",\n SPAN_ID: \"$span.span_id\",\n OUTPUT: \"$output\",\n STYLE: \"$style\",\n STYLE_ICON: \"$style.icon\",\n STYLE_VARIANT: \"$style.variant\",\n STYLE_ACCESSORY: \"$style.accessory\",\n METADATA: \"$metadata\",\n TRIGGER: \"$trigger\",\n PAYLOAD: \"$payload\",\n SHOW: \"$show\",\n SHOW_ACTIONS: \"$show.actions\",\n WORKER_ID: \"worker.id\",\n WORKER_VERSION: \"worker.version\",\n CLI_VERSION: \"cli.version\",\n SDK_VERSION: \"sdk.version\",\n SDK_LANGUAGE: \"sdk.language\",\n RETRY_AT: \"retry.at\",\n RETRY_DELAY: \"retry.delay\",\n RETRY_COUNT: \"retry.count\",\n};\n","import { Attributes } from \"@opentelemetry/api\";\n\nexport function flattenAttributes(\n obj: Record<string, unknown> | Array<unknown> | string | boolean | number | null | undefined,\n prefix?: string\n): Attributes {\n const result: Attributes = {};\n\n // Check if obj is null or undefined\n if (!obj) {\n return result;\n }\n\n if (typeof obj === \"string\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n if (typeof obj === \"number\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n if (typeof obj === \"boolean\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n for (const [key, value] of Object.entries(obj)) {\n const newPrefix = `${prefix ? `${prefix}.` : \"\"}${key}`;\n if (Array.isArray(value)) {\n for (let i = 0; i < value.length; i++) {\n if (typeof value[i] === \"object\" && value[i] !== null) {\n // update null check here as well\n Object.assign(result, flattenAttributes(value[i], `${newPrefix}.[${i}]`));\n } else {\n result[`${newPrefix}.[${i}]`] = value[i];\n }\n }\n } else if (isRecord(value)) {\n // update null check here\n Object.assign(result, flattenAttributes(value, newPrefix));\n } else {\n if (typeof value === \"number\" || typeof value === \"string\" || typeof value === \"boolean\") {\n result[newPrefix] = value;\n }\n }\n }\n\n return result;\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return value !== null && typeof value === \"object\" && !Array.isArray(value);\n}\n\nexport function unflattenAttributes(obj: Attributes): Record<string, unknown> {\n if (typeof obj !== \"object\" || obj === null || Array.isArray(obj)) {\n return obj;\n }\n\n const result: Record<string, unknown> = {};\n\n for (const [key, value] of Object.entries(obj)) {\n const parts = key.split(\".\").reduce((acc, part) => {\n // Splitting array indices as separate parts\n if (detectIsArrayIndex(part)) {\n acc.push(part);\n } else {\n acc.push(...part.split(/\\.\\[(.*?)\\]/).filter(Boolean));\n }\n return acc;\n }, [] as string[]);\n\n let current: Record<string, unknown> = result;\n for (let i = 0; i < parts.length - 1; i++) {\n const part = parts[i];\n const isArray = detectIsArrayIndex(part);\n const cleanPart = isArray ? part.substring(1, part.length - 1) : part;\n const nextIsArray = detectIsArrayIndex(parts[i + 1]);\n if (!current[cleanPart]) {\n current[cleanPart] = nextIsArray ? [] : {};\n }\n current = current[cleanPart] as Record<string, unknown>;\n }\n const lastPart = parts[parts.length - 1];\n const cleanLastPart = detectIsArrayIndex(lastPart)\n ? parseInt(lastPart.substring(1, lastPart.length - 1), 10)\n : lastPart;\n current[cleanLastPart] = value;\n }\n\n return result;\n}\n\nfunction detectIsArrayIndex(key: string): boolean {\n const match = key.match(/^\\[(\\d+)\\]$/);\n\n if (match) {\n return true;\n }\n\n return false;\n}\n\nexport function primitiveValueOrflattenedAttributes(\n obj: Record<string, unknown> | Array<unknown> | string | boolean | number | undefined,\n prefix: string | undefined\n): Attributes | string | number | boolean | undefined {\n if (\n typeof obj === \"string\" ||\n typeof obj === \"number\" ||\n typeof obj === \"boolean\" ||\n obj === null ||\n obj === undefined\n ) {\n return obj;\n }\n\n const attributes = flattenAttributes(obj, prefix);\n\n if (\n prefix !== undefined &&\n typeof attributes[prefix] !== \"undefined\" &&\n attributes[prefix] !== null\n ) {\n return attributes[prefix] as unknown as Attributes;\n }\n\n return attributes;\n}\n","import { AsyncLocalStorage } from \"node:async_hooks\";\n\nexport class SafeAsyncLocalStorage<T> {\n private storage: AsyncLocalStorage<T>;\n\n constructor() {\n this.storage = new AsyncLocalStorage<T>();\n }\n\n runWith<R extends (...args: any[]) => Promise<any>>(context: T, fn: R): Promise<ReturnType<R>> {\n return this.storage.run(context, fn);\n }\n\n getStore(): T | undefined {\n return this.storage.getStore();\n }\n}\n","import { Attributes, Context } from \"@opentelemetry/api\";\nimport { TaskRunContext, type BackgroundWorkerProperties } from \"../schemas\";\nimport { flattenAttributes } from \"../utils/flattenAttributes\";\nimport { SafeAsyncLocalStorage } from \"../utils/safeAsyncLocalStorage\";\n\ntype TaskContext = {\n ctx: TaskRunContext;\n payload: any;\n worker: BackgroundWorkerProperties;\n};\n\nexport class TaskContextManager {\n private _storage: SafeAsyncLocalStorage<TaskContext> = new SafeAsyncLocalStorage<TaskContext>();\n\n get isInsideTask(): boolean {\n return this.#getStore() !== undefined;\n }\n\n get ctx(): TaskRunContext | undefined {\n const store = this.#getStore();\n return store?.ctx;\n }\n\n get payload(): any | undefined {\n const store = this.#getStore();\n return store?.payload;\n }\n\n get worker(): BackgroundWorkerProperties | undefined {\n const store = this.#getStore();\n return store?.worker;\n }\n\n get attributes(): Attributes {\n if (this.ctx) {\n return {\n ...this.contextAttributes,\n ...this.workerAttributes,\n ...this.payloadAttributes,\n [SemanticResourceAttributes.SERVICE_NAME]: this.ctx.task.id,\n };\n }\n\n return {};\n }\n\n get payloadAttributes(): Attributes {\n if (this.payload) {\n return flattenAttributes(this.payload, \"payload\");\n }\n\n return {};\n }\n\n get workerAttributes(): Attributes {\n if (this.worker) {\n return {\n [SemanticInternalAttributes.WORKER_ID]: this.worker.id,\n [SemanticInternalAttributes.WORKER_VERSION]: this.worker.version,\n };\n }\n\n return {};\n }\n\n get contextAttributes(): Attributes {\n if (this.ctx) {\n return {\n [SemanticInternalAttributes.ATTEMPT_ID]: this.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: this.ctx.attempt.number,\n [SemanticInternalAttributes.TASK_SLUG]: this.ctx.task.id,\n [SemanticInternalAttributes.TASK_PATH]: this.ctx.task.filePath,\n [SemanticInternalAttributes.TASK_EXPORT_NAME]: this.ctx.task.exportName,\n [SemanticInternalAttributes.QUEUE_NAME]: this.ctx.queue.name,\n [SemanticInternalAttributes.QUEUE_ID]: this.ctx.queue.id,\n [SemanticInternalAttributes.ENVIRONMENT_ID]: this.ctx.environment.id,\n [SemanticInternalAttributes.ENVIRONMENT_TYPE]: this.ctx.environment.type,\n [SemanticInternalAttributes.ORGANIZATION_ID]: this.ctx.organization.id,\n [SemanticInternalAttributes.PROJECT_ID]: this.ctx.project.id,\n [SemanticInternalAttributes.PROJECT_REF]: this.ctx.project.ref,\n [SemanticInternalAttributes.PROJECT_NAME]: this.ctx.project.name,\n [SemanticInternalAttributes.RUN_ID]: this.ctx.run.id,\n [SemanticInternalAttributes.RUN_IS_TEST]: this.ctx.run.isTest,\n [SemanticInternalAttributes.ORGANIZATION_SLUG]: this.ctx.organization.slug,\n [SemanticInternalAttributes.ORGANIZATION_NAME]: this.ctx.organization.name,\n [SemanticInternalAttributes.BATCH_ID]: this.ctx.batch?.id,\n };\n }\n\n return {};\n }\n\n runWith<R extends (...args: any[]) => Promise<any>>(\n context: TaskContext,\n fn: R\n ): Promise<ReturnType<R>> {\n return this._storage.runWith(context, fn);\n }\n\n #getStore(): TaskContext | undefined {\n return this._storage.getStore();\n }\n}\n\nexport const taskContextManager = new TaskContextManager();\n\nimport { Span, SpanProcessor } from \"@opentelemetry/sdk-trace-base\";\nimport { SemanticResourceAttributes } from \"@opentelemetry/semantic-conventions\";\nimport { SemanticInternalAttributes } from \"../semanticInternalAttributes\";\nimport { LogRecord, LogRecordProcessor } from \"@opentelemetry/sdk-logs\";\n\nexport class TaskContextSpanProcessor implements SpanProcessor {\n private _innerProcessor: SpanProcessor;\n\n constructor(innerProcessor: SpanProcessor) {\n this._innerProcessor = innerProcessor;\n }\n\n // Called when a span starts\n onStart(span: Span, parentContext: Context): void {\n if (taskContextManager.ctx) {\n span.setAttributes(\n flattenAttributes(\n {\n [SemanticInternalAttributes.ATTEMPT_ID]: taskContextManager.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: taskContextManager.ctx.attempt.number,\n },\n SemanticInternalAttributes.METADATA\n )\n );\n }\n\n this._innerProcessor.onStart(span, parentContext);\n }\n\n // Delegate the rest of the methods to the wrapped processor\n\n onEnd(span: Span): void {\n this._innerProcessor.onEnd(span);\n }\n\n shutdown(): Promise<void> {\n return this._innerProcessor.shutdown();\n }\n\n forceFlush(): Promise<void> {\n return this._innerProcessor.forceFlush();\n }\n}\n\nexport class TaskContextLogProcessor implements LogRecordProcessor {\n private _innerProcessor: LogRecordProcessor;\n\n constructor(innerProcessor: LogRecordProcessor) {\n this._innerProcessor = innerProcessor;\n }\n forceFlush(): Promise<void> {\n return this._innerProcessor.forceFlush();\n }\n onEmit(logRecord: LogRecord, context?: Context | undefined): void {\n // Adds in the context attributes to the log record\n if (taskContextManager.ctx) {\n logRecord.setAttributes(\n flattenAttributes(\n {\n [SemanticInternalAttributes.ATTEMPT_ID]: taskContextManager.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: taskContextManager.ctx.attempt.number,\n },\n SemanticInternalAttributes.METADATA\n )\n );\n }\n\n this._innerProcessor.onEmit(logRecord, context);\n }\n shutdown(): Promise<void> {\n return this._innerProcessor.shutdown();\n }\n}\n","export function getEnvVar(name: string): string | undefined {\n // This could run in a non-Node.js environment (Bun, Deno, CF Worker, etc.), so don't just assume process.env is a thing\n if (typeof process !== \"undefined\" && typeof process.env === \"object\" && process.env !== null) {\n return process.env[name];\n }\n}\n"]}
1
+ {"version":3,"sources":["../../../src/v3/otel/index.ts","../../../src/v3/otel/tracingSDK.ts","../../../src/v3/limits.ts","../../../src/v3/semanticInternalAttributes.ts","../../../src/v3/utils/flattenAttributes.ts","../../../src/v3/utils/safeAsyncLocalStorage.ts","../../../src/v3/tasks/taskContextManager.ts","../../../src/v3/utils/getEnv.ts"],"names":["SpanStatusCode","DiagConsoleLogger","DiagLogLevel","diag","logs","OTLPLogExporter","OTLPTraceExporter","registerInstrumentations","Resource","detectResourcesSync","processDetectorSync","BatchLogRecordProcessor","LoggerProvider","SimpleLogRecordProcessor","BatchSpanProcessor","NodeTracerProvider","SimpleSpanProcessor","SemanticResourceAttributes","OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT","OTEL_LOG_ATTRIBUTE_COUNT_LIMIT","OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT","OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT","OTEL_SPAN_EVENT_COUNT_LIMIT","OTEL_LINK_COUNT_LIMIT","OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT","OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT","OFFLOAD_IO_PACKET_LENGTH_LIMIT","SemanticInternalAttributes","ENVIRONMENT_ID","ENVIRONMENT_TYPE","ORGANIZATION_ID","ORGANIZATION_SLUG","ORGANIZATION_NAME","PROJECT_ID","PROJECT_REF","PROJECT_NAME","PROJECT_DIR","ATTEMPT_ID","ATTEMPT_NUMBER","RUN_ID","RUN_IS_TEST","BATCH_ID","TASK_SLUG","TASK_PATH","TASK_EXPORT_NAME","QUEUE_NAME","QUEUE_ID","SPAN_PARTIAL","SPAN_ID","OUTPUT","OUTPUT_TYPE","STYLE","STYLE_ICON","STYLE_VARIANT","STYLE_ACCESSORY","METADATA","TRIGGER","PAYLOAD","PAYLOAD_TYPE","SHOW","SHOW_ACTIONS","WORKER_ID","WORKER_VERSION","CLI_VERSION","SDK_VERSION","SDK_LANGUAGE","RETRY_AT","RETRY_DELAY","RETRY_COUNT","flattenAttributes","obj","prefix","result","key","value","Object","entries","newPrefix","Array","isArray","i","length","assign","isRecord","AsyncLocalStorage","SafeAsyncLocalStorage","constructor","storage","runWith","context","fn","run","getStore","TaskContextManager","_storage","isInsideTask","undefined","ctx","store","worker","attributes","contextAttributes","workerAttributes","id","version","attempt","number","task","filePath","exportName","queue","name","environment","type","organization","project","ref","isTest","slug","batch","taskContextManager","TaskContextSpanProcessor","innerProcessor","_innerProcessor","onStart","span","parentContext","setAttributes","onEnd","shutdown","forceFlush","TaskContextLogProcessor","onEmit","logRecord","getEnvVar","process","env","AsyncResourceDetector","_resolved","_promise","Promise","resolver","_resolver","detect","_config","resolveWithAttributes","Error","TracingSDK","config","asyncResourceDetector","setLogLevel","diagLogLevel","envResourceAttributesSerialized","envResourceAttributes","JSON","parse","commonResources","detectors","merge","CLOUD_PROVIDER","resource","traceProvider","forceFlushTimeoutMillis","spanLimits","attributeCountLimit","attributeValueLengthLimit","eventCountLimit","attributePerEventCountLimit","linkCountLimit","attributePerLinkCountLimit","spanExporter","url","timeoutMillis","addSpanProcessor","maxExportBatchSize","parseInt","scheduledDelayMillis","exportTimeoutMillis","maxQueueSize","register","instrumentations","tracerProvider","logExporter","loggerProvider","logRecordLimits","addLogRecordProcessor","_logProvider","_spanExporter","_traceProvider","setGlobalLoggerProvider","getLogger","bind","getTracer","flush","level","NONE","ERROR","WARN","INFO","DEBUG","VERBOSE","ALL","setLogger","recordSpanException","error","recordException","stringify","setStatus","code"],"mappings":"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","sourcesContent":["import { Span, SpanStatusCode } from \"@opentelemetry/api\";\n\nexport { TracingSDK, type TracingSDKConfig, type TracingDiagnosticLogLevel } from \"./tracingSDK\";\n\nexport function recordSpanException(span: Span, error: unknown) {\n if (error instanceof Error) {\n span.recordException(error);\n } else if (typeof error === \"string\") {\n span.recordException(new Error(error));\n } else {\n span.recordException(new Error(JSON.stringify(error)));\n }\n\n span.setStatus({ code: SpanStatusCode.ERROR });\n}\n","import { DiagConsoleLogger, DiagLogLevel, TracerProvider, diag } from \"@opentelemetry/api\";\nimport { logs } from \"@opentelemetry/api-logs\";\nimport { OTLPLogExporter } from \"@opentelemetry/exporter-logs-otlp-http\";\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-http\";\nimport {\n registerInstrumentations,\n type InstrumentationOption,\n} from \"@opentelemetry/instrumentation\";\nimport {\n DetectorSync,\n IResource,\n Resource,\n ResourceAttributes,\n ResourceDetectionConfig,\n detectResourcesSync,\n processDetectorSync,\n} from \"@opentelemetry/resources\";\nimport {\n BatchLogRecordProcessor,\n LoggerProvider,\n SimpleLogRecordProcessor,\n} from \"@opentelemetry/sdk-logs\";\nimport {\n BatchSpanProcessor,\n NodeTracerProvider,\n SimpleSpanProcessor,\n SpanExporter,\n} from \"@opentelemetry/sdk-trace-node\";\nimport { SemanticResourceAttributes } from \"@opentelemetry/semantic-conventions\";\nimport {\n OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT,\n OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT,\n OTEL_LINK_COUNT_LIMIT,\n OTEL_LOG_ATTRIBUTE_COUNT_LIMIT,\n OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT,\n OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT,\n OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT,\n OTEL_SPAN_EVENT_COUNT_LIMIT,\n} from \"../limits\";\nimport { SemanticInternalAttributes } from \"../semanticInternalAttributes\";\nimport { TaskContextLogProcessor, TaskContextSpanProcessor } from \"../tasks/taskContextManager\";\nimport { getEnvVar } from \"../utils/getEnv\";\n\nclass AsyncResourceDetector implements DetectorSync {\n private _promise: Promise<ResourceAttributes>;\n private _resolver?: (value: ResourceAttributes) => void;\n private _resolved: boolean = false;\n\n constructor() {\n this._promise = new Promise((resolver) => {\n this._resolver = resolver;\n });\n }\n\n detect(_config?: ResourceDetectionConfig): Resource {\n return new Resource({}, this._promise);\n }\n\n resolveWithAttributes(attributes: ResourceAttributes) {\n if (!this._resolver) {\n throw new Error(\"Resolver not available\");\n }\n\n if (this._resolved) {\n return;\n }\n\n this._resolved = true;\n this._resolver(attributes);\n }\n}\n\nexport type TracingDiagnosticLogLevel =\n | \"none\"\n | \"error\"\n | \"warn\"\n | \"info\"\n | \"debug\"\n | \"verbose\"\n | \"all\";\n\nexport type TracingSDKConfig = {\n url: string;\n forceFlushTimeoutMillis?: number;\n resource?: IResource;\n instrumentations?: InstrumentationOption[];\n diagLogLevel?: TracingDiagnosticLogLevel;\n};\n\nexport class TracingSDK {\n public readonly asyncResourceDetector = new AsyncResourceDetector();\n private readonly _logProvider: LoggerProvider;\n private readonly _spanExporter: SpanExporter;\n private readonly _traceProvider: NodeTracerProvider;\n\n public readonly getLogger: LoggerProvider[\"getLogger\"];\n public readonly getTracer: TracerProvider[\"getTracer\"];\n\n constructor(private readonly config: TracingSDKConfig) {\n setLogLevel(config.diagLogLevel ?? \"none\");\n\n const envResourceAttributesSerialized = getEnvVar(\"OTEL_RESOURCE_ATTRIBUTES\");\n const envResourceAttributes = envResourceAttributesSerialized\n ? JSON.parse(envResourceAttributesSerialized)\n : {};\n\n const commonResources = detectResourcesSync({\n detectors: [this.asyncResourceDetector, processDetectorSync],\n })\n .merge(\n new Resource({\n [SemanticResourceAttributes.CLOUD_PROVIDER]: \"trigger.dev\",\n [SemanticInternalAttributes.TRIGGER]: true,\n })\n )\n .merge(config.resource ?? new Resource({}))\n .merge(new Resource(envResourceAttributes));\n\n const traceProvider = new NodeTracerProvider({\n forceFlushTimeoutMillis: config.forceFlushTimeoutMillis ?? 500,\n resource: commonResources,\n spanLimits: {\n attributeCountLimit: OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT,\n attributeValueLengthLimit: OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT,\n eventCountLimit: OTEL_SPAN_EVENT_COUNT_LIMIT,\n attributePerEventCountLimit: OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT,\n linkCountLimit: OTEL_LINK_COUNT_LIMIT,\n attributePerLinkCountLimit: OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT,\n },\n });\n\n const spanExporter = new OTLPTraceExporter({\n url: `${config.url}/v1/traces`,\n timeoutMillis: config.forceFlushTimeoutMillis ?? 1000,\n });\n\n traceProvider.addSpanProcessor(\n new TaskContextSpanProcessor(\n getEnvVar(\"OTEL_BATCH_PROCESSING_ENABLED\") === \"1\"\n ? new BatchSpanProcessor(spanExporter, {\n maxExportBatchSize: parseInt(getEnvVar(\"OTEL_SPAN_MAX_EXPORT_BATCH_SIZE\") ?? \"64\"),\n scheduledDelayMillis: parseInt(\n getEnvVar(\"OTEL_SPAN_SCHEDULED_DELAY_MILLIS\") ?? \"200\"\n ),\n exportTimeoutMillis: parseInt(\n getEnvVar(\"OTEL_SPAN_EXPORT_TIMEOUT_MILLIS\") ?? \"30000\"\n ),\n maxQueueSize: parseInt(getEnvVar(\"OTEL_SPAN_MAX_QUEUE_SIZE\") ?? \"512\"),\n })\n : new SimpleSpanProcessor(spanExporter)\n )\n );\n\n traceProvider.register();\n\n registerInstrumentations({\n instrumentations: config.instrumentations ?? [],\n tracerProvider: traceProvider,\n });\n\n const logExporter = new OTLPLogExporter({\n url: `${config.url}/v1/logs`,\n });\n\n // To start a logger, you first need to initialize the Logger provider.\n const loggerProvider = new LoggerProvider({\n resource: commonResources,\n logRecordLimits: {\n attributeCountLimit: OTEL_LOG_ATTRIBUTE_COUNT_LIMIT,\n attributeValueLengthLimit: OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT,\n },\n });\n\n loggerProvider.addLogRecordProcessor(\n new TaskContextLogProcessor(\n getEnvVar(\"OTEL_BATCH_PROCESSING_ENABLED\") === \"1\"\n ? new BatchLogRecordProcessor(logExporter, {\n maxExportBatchSize: parseInt(getEnvVar(\"OTEL_LOG_MAX_EXPORT_BATCH_SIZE\") ?? \"64\"),\n scheduledDelayMillis: parseInt(getEnvVar(\"OTEL_LOG_SCHEDULED_DELAY_MILLIS\") ?? \"200\"),\n exportTimeoutMillis: parseInt(getEnvVar(\"OTEL_LOG_EXPORT_TIMEOUT_MILLIS\") ?? \"30000\"),\n maxQueueSize: parseInt(getEnvVar(\"OTEL_LOG_MAX_QUEUE_SIZE\") ?? \"512\"),\n })\n : new SimpleLogRecordProcessor(logExporter)\n )\n );\n\n this._logProvider = loggerProvider;\n this._spanExporter = spanExporter;\n this._traceProvider = traceProvider;\n\n logs.setGlobalLoggerProvider(loggerProvider);\n\n this.getLogger = loggerProvider.getLogger.bind(loggerProvider);\n this.getTracer = traceProvider.getTracer.bind(traceProvider);\n }\n\n public async flush() {\n await this._traceProvider.forceFlush();\n await this._logProvider.forceFlush();\n }\n\n public async shutdown() {\n await this._traceProvider.shutdown();\n await this._logProvider.shutdown();\n }\n}\n\nfunction setLogLevel(level: TracingDiagnosticLogLevel) {\n let diagLogLevel: DiagLogLevel;\n\n switch (level) {\n case \"none\":\n diagLogLevel = DiagLogLevel.NONE;\n break;\n case \"error\":\n diagLogLevel = DiagLogLevel.ERROR;\n break;\n case \"warn\":\n diagLogLevel = DiagLogLevel.WARN;\n break;\n case \"info\":\n diagLogLevel = DiagLogLevel.INFO;\n break;\n case \"debug\":\n diagLogLevel = DiagLogLevel.DEBUG;\n break;\n case \"verbose\":\n diagLogLevel = DiagLogLevel.VERBOSE;\n break;\n case \"all\":\n diagLogLevel = DiagLogLevel.ALL;\n break;\n default:\n diagLogLevel = DiagLogLevel.NONE;\n }\n\n diag.setLogger(new DiagConsoleLogger(), diagLogLevel);\n}\n","import { AttributeValue, Attributes } from \"@opentelemetry/api\";\n\nexport const OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT = 256;\nexport const OTEL_LOG_ATTRIBUTE_COUNT_LIMIT = 256;\nexport const OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT = 1028;\nexport const OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT = 1028;\nexport const OTEL_SPAN_EVENT_COUNT_LIMIT = 10;\nexport const OTEL_LINK_COUNT_LIMIT = 2;\nexport const OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT = 10;\nexport const OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT = 10;\nexport const OFFLOAD_IO_PACKET_LENGTH_LIMIT = 128 * 1024;\n\nexport function imposeAttributeLimits(attributes: Attributes): Attributes {\n const newAttributes: Attributes = {};\n\n for (const [key, value] of Object.entries(attributes)) {\n if (calculateAttributeValueLength(value) > OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT) {\n continue;\n }\n\n if (Object.keys(newAttributes).length >= OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT) {\n break;\n }\n\n newAttributes[key] = value;\n }\n\n return newAttributes;\n}\n\nfunction calculateAttributeValueLength(value: AttributeValue | undefined | null): number {\n if (value === undefined || value === null) {\n return 0;\n }\n\n if (typeof value === \"string\") {\n return value.length;\n }\n\n if (typeof value === \"number\") {\n return 8;\n }\n\n if (typeof value === \"boolean\") {\n return 4;\n }\n\n if (Array.isArray(value)) {\n return value.reduce((acc: number, v) => acc + calculateAttributeValueLength(v), 0);\n }\n\n return 0;\n}\n","export const SemanticInternalAttributes = {\n ENVIRONMENT_ID: \"ctx.environment.id\",\n ENVIRONMENT_TYPE: \"ctx.environment.type\",\n ORGANIZATION_ID: \"ctx.organization.id\",\n ORGANIZATION_SLUG: \"ctx.organization.slug\",\n ORGANIZATION_NAME: \"ctx.organization.name\",\n PROJECT_ID: \"ctx.project.id\",\n PROJECT_REF: \"ctx.project.ref\",\n PROJECT_NAME: \"ctx.project.title\",\n PROJECT_DIR: \"project.dir\",\n ATTEMPT_ID: \"ctx.attempt.id\",\n ATTEMPT_NUMBER: \"ctx.attempt.number\",\n RUN_ID: \"ctx.run.id\",\n RUN_IS_TEST: \"ctx.run.isTest\",\n BATCH_ID: \"ctx.batch.id\",\n TASK_SLUG: \"ctx.task.id\",\n TASK_PATH: \"ctx.task.filePath\",\n TASK_EXPORT_NAME: \"ctx.task.exportName\",\n QUEUE_NAME: \"ctx.queue.name\",\n QUEUE_ID: \"ctx.queue.id\",\n SPAN_PARTIAL: \"$span.partial\",\n SPAN_ID: \"$span.span_id\",\n OUTPUT: \"$output\",\n OUTPUT_TYPE: \"$mime_type_output\",\n STYLE: \"$style\",\n STYLE_ICON: \"$style.icon\",\n STYLE_VARIANT: \"$style.variant\",\n STYLE_ACCESSORY: \"$style.accessory\",\n METADATA: \"$metadata\",\n TRIGGER: \"$trigger\",\n PAYLOAD: \"$payload\",\n PAYLOAD_TYPE: \"$mime_type_payload\",\n SHOW: \"$show\",\n SHOW_ACTIONS: \"$show.actions\",\n WORKER_ID: \"worker.id\",\n WORKER_VERSION: \"worker.version\",\n CLI_VERSION: \"cli.version\",\n SDK_VERSION: \"sdk.version\",\n SDK_LANGUAGE: \"sdk.language\",\n RETRY_AT: \"retry.at\",\n RETRY_DELAY: \"retry.delay\",\n RETRY_COUNT: \"retry.count\",\n};\n","import { Attributes } from \"@opentelemetry/api\";\n\nexport function flattenAttributes(\n obj: Record<string, unknown> | Array<unknown> | string | boolean | number | null | undefined,\n prefix?: string\n): Attributes {\n const result: Attributes = {};\n\n // Check if obj is null or undefined\n if (!obj) {\n return result;\n }\n\n if (typeof obj === \"string\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n if (typeof obj === \"number\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n if (typeof obj === \"boolean\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n for (const [key, value] of Object.entries(obj)) {\n const newPrefix = `${prefix ? `${prefix}.` : \"\"}${key}`;\n if (Array.isArray(value)) {\n for (let i = 0; i < value.length; i++) {\n if (typeof value[i] === \"object\" && value[i] !== null) {\n // update null check here as well\n Object.assign(result, flattenAttributes(value[i], `${newPrefix}.[${i}]`));\n } else {\n result[`${newPrefix}.[${i}]`] = value[i];\n }\n }\n } else if (isRecord(value)) {\n // update null check here\n Object.assign(result, flattenAttributes(value, newPrefix));\n } else {\n if (typeof value === \"number\" || typeof value === \"string\" || typeof value === \"boolean\") {\n result[newPrefix] = value;\n }\n }\n }\n\n return result;\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return value !== null && typeof value === \"object\" && !Array.isArray(value);\n}\n\nexport function unflattenAttributes(obj: Attributes): Record<string, unknown> {\n if (typeof obj !== \"object\" || obj === null || Array.isArray(obj)) {\n return obj;\n }\n\n const result: Record<string, unknown> = {};\n\n for (const [key, value] of Object.entries(obj)) {\n const parts = key.split(\".\").reduce((acc, part) => {\n // Splitting array indices as separate parts\n if (detectIsArrayIndex(part)) {\n acc.push(part);\n } else {\n acc.push(...part.split(/\\.\\[(.*?)\\]/).filter(Boolean));\n }\n return acc;\n }, [] as string[]);\n\n let current: Record<string, unknown> = result;\n for (let i = 0; i < parts.length - 1; i++) {\n const part = parts[i];\n const isArray = detectIsArrayIndex(part);\n const cleanPart = isArray ? part.substring(1, part.length - 1) : part;\n const nextIsArray = detectIsArrayIndex(parts[i + 1]);\n if (!current[cleanPart]) {\n current[cleanPart] = nextIsArray ? [] : {};\n }\n current = current[cleanPart] as Record<string, unknown>;\n }\n const lastPart = parts[parts.length - 1];\n const cleanLastPart = detectIsArrayIndex(lastPart)\n ? parseInt(lastPart.substring(1, lastPart.length - 1), 10)\n : lastPart;\n current[cleanLastPart] = value;\n }\n\n return result;\n}\n\nfunction detectIsArrayIndex(key: string): boolean {\n const match = key.match(/^\\[(\\d+)\\]$/);\n\n if (match) {\n return true;\n }\n\n return false;\n}\n\nexport function primitiveValueOrflattenedAttributes(\n obj: Record<string, unknown> | Array<unknown> | string | boolean | number | undefined,\n prefix: string | undefined\n): Attributes | string | number | boolean | undefined {\n if (\n typeof obj === \"string\" ||\n typeof obj === \"number\" ||\n typeof obj === \"boolean\" ||\n obj === null ||\n obj === undefined\n ) {\n return obj;\n }\n\n const attributes = flattenAttributes(obj, prefix);\n\n if (\n prefix !== undefined &&\n typeof attributes[prefix] !== \"undefined\" &&\n attributes[prefix] !== null\n ) {\n return attributes[prefix] as unknown as Attributes;\n }\n\n return attributes;\n}\n","import { AsyncLocalStorage } from \"node:async_hooks\";\n\nexport class SafeAsyncLocalStorage<T> {\n private storage: AsyncLocalStorage<T>;\n\n constructor() {\n this.storage = new AsyncLocalStorage<T>();\n }\n\n runWith<R extends (...args: any[]) => Promise<any>>(context: T, fn: R): Promise<ReturnType<R>> {\n return this.storage.run(context, fn);\n }\n\n getStore(): T | undefined {\n return this.storage.getStore();\n }\n}\n","import { Attributes, Context } from \"@opentelemetry/api\";\nimport { TaskRunContext, type BackgroundWorkerProperties } from \"../schemas\";\nimport { flattenAttributes } from \"../utils/flattenAttributes\";\nimport { SafeAsyncLocalStorage } from \"../utils/safeAsyncLocalStorage\";\n\ntype TaskContext = {\n ctx: TaskRunContext;\n worker: BackgroundWorkerProperties;\n};\n\nexport class TaskContextManager {\n private _storage: SafeAsyncLocalStorage<TaskContext> = new SafeAsyncLocalStorage<TaskContext>();\n\n get isInsideTask(): boolean {\n return this.#getStore() !== undefined;\n }\n\n get ctx(): TaskRunContext | undefined {\n const store = this.#getStore();\n return store?.ctx;\n }\n\n get worker(): BackgroundWorkerProperties | undefined {\n const store = this.#getStore();\n return store?.worker;\n }\n\n get attributes(): Attributes {\n if (this.ctx) {\n return {\n ...this.contextAttributes,\n ...this.workerAttributes,\n };\n }\n\n return {};\n }\n\n get workerAttributes(): Attributes {\n if (this.worker) {\n return {\n [SemanticInternalAttributes.WORKER_ID]: this.worker.id,\n [SemanticInternalAttributes.WORKER_VERSION]: this.worker.version,\n };\n }\n\n return {};\n }\n\n get contextAttributes(): Attributes {\n if (this.ctx) {\n return {\n [SemanticInternalAttributes.ATTEMPT_ID]: this.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: this.ctx.attempt.number,\n [SemanticInternalAttributes.TASK_SLUG]: this.ctx.task.id,\n [SemanticInternalAttributes.TASK_PATH]: this.ctx.task.filePath,\n [SemanticInternalAttributes.TASK_EXPORT_NAME]: this.ctx.task.exportName,\n [SemanticInternalAttributes.QUEUE_NAME]: this.ctx.queue.name,\n [SemanticInternalAttributes.QUEUE_ID]: this.ctx.queue.id,\n [SemanticInternalAttributes.ENVIRONMENT_ID]: this.ctx.environment.id,\n [SemanticInternalAttributes.ENVIRONMENT_TYPE]: this.ctx.environment.type,\n [SemanticInternalAttributes.ORGANIZATION_ID]: this.ctx.organization.id,\n [SemanticInternalAttributes.PROJECT_ID]: this.ctx.project.id,\n [SemanticInternalAttributes.PROJECT_REF]: this.ctx.project.ref,\n [SemanticInternalAttributes.PROJECT_NAME]: this.ctx.project.name,\n [SemanticInternalAttributes.RUN_ID]: this.ctx.run.id,\n [SemanticInternalAttributes.RUN_IS_TEST]: this.ctx.run.isTest,\n [SemanticInternalAttributes.ORGANIZATION_SLUG]: this.ctx.organization.slug,\n [SemanticInternalAttributes.ORGANIZATION_NAME]: this.ctx.organization.name,\n [SemanticInternalAttributes.BATCH_ID]: this.ctx.batch?.id,\n };\n }\n\n return {};\n }\n\n runWith<R extends (...args: any[]) => Promise<any>>(\n context: TaskContext,\n fn: R\n ): Promise<ReturnType<R>> {\n return this._storage.runWith(context, fn);\n }\n\n #getStore(): TaskContext | undefined {\n return this._storage.getStore();\n }\n}\n\nexport const taskContextManager = new TaskContextManager();\n\nimport { LogRecord, LogRecordProcessor } from \"@opentelemetry/sdk-logs\";\nimport { Span, SpanProcessor } from \"@opentelemetry/sdk-trace-base\";\nimport { SemanticInternalAttributes } from \"../semanticInternalAttributes\";\n\nexport class TaskContextSpanProcessor implements SpanProcessor {\n private _innerProcessor: SpanProcessor;\n\n constructor(innerProcessor: SpanProcessor) {\n this._innerProcessor = innerProcessor;\n }\n\n // Called when a span starts\n onStart(span: Span, parentContext: Context): void {\n if (taskContextManager.ctx) {\n span.setAttributes(\n flattenAttributes(\n {\n [SemanticInternalAttributes.ATTEMPT_ID]: taskContextManager.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: taskContextManager.ctx.attempt.number,\n },\n SemanticInternalAttributes.METADATA\n )\n );\n }\n\n this._innerProcessor.onStart(span, parentContext);\n }\n\n // Delegate the rest of the methods to the wrapped processor\n\n onEnd(span: Span): void {\n this._innerProcessor.onEnd(span);\n }\n\n shutdown(): Promise<void> {\n return this._innerProcessor.shutdown();\n }\n\n forceFlush(): Promise<void> {\n return this._innerProcessor.forceFlush();\n }\n}\n\nexport class TaskContextLogProcessor implements LogRecordProcessor {\n private _innerProcessor: LogRecordProcessor;\n\n constructor(innerProcessor: LogRecordProcessor) {\n this._innerProcessor = innerProcessor;\n }\n forceFlush(): Promise<void> {\n return this._innerProcessor.forceFlush();\n }\n onEmit(logRecord: LogRecord, context?: Context | undefined): void {\n // Adds in the context attributes to the log record\n if (taskContextManager.ctx) {\n logRecord.setAttributes(\n flattenAttributes(\n {\n [SemanticInternalAttributes.ATTEMPT_ID]: taskContextManager.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: taskContextManager.ctx.attempt.number,\n },\n SemanticInternalAttributes.METADATA\n )\n );\n }\n\n this._innerProcessor.onEmit(logRecord, context);\n }\n shutdown(): Promise<void> {\n return this._innerProcessor.shutdown();\n }\n}\n","export function getEnvVar(name: string): string | undefined {\n // This could run in a non-Node.js environment (Bun, Deno, CF Worker, etc.), so don't just assume process.env is a thing\n if (typeof process !== \"undefined\" && typeof process.env === \"object\" && process.env !== null) {\n return process.env[name];\n }\n}\n"]}
@@ -4,8 +4,8 @@ import { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';
4
4
  import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';
5
5
  import { registerInstrumentations } from '@opentelemetry/instrumentation';
6
6
  import { Resource, detectResourcesSync, processDetectorSync } from '@opentelemetry/resources';
7
- import { LoggerProvider, SimpleLogRecordProcessor } from '@opentelemetry/sdk-logs';
8
- import { NodeTracerProvider, SimpleSpanProcessor } from '@opentelemetry/sdk-trace-node';
7
+ import { LoggerProvider, BatchLogRecordProcessor, SimpleLogRecordProcessor } from '@opentelemetry/sdk-logs';
8
+ import { NodeTracerProvider, BatchSpanProcessor, SimpleSpanProcessor } from '@opentelemetry/sdk-trace-node';
9
9
  import { SemanticResourceAttributes } from '@opentelemetry/semantic-conventions';
10
10
  import { AsyncLocalStorage } from 'node:async_hooks';
11
11
 
@@ -30,6 +30,16 @@ var __privateMethod = (obj, member, method) => {
30
30
  return method;
31
31
  };
32
32
 
33
+ // src/v3/limits.ts
34
+ var OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT = 256;
35
+ var OTEL_LOG_ATTRIBUTE_COUNT_LIMIT = 256;
36
+ var OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT = 1028;
37
+ var OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT = 1028;
38
+ var OTEL_SPAN_EVENT_COUNT_LIMIT = 10;
39
+ var OTEL_LINK_COUNT_LIMIT = 2;
40
+ var OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT = 10;
41
+ var OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT = 10;
42
+
33
43
  // src/v3/semanticInternalAttributes.ts
34
44
  var SemanticInternalAttributes = {
35
45
  ENVIRONMENT_ID: "ctx.environment.id",
@@ -54,6 +64,7 @@ var SemanticInternalAttributes = {
54
64
  SPAN_PARTIAL: "$span.partial",
55
65
  SPAN_ID: "$span.span_id",
56
66
  OUTPUT: "$output",
67
+ OUTPUT_TYPE: "$mime_type_output",
57
68
  STYLE: "$style",
58
69
  STYLE_ICON: "$style.icon",
59
70
  STYLE_VARIANT: "$style.variant",
@@ -61,6 +72,7 @@ var SemanticInternalAttributes = {
61
72
  METADATA: "$metadata",
62
73
  TRIGGER: "$trigger",
63
74
  PAYLOAD: "$payload",
75
+ PAYLOAD_TYPE: "$mime_type_payload",
64
76
  SHOW: "$show",
65
77
  SHOW_ACTIONS: "$show.actions",
66
78
  WORKER_ID: "worker.id",
@@ -129,6 +141,8 @@ var _SafeAsyncLocalStorage = class _SafeAsyncLocalStorage {
129
141
  };
130
142
  __name(_SafeAsyncLocalStorage, "SafeAsyncLocalStorage");
131
143
  var SafeAsyncLocalStorage = _SafeAsyncLocalStorage;
144
+
145
+ // src/v3/tasks/taskContextManager.ts
132
146
  var _getStore, getStore_fn;
133
147
  var _TaskContextManager = class _TaskContextManager {
134
148
  constructor() {
@@ -142,10 +156,6 @@ var _TaskContextManager = class _TaskContextManager {
142
156
  const store = __privateMethod(this, _getStore, getStore_fn).call(this);
143
157
  return store?.ctx;
144
158
  }
145
- get payload() {
146
- const store = __privateMethod(this, _getStore, getStore_fn).call(this);
147
- return store?.payload;
148
- }
149
159
  get worker() {
150
160
  const store = __privateMethod(this, _getStore, getStore_fn).call(this);
151
161
  return store?.worker;
@@ -154,19 +164,11 @@ var _TaskContextManager = class _TaskContextManager {
154
164
  if (this.ctx) {
155
165
  return {
156
166
  ...this.contextAttributes,
157
- ...this.workerAttributes,
158
- ...this.payloadAttributes,
159
- [SemanticResourceAttributes.SERVICE_NAME]: this.ctx.task.id
167
+ ...this.workerAttributes
160
168
  };
161
169
  }
162
170
  return {};
163
171
  }
164
- get payloadAttributes() {
165
- if (this.payload) {
166
- return flattenAttributes(this.payload, "payload");
167
- }
168
- return {};
169
- }
170
172
  get workerAttributes() {
171
173
  if (this.worker) {
172
174
  return {
@@ -313,19 +315,24 @@ var _TracingSDK = class _TracingSDK {
313
315
  forceFlushTimeoutMillis: config.forceFlushTimeoutMillis ?? 500,
314
316
  resource: commonResources,
315
317
  spanLimits: {
316
- attributeCountLimit: 1e3,
317
- attributeValueLengthLimit: 1e3,
318
- eventCountLimit: 100,
319
- attributePerEventCountLimit: 100,
320
- linkCountLimit: 10,
321
- attributePerLinkCountLimit: 100
318
+ attributeCountLimit: OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT,
319
+ attributeValueLengthLimit: OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT,
320
+ eventCountLimit: OTEL_SPAN_EVENT_COUNT_LIMIT,
321
+ attributePerEventCountLimit: OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT,
322
+ linkCountLimit: OTEL_LINK_COUNT_LIMIT,
323
+ attributePerLinkCountLimit: OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT
322
324
  }
323
325
  });
324
326
  const spanExporter = new OTLPTraceExporter({
325
327
  url: `${config.url}/v1/traces`,
326
328
  timeoutMillis: config.forceFlushTimeoutMillis ?? 1e3
327
329
  });
328
- traceProvider.addSpanProcessor(new TaskContextSpanProcessor(new SimpleSpanProcessor(spanExporter)));
330
+ traceProvider.addSpanProcessor(new TaskContextSpanProcessor(getEnvVar("OTEL_BATCH_PROCESSING_ENABLED") === "1" ? new BatchSpanProcessor(spanExporter, {
331
+ maxExportBatchSize: parseInt(getEnvVar("OTEL_SPAN_MAX_EXPORT_BATCH_SIZE") ?? "64"),
332
+ scheduledDelayMillis: parseInt(getEnvVar("OTEL_SPAN_SCHEDULED_DELAY_MILLIS") ?? "200"),
333
+ exportTimeoutMillis: parseInt(getEnvVar("OTEL_SPAN_EXPORT_TIMEOUT_MILLIS") ?? "30000"),
334
+ maxQueueSize: parseInt(getEnvVar("OTEL_SPAN_MAX_QUEUE_SIZE") ?? "512")
335
+ }) : new SimpleSpanProcessor(spanExporter)));
329
336
  traceProvider.register();
330
337
  registerInstrumentations({
331
338
  instrumentations: config.instrumentations ?? [],
@@ -337,11 +344,16 @@ var _TracingSDK = class _TracingSDK {
337
344
  const loggerProvider = new LoggerProvider({
338
345
  resource: commonResources,
339
346
  logRecordLimits: {
340
- attributeCountLimit: 1e3,
341
- attributeValueLengthLimit: 1e3
347
+ attributeCountLimit: OTEL_LOG_ATTRIBUTE_COUNT_LIMIT,
348
+ attributeValueLengthLimit: OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT
342
349
  }
343
350
  });
344
- loggerProvider.addLogRecordProcessor(new TaskContextLogProcessor(new SimpleLogRecordProcessor(logExporter)));
351
+ loggerProvider.addLogRecordProcessor(new TaskContextLogProcessor(getEnvVar("OTEL_BATCH_PROCESSING_ENABLED") === "1" ? new BatchLogRecordProcessor(logExporter, {
352
+ maxExportBatchSize: parseInt(getEnvVar("OTEL_LOG_MAX_EXPORT_BATCH_SIZE") ?? "64"),
353
+ scheduledDelayMillis: parseInt(getEnvVar("OTEL_LOG_SCHEDULED_DELAY_MILLIS") ?? "200"),
354
+ exportTimeoutMillis: parseInt(getEnvVar("OTEL_LOG_EXPORT_TIMEOUT_MILLIS") ?? "30000"),
355
+ maxQueueSize: parseInt(getEnvVar("OTEL_LOG_MAX_QUEUE_SIZE") ?? "512")
356
+ }) : new SimpleLogRecordProcessor(logExporter)));
345
357
  this._logProvider = loggerProvider;
346
358
  this._spanExporter = spanExporter;
347
359
  this._traceProvider = traceProvider;
@@ -350,11 +362,11 @@ var _TracingSDK = class _TracingSDK {
350
362
  this.getTracer = traceProvider.getTracer.bind(traceProvider);
351
363
  }
352
364
  async flush() {
353
- await this._spanExporter.forceFlush?.();
365
+ await this._traceProvider.forceFlush();
354
366
  await this._logProvider.forceFlush();
355
367
  }
356
368
  async shutdown() {
357
- await this._spanExporter.shutdown();
369
+ await this._traceProvider.shutdown();
358
370
  await this._logProvider.shutdown();
359
371
  }
360
372
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/v3/otel/index.ts","../../../src/v3/otel/tracingSDK.ts","../../../src/v3/semanticInternalAttributes.ts","../../../src/v3/utils/flattenAttributes.ts","../../../src/v3/utils/safeAsyncLocalStorage.ts","../../../src/v3/tasks/taskContextManager.ts","../../../src/v3/utils/getEnv.ts"],"names":["SpanStatusCode","DiagConsoleLogger","DiagLogLevel","diag","logs","OTLPLogExporter","OTLPTraceExporter","registerInstrumentations","Resource","detectResourcesSync","processDetectorSync","LoggerProvider","SimpleLogRecordProcessor","NodeTracerProvider","SimpleSpanProcessor","SemanticResourceAttributes","SemanticInternalAttributes","ENVIRONMENT_ID","ENVIRONMENT_TYPE","ORGANIZATION_ID","ORGANIZATION_SLUG","ORGANIZATION_NAME","PROJECT_ID","PROJECT_REF","PROJECT_NAME","PROJECT_DIR","ATTEMPT_ID","ATTEMPT_NUMBER","RUN_ID","RUN_IS_TEST","BATCH_ID","TASK_SLUG","TASK_PATH","TASK_EXPORT_NAME","QUEUE_NAME","QUEUE_ID","SPAN_PARTIAL","SPAN_ID","OUTPUT","STYLE","STYLE_ICON","STYLE_VARIANT","STYLE_ACCESSORY","METADATA","TRIGGER","PAYLOAD","SHOW","SHOW_ACTIONS","WORKER_ID","WORKER_VERSION","CLI_VERSION","SDK_VERSION","SDK_LANGUAGE","RETRY_AT","RETRY_DELAY","RETRY_COUNT","flattenAttributes","obj","prefix","result","key","value","Object","entries","newPrefix","Array","isArray","i","length","assign","isRecord","AsyncLocalStorage","SafeAsyncLocalStorage","constructor","storage","runWith","context","fn","run","getStore","TaskContextManager","_storage","isInsideTask","undefined","ctx","store","payload","worker","attributes","contextAttributes","workerAttributes","payloadAttributes","SERVICE_NAME","task","id","version","attempt","number","filePath","exportName","queue","name","environment","type","organization","project","ref","isTest","slug","batch","taskContextManager","TaskContextSpanProcessor","innerProcessor","_innerProcessor","onStart","span","parentContext","setAttributes","onEnd","shutdown","forceFlush","TaskContextLogProcessor","onEmit","logRecord","getEnvVar","process","env","AsyncResourceDetector","_resolved","_promise","Promise","resolver","_resolver","detect","_config","resolveWithAttributes","Error","TracingSDK","config","asyncResourceDetector","setLogLevel","diagLogLevel","envResourceAttributesSerialized","envResourceAttributes","JSON","parse","commonResources","detectors","merge","CLOUD_PROVIDER","resource","traceProvider","forceFlushTimeoutMillis","spanLimits","attributeCountLimit","attributeValueLengthLimit","eventCountLimit","attributePerEventCountLimit","linkCountLimit","attributePerLinkCountLimit","spanExporter","url","timeoutMillis","addSpanProcessor","register","instrumentations","tracerProvider","logExporter","loggerProvider","logRecordLimits","addLogRecordProcessor","_logProvider","_spanExporter","_traceProvider","setGlobalLoggerProvider","getLogger","bind","getTracer","flush","level","NONE","ERROR","WARN","INFO","DEBUG","VERBOSE","ALL","setLogger","recordSpanException","error","recordException","stringify","setStatus","code"],"mappings":"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","sourcesContent":["import { Span, SpanStatusCode } from \"@opentelemetry/api\";\n\nexport { TracingSDK, type TracingSDKConfig, type TracingDiagnosticLogLevel } from \"./tracingSDK\";\n\nexport function recordSpanException(span: Span, error: unknown) {\n if (error instanceof Error) {\n span.recordException(error);\n } else if (typeof error === \"string\") {\n span.recordException(new Error(error));\n } else {\n span.recordException(new Error(JSON.stringify(error)));\n }\n\n span.setStatus({ code: SpanStatusCode.ERROR });\n}\n","import { DiagConsoleLogger, DiagLogLevel, TracerProvider, diag } from \"@opentelemetry/api\";\nimport { logs } from \"@opentelemetry/api-logs\";\nimport { OTLPLogExporter } from \"@opentelemetry/exporter-logs-otlp-http\";\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-http\";\nimport {\n registerInstrumentations,\n type InstrumentationOption,\n} from \"@opentelemetry/instrumentation\";\nimport {\n DetectorSync,\n IResource,\n Resource,\n ResourceAttributes,\n ResourceDetectionConfig,\n detectResourcesSync,\n processDetectorSync,\n} from \"@opentelemetry/resources\";\nimport { LoggerProvider, SimpleLogRecordProcessor } from \"@opentelemetry/sdk-logs\";\nimport {\n NodeTracerProvider,\n SimpleSpanProcessor,\n SpanExporter,\n} from \"@opentelemetry/sdk-trace-node\";\nimport { SemanticResourceAttributes } from \"@opentelemetry/semantic-conventions\";\nimport { SemanticInternalAttributes } from \"../semanticInternalAttributes\";\nimport { TaskContextLogProcessor, TaskContextSpanProcessor } from \"../tasks/taskContextManager\";\nimport { getEnvVar } from \"../utils/getEnv\";\n\nclass AsyncResourceDetector implements DetectorSync {\n private _promise: Promise<ResourceAttributes>;\n private _resolver?: (value: ResourceAttributes) => void;\n private _resolved: boolean = false;\n\n constructor() {\n this._promise = new Promise((resolver) => {\n this._resolver = resolver;\n });\n }\n\n detect(_config?: ResourceDetectionConfig): Resource {\n return new Resource({}, this._promise);\n }\n\n resolveWithAttributes(attributes: ResourceAttributes) {\n if (!this._resolver) {\n throw new Error(\"Resolver not available\");\n }\n\n if (this._resolved) {\n return;\n }\n\n this._resolved = true;\n this._resolver(attributes);\n }\n}\n\nexport type TracingDiagnosticLogLevel =\n | \"none\"\n | \"error\"\n | \"warn\"\n | \"info\"\n | \"debug\"\n | \"verbose\"\n | \"all\";\n\nexport type TracingSDKConfig = {\n url: string;\n forceFlushTimeoutMillis?: number;\n resource?: IResource;\n instrumentations?: InstrumentationOption[];\n diagLogLevel?: TracingDiagnosticLogLevel;\n};\n\nexport class TracingSDK {\n public readonly asyncResourceDetector = new AsyncResourceDetector();\n private readonly _logProvider: LoggerProvider;\n private readonly _spanExporter: SpanExporter;\n private readonly _traceProvider: TracerProvider;\n\n public readonly getLogger: LoggerProvider[\"getLogger\"];\n public readonly getTracer: TracerProvider[\"getTracer\"];\n\n constructor(private readonly config: TracingSDKConfig) {\n setLogLevel(config.diagLogLevel ?? \"none\");\n\n const envResourceAttributesSerialized = getEnvVar(\"OTEL_RESOURCE_ATTRIBUTES\");\n const envResourceAttributes = envResourceAttributesSerialized\n ? JSON.parse(envResourceAttributesSerialized)\n : {};\n\n const commonResources = detectResourcesSync({\n detectors: [this.asyncResourceDetector, processDetectorSync],\n })\n .merge(\n new Resource({\n [SemanticResourceAttributes.CLOUD_PROVIDER]: \"trigger.dev\",\n [SemanticInternalAttributes.TRIGGER]: true,\n })\n )\n .merge(config.resource ?? new Resource({}))\n .merge(new Resource(envResourceAttributes));\n\n const traceProvider = new NodeTracerProvider({\n forceFlushTimeoutMillis: config.forceFlushTimeoutMillis ?? 500,\n resource: commonResources,\n spanLimits: {\n attributeCountLimit: 1000,\n attributeValueLengthLimit: 1000,\n eventCountLimit: 100,\n attributePerEventCountLimit: 100,\n linkCountLimit: 10,\n attributePerLinkCountLimit: 100,\n },\n });\n\n const spanExporter = new OTLPTraceExporter({\n url: `${config.url}/v1/traces`,\n timeoutMillis: config.forceFlushTimeoutMillis ?? 1000,\n });\n\n traceProvider.addSpanProcessor(\n new TaskContextSpanProcessor(new SimpleSpanProcessor(spanExporter))\n );\n traceProvider.register();\n\n registerInstrumentations({\n instrumentations: config.instrumentations ?? [],\n tracerProvider: traceProvider,\n });\n\n const logExporter = new OTLPLogExporter({\n url: `${config.url}/v1/logs`,\n });\n\n // To start a logger, you first need to initialize the Logger provider.\n const loggerProvider = new LoggerProvider({\n resource: commonResources,\n logRecordLimits: {\n attributeCountLimit: 1000,\n attributeValueLengthLimit: 1000,\n },\n });\n\n loggerProvider.addLogRecordProcessor(\n new TaskContextLogProcessor(new SimpleLogRecordProcessor(logExporter))\n );\n\n this._logProvider = loggerProvider;\n this._spanExporter = spanExporter;\n this._traceProvider = traceProvider;\n\n logs.setGlobalLoggerProvider(loggerProvider);\n\n this.getLogger = loggerProvider.getLogger.bind(loggerProvider);\n this.getTracer = traceProvider.getTracer.bind(traceProvider);\n }\n\n public async flush() {\n await this._spanExporter.forceFlush?.();\n await this._logProvider.forceFlush();\n }\n\n public async shutdown() {\n await this._spanExporter.shutdown();\n await this._logProvider.shutdown();\n }\n}\n\nfunction setLogLevel(level: TracingDiagnosticLogLevel) {\n let diagLogLevel: DiagLogLevel;\n\n switch (level) {\n case \"none\":\n diagLogLevel = DiagLogLevel.NONE;\n break;\n case \"error\":\n diagLogLevel = DiagLogLevel.ERROR;\n break;\n case \"warn\":\n diagLogLevel = DiagLogLevel.WARN;\n break;\n case \"info\":\n diagLogLevel = DiagLogLevel.INFO;\n break;\n case \"debug\":\n diagLogLevel = DiagLogLevel.DEBUG;\n break;\n case \"verbose\":\n diagLogLevel = DiagLogLevel.VERBOSE;\n break;\n case \"all\":\n diagLogLevel = DiagLogLevel.ALL;\n break;\n default:\n diagLogLevel = DiagLogLevel.NONE;\n }\n\n diag.setLogger(new DiagConsoleLogger(), diagLogLevel);\n}\n","export const SemanticInternalAttributes = {\n ENVIRONMENT_ID: \"ctx.environment.id\",\n ENVIRONMENT_TYPE: \"ctx.environment.type\",\n ORGANIZATION_ID: \"ctx.organization.id\",\n ORGANIZATION_SLUG: \"ctx.organization.slug\",\n ORGANIZATION_NAME: \"ctx.organization.name\",\n PROJECT_ID: \"ctx.project.id\",\n PROJECT_REF: \"ctx.project.ref\",\n PROJECT_NAME: \"ctx.project.title\",\n PROJECT_DIR: \"project.dir\",\n ATTEMPT_ID: \"ctx.attempt.id\",\n ATTEMPT_NUMBER: \"ctx.attempt.number\",\n RUN_ID: \"ctx.run.id\",\n RUN_IS_TEST: \"ctx.run.isTest\",\n BATCH_ID: \"ctx.batch.id\",\n TASK_SLUG: \"ctx.task.id\",\n TASK_PATH: \"ctx.task.filePath\",\n TASK_EXPORT_NAME: \"ctx.task.exportName\",\n QUEUE_NAME: \"ctx.queue.name\",\n QUEUE_ID: \"ctx.queue.id\",\n SPAN_PARTIAL: \"$span.partial\",\n SPAN_ID: \"$span.span_id\",\n OUTPUT: \"$output\",\n STYLE: \"$style\",\n STYLE_ICON: \"$style.icon\",\n STYLE_VARIANT: \"$style.variant\",\n STYLE_ACCESSORY: \"$style.accessory\",\n METADATA: \"$metadata\",\n TRIGGER: \"$trigger\",\n PAYLOAD: \"$payload\",\n SHOW: \"$show\",\n SHOW_ACTIONS: \"$show.actions\",\n WORKER_ID: \"worker.id\",\n WORKER_VERSION: \"worker.version\",\n CLI_VERSION: \"cli.version\",\n SDK_VERSION: \"sdk.version\",\n SDK_LANGUAGE: \"sdk.language\",\n RETRY_AT: \"retry.at\",\n RETRY_DELAY: \"retry.delay\",\n RETRY_COUNT: \"retry.count\",\n};\n","import { Attributes } from \"@opentelemetry/api\";\n\nexport function flattenAttributes(\n obj: Record<string, unknown> | Array<unknown> | string | boolean | number | null | undefined,\n prefix?: string\n): Attributes {\n const result: Attributes = {};\n\n // Check if obj is null or undefined\n if (!obj) {\n return result;\n }\n\n if (typeof obj === \"string\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n if (typeof obj === \"number\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n if (typeof obj === \"boolean\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n for (const [key, value] of Object.entries(obj)) {\n const newPrefix = `${prefix ? `${prefix}.` : \"\"}${key}`;\n if (Array.isArray(value)) {\n for (let i = 0; i < value.length; i++) {\n if (typeof value[i] === \"object\" && value[i] !== null) {\n // update null check here as well\n Object.assign(result, flattenAttributes(value[i], `${newPrefix}.[${i}]`));\n } else {\n result[`${newPrefix}.[${i}]`] = value[i];\n }\n }\n } else if (isRecord(value)) {\n // update null check here\n Object.assign(result, flattenAttributes(value, newPrefix));\n } else {\n if (typeof value === \"number\" || typeof value === \"string\" || typeof value === \"boolean\") {\n result[newPrefix] = value;\n }\n }\n }\n\n return result;\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return value !== null && typeof value === \"object\" && !Array.isArray(value);\n}\n\nexport function unflattenAttributes(obj: Attributes): Record<string, unknown> {\n if (typeof obj !== \"object\" || obj === null || Array.isArray(obj)) {\n return obj;\n }\n\n const result: Record<string, unknown> = {};\n\n for (const [key, value] of Object.entries(obj)) {\n const parts = key.split(\".\").reduce((acc, part) => {\n // Splitting array indices as separate parts\n if (detectIsArrayIndex(part)) {\n acc.push(part);\n } else {\n acc.push(...part.split(/\\.\\[(.*?)\\]/).filter(Boolean));\n }\n return acc;\n }, [] as string[]);\n\n let current: Record<string, unknown> = result;\n for (let i = 0; i < parts.length - 1; i++) {\n const part = parts[i];\n const isArray = detectIsArrayIndex(part);\n const cleanPart = isArray ? part.substring(1, part.length - 1) : part;\n const nextIsArray = detectIsArrayIndex(parts[i + 1]);\n if (!current[cleanPart]) {\n current[cleanPart] = nextIsArray ? [] : {};\n }\n current = current[cleanPart] as Record<string, unknown>;\n }\n const lastPart = parts[parts.length - 1];\n const cleanLastPart = detectIsArrayIndex(lastPart)\n ? parseInt(lastPart.substring(1, lastPart.length - 1), 10)\n : lastPart;\n current[cleanLastPart] = value;\n }\n\n return result;\n}\n\nfunction detectIsArrayIndex(key: string): boolean {\n const match = key.match(/^\\[(\\d+)\\]$/);\n\n if (match) {\n return true;\n }\n\n return false;\n}\n\nexport function primitiveValueOrflattenedAttributes(\n obj: Record<string, unknown> | Array<unknown> | string | boolean | number | undefined,\n prefix: string | undefined\n): Attributes | string | number | boolean | undefined {\n if (\n typeof obj === \"string\" ||\n typeof obj === \"number\" ||\n typeof obj === \"boolean\" ||\n obj === null ||\n obj === undefined\n ) {\n return obj;\n }\n\n const attributes = flattenAttributes(obj, prefix);\n\n if (\n prefix !== undefined &&\n typeof attributes[prefix] !== \"undefined\" &&\n attributes[prefix] !== null\n ) {\n return attributes[prefix] as unknown as Attributes;\n }\n\n return attributes;\n}\n","import { AsyncLocalStorage } from \"node:async_hooks\";\n\nexport class SafeAsyncLocalStorage<T> {\n private storage: AsyncLocalStorage<T>;\n\n constructor() {\n this.storage = new AsyncLocalStorage<T>();\n }\n\n runWith<R extends (...args: any[]) => Promise<any>>(context: T, fn: R): Promise<ReturnType<R>> {\n return this.storage.run(context, fn);\n }\n\n getStore(): T | undefined {\n return this.storage.getStore();\n }\n}\n","import { Attributes, Context } from \"@opentelemetry/api\";\nimport { TaskRunContext, type BackgroundWorkerProperties } from \"../schemas\";\nimport { flattenAttributes } from \"../utils/flattenAttributes\";\nimport { SafeAsyncLocalStorage } from \"../utils/safeAsyncLocalStorage\";\n\ntype TaskContext = {\n ctx: TaskRunContext;\n payload: any;\n worker: BackgroundWorkerProperties;\n};\n\nexport class TaskContextManager {\n private _storage: SafeAsyncLocalStorage<TaskContext> = new SafeAsyncLocalStorage<TaskContext>();\n\n get isInsideTask(): boolean {\n return this.#getStore() !== undefined;\n }\n\n get ctx(): TaskRunContext | undefined {\n const store = this.#getStore();\n return store?.ctx;\n }\n\n get payload(): any | undefined {\n const store = this.#getStore();\n return store?.payload;\n }\n\n get worker(): BackgroundWorkerProperties | undefined {\n const store = this.#getStore();\n return store?.worker;\n }\n\n get attributes(): Attributes {\n if (this.ctx) {\n return {\n ...this.contextAttributes,\n ...this.workerAttributes,\n ...this.payloadAttributes,\n [SemanticResourceAttributes.SERVICE_NAME]: this.ctx.task.id,\n };\n }\n\n return {};\n }\n\n get payloadAttributes(): Attributes {\n if (this.payload) {\n return flattenAttributes(this.payload, \"payload\");\n }\n\n return {};\n }\n\n get workerAttributes(): Attributes {\n if (this.worker) {\n return {\n [SemanticInternalAttributes.WORKER_ID]: this.worker.id,\n [SemanticInternalAttributes.WORKER_VERSION]: this.worker.version,\n };\n }\n\n return {};\n }\n\n get contextAttributes(): Attributes {\n if (this.ctx) {\n return {\n [SemanticInternalAttributes.ATTEMPT_ID]: this.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: this.ctx.attempt.number,\n [SemanticInternalAttributes.TASK_SLUG]: this.ctx.task.id,\n [SemanticInternalAttributes.TASK_PATH]: this.ctx.task.filePath,\n [SemanticInternalAttributes.TASK_EXPORT_NAME]: this.ctx.task.exportName,\n [SemanticInternalAttributes.QUEUE_NAME]: this.ctx.queue.name,\n [SemanticInternalAttributes.QUEUE_ID]: this.ctx.queue.id,\n [SemanticInternalAttributes.ENVIRONMENT_ID]: this.ctx.environment.id,\n [SemanticInternalAttributes.ENVIRONMENT_TYPE]: this.ctx.environment.type,\n [SemanticInternalAttributes.ORGANIZATION_ID]: this.ctx.organization.id,\n [SemanticInternalAttributes.PROJECT_ID]: this.ctx.project.id,\n [SemanticInternalAttributes.PROJECT_REF]: this.ctx.project.ref,\n [SemanticInternalAttributes.PROJECT_NAME]: this.ctx.project.name,\n [SemanticInternalAttributes.RUN_ID]: this.ctx.run.id,\n [SemanticInternalAttributes.RUN_IS_TEST]: this.ctx.run.isTest,\n [SemanticInternalAttributes.ORGANIZATION_SLUG]: this.ctx.organization.slug,\n [SemanticInternalAttributes.ORGANIZATION_NAME]: this.ctx.organization.name,\n [SemanticInternalAttributes.BATCH_ID]: this.ctx.batch?.id,\n };\n }\n\n return {};\n }\n\n runWith<R extends (...args: any[]) => Promise<any>>(\n context: TaskContext,\n fn: R\n ): Promise<ReturnType<R>> {\n return this._storage.runWith(context, fn);\n }\n\n #getStore(): TaskContext | undefined {\n return this._storage.getStore();\n }\n}\n\nexport const taskContextManager = new TaskContextManager();\n\nimport { Span, SpanProcessor } from \"@opentelemetry/sdk-trace-base\";\nimport { SemanticResourceAttributes } from \"@opentelemetry/semantic-conventions\";\nimport { SemanticInternalAttributes } from \"../semanticInternalAttributes\";\nimport { LogRecord, LogRecordProcessor } from \"@opentelemetry/sdk-logs\";\n\nexport class TaskContextSpanProcessor implements SpanProcessor {\n private _innerProcessor: SpanProcessor;\n\n constructor(innerProcessor: SpanProcessor) {\n this._innerProcessor = innerProcessor;\n }\n\n // Called when a span starts\n onStart(span: Span, parentContext: Context): void {\n if (taskContextManager.ctx) {\n span.setAttributes(\n flattenAttributes(\n {\n [SemanticInternalAttributes.ATTEMPT_ID]: taskContextManager.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: taskContextManager.ctx.attempt.number,\n },\n SemanticInternalAttributes.METADATA\n )\n );\n }\n\n this._innerProcessor.onStart(span, parentContext);\n }\n\n // Delegate the rest of the methods to the wrapped processor\n\n onEnd(span: Span): void {\n this._innerProcessor.onEnd(span);\n }\n\n shutdown(): Promise<void> {\n return this._innerProcessor.shutdown();\n }\n\n forceFlush(): Promise<void> {\n return this._innerProcessor.forceFlush();\n }\n}\n\nexport class TaskContextLogProcessor implements LogRecordProcessor {\n private _innerProcessor: LogRecordProcessor;\n\n constructor(innerProcessor: LogRecordProcessor) {\n this._innerProcessor = innerProcessor;\n }\n forceFlush(): Promise<void> {\n return this._innerProcessor.forceFlush();\n }\n onEmit(logRecord: LogRecord, context?: Context | undefined): void {\n // Adds in the context attributes to the log record\n if (taskContextManager.ctx) {\n logRecord.setAttributes(\n flattenAttributes(\n {\n [SemanticInternalAttributes.ATTEMPT_ID]: taskContextManager.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: taskContextManager.ctx.attempt.number,\n },\n SemanticInternalAttributes.METADATA\n )\n );\n }\n\n this._innerProcessor.onEmit(logRecord, context);\n }\n shutdown(): Promise<void> {\n return this._innerProcessor.shutdown();\n }\n}\n","export function getEnvVar(name: string): string | undefined {\n // This could run in a non-Node.js environment (Bun, Deno, CF Worker, etc.), so don't just assume process.env is a thing\n if (typeof process !== \"undefined\" && typeof process.env === \"object\" && process.env !== null) {\n return process.env[name];\n }\n}\n"]}
1
+ {"version":3,"sources":["../../../src/v3/otel/index.ts","../../../src/v3/otel/tracingSDK.ts","../../../src/v3/limits.ts","../../../src/v3/semanticInternalAttributes.ts","../../../src/v3/utils/flattenAttributes.ts","../../../src/v3/utils/safeAsyncLocalStorage.ts","../../../src/v3/tasks/taskContextManager.ts","../../../src/v3/utils/getEnv.ts"],"names":["SpanStatusCode","DiagConsoleLogger","DiagLogLevel","diag","logs","OTLPLogExporter","OTLPTraceExporter","registerInstrumentations","Resource","detectResourcesSync","processDetectorSync","BatchLogRecordProcessor","LoggerProvider","SimpleLogRecordProcessor","BatchSpanProcessor","NodeTracerProvider","SimpleSpanProcessor","SemanticResourceAttributes","OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT","OTEL_LOG_ATTRIBUTE_COUNT_LIMIT","OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT","OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT","OTEL_SPAN_EVENT_COUNT_LIMIT","OTEL_LINK_COUNT_LIMIT","OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT","OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT","OFFLOAD_IO_PACKET_LENGTH_LIMIT","SemanticInternalAttributes","ENVIRONMENT_ID","ENVIRONMENT_TYPE","ORGANIZATION_ID","ORGANIZATION_SLUG","ORGANIZATION_NAME","PROJECT_ID","PROJECT_REF","PROJECT_NAME","PROJECT_DIR","ATTEMPT_ID","ATTEMPT_NUMBER","RUN_ID","RUN_IS_TEST","BATCH_ID","TASK_SLUG","TASK_PATH","TASK_EXPORT_NAME","QUEUE_NAME","QUEUE_ID","SPAN_PARTIAL","SPAN_ID","OUTPUT","OUTPUT_TYPE","STYLE","STYLE_ICON","STYLE_VARIANT","STYLE_ACCESSORY","METADATA","TRIGGER","PAYLOAD","PAYLOAD_TYPE","SHOW","SHOW_ACTIONS","WORKER_ID","WORKER_VERSION","CLI_VERSION","SDK_VERSION","SDK_LANGUAGE","RETRY_AT","RETRY_DELAY","RETRY_COUNT","flattenAttributes","obj","prefix","result","key","value","Object","entries","newPrefix","Array","isArray","i","length","assign","isRecord","AsyncLocalStorage","SafeAsyncLocalStorage","constructor","storage","runWith","context","fn","run","getStore","TaskContextManager","_storage","isInsideTask","undefined","ctx","store","worker","attributes","contextAttributes","workerAttributes","id","version","attempt","number","task","filePath","exportName","queue","name","environment","type","organization","project","ref","isTest","slug","batch","taskContextManager","TaskContextSpanProcessor","innerProcessor","_innerProcessor","onStart","span","parentContext","setAttributes","onEnd","shutdown","forceFlush","TaskContextLogProcessor","onEmit","logRecord","getEnvVar","process","env","AsyncResourceDetector","_resolved","_promise","Promise","resolver","_resolver","detect","_config","resolveWithAttributes","Error","TracingSDK","config","asyncResourceDetector","setLogLevel","diagLogLevel","envResourceAttributesSerialized","envResourceAttributes","JSON","parse","commonResources","detectors","merge","CLOUD_PROVIDER","resource","traceProvider","forceFlushTimeoutMillis","spanLimits","attributeCountLimit","attributeValueLengthLimit","eventCountLimit","attributePerEventCountLimit","linkCountLimit","attributePerLinkCountLimit","spanExporter","url","timeoutMillis","addSpanProcessor","maxExportBatchSize","parseInt","scheduledDelayMillis","exportTimeoutMillis","maxQueueSize","register","instrumentations","tracerProvider","logExporter","loggerProvider","logRecordLimits","addLogRecordProcessor","_logProvider","_spanExporter","_traceProvider","setGlobalLoggerProvider","getLogger","bind","getTracer","flush","level","NONE","ERROR","WARN","INFO","DEBUG","VERBOSE","ALL","setLogger","recordSpanException","error","recordException","stringify","setStatus","code"],"mappings":"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","sourcesContent":["import { Span, SpanStatusCode } from \"@opentelemetry/api\";\n\nexport { TracingSDK, type TracingSDKConfig, type TracingDiagnosticLogLevel } from \"./tracingSDK\";\n\nexport function recordSpanException(span: Span, error: unknown) {\n if (error instanceof Error) {\n span.recordException(error);\n } else if (typeof error === \"string\") {\n span.recordException(new Error(error));\n } else {\n span.recordException(new Error(JSON.stringify(error)));\n }\n\n span.setStatus({ code: SpanStatusCode.ERROR });\n}\n","import { DiagConsoleLogger, DiagLogLevel, TracerProvider, diag } from \"@opentelemetry/api\";\nimport { logs } from \"@opentelemetry/api-logs\";\nimport { OTLPLogExporter } from \"@opentelemetry/exporter-logs-otlp-http\";\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-http\";\nimport {\n registerInstrumentations,\n type InstrumentationOption,\n} from \"@opentelemetry/instrumentation\";\nimport {\n DetectorSync,\n IResource,\n Resource,\n ResourceAttributes,\n ResourceDetectionConfig,\n detectResourcesSync,\n processDetectorSync,\n} from \"@opentelemetry/resources\";\nimport {\n BatchLogRecordProcessor,\n LoggerProvider,\n SimpleLogRecordProcessor,\n} from \"@opentelemetry/sdk-logs\";\nimport {\n BatchSpanProcessor,\n NodeTracerProvider,\n SimpleSpanProcessor,\n SpanExporter,\n} from \"@opentelemetry/sdk-trace-node\";\nimport { SemanticResourceAttributes } from \"@opentelemetry/semantic-conventions\";\nimport {\n OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT,\n OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT,\n OTEL_LINK_COUNT_LIMIT,\n OTEL_LOG_ATTRIBUTE_COUNT_LIMIT,\n OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT,\n OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT,\n OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT,\n OTEL_SPAN_EVENT_COUNT_LIMIT,\n} from \"../limits\";\nimport { SemanticInternalAttributes } from \"../semanticInternalAttributes\";\nimport { TaskContextLogProcessor, TaskContextSpanProcessor } from \"../tasks/taskContextManager\";\nimport { getEnvVar } from \"../utils/getEnv\";\n\nclass AsyncResourceDetector implements DetectorSync {\n private _promise: Promise<ResourceAttributes>;\n private _resolver?: (value: ResourceAttributes) => void;\n private _resolved: boolean = false;\n\n constructor() {\n this._promise = new Promise((resolver) => {\n this._resolver = resolver;\n });\n }\n\n detect(_config?: ResourceDetectionConfig): Resource {\n return new Resource({}, this._promise);\n }\n\n resolveWithAttributes(attributes: ResourceAttributes) {\n if (!this._resolver) {\n throw new Error(\"Resolver not available\");\n }\n\n if (this._resolved) {\n return;\n }\n\n this._resolved = true;\n this._resolver(attributes);\n }\n}\n\nexport type TracingDiagnosticLogLevel =\n | \"none\"\n | \"error\"\n | \"warn\"\n | \"info\"\n | \"debug\"\n | \"verbose\"\n | \"all\";\n\nexport type TracingSDKConfig = {\n url: string;\n forceFlushTimeoutMillis?: number;\n resource?: IResource;\n instrumentations?: InstrumentationOption[];\n diagLogLevel?: TracingDiagnosticLogLevel;\n};\n\nexport class TracingSDK {\n public readonly asyncResourceDetector = new AsyncResourceDetector();\n private readonly _logProvider: LoggerProvider;\n private readonly _spanExporter: SpanExporter;\n private readonly _traceProvider: NodeTracerProvider;\n\n public readonly getLogger: LoggerProvider[\"getLogger\"];\n public readonly getTracer: TracerProvider[\"getTracer\"];\n\n constructor(private readonly config: TracingSDKConfig) {\n setLogLevel(config.diagLogLevel ?? \"none\");\n\n const envResourceAttributesSerialized = getEnvVar(\"OTEL_RESOURCE_ATTRIBUTES\");\n const envResourceAttributes = envResourceAttributesSerialized\n ? JSON.parse(envResourceAttributesSerialized)\n : {};\n\n const commonResources = detectResourcesSync({\n detectors: [this.asyncResourceDetector, processDetectorSync],\n })\n .merge(\n new Resource({\n [SemanticResourceAttributes.CLOUD_PROVIDER]: \"trigger.dev\",\n [SemanticInternalAttributes.TRIGGER]: true,\n })\n )\n .merge(config.resource ?? new Resource({}))\n .merge(new Resource(envResourceAttributes));\n\n const traceProvider = new NodeTracerProvider({\n forceFlushTimeoutMillis: config.forceFlushTimeoutMillis ?? 500,\n resource: commonResources,\n spanLimits: {\n attributeCountLimit: OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT,\n attributeValueLengthLimit: OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT,\n eventCountLimit: OTEL_SPAN_EVENT_COUNT_LIMIT,\n attributePerEventCountLimit: OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT,\n linkCountLimit: OTEL_LINK_COUNT_LIMIT,\n attributePerLinkCountLimit: OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT,\n },\n });\n\n const spanExporter = new OTLPTraceExporter({\n url: `${config.url}/v1/traces`,\n timeoutMillis: config.forceFlushTimeoutMillis ?? 1000,\n });\n\n traceProvider.addSpanProcessor(\n new TaskContextSpanProcessor(\n getEnvVar(\"OTEL_BATCH_PROCESSING_ENABLED\") === \"1\"\n ? new BatchSpanProcessor(spanExporter, {\n maxExportBatchSize: parseInt(getEnvVar(\"OTEL_SPAN_MAX_EXPORT_BATCH_SIZE\") ?? \"64\"),\n scheduledDelayMillis: parseInt(\n getEnvVar(\"OTEL_SPAN_SCHEDULED_DELAY_MILLIS\") ?? \"200\"\n ),\n exportTimeoutMillis: parseInt(\n getEnvVar(\"OTEL_SPAN_EXPORT_TIMEOUT_MILLIS\") ?? \"30000\"\n ),\n maxQueueSize: parseInt(getEnvVar(\"OTEL_SPAN_MAX_QUEUE_SIZE\") ?? \"512\"),\n })\n : new SimpleSpanProcessor(spanExporter)\n )\n );\n\n traceProvider.register();\n\n registerInstrumentations({\n instrumentations: config.instrumentations ?? [],\n tracerProvider: traceProvider,\n });\n\n const logExporter = new OTLPLogExporter({\n url: `${config.url}/v1/logs`,\n });\n\n // To start a logger, you first need to initialize the Logger provider.\n const loggerProvider = new LoggerProvider({\n resource: commonResources,\n logRecordLimits: {\n attributeCountLimit: OTEL_LOG_ATTRIBUTE_COUNT_LIMIT,\n attributeValueLengthLimit: OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT,\n },\n });\n\n loggerProvider.addLogRecordProcessor(\n new TaskContextLogProcessor(\n getEnvVar(\"OTEL_BATCH_PROCESSING_ENABLED\") === \"1\"\n ? new BatchLogRecordProcessor(logExporter, {\n maxExportBatchSize: parseInt(getEnvVar(\"OTEL_LOG_MAX_EXPORT_BATCH_SIZE\") ?? \"64\"),\n scheduledDelayMillis: parseInt(getEnvVar(\"OTEL_LOG_SCHEDULED_DELAY_MILLIS\") ?? \"200\"),\n exportTimeoutMillis: parseInt(getEnvVar(\"OTEL_LOG_EXPORT_TIMEOUT_MILLIS\") ?? \"30000\"),\n maxQueueSize: parseInt(getEnvVar(\"OTEL_LOG_MAX_QUEUE_SIZE\") ?? \"512\"),\n })\n : new SimpleLogRecordProcessor(logExporter)\n )\n );\n\n this._logProvider = loggerProvider;\n this._spanExporter = spanExporter;\n this._traceProvider = traceProvider;\n\n logs.setGlobalLoggerProvider(loggerProvider);\n\n this.getLogger = loggerProvider.getLogger.bind(loggerProvider);\n this.getTracer = traceProvider.getTracer.bind(traceProvider);\n }\n\n public async flush() {\n await this._traceProvider.forceFlush();\n await this._logProvider.forceFlush();\n }\n\n public async shutdown() {\n await this._traceProvider.shutdown();\n await this._logProvider.shutdown();\n }\n}\n\nfunction setLogLevel(level: TracingDiagnosticLogLevel) {\n let diagLogLevel: DiagLogLevel;\n\n switch (level) {\n case \"none\":\n diagLogLevel = DiagLogLevel.NONE;\n break;\n case \"error\":\n diagLogLevel = DiagLogLevel.ERROR;\n break;\n case \"warn\":\n diagLogLevel = DiagLogLevel.WARN;\n break;\n case \"info\":\n diagLogLevel = DiagLogLevel.INFO;\n break;\n case \"debug\":\n diagLogLevel = DiagLogLevel.DEBUG;\n break;\n case \"verbose\":\n diagLogLevel = DiagLogLevel.VERBOSE;\n break;\n case \"all\":\n diagLogLevel = DiagLogLevel.ALL;\n break;\n default:\n diagLogLevel = DiagLogLevel.NONE;\n }\n\n diag.setLogger(new DiagConsoleLogger(), diagLogLevel);\n}\n","import { AttributeValue, Attributes } from \"@opentelemetry/api\";\n\nexport const OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT = 256;\nexport const OTEL_LOG_ATTRIBUTE_COUNT_LIMIT = 256;\nexport const OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT = 1028;\nexport const OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT = 1028;\nexport const OTEL_SPAN_EVENT_COUNT_LIMIT = 10;\nexport const OTEL_LINK_COUNT_LIMIT = 2;\nexport const OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT = 10;\nexport const OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT = 10;\nexport const OFFLOAD_IO_PACKET_LENGTH_LIMIT = 128 * 1024;\n\nexport function imposeAttributeLimits(attributes: Attributes): Attributes {\n const newAttributes: Attributes = {};\n\n for (const [key, value] of Object.entries(attributes)) {\n if (calculateAttributeValueLength(value) > OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT) {\n continue;\n }\n\n if (Object.keys(newAttributes).length >= OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT) {\n break;\n }\n\n newAttributes[key] = value;\n }\n\n return newAttributes;\n}\n\nfunction calculateAttributeValueLength(value: AttributeValue | undefined | null): number {\n if (value === undefined || value === null) {\n return 0;\n }\n\n if (typeof value === \"string\") {\n return value.length;\n }\n\n if (typeof value === \"number\") {\n return 8;\n }\n\n if (typeof value === \"boolean\") {\n return 4;\n }\n\n if (Array.isArray(value)) {\n return value.reduce((acc: number, v) => acc + calculateAttributeValueLength(v), 0);\n }\n\n return 0;\n}\n","export const SemanticInternalAttributes = {\n ENVIRONMENT_ID: \"ctx.environment.id\",\n ENVIRONMENT_TYPE: \"ctx.environment.type\",\n ORGANIZATION_ID: \"ctx.organization.id\",\n ORGANIZATION_SLUG: \"ctx.organization.slug\",\n ORGANIZATION_NAME: \"ctx.organization.name\",\n PROJECT_ID: \"ctx.project.id\",\n PROJECT_REF: \"ctx.project.ref\",\n PROJECT_NAME: \"ctx.project.title\",\n PROJECT_DIR: \"project.dir\",\n ATTEMPT_ID: \"ctx.attempt.id\",\n ATTEMPT_NUMBER: \"ctx.attempt.number\",\n RUN_ID: \"ctx.run.id\",\n RUN_IS_TEST: \"ctx.run.isTest\",\n BATCH_ID: \"ctx.batch.id\",\n TASK_SLUG: \"ctx.task.id\",\n TASK_PATH: \"ctx.task.filePath\",\n TASK_EXPORT_NAME: \"ctx.task.exportName\",\n QUEUE_NAME: \"ctx.queue.name\",\n QUEUE_ID: \"ctx.queue.id\",\n SPAN_PARTIAL: \"$span.partial\",\n SPAN_ID: \"$span.span_id\",\n OUTPUT: \"$output\",\n OUTPUT_TYPE: \"$mime_type_output\",\n STYLE: \"$style\",\n STYLE_ICON: \"$style.icon\",\n STYLE_VARIANT: \"$style.variant\",\n STYLE_ACCESSORY: \"$style.accessory\",\n METADATA: \"$metadata\",\n TRIGGER: \"$trigger\",\n PAYLOAD: \"$payload\",\n PAYLOAD_TYPE: \"$mime_type_payload\",\n SHOW: \"$show\",\n SHOW_ACTIONS: \"$show.actions\",\n WORKER_ID: \"worker.id\",\n WORKER_VERSION: \"worker.version\",\n CLI_VERSION: \"cli.version\",\n SDK_VERSION: \"sdk.version\",\n SDK_LANGUAGE: \"sdk.language\",\n RETRY_AT: \"retry.at\",\n RETRY_DELAY: \"retry.delay\",\n RETRY_COUNT: \"retry.count\",\n};\n","import { Attributes } from \"@opentelemetry/api\";\n\nexport function flattenAttributes(\n obj: Record<string, unknown> | Array<unknown> | string | boolean | number | null | undefined,\n prefix?: string\n): Attributes {\n const result: Attributes = {};\n\n // Check if obj is null or undefined\n if (!obj) {\n return result;\n }\n\n if (typeof obj === \"string\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n if (typeof obj === \"number\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n if (typeof obj === \"boolean\") {\n result[prefix || \"\"] = obj;\n return result;\n }\n\n for (const [key, value] of Object.entries(obj)) {\n const newPrefix = `${prefix ? `${prefix}.` : \"\"}${key}`;\n if (Array.isArray(value)) {\n for (let i = 0; i < value.length; i++) {\n if (typeof value[i] === \"object\" && value[i] !== null) {\n // update null check here as well\n Object.assign(result, flattenAttributes(value[i], `${newPrefix}.[${i}]`));\n } else {\n result[`${newPrefix}.[${i}]`] = value[i];\n }\n }\n } else if (isRecord(value)) {\n // update null check here\n Object.assign(result, flattenAttributes(value, newPrefix));\n } else {\n if (typeof value === \"number\" || typeof value === \"string\" || typeof value === \"boolean\") {\n result[newPrefix] = value;\n }\n }\n }\n\n return result;\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return value !== null && typeof value === \"object\" && !Array.isArray(value);\n}\n\nexport function unflattenAttributes(obj: Attributes): Record<string, unknown> {\n if (typeof obj !== \"object\" || obj === null || Array.isArray(obj)) {\n return obj;\n }\n\n const result: Record<string, unknown> = {};\n\n for (const [key, value] of Object.entries(obj)) {\n const parts = key.split(\".\").reduce((acc, part) => {\n // Splitting array indices as separate parts\n if (detectIsArrayIndex(part)) {\n acc.push(part);\n } else {\n acc.push(...part.split(/\\.\\[(.*?)\\]/).filter(Boolean));\n }\n return acc;\n }, [] as string[]);\n\n let current: Record<string, unknown> = result;\n for (let i = 0; i < parts.length - 1; i++) {\n const part = parts[i];\n const isArray = detectIsArrayIndex(part);\n const cleanPart = isArray ? part.substring(1, part.length - 1) : part;\n const nextIsArray = detectIsArrayIndex(parts[i + 1]);\n if (!current[cleanPart]) {\n current[cleanPart] = nextIsArray ? [] : {};\n }\n current = current[cleanPart] as Record<string, unknown>;\n }\n const lastPart = parts[parts.length - 1];\n const cleanLastPart = detectIsArrayIndex(lastPart)\n ? parseInt(lastPart.substring(1, lastPart.length - 1), 10)\n : lastPart;\n current[cleanLastPart] = value;\n }\n\n return result;\n}\n\nfunction detectIsArrayIndex(key: string): boolean {\n const match = key.match(/^\\[(\\d+)\\]$/);\n\n if (match) {\n return true;\n }\n\n return false;\n}\n\nexport function primitiveValueOrflattenedAttributes(\n obj: Record<string, unknown> | Array<unknown> | string | boolean | number | undefined,\n prefix: string | undefined\n): Attributes | string | number | boolean | undefined {\n if (\n typeof obj === \"string\" ||\n typeof obj === \"number\" ||\n typeof obj === \"boolean\" ||\n obj === null ||\n obj === undefined\n ) {\n return obj;\n }\n\n const attributes = flattenAttributes(obj, prefix);\n\n if (\n prefix !== undefined &&\n typeof attributes[prefix] !== \"undefined\" &&\n attributes[prefix] !== null\n ) {\n return attributes[prefix] as unknown as Attributes;\n }\n\n return attributes;\n}\n","import { AsyncLocalStorage } from \"node:async_hooks\";\n\nexport class SafeAsyncLocalStorage<T> {\n private storage: AsyncLocalStorage<T>;\n\n constructor() {\n this.storage = new AsyncLocalStorage<T>();\n }\n\n runWith<R extends (...args: any[]) => Promise<any>>(context: T, fn: R): Promise<ReturnType<R>> {\n return this.storage.run(context, fn);\n }\n\n getStore(): T | undefined {\n return this.storage.getStore();\n }\n}\n","import { Attributes, Context } from \"@opentelemetry/api\";\nimport { TaskRunContext, type BackgroundWorkerProperties } from \"../schemas\";\nimport { flattenAttributes } from \"../utils/flattenAttributes\";\nimport { SafeAsyncLocalStorage } from \"../utils/safeAsyncLocalStorage\";\n\ntype TaskContext = {\n ctx: TaskRunContext;\n worker: BackgroundWorkerProperties;\n};\n\nexport class TaskContextManager {\n private _storage: SafeAsyncLocalStorage<TaskContext> = new SafeAsyncLocalStorage<TaskContext>();\n\n get isInsideTask(): boolean {\n return this.#getStore() !== undefined;\n }\n\n get ctx(): TaskRunContext | undefined {\n const store = this.#getStore();\n return store?.ctx;\n }\n\n get worker(): BackgroundWorkerProperties | undefined {\n const store = this.#getStore();\n return store?.worker;\n }\n\n get attributes(): Attributes {\n if (this.ctx) {\n return {\n ...this.contextAttributes,\n ...this.workerAttributes,\n };\n }\n\n return {};\n }\n\n get workerAttributes(): Attributes {\n if (this.worker) {\n return {\n [SemanticInternalAttributes.WORKER_ID]: this.worker.id,\n [SemanticInternalAttributes.WORKER_VERSION]: this.worker.version,\n };\n }\n\n return {};\n }\n\n get contextAttributes(): Attributes {\n if (this.ctx) {\n return {\n [SemanticInternalAttributes.ATTEMPT_ID]: this.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: this.ctx.attempt.number,\n [SemanticInternalAttributes.TASK_SLUG]: this.ctx.task.id,\n [SemanticInternalAttributes.TASK_PATH]: this.ctx.task.filePath,\n [SemanticInternalAttributes.TASK_EXPORT_NAME]: this.ctx.task.exportName,\n [SemanticInternalAttributes.QUEUE_NAME]: this.ctx.queue.name,\n [SemanticInternalAttributes.QUEUE_ID]: this.ctx.queue.id,\n [SemanticInternalAttributes.ENVIRONMENT_ID]: this.ctx.environment.id,\n [SemanticInternalAttributes.ENVIRONMENT_TYPE]: this.ctx.environment.type,\n [SemanticInternalAttributes.ORGANIZATION_ID]: this.ctx.organization.id,\n [SemanticInternalAttributes.PROJECT_ID]: this.ctx.project.id,\n [SemanticInternalAttributes.PROJECT_REF]: this.ctx.project.ref,\n [SemanticInternalAttributes.PROJECT_NAME]: this.ctx.project.name,\n [SemanticInternalAttributes.RUN_ID]: this.ctx.run.id,\n [SemanticInternalAttributes.RUN_IS_TEST]: this.ctx.run.isTest,\n [SemanticInternalAttributes.ORGANIZATION_SLUG]: this.ctx.organization.slug,\n [SemanticInternalAttributes.ORGANIZATION_NAME]: this.ctx.organization.name,\n [SemanticInternalAttributes.BATCH_ID]: this.ctx.batch?.id,\n };\n }\n\n return {};\n }\n\n runWith<R extends (...args: any[]) => Promise<any>>(\n context: TaskContext,\n fn: R\n ): Promise<ReturnType<R>> {\n return this._storage.runWith(context, fn);\n }\n\n #getStore(): TaskContext | undefined {\n return this._storage.getStore();\n }\n}\n\nexport const taskContextManager = new TaskContextManager();\n\nimport { LogRecord, LogRecordProcessor } from \"@opentelemetry/sdk-logs\";\nimport { Span, SpanProcessor } from \"@opentelemetry/sdk-trace-base\";\nimport { SemanticInternalAttributes } from \"../semanticInternalAttributes\";\n\nexport class TaskContextSpanProcessor implements SpanProcessor {\n private _innerProcessor: SpanProcessor;\n\n constructor(innerProcessor: SpanProcessor) {\n this._innerProcessor = innerProcessor;\n }\n\n // Called when a span starts\n onStart(span: Span, parentContext: Context): void {\n if (taskContextManager.ctx) {\n span.setAttributes(\n flattenAttributes(\n {\n [SemanticInternalAttributes.ATTEMPT_ID]: taskContextManager.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: taskContextManager.ctx.attempt.number,\n },\n SemanticInternalAttributes.METADATA\n )\n );\n }\n\n this._innerProcessor.onStart(span, parentContext);\n }\n\n // Delegate the rest of the methods to the wrapped processor\n\n onEnd(span: Span): void {\n this._innerProcessor.onEnd(span);\n }\n\n shutdown(): Promise<void> {\n return this._innerProcessor.shutdown();\n }\n\n forceFlush(): Promise<void> {\n return this._innerProcessor.forceFlush();\n }\n}\n\nexport class TaskContextLogProcessor implements LogRecordProcessor {\n private _innerProcessor: LogRecordProcessor;\n\n constructor(innerProcessor: LogRecordProcessor) {\n this._innerProcessor = innerProcessor;\n }\n forceFlush(): Promise<void> {\n return this._innerProcessor.forceFlush();\n }\n onEmit(logRecord: LogRecord, context?: Context | undefined): void {\n // Adds in the context attributes to the log record\n if (taskContextManager.ctx) {\n logRecord.setAttributes(\n flattenAttributes(\n {\n [SemanticInternalAttributes.ATTEMPT_ID]: taskContextManager.ctx.attempt.id,\n [SemanticInternalAttributes.ATTEMPT_NUMBER]: taskContextManager.ctx.attempt.number,\n },\n SemanticInternalAttributes.METADATA\n )\n );\n }\n\n this._innerProcessor.onEmit(logRecord, context);\n }\n shutdown(): Promise<void> {\n return this._innerProcessor.shutdown();\n }\n}\n","export function getEnvVar(name: string): string | undefined {\n // This could run in a non-Node.js environment (Bun, Deno, CF Worker, etc.), so don't just assume process.env is a thing\n if (typeof process !== \"undefined\" && typeof process.env === \"object\" && process.env !== null) {\n return process.env[name];\n }\n}\n"]}