autotel-cloudflare 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +432 -0
  3. package/dist/actors.d.ts +248 -0
  4. package/dist/actors.js +1030 -0
  5. package/dist/actors.js.map +1 -0
  6. package/dist/agents.d.ts +219 -0
  7. package/dist/agents.js +276 -0
  8. package/dist/agents.js.map +1 -0
  9. package/dist/bindings.d.ts +40 -0
  10. package/dist/bindings.js +4 -0
  11. package/dist/bindings.js.map +1 -0
  12. package/dist/chunk-JDPN3HND.js +520 -0
  13. package/dist/chunk-JDPN3HND.js.map +1 -0
  14. package/dist/chunk-QXFYTHQF.js +298 -0
  15. package/dist/chunk-QXFYTHQF.js.map +1 -0
  16. package/dist/chunk-SKKRPS5K.js +50 -0
  17. package/dist/chunk-SKKRPS5K.js.map +1 -0
  18. package/dist/events.d.ts +1 -0
  19. package/dist/events.js +3 -0
  20. package/dist/events.js.map +1 -0
  21. package/dist/handlers.d.ts +121 -0
  22. package/dist/handlers.js +4 -0
  23. package/dist/handlers.js.map +1 -0
  24. package/dist/index.d.ts +144 -0
  25. package/dist/index.js +576 -0
  26. package/dist/index.js.map +1 -0
  27. package/dist/logger.d.ts +1 -0
  28. package/dist/logger.js +3 -0
  29. package/dist/logger.js.map +1 -0
  30. package/dist/sampling.d.ts +4 -0
  31. package/dist/sampling.js +3 -0
  32. package/dist/sampling.js.map +1 -0
  33. package/dist/testing.d.ts +1 -0
  34. package/dist/testing.js +3 -0
  35. package/dist/testing.js.map +1 -0
  36. package/package.json +107 -0
  37. package/src/actors/alarms.ts +225 -0
  38. package/src/actors/index.ts +36 -0
  39. package/src/actors/instrument-actor.test.ts +179 -0
  40. package/src/actors/instrument-actor.ts +574 -0
  41. package/src/actors/sockets.ts +217 -0
  42. package/src/actors/storage.ts +263 -0
  43. package/src/actors/traced-handler.ts +300 -0
  44. package/src/actors/types.ts +98 -0
  45. package/src/actors.ts +50 -0
  46. package/src/agents/index.ts +42 -0
  47. package/src/agents/otel-observability.test.ts +329 -0
  48. package/src/agents/otel-observability.ts +465 -0
  49. package/src/agents/types.ts +167 -0
  50. package/src/agents.ts +76 -0
  51. package/src/bindings/bindings.ts +621 -0
  52. package/src/bindings/common.ts +75 -0
  53. package/src/bindings/index.ts +12 -0
  54. package/src/bindings.ts +6 -0
  55. package/src/events.ts +6 -0
  56. package/src/global/cache.test.ts +292 -0
  57. package/src/global/cache.ts +164 -0
  58. package/src/global/fetch.test.ts +344 -0
  59. package/src/global/fetch.ts +134 -0
  60. package/src/global/index.ts +7 -0
  61. package/src/handlers/durable-objects.test.ts +524 -0
  62. package/src/handlers/durable-objects.ts +250 -0
  63. package/src/handlers/index.ts +6 -0
  64. package/src/handlers/workflows.ts +318 -0
  65. package/src/handlers.ts +6 -0
  66. package/src/index.ts +57 -0
  67. package/src/logger.ts +6 -0
  68. package/src/sampling.ts +6 -0
  69. package/src/testing.ts +6 -0
  70. package/src/wrappers/index.ts +8 -0
  71. package/src/wrappers/instrument.integration.test.ts +468 -0
  72. package/src/wrappers/instrument.ts +643 -0
  73. package/src/wrappers/wrap-do.ts +34 -0
  74. package/src/wrappers/wrap-module.ts +37 -0
package/dist/agents.js ADDED
@@ -0,0 +1,276 @@
1
+ import { trace, SpanStatusCode, SpanKind } from '@opentelemetry/api';
2
+ import { resourceFromAttributes } from '@opentelemetry/resources';
3
+ import { createInitialiser, WorkerTracerProvider, WorkerTracer } from 'autotel-edge';
4
+
5
+ // src/agents/otel-observability.ts
6
+ var activeSpans = /* @__PURE__ */ new Map();
7
+ var providerInitialized = false;
8
+ function initProvider(config) {
9
+ if (providerInitialized) return;
10
+ const resource = resourceFromAttributes({
11
+ "service.name": config.service.name,
12
+ "service.version": config.service.version,
13
+ "service.namespace": config.service.namespace,
14
+ "cloud.provider": "cloudflare",
15
+ "cloud.platform": "cloudflare.workers",
16
+ "telemetry.sdk.name": "autotel-cloudflare",
17
+ "telemetry.sdk.language": "js",
18
+ "agent.framework": "cloudflare-agents"
19
+ });
20
+ const provider = new WorkerTracerProvider(config.spanProcessors, resource);
21
+ provider.register();
22
+ const tracer = trace.getTracer("autotel-cloudflare/agents");
23
+ tracer.setHeadSampler(config.sampling.headSampler);
24
+ providerInitialized = true;
25
+ }
26
+ function getDefaultSpanName(event) {
27
+ switch (event.type) {
28
+ case "rpc": {
29
+ return `agent.rpc ${event.payload.method}`;
30
+ }
31
+ case "schedule:create": {
32
+ return `agent.schedule.create ${event.payload.callback}`;
33
+ }
34
+ case "schedule:execute": {
35
+ return `agent.schedule.execute ${event.payload.callback}`;
36
+ }
37
+ case "schedule:cancel": {
38
+ return `agent.schedule.cancel ${event.payload.callback}`;
39
+ }
40
+ case "connect": {
41
+ return `agent.connect`;
42
+ }
43
+ case "destroy": {
44
+ return `agent.destroy`;
45
+ }
46
+ case "state:update": {
47
+ return `agent.state.update`;
48
+ }
49
+ case "message:request": {
50
+ return `agent.message.request`;
51
+ }
52
+ case "message:response": {
53
+ return `agent.message.response`;
54
+ }
55
+ case "message:clear": {
56
+ return `agent.message.clear`;
57
+ }
58
+ case "mcp:client:preconnect": {
59
+ return `mcp.preconnect ${event.payload.serverId}`;
60
+ }
61
+ case "mcp:client:connect": {
62
+ return `mcp.connect ${event.payload.url}`;
63
+ }
64
+ case "mcp:client:authorize": {
65
+ return `mcp.authorize ${event.payload.serverId}`;
66
+ }
67
+ case "mcp:client:discover": {
68
+ return `mcp.discover`;
69
+ }
70
+ default: {
71
+ return `agent.${event.type}`;
72
+ }
73
+ }
74
+ }
75
+ function getDefaultAttributes(event) {
76
+ const attrs = {
77
+ "agent.event.type": event.type,
78
+ "agent.event.id": event.id
79
+ };
80
+ switch (event.type) {
81
+ case "rpc": {
82
+ attrs["agent.rpc.method"] = event.payload.method;
83
+ if (event.payload.streaming !== void 0) {
84
+ attrs["agent.rpc.streaming"] = event.payload.streaming;
85
+ }
86
+ break;
87
+ }
88
+ case "schedule:create":
89
+ case "schedule:execute":
90
+ case "schedule:cancel": {
91
+ attrs["agent.schedule.callback"] = event.payload.callback;
92
+ attrs["agent.schedule.id"] = event.payload.id;
93
+ break;
94
+ }
95
+ case "connect": {
96
+ attrs["agent.connection.id"] = event.payload.connectionId;
97
+ break;
98
+ }
99
+ case "mcp:client:preconnect": {
100
+ attrs["agent.mcp.server_id"] = event.payload.serverId;
101
+ break;
102
+ }
103
+ case "mcp:client:connect": {
104
+ attrs["agent.mcp.url"] = event.payload.url;
105
+ attrs["agent.mcp.transport"] = event.payload.transport;
106
+ attrs["agent.mcp.state"] = event.payload.state;
107
+ if (event.payload.error) {
108
+ attrs["agent.mcp.error"] = event.payload.error;
109
+ }
110
+ break;
111
+ }
112
+ case "mcp:client:authorize": {
113
+ attrs["agent.mcp.server_id"] = event.payload.serverId;
114
+ attrs["agent.mcp.auth_url"] = event.payload.authUrl;
115
+ if (event.payload.clientId) {
116
+ attrs["agent.mcp.client_id"] = event.payload.clientId;
117
+ }
118
+ break;
119
+ }
120
+ }
121
+ for (const [key, value] of Object.entries(event.payload)) {
122
+ if (attrs[`agent.${key}`] === void 0 && (typeof value === "string" || typeof value === "number" || typeof value === "boolean")) {
123
+ attrs[`agent.payload.${key}`] = value;
124
+ }
125
+ }
126
+ return attrs;
127
+ }
128
+ function getSpanKind(event) {
129
+ switch (event.type) {
130
+ case "rpc": {
131
+ return SpanKind.SERVER;
132
+ }
133
+ case "connect": {
134
+ return SpanKind.SERVER;
135
+ }
136
+ case "mcp:client:connect":
137
+ case "mcp:client:preconnect":
138
+ case "mcp:client:authorize":
139
+ case "mcp:client:discover": {
140
+ return SpanKind.CLIENT;
141
+ }
142
+ default: {
143
+ return SpanKind.INTERNAL;
144
+ }
145
+ }
146
+ }
147
+ function shouldTraceEvent(event, options) {
148
+ const defaults = {
149
+ traceRpc: true,
150
+ traceSchedule: true,
151
+ traceMcp: true,
152
+ traceStateUpdates: false,
153
+ traceMessages: true,
154
+ traceLifecycle: true
155
+ };
156
+ const opts = { ...defaults, ...options };
157
+ switch (event.type) {
158
+ case "rpc": {
159
+ return opts.traceRpc ?? true;
160
+ }
161
+ case "schedule:create":
162
+ case "schedule:execute":
163
+ case "schedule:cancel": {
164
+ return opts.traceSchedule ?? true;
165
+ }
166
+ case "mcp:client:preconnect":
167
+ case "mcp:client:connect":
168
+ case "mcp:client:authorize":
169
+ case "mcp:client:discover": {
170
+ return opts.traceMcp ?? true;
171
+ }
172
+ case "state:update": {
173
+ return opts.traceStateUpdates ?? false;
174
+ }
175
+ case "message:request":
176
+ case "message:response":
177
+ case "message:clear": {
178
+ return opts.traceMessages ?? true;
179
+ }
180
+ case "connect":
181
+ case "destroy": {
182
+ return opts.traceLifecycle ?? true;
183
+ }
184
+ default: {
185
+ return true;
186
+ }
187
+ }
188
+ }
189
+ async function exportSpans(traceId, ctx) {
190
+ const tracer = trace.getTracer("autotel-cloudflare/agents");
191
+ if (tracer instanceof WorkerTracer) {
192
+ try {
193
+ await scheduler.wait(1);
194
+ await tracer.forceFlush(traceId);
195
+ } catch (error) {
196
+ console.error("[autotel-cloudflare/agents] Failed to export spans:", error);
197
+ }
198
+ }
199
+ }
200
+ var OtelObservability = class {
201
+ config;
202
+ options;
203
+ initialized = false;
204
+ constructor(config) {
205
+ const initialiser = createInitialiser(config);
206
+ this.config = initialiser({}, void 0);
207
+ this.options = config.agents ?? {};
208
+ }
209
+ /**
210
+ * Initialize the tracer provider (called lazily on first emit)
211
+ */
212
+ initialize() {
213
+ if (this.initialized) return;
214
+ initProvider(this.config);
215
+ this.initialized = true;
216
+ }
217
+ /**
218
+ * Emit an observability event
219
+ *
220
+ * Converts the event to an OpenTelemetry span based on the event type.
221
+ */
222
+ emit(event, ctx) {
223
+ this.initialize();
224
+ if (!shouldTraceEvent(event, this.options)) {
225
+ return;
226
+ }
227
+ const tracer = trace.getTracer("autotel-cloudflare/agents");
228
+ const spanName = this.options.spanNameFormatter ? this.options.spanNameFormatter(event) : getDefaultSpanName(event);
229
+ const defaultAttrs = getDefaultAttributes(event);
230
+ const customAttrs = this.options.attributeExtractor ? this.options.attributeExtractor(event) : {};
231
+ const attributes = { ...defaultAttrs, ...customAttrs };
232
+ const kind = getSpanKind(event);
233
+ const span = tracer.startSpan(spanName, {
234
+ kind,
235
+ attributes,
236
+ startTime: event.timestamp
237
+ });
238
+ span.setStatus({ code: SpanStatusCode.OK });
239
+ span.end(event.timestamp + 1);
240
+ activeSpans.set(event.id, span);
241
+ const traceId = span.spanContext().traceId;
242
+ if (ctx && "waitUntil" in ctx && typeof ctx.waitUntil === "function") {
243
+ ctx.waitUntil(exportSpans(traceId));
244
+ } else {
245
+ void exportSpans(traceId);
246
+ }
247
+ }
248
+ };
249
+ function createOtelObservability(config) {
250
+ return new OtelObservability(config);
251
+ }
252
+ function createOtelObservabilityFromEnv(env, options) {
253
+ const endpoint = env.OTEL_EXPORTER_OTLP_ENDPOINT || void 0;
254
+ const serviceName = env.OTEL_SERVICE_NAME || "cloudflare-agent";
255
+ let headers;
256
+ const headersStr = env.OTEL_EXPORTER_OTLP_HEADERS;
257
+ if (headersStr) {
258
+ headers = {};
259
+ for (const pair of headersStr.split(",")) {
260
+ const [key, value] = pair.split("=");
261
+ if (key && value) {
262
+ headers[key.trim()] = value.trim();
263
+ }
264
+ }
265
+ }
266
+ const exporterUrl = endpoint || "http://localhost:4318/v1/traces";
267
+ return createOtelObservability({
268
+ service: { name: serviceName },
269
+ exporter: { url: exporterUrl, headers },
270
+ agents: options
271
+ });
272
+ }
273
+
274
+ export { OtelObservability, createOtelObservability, createOtelObservabilityFromEnv };
275
+ //# sourceMappingURL=agents.js.map
276
+ //# sourceMappingURL=agents.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/agents/otel-observability.ts"],"names":[],"mappings":"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","file":"agents.js","sourcesContent":["/**\n * OpenTelemetry-based Observability implementation for Cloudflare Agents SDK\n *\n * Converts Agent events into OpenTelemetry spans for distributed tracing.\n *\n * @example\n * ```typescript\n * import { Agent } from 'agents'\n * import { createOtelObservability } from 'autotel-cloudflare/agents'\n *\n * class MyAgent extends Agent<Env> {\n * observability = createOtelObservability({\n * service: { name: 'my-agent' },\n * exporter: { url: env.OTLP_ENDPOINT }\n * })\n *\n * @callable()\n * async doSomething() {\n * // This RPC call will be automatically traced\n * return 'done'\n * }\n * }\n * ```\n */\n\nimport {\n trace,\n SpanStatusCode,\n SpanKind,\n type Span,\n type Attributes,\n} from '@opentelemetry/api';\nimport { resourceFromAttributes } from '@opentelemetry/resources';\nimport {\n createInitialiser,\n WorkerTracerProvider,\n WorkerTracer,\n type ResolvedEdgeConfig,\n} from 'autotel-edge';\nimport type {\n Observability,\n ObservabilityEvent,\n OtelObservabilityConfig,\n AgentInstrumentationOptions,\n} from './types';\n\n/**\n * Map of active spans keyed by event ID\n * Used to correlate start/end events\n */\nconst activeSpans = new Map<string, Span>();\n\n/**\n * Whether the provider has been initialized\n */\nlet providerInitialized = false;\n\n/**\n * Initialize the tracer provider for Agents\n */\nfunction initProvider(config: ResolvedEdgeConfig): void {\n if (providerInitialized) return;\n\n // Create resource with agent-specific attributes\n const resource = resourceFromAttributes({\n 'service.name': config.service.name,\n 'service.version': config.service.version,\n 'service.namespace': config.service.namespace,\n 'cloud.provider': 'cloudflare',\n 'cloud.platform': 'cloudflare.workers',\n 'telemetry.sdk.name': 'autotel-cloudflare',\n 'telemetry.sdk.language': 'js',\n 'agent.framework': 'cloudflare-agents',\n });\n\n // Create and register provider\n const provider = new WorkerTracerProvider(config.spanProcessors, resource);\n provider.register();\n\n // Set head sampler on tracer\n const tracer = trace.getTracer('autotel-cloudflare/agents') as WorkerTracer;\n tracer.setHeadSampler(config.sampling.headSampler);\n\n providerInitialized = true;\n}\n\n/**\n * Get default span name for an event\n */\nfunction getDefaultSpanName(event: ObservabilityEvent): string {\n switch (event.type) {\n case 'rpc': {\n return `agent.rpc ${event.payload.method}`;\n }\n case 'schedule:create': {\n return `agent.schedule.create ${event.payload.callback}`;\n }\n case 'schedule:execute': {\n return `agent.schedule.execute ${event.payload.callback}`;\n }\n case 'schedule:cancel': {\n return `agent.schedule.cancel ${event.payload.callback}`;\n }\n case 'connect': {\n return `agent.connect`;\n }\n case 'destroy': {\n return `agent.destroy`;\n }\n case 'state:update': {\n return `agent.state.update`;\n }\n case 'message:request': {\n return `agent.message.request`;\n }\n case 'message:response': {\n return `agent.message.response`;\n }\n case 'message:clear': {\n return `agent.message.clear`;\n }\n case 'mcp:client:preconnect': {\n return `mcp.preconnect ${event.payload.serverId}`;\n }\n case 'mcp:client:connect': {\n return `mcp.connect ${event.payload.url}`;\n }\n case 'mcp:client:authorize': {\n return `mcp.authorize ${event.payload.serverId}`;\n }\n case 'mcp:client:discover': {\n return `mcp.discover`;\n }\n default: {\n return `agent.${(event as ObservabilityEvent).type}`;\n }\n }\n}\n\n/**\n * Get default attributes for an event\n */\nfunction getDefaultAttributes(event: ObservabilityEvent): Attributes {\n const attrs: Attributes = {\n 'agent.event.type': event.type,\n 'agent.event.id': event.id,\n };\n\n // Add type-specific attributes\n switch (event.type) {\n case 'rpc': {\n attrs['agent.rpc.method'] = event.payload.method;\n if (event.payload.streaming !== undefined) {\n attrs['agent.rpc.streaming'] = event.payload.streaming;\n }\n break;\n }\n\n case 'schedule:create':\n case 'schedule:execute':\n case 'schedule:cancel': {\n attrs['agent.schedule.callback'] = event.payload.callback;\n attrs['agent.schedule.id'] = event.payload.id;\n break;\n }\n\n case 'connect': {\n attrs['agent.connection.id'] = event.payload.connectionId;\n break;\n }\n\n case 'mcp:client:preconnect': {\n attrs['agent.mcp.server_id'] = event.payload.serverId;\n break;\n }\n\n case 'mcp:client:connect': {\n attrs['agent.mcp.url'] = event.payload.url;\n attrs['agent.mcp.transport'] = event.payload.transport;\n attrs['agent.mcp.state'] = event.payload.state;\n if (event.payload.error) {\n attrs['agent.mcp.error'] = event.payload.error;\n }\n break;\n }\n\n case 'mcp:client:authorize': {\n attrs['agent.mcp.server_id'] = event.payload.serverId;\n attrs['agent.mcp.auth_url'] = event.payload.authUrl;\n if (event.payload.clientId) {\n attrs['agent.mcp.client_id'] = event.payload.clientId;\n }\n break;\n }\n }\n\n // Add any additional payload properties as attributes\n for (const [key, value] of Object.entries(event.payload)) {\n if (\n attrs[`agent.${key}`] === undefined &&\n (typeof value === 'string' || typeof value === 'number' || typeof value === 'boolean')\n ) {\n attrs[`agent.payload.${key}`] = value;\n }\n }\n\n return attrs;\n}\n\n/**\n * Determine span kind based on event type\n */\nfunction getSpanKind(event: ObservabilityEvent): SpanKind {\n switch (event.type) {\n case 'rpc': {\n return SpanKind.SERVER;\n }\n case 'connect': {\n return SpanKind.SERVER;\n }\n case 'mcp:client:connect':\n case 'mcp:client:preconnect':\n case 'mcp:client:authorize':\n case 'mcp:client:discover': {\n return SpanKind.CLIENT;\n }\n default: {\n return SpanKind.INTERNAL;\n }\n }\n}\n\n/**\n * Check if an event type should be traced based on options\n */\nfunction shouldTraceEvent(\n event: ObservabilityEvent,\n options: AgentInstrumentationOptions,\n): boolean {\n const defaults: AgentInstrumentationOptions = {\n traceRpc: true,\n traceSchedule: true,\n traceMcp: true,\n traceStateUpdates: false,\n traceMessages: true,\n traceLifecycle: true,\n };\n\n const opts = { ...defaults, ...options };\n\n switch (event.type) {\n case 'rpc': {\n return opts.traceRpc ?? true;\n }\n\n case 'schedule:create':\n case 'schedule:execute':\n case 'schedule:cancel': {\n return opts.traceSchedule ?? true;\n }\n\n case 'mcp:client:preconnect':\n case 'mcp:client:connect':\n case 'mcp:client:authorize':\n case 'mcp:client:discover': {\n return opts.traceMcp ?? true;\n }\n\n case 'state:update': {\n return opts.traceStateUpdates ?? false;\n }\n\n case 'message:request':\n case 'message:response':\n case 'message:clear': {\n return opts.traceMessages ?? true;\n }\n\n case 'connect':\n case 'destroy': {\n return opts.traceLifecycle ?? true;\n }\n\n default: {\n return true;\n }\n }\n}\n\n/**\n * Export spans asynchronously\n */\nasync function exportSpans(traceId: string, ctx?: DurableObjectState): Promise<void> {\n const tracer = trace.getTracer('autotel-cloudflare/agents');\n if (tracer instanceof WorkerTracer) {\n try {\n await scheduler.wait(1);\n await tracer.forceFlush(traceId);\n } catch (error) {\n console.error('[autotel-cloudflare/agents] Failed to export spans:', error);\n }\n }\n\n // If we have a DurableObject context, use waitUntil for export\n if (ctx && 'waitUntil' in ctx) {\n // Already exported above, but could defer more work here\n }\n}\n\n/**\n * OpenTelemetry-based Observability implementation\n *\n * Implements the Agents SDK Observability interface and converts\n * events into OpenTelemetry spans.\n */\nexport class OtelObservability implements Observability {\n private config: ResolvedEdgeConfig;\n private options: AgentInstrumentationOptions;\n private initialized = false;\n\n constructor(config: OtelObservabilityConfig) {\n // Use createInitialiser to resolve the config\n const initialiser = createInitialiser(config);\n this.config = initialiser({}, undefined);\n this.options = config.agents ?? {};\n }\n\n /**\n * Initialize the tracer provider (called lazily on first emit)\n */\n private initialize(): void {\n if (this.initialized) return;\n initProvider(this.config);\n this.initialized = true;\n }\n\n /**\n * Emit an observability event\n *\n * Converts the event to an OpenTelemetry span based on the event type.\n */\n emit(event: ObservabilityEvent, ctx?: DurableObjectState): void {\n // Initialize provider on first emit\n this.initialize();\n\n // Check if this event type should be traced\n if (!shouldTraceEvent(event, this.options)) {\n return;\n }\n\n const tracer = trace.getTracer('autotel-cloudflare/agents');\n\n // Get span name (custom or default)\n const spanName = this.options.spanNameFormatter\n ? this.options.spanNameFormatter(event)\n : getDefaultSpanName(event);\n\n // Get attributes (custom + default)\n const defaultAttrs = getDefaultAttributes(event);\n const customAttrs = this.options.attributeExtractor\n ? this.options.attributeExtractor(event)\n : {};\n const attributes = { ...defaultAttrs, ...customAttrs };\n\n // Determine span kind\n const kind = getSpanKind(event);\n\n // Create span with event timestamp\n const span = tracer.startSpan(spanName, {\n kind,\n attributes,\n startTime: event.timestamp,\n });\n\n // For short-lived events, end immediately\n // For events that have duration (like RPC), we would ideally track start/end\n // But the Agents SDK emits single events, so we create point-in-time spans\n span.setStatus({ code: SpanStatusCode.OK });\n span.end(event.timestamp + 1); // End 1ms after start\n\n // Store span for potential correlation\n activeSpans.set(event.id, span);\n\n // Schedule span export\n const traceId = span.spanContext().traceId;\n if (ctx && 'waitUntil' in ctx && typeof (ctx as any).waitUntil === 'function') {\n (ctx as any).waitUntil(exportSpans(traceId, ctx));\n } else {\n // In environments without waitUntil, export synchronously-ish\n void exportSpans(traceId, ctx);\n }\n }\n}\n\n/**\n * Create an OtelObservability instance\n *\n * @example\n * ```typescript\n * import { Agent } from 'agents'\n * import { createOtelObservability } from 'autotel-cloudflare/agents'\n *\n * class MyAgent extends Agent<Env> {\n * observability = createOtelObservability({\n * service: { name: 'my-agent' },\n * exporter: { url: env.OTLP_ENDPOINT }\n * })\n * }\n * ```\n */\nexport function createOtelObservability(config: OtelObservabilityConfig): OtelObservability {\n return new OtelObservability(config);\n}\n\n/**\n * Create an OtelObservability instance with environment-based config\n *\n * Use this when you need to access environment variables for configuration.\n *\n * @example\n * ```typescript\n * import { Agent } from 'agents'\n * import { createOtelObservabilityFromEnv } from 'autotel-cloudflare/agents'\n *\n * class MyAgent extends Agent<Env> {\n * observability?: OtelObservability\n *\n * constructor(state: DurableObjectState, env: Env) {\n * super(state, env)\n * this.observability = createOtelObservabilityFromEnv(env)\n * }\n * }\n * ```\n */\nexport function createOtelObservabilityFromEnv(\n env: Record<string, unknown>,\n options?: AgentInstrumentationOptions,\n): OtelObservability {\n // Extract standard OTLP env vars\n const endpoint = (env.OTEL_EXPORTER_OTLP_ENDPOINT as string) || undefined;\n const serviceName = (env.OTEL_SERVICE_NAME as string) || 'cloudflare-agent';\n\n // Parse headers if present\n let headers: Record<string, string> | undefined;\n const headersStr = env.OTEL_EXPORTER_OTLP_HEADERS as string;\n if (headersStr) {\n headers = {};\n for (const pair of headersStr.split(',')) {\n const [key, value] = pair.split('=');\n if (key && value) {\n headers[key.trim()] = value.trim();\n }\n }\n }\n\n // If no endpoint is configured, use a default localhost endpoint\n // In production, users should set OTEL_EXPORTER_OTLP_ENDPOINT\n const exporterUrl = endpoint || 'http://localhost:4318/v1/traces';\n\n return createOtelObservability({\n service: { name: serviceName },\n exporter: { url: exporterUrl, headers },\n agents: options,\n });\n}\n"]}
@@ -0,0 +1,40 @@
1
+ /**
2
+ * Auto-instrumentation for Cloudflare Workers bindings
3
+ *
4
+ * Note: This file uses Cloudflare Workers types (KVNamespace, R2Bucket, D1Database, Fetcher, etc.)
5
+ * which are globally available via @cloudflare/workers-types when listed in tsconfig.json.
6
+ * These types are devDependencies only - they're not runtime dependencies.
7
+ * At runtime, Cloudflare Workers runtime provides the actual implementations.
8
+ *
9
+ * This module provides automatic tracing for Cloudflare bindings:
10
+ * - KV (key-value operations)
11
+ * - R2 (object storage operations)
12
+ * - D1 (database operations)
13
+ * - Service Bindings
14
+ * - Events Engine
15
+ * - Workers AI
16
+ * - Vectorize
17
+ * - Hyperdrive
18
+ */
19
+ /**
20
+ * Instrument KV namespace
21
+ */
22
+ declare function instrumentKV<K extends KVNamespace>(kv: K, namespaceName?: string): K;
23
+ /**
24
+ * Instrument R2 bucket
25
+ */
26
+ declare function instrumentR2<R extends R2Bucket>(r2: R, bucketName?: string): R;
27
+ /**
28
+ * Instrument D1 database
29
+ */
30
+ declare function instrumentD1<D extends D1Database>(d1: D, databaseName?: string): D;
31
+ /**
32
+ * Instrument service binding (Fetcher)
33
+ */
34
+ declare function instrumentServiceBinding<F extends Fetcher>(fetcher: F, serviceName?: string): F;
35
+ /**
36
+ * Auto-instrument all Cloudflare bindings in the environment
37
+ */
38
+ declare function instrumentBindings(env: Record<string, any>): Record<string, any>;
39
+
40
+ export { instrumentBindings, instrumentD1, instrumentKV, instrumentR2, instrumentServiceBinding };
@@ -0,0 +1,4 @@
1
+ export { instrumentBindings, instrumentD1, instrumentKV, instrumentR2, instrumentServiceBinding } from './chunk-JDPN3HND.js';
2
+ import './chunk-SKKRPS5K.js';
3
+ //# sourceMappingURL=bindings.js.map
4
+ //# sourceMappingURL=bindings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"bindings.js"}