@dexto/core 1.8.2 → 1.8.4

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 (56) hide show
  1. package/dist/agent/DextoAgent.cjs +11 -12
  2. package/dist/agent/DextoAgent.d.ts +4 -2
  3. package/dist/agent/DextoAgent.d.ts.map +1 -1
  4. package/dist/agent/DextoAgent.js +15 -13
  5. package/dist/events/index.cjs +8 -0
  6. package/dist/events/index.d.ts +25 -14
  7. package/dist/events/index.d.ts.map +1 -1
  8. package/dist/events/index.js +8 -0
  9. package/dist/index.browser.cjs +6 -0
  10. package/dist/index.browser.d.ts +2 -0
  11. package/dist/index.browser.d.ts.map +1 -1
  12. package/dist/index.browser.js +4 -0
  13. package/dist/llm/executor/provider-error.cjs +214 -0
  14. package/dist/llm/executor/provider-error.d.ts +26 -0
  15. package/dist/llm/executor/provider-error.d.ts.map +1 -0
  16. package/dist/llm/executor/provider-error.js +190 -0
  17. package/dist/llm/executor/stream-processor.cjs +34 -5
  18. package/dist/llm/executor/stream-processor.d.ts +4 -1
  19. package/dist/llm/executor/stream-processor.d.ts.map +1 -1
  20. package/dist/llm/executor/stream-processor.js +34 -5
  21. package/dist/llm/executor/turn-executor.cjs +185 -124
  22. package/dist/llm/executor/turn-executor.d.ts +5 -5
  23. package/dist/llm/executor/turn-executor.d.ts.map +1 -1
  24. package/dist/llm/executor/turn-executor.js +184 -120
  25. package/dist/session/chat-session.cjs +37 -22
  26. package/dist/session/chat-session.d.ts.map +1 -1
  27. package/dist/session/chat-session.js +38 -22
  28. package/dist/session/title-generator.cjs +19 -2
  29. package/dist/session/title-generator.d.ts +8 -0
  30. package/dist/session/title-generator.d.ts.map +1 -1
  31. package/dist/session/title-generator.js +19 -2
  32. package/dist/systemPrompt/contributors.cjs +10 -1
  33. package/dist/systemPrompt/contributors.d.ts.map +1 -1
  34. package/dist/systemPrompt/contributors.js +10 -1
  35. package/dist/telemetry/browser.cjs +138 -0
  36. package/dist/telemetry/browser.d.ts +30 -0
  37. package/dist/telemetry/browser.d.ts.map +1 -0
  38. package/dist/telemetry/browser.js +115 -0
  39. package/dist/telemetry/index.cjs +5 -2
  40. package/dist/telemetry/index.d.ts +1 -0
  41. package/dist/telemetry/index.d.ts.map +1 -1
  42. package/dist/telemetry/index.js +3 -1
  43. package/dist/telemetry/operation-span.cjs +73 -0
  44. package/dist/telemetry/operation-span.d.ts +13 -0
  45. package/dist/telemetry/operation-span.d.ts.map +1 -0
  46. package/dist/telemetry/operation-span.js +50 -0
  47. package/dist/telemetry/telemetry.cjs +2 -3
  48. package/dist/telemetry/telemetry.d.ts.map +1 -1
  49. package/dist/telemetry/telemetry.js +2 -3
  50. package/dist/telemetry/utils.cjs +11 -12
  51. package/dist/telemetry/utils.d.ts.map +1 -1
  52. package/dist/telemetry/utils.js +11 -12
  53. package/dist/tools/tool-call-metadata.cjs +118 -6
  54. package/dist/tools/tool-call-metadata.d.ts.map +1 -1
  55. package/dist/tools/tool-call-metadata.js +118 -6
  56. package/package.json +2 -2
@@ -30,9 +30,12 @@ async function generateSessionTitle(config, userText, logger, opts = {}) {
30
30
  });
31
31
  const processed = postProcessTitle(result.text);
32
32
  if (!processed) {
33
- return { error: "LLM returned empty title" };
33
+ return {
34
+ error: "LLM returned empty title",
35
+ usage: toSessionTitleTokenUsage(result.totalUsage)
36
+ };
34
37
  }
35
- return { title: processed };
38
+ return { title: processed, usage: toSessionTitleTokenUsage(result.totalUsage) };
36
39
  } catch (error) {
37
40
  if (controller?.signal.aborted) {
38
41
  return { timedOut: true, error: "Timed out while waiting for LLM response" };
@@ -45,6 +48,20 @@ async function generateSessionTitle(config, userText, logger, opts = {}) {
45
48
  }
46
49
  }
47
50
  }
51
+ function toSessionTitleTokenUsage(usage) {
52
+ const tokenUsage = {};
53
+ copyTokenUsageNumber(tokenUsage, "cachedInputTokens", usage.cachedInputTokens);
54
+ copyTokenUsageNumber(tokenUsage, "inputTokens", usage.inputTokens);
55
+ copyTokenUsageNumber(tokenUsage, "outputTokens", usage.outputTokens);
56
+ copyTokenUsageNumber(tokenUsage, "reasoningTokens", usage.reasoningTokens);
57
+ copyTokenUsageNumber(tokenUsage, "totalTokens", usage.totalTokens);
58
+ return tokenUsage;
59
+ }
60
+ function copyTokenUsageNumber(target, key, value) {
61
+ if (typeof value === "number" && Number.isFinite(value)) {
62
+ target[key] = value;
63
+ }
64
+ }
48
65
  function deriveHeuristicTitle(userText) {
49
66
  const sanitized = sanitizeUserText(userText, 120);
50
67
  if (!sanitized) return void 0;
@@ -29,6 +29,7 @@ var import_promises = require("fs/promises");
29
29
  var import_path = require("path");
30
30
  var import_errors = require("./errors.js");
31
31
  var import_DextoRuntimeError = require("../errors/DextoRuntimeError.js");
32
+ var import_operation_span = require("../telemetry/operation-span.js");
32
33
  class StaticContributor {
33
34
  constructor(id, priority, content) {
34
35
  this.id = id;
@@ -203,7 +204,15 @@ class SkillsContributor {
203
204
  logger;
204
205
  async getContent(_context) {
205
206
  try {
206
- const skills = await this.skillManager.list();
207
+ const skills = await (0, import_operation_span.recordOperationSpan)(
208
+ {
209
+ name: "skills.list",
210
+ componentName: "SkillsContributor",
211
+ resultAttributes: (skills2) => ({ "skills.count": skills2.length })
212
+ },
213
+ () => this.skillManager.list(),
214
+ this.logger
215
+ );
207
216
  if (skills.length === 0) {
208
217
  return "";
209
218
  }
@@ -1 +1 @@
1
- {"version":3,"file":"contributors.d.ts","sourceRoot":"","sources":["../../src/systemPrompt/contributors.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"contributors.d.ts","sourceRoot":"","sources":["../../src/systemPrompt/contributors.ts"],"names":[],"mappings":"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"}
@@ -3,6 +3,7 @@ import { readFile, stat } from "fs/promises";
3
3
  import { resolve, extname } from "path";
4
4
  import { SystemPromptError } from "./errors.js";
5
5
  import { DextoRuntimeError } from "../errors/DextoRuntimeError.js";
6
+ import { recordOperationSpan } from "../telemetry/operation-span.js";
6
7
  class StaticContributor {
7
8
  constructor(id, priority, content) {
8
9
  this.id = id;
@@ -177,7 +178,15 @@ class SkillsContributor {
177
178
  logger;
178
179
  async getContent(_context) {
179
180
  try {
180
- const skills = await this.skillManager.list();
181
+ const skills = await recordOperationSpan(
182
+ {
183
+ name: "skills.list",
184
+ componentName: "SkillsContributor",
185
+ resultAttributes: (skills2) => ({ "skills.count": skills2.length })
186
+ },
187
+ () => this.skillManager.list(),
188
+ this.logger
189
+ );
181
190
  if (skills.length === 0) {
182
191
  return "";
183
192
  }
@@ -0,0 +1,138 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var browser_exports = {};
20
+ __export(browser_exports, {
21
+ Telemetry: () => Telemetry
22
+ });
23
+ module.exports = __toCommonJS(browser_exports);
24
+ var import_api = require("@opentelemetry/api");
25
+ function isGlobalTelemetryLike(value) {
26
+ if (typeof value !== "object" || value === null) {
27
+ return false;
28
+ }
29
+ return typeof Reflect.get(value, "forceFlush") === "function" && typeof Reflect.get(value, "isInitialized") === "function" && typeof Reflect.get(value, "name") === "string" && typeof Reflect.get(value, "shutdown") === "function" && Reflect.get(value, "tracer") !== void 0;
30
+ }
31
+ class Telemetry {
32
+ tracer;
33
+ name;
34
+ _isInitialized;
35
+ _shutdownHandler;
36
+ static _initPromise;
37
+ constructor(config, options) {
38
+ const serviceName = config.serviceName ?? "dexto-service";
39
+ const tracerName = config.tracerName ?? serviceName;
40
+ this.name = serviceName;
41
+ this.tracer = import_api.trace.getTracer(tracerName);
42
+ this._shutdownHandler = options.shutdown;
43
+ this._isInitialized = options.initialized;
44
+ }
45
+ static async registerGlobal(options = {}) {
46
+ const existing = Telemetry.getGlobalInstance();
47
+ if (existing !== void 0) {
48
+ return existing;
49
+ }
50
+ if (Telemetry._initPromise !== void 0) {
51
+ return Telemetry._initPromise;
52
+ }
53
+ Telemetry._initPromise = Promise.resolve().then(() => {
54
+ const current = Telemetry.getGlobalInstance();
55
+ if (current !== void 0) {
56
+ return current;
57
+ }
58
+ const telemetry = new Telemetry(options.config ?? {}, {
59
+ initialized: options.initialized ?? true,
60
+ ...options.shutdown !== void 0 && { shutdown: options.shutdown }
61
+ });
62
+ Telemetry.setGlobalInstance(telemetry);
63
+ return telemetry;
64
+ });
65
+ return Telemetry._initPromise;
66
+ }
67
+ static getActiveSpan() {
68
+ return import_api.trace.getActiveSpan();
69
+ }
70
+ static get() {
71
+ const telemetry = Telemetry.getGlobalInstance();
72
+ if (telemetry === void 0) {
73
+ throw new Error("Telemetry not initialized. Call Telemetry.registerGlobal() first.");
74
+ }
75
+ return telemetry;
76
+ }
77
+ static hasGlobalInstance() {
78
+ return Telemetry.getGlobalInstance() !== void 0;
79
+ }
80
+ static async shutdownGlobal() {
81
+ const telemetry = Telemetry.getGlobalInstance();
82
+ if (telemetry !== void 0) {
83
+ await telemetry.shutdown();
84
+ }
85
+ Telemetry.setGlobalInstance(void 0);
86
+ Telemetry._initPromise = void 0;
87
+ }
88
+ static setBaggage(baggage, ctx = import_api.context.active()) {
89
+ const currentBaggage = Object.fromEntries(
90
+ import_api.propagation.getBaggage(ctx)?.getAllEntries() ?? []
91
+ );
92
+ return import_api.propagation.setBaggage(
93
+ ctx,
94
+ import_api.propagation.createBaggage({
95
+ ...currentBaggage,
96
+ ...baggage
97
+ })
98
+ );
99
+ }
100
+ static withContext(ctx, fn) {
101
+ return import_api.context.with(ctx, fn);
102
+ }
103
+ isInitialized() {
104
+ return this._isInitialized;
105
+ }
106
+ async forceFlush() {
107
+ const provider = import_api.trace.getTracerProvider();
108
+ const forceFlush = Reflect.get(provider, "forceFlush");
109
+ if (typeof forceFlush === "function") {
110
+ await Reflect.apply(forceFlush, provider, []);
111
+ }
112
+ }
113
+ async shutdown() {
114
+ try {
115
+ await this._shutdownHandler?.();
116
+ } finally {
117
+ this._isInitialized = false;
118
+ this._shutdownHandler = void 0;
119
+ Telemetry.setGlobalInstance(void 0);
120
+ Telemetry._initPromise = void 0;
121
+ }
122
+ }
123
+ static getGlobalInstance() {
124
+ const telemetry = Reflect.get(globalThis, "__TELEMETRY__");
125
+ return isGlobalTelemetryLike(telemetry) ? telemetry : void 0;
126
+ }
127
+ static setGlobalInstance(telemetry) {
128
+ if (telemetry === void 0) {
129
+ Reflect.deleteProperty(globalThis, "__TELEMETRY__");
130
+ return;
131
+ }
132
+ Reflect.set(globalThis, "__TELEMETRY__", telemetry);
133
+ }
134
+ }
135
+ // Annotate the CommonJS export names for ESM import in node:
136
+ 0 && (module.exports = {
137
+ Telemetry
138
+ });
@@ -0,0 +1,30 @@
1
+ import type { BaggageEntry, Context, Tracer } from '@opentelemetry/api';
2
+ import type { OtelConfiguration } from './schemas.js';
3
+ export type TelemetryShutdownHandler = () => Promise<void>;
4
+ export type TelemetryRegistrationOptions = {
5
+ config?: OtelConfiguration | undefined;
6
+ initialized?: boolean | undefined;
7
+ shutdown?: TelemetryShutdownHandler | undefined;
8
+ };
9
+ export type BrowserTelemetryInstance = Pick<Telemetry, 'forceFlush' | 'isInitialized' | 'name' | 'shutdown' | 'tracer'>;
10
+ export declare class Telemetry {
11
+ tracer: Tracer;
12
+ name: string;
13
+ private _isInitialized;
14
+ private _shutdownHandler?;
15
+ private static _initPromise?;
16
+ private constructor();
17
+ static registerGlobal(options?: TelemetryRegistrationOptions): Promise<BrowserTelemetryInstance>;
18
+ static getActiveSpan(): import("@opentelemetry/api").Span | undefined;
19
+ static get(): BrowserTelemetryInstance;
20
+ static hasGlobalInstance(): boolean;
21
+ static shutdownGlobal(): Promise<void>;
22
+ static setBaggage(baggage: Record<string, BaggageEntry>, ctx?: Context): Context;
23
+ static withContext<T>(ctx: Context, fn: () => T): T;
24
+ isInitialized(): boolean;
25
+ forceFlush(): Promise<void>;
26
+ shutdown(): Promise<void>;
27
+ private static getGlobalInstance;
28
+ private static setGlobalInstance;
29
+ }
30
+ //# sourceMappingURL=browser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"browser.d.ts","sourceRoot":"","sources":["../../src/telemetry/browser.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AACxE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAEtD,MAAM,MAAM,wBAAwB,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;AAE3D,MAAM,MAAM,4BAA4B,GAAG;IACvC,MAAM,CAAC,EAAE,iBAAiB,GAAG,SAAS,CAAC;IACvC,WAAW,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAClC,QAAQ,CAAC,EAAE,wBAAwB,GAAG,SAAS,CAAC;CACnD,CAAC;AAOF,MAAM,MAAM,wBAAwB,GAAG,IAAI,CACvC,SAAS,EACT,YAAY,GAAG,eAAe,GAAG,MAAM,GAAG,UAAU,GAAG,QAAQ,CAClE,CAAC;AAgBF,qBAAa,SAAS;IACX,MAAM,EAAE,MAAM,CAAC;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,cAAc,CAAU;IAChC,OAAO,CAAC,gBAAgB,CAAC,CAAuC;IAChE,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,CAAgD;IAE5E,OAAO;WAUM,cAAc,CACvB,OAAO,GAAE,4BAAiC,GAC3C,OAAO,CAAC,wBAAwB,CAAC;IA2BpC,MAAM,CAAC,aAAa;IAIpB,MAAM,CAAC,GAAG,IAAI,wBAAwB;IAQtC,MAAM,CAAC,iBAAiB,IAAI,OAAO;WAItB,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC;IAS5C,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC,EAAE,GAAG,GAAE,OAA8B;IAa5F,MAAM,CAAC,WAAW,CAAC,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC;IAI5C,aAAa,IAAI,OAAO;IAIlB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ3B,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAWtC,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAKhC,OAAO,CAAC,MAAM,CAAC,iBAAiB;CAOnC"}
@@ -0,0 +1,115 @@
1
+ import "../chunk-C6A6W6XS.js";
2
+ import { context as otlpContext, propagation, trace } from "@opentelemetry/api";
3
+ function isGlobalTelemetryLike(value) {
4
+ if (typeof value !== "object" || value === null) {
5
+ return false;
6
+ }
7
+ return typeof Reflect.get(value, "forceFlush") === "function" && typeof Reflect.get(value, "isInitialized") === "function" && typeof Reflect.get(value, "name") === "string" && typeof Reflect.get(value, "shutdown") === "function" && Reflect.get(value, "tracer") !== void 0;
8
+ }
9
+ class Telemetry {
10
+ tracer;
11
+ name;
12
+ _isInitialized;
13
+ _shutdownHandler;
14
+ static _initPromise;
15
+ constructor(config, options) {
16
+ const serviceName = config.serviceName ?? "dexto-service";
17
+ const tracerName = config.tracerName ?? serviceName;
18
+ this.name = serviceName;
19
+ this.tracer = trace.getTracer(tracerName);
20
+ this._shutdownHandler = options.shutdown;
21
+ this._isInitialized = options.initialized;
22
+ }
23
+ static async registerGlobal(options = {}) {
24
+ const existing = Telemetry.getGlobalInstance();
25
+ if (existing !== void 0) {
26
+ return existing;
27
+ }
28
+ if (Telemetry._initPromise !== void 0) {
29
+ return Telemetry._initPromise;
30
+ }
31
+ Telemetry._initPromise = Promise.resolve().then(() => {
32
+ const current = Telemetry.getGlobalInstance();
33
+ if (current !== void 0) {
34
+ return current;
35
+ }
36
+ const telemetry = new Telemetry(options.config ?? {}, {
37
+ initialized: options.initialized ?? true,
38
+ ...options.shutdown !== void 0 && { shutdown: options.shutdown }
39
+ });
40
+ Telemetry.setGlobalInstance(telemetry);
41
+ return telemetry;
42
+ });
43
+ return Telemetry._initPromise;
44
+ }
45
+ static getActiveSpan() {
46
+ return trace.getActiveSpan();
47
+ }
48
+ static get() {
49
+ const telemetry = Telemetry.getGlobalInstance();
50
+ if (telemetry === void 0) {
51
+ throw new Error("Telemetry not initialized. Call Telemetry.registerGlobal() first.");
52
+ }
53
+ return telemetry;
54
+ }
55
+ static hasGlobalInstance() {
56
+ return Telemetry.getGlobalInstance() !== void 0;
57
+ }
58
+ static async shutdownGlobal() {
59
+ const telemetry = Telemetry.getGlobalInstance();
60
+ if (telemetry !== void 0) {
61
+ await telemetry.shutdown();
62
+ }
63
+ Telemetry.setGlobalInstance(void 0);
64
+ Telemetry._initPromise = void 0;
65
+ }
66
+ static setBaggage(baggage, ctx = otlpContext.active()) {
67
+ const currentBaggage = Object.fromEntries(
68
+ propagation.getBaggage(ctx)?.getAllEntries() ?? []
69
+ );
70
+ return propagation.setBaggage(
71
+ ctx,
72
+ propagation.createBaggage({
73
+ ...currentBaggage,
74
+ ...baggage
75
+ })
76
+ );
77
+ }
78
+ static withContext(ctx, fn) {
79
+ return otlpContext.with(ctx, fn);
80
+ }
81
+ isInitialized() {
82
+ return this._isInitialized;
83
+ }
84
+ async forceFlush() {
85
+ const provider = trace.getTracerProvider();
86
+ const forceFlush = Reflect.get(provider, "forceFlush");
87
+ if (typeof forceFlush === "function") {
88
+ await Reflect.apply(forceFlush, provider, []);
89
+ }
90
+ }
91
+ async shutdown() {
92
+ try {
93
+ await this._shutdownHandler?.();
94
+ } finally {
95
+ this._isInitialized = false;
96
+ this._shutdownHandler = void 0;
97
+ Telemetry.setGlobalInstance(void 0);
98
+ Telemetry._initPromise = void 0;
99
+ }
100
+ }
101
+ static getGlobalInstance() {
102
+ const telemetry = Reflect.get(globalThis, "__TELEMETRY__");
103
+ return isGlobalTelemetryLike(telemetry) ? telemetry : void 0;
104
+ }
105
+ static setGlobalInstance(telemetry) {
106
+ if (telemetry === void 0) {
107
+ Reflect.deleteProperty(globalThis, "__TELEMETRY__");
108
+ return;
109
+ }
110
+ Reflect.set(globalThis, "__TELEMETRY__", telemetry);
111
+ }
112
+ }
113
+ export {
114
+ Telemetry
115
+ };
@@ -19,13 +19,16 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
19
19
  var telemetry_exports = {};
20
20
  __export(telemetry_exports, {
21
21
  OtelConfigurationSchema: () => import_schemas.OtelConfigurationSchema,
22
- Telemetry: () => import_telemetry.Telemetry
22
+ Telemetry: () => import_telemetry.Telemetry,
23
+ recordOperationSpan: () => import_operation_span.recordOperationSpan
23
24
  });
24
25
  module.exports = __toCommonJS(telemetry_exports);
25
26
  var import_telemetry = require("./telemetry.js");
26
27
  var import_schemas = require("./schemas.js");
28
+ var import_operation_span = require("./operation-span.js");
27
29
  // Annotate the CommonJS export names for ESM import in node:
28
30
  0 && (module.exports = {
29
31
  OtelConfigurationSchema,
30
- Telemetry
32
+ Telemetry,
33
+ recordOperationSpan
31
34
  });
@@ -1,4 +1,5 @@
1
1
  export { Telemetry, type TelemetryRegistrationOptions, type TelemetryShutdownHandler, } from './telemetry.js';
2
2
  export { OtelConfigurationSchema } from './schemas.js';
3
3
  export type { OtelConfiguration } from './schemas.js';
4
+ export { recordOperationSpan, type OperationSpanOptions } from './operation-span.js';
4
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/telemetry/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,KAAK,4BAA4B,EACjC,KAAK,wBAAwB,GAChC,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,YAAY,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/telemetry/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,KAAK,4BAA4B,EACjC,KAAK,wBAAwB,GAChC,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,YAAY,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,KAAK,oBAAoB,EAAE,MAAM,qBAAqB,CAAC"}
@@ -3,7 +3,9 @@ import {
3
3
  Telemetry
4
4
  } from "./telemetry.js";
5
5
  import { OtelConfigurationSchema } from "./schemas.js";
6
+ import { recordOperationSpan } from "./operation-span.js";
6
7
  export {
7
8
  OtelConfigurationSchema,
8
- Telemetry
9
+ Telemetry,
10
+ recordOperationSpan
9
11
  };
@@ -0,0 +1,73 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var operation_span_exports = {};
20
+ __export(operation_span_exports, {
21
+ recordOperationSpan: () => recordOperationSpan
22
+ });
23
+ module.exports = __toCommonJS(operation_span_exports);
24
+ var import_api = require("@opentelemetry/api");
25
+ var import_utils = require("./utils.js");
26
+ async function recordOperationSpan(options, operation, logger) {
27
+ const skipIfNoTelemetry = options.skipIfNoTelemetry ?? true;
28
+ if (skipIfNoTelemetry && !(0, import_utils.hasActiveTelemetry)(logger)) {
29
+ return operation();
30
+ }
31
+ const span = import_api.trace.getTracer(options.tracerName ?? "dexto").startSpan(options.name, { kind: import_api.SpanKind.INTERNAL });
32
+ const spanContext = import_api.trace.setSpan(import_api.context.active(), span);
33
+ (0, import_utils.addBaggageAttributesToSpan)(span, spanContext, logger);
34
+ if (options.componentName !== void 0) {
35
+ span.setAttribute("componentName", options.componentName);
36
+ }
37
+ setOperationSpanAttributes(span, options.attributes);
38
+ try {
39
+ const result = await import_api.context.with(spanContext, operation);
40
+ try {
41
+ setOperationSpanAttributes(span, options.resultAttributes?.(result));
42
+ } catch (error) {
43
+ logger?.debug("Failed to set OpenTelemetry result attributes", {
44
+ error: error instanceof Error ? error.message : String(error),
45
+ span: options.name
46
+ });
47
+ }
48
+ span.setStatus({ code: import_api.SpanStatusCode.OK });
49
+ return result;
50
+ } catch (error) {
51
+ if (error instanceof Error) {
52
+ span.recordException(error);
53
+ span.setStatus({ code: import_api.SpanStatusCode.ERROR, message: error.message });
54
+ } else {
55
+ span.setStatus({ code: import_api.SpanStatusCode.ERROR, message: String(error) });
56
+ }
57
+ throw error;
58
+ } finally {
59
+ span.end();
60
+ }
61
+ }
62
+ function setOperationSpanAttributes(span, attributes) {
63
+ if (span === void 0 || attributes === void 0) {
64
+ return;
65
+ }
66
+ for (const [key, value] of Object.entries(attributes)) {
67
+ span.setAttribute(key, value);
68
+ }
69
+ }
70
+ // Annotate the CommonJS export names for ESM import in node:
71
+ 0 && (module.exports = {
72
+ recordOperationSpan
73
+ });
@@ -0,0 +1,13 @@
1
+ import type { Logger } from '../logger/v2/types.js';
2
+ type OperationSpanAttributes = Record<string, string | number | boolean>;
3
+ export type OperationSpanOptions<T> = {
4
+ attributes?: OperationSpanAttributes;
5
+ componentName?: string;
6
+ name: string;
7
+ resultAttributes?: (result: T) => OperationSpanAttributes | undefined;
8
+ skipIfNoTelemetry?: boolean;
9
+ tracerName?: string;
10
+ };
11
+ export declare function recordOperationSpan<T>(options: OperationSpanOptions<T>, operation: () => T | Promise<T>, logger?: Logger): Promise<T>;
12
+ export {};
13
+ //# sourceMappingURL=operation-span.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"operation-span.d.ts","sourceRoot":"","sources":["../../src/telemetry/operation-span.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAGpD,KAAK,uBAAuB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC;AAEzE,MAAM,MAAM,oBAAoB,CAAC,CAAC,IAAI;IAClC,UAAU,CAAC,EAAE,uBAAuB,CAAC;IACrC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,gBAAgB,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,uBAAuB,GAAG,SAAS,CAAC;IACtE,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,wBAAsB,mBAAmB,CAAC,CAAC,EACvC,OAAO,EAAE,oBAAoB,CAAC,CAAC,CAAC,EAChC,SAAS,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,EAC/B,MAAM,CAAC,EAAE,MAAM,GAChB,OAAO,CAAC,CAAC,CAAC,CAyCZ"}
@@ -0,0 +1,50 @@
1
+ import "../chunk-C6A6W6XS.js";
2
+ import { context, SpanKind, SpanStatusCode, trace } from "@opentelemetry/api";
3
+ import { addBaggageAttributesToSpan, hasActiveTelemetry } from "./utils.js";
4
+ async function recordOperationSpan(options, operation, logger) {
5
+ const skipIfNoTelemetry = options.skipIfNoTelemetry ?? true;
6
+ if (skipIfNoTelemetry && !hasActiveTelemetry(logger)) {
7
+ return operation();
8
+ }
9
+ const span = trace.getTracer(options.tracerName ?? "dexto").startSpan(options.name, { kind: SpanKind.INTERNAL });
10
+ const spanContext = trace.setSpan(context.active(), span);
11
+ addBaggageAttributesToSpan(span, spanContext, logger);
12
+ if (options.componentName !== void 0) {
13
+ span.setAttribute("componentName", options.componentName);
14
+ }
15
+ setOperationSpanAttributes(span, options.attributes);
16
+ try {
17
+ const result = await context.with(spanContext, operation);
18
+ try {
19
+ setOperationSpanAttributes(span, options.resultAttributes?.(result));
20
+ } catch (error) {
21
+ logger?.debug("Failed to set OpenTelemetry result attributes", {
22
+ error: error instanceof Error ? error.message : String(error),
23
+ span: options.name
24
+ });
25
+ }
26
+ span.setStatus({ code: SpanStatusCode.OK });
27
+ return result;
28
+ } catch (error) {
29
+ if (error instanceof Error) {
30
+ span.recordException(error);
31
+ span.setStatus({ code: SpanStatusCode.ERROR, message: error.message });
32
+ } else {
33
+ span.setStatus({ code: SpanStatusCode.ERROR, message: String(error) });
34
+ }
35
+ throw error;
36
+ } finally {
37
+ span.end();
38
+ }
39
+ }
40
+ function setOperationSpanAttributes(span, attributes) {
41
+ if (span === void 0 || attributes === void 0) {
42
+ return;
43
+ }
44
+ for (const [key, value] of Object.entries(attributes)) {
45
+ span.setAttribute(key, value);
46
+ }
47
+ }
48
+ export {
49
+ recordOperationSpan
50
+ };
@@ -32,7 +32,6 @@ __export(telemetry_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(telemetry_exports);
34
34
  var import_api = require("@opentelemetry/api");
35
- var import_logger = require("../logger/logger.js");
36
35
  var import_errors = require("./errors.js");
37
36
  var import_DextoRuntimeError = require("../errors/DextoRuntimeError.js");
38
37
  class Telemetry {
@@ -318,7 +317,7 @@ class Telemetry {
318
317
  }
319
318
  } catch (error) {
320
319
  const errorMsg = error instanceof Error ? error.message : String(error);
321
- import_logger.logger.warn(`Telemetry shutdown failed to flush spans (non-blocking): ${errorMsg}`);
320
+ console.warn(`Telemetry shutdown failed to flush spans (non-blocking): ${errorMsg}`);
322
321
  } finally {
323
322
  this.cleanupAfterShutdown();
324
323
  }
@@ -326,7 +325,7 @@ class Telemetry {
326
325
  cleanupAfterShutdown() {
327
326
  this._isInitialized = false;
328
327
  globalThis.__TELEMETRY__ = void 0;
329
- if (Telemetry._signalHandlers) {
328
+ if (Telemetry._signalHandlers && typeof process !== "undefined") {
330
329
  process.off("SIGTERM", Telemetry._signalHandlers.sigterm);
331
330
  process.off("SIGINT", Telemetry._signalHandlers.sigint);
332
331
  Telemetry._signalHandlers = void 0;
@@ -1 +1 @@
1
- {"version":3,"file":"telemetry.d.ts","sourceRoot":"","sources":["../../src/telemetry/telemetry.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AACxE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAUtD,MAAM,MAAM,wBAAwB,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;AAE3D,MAAM,MAAM,4BAA4B,GAAG;IACvC,MAAM,CAAC,EAAE,iBAAiB,GAAG,SAAS,CAAC;IACvC,WAAW,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAClC,QAAQ,CAAC,EAAE,wBAAwB,GAAG,SAAS,CAAC;CACnD,CAAC;AASF,OAAO,CAAC,MAAM,CAAC;IACX,IAAI,aAAa,EAAE,SAAS,GAAG,SAAS,CAAC;CAC5C;AAED;;;;;;;;GAQG;AACH,qBAAa,SAAS;IACX,MAAM,EAAE,MAAM,CAA4B;IACjD,IAAI,EAAE,MAAM,CAAmB;IAC/B,OAAO,CAAC,cAAc,CAAkB;IACxC,OAAO,CAAC,IAAI,CAAC,CAA0B;IACvC,OAAO,CAAC,gBAAgB,CAAC,CAAuC;IAChE,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,CAAiC;IAC7D,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC,CAA0D;IAEzF,OAAO;mBAWc,kBAAkB;IA0DvC;;;;;OAKG;WACU,IAAI,CACb,MAAM,GAAE,iBAAsB,EAC9B,QAAQ,CAAC,EAAE,OAAO,+BAA+B,EAAE,YAAY,GAChE,OAAO,CAAC,SAAS,CAAC;IAiIrB;;;;OAIG;WACU,cAAc,CAAC,OAAO,GAAE,4BAAiC,GAAG,OAAO,CAAC,SAAS,CAAC;IAiC3F,MAAM,CAAC,aAAa;IAKpB;;;;OAIG;IACH,MAAM,CAAC,GAAG,IAAI,SAAS;IAOvB;;;OAGG;IACH,MAAM,CAAC,iBAAiB,IAAI,OAAO;IAInC;;;;;OAKG;WACU,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC;IAS5C;;;OAGG;IACI,aAAa,IAAI,OAAO;IAI/B,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC,EAAE,GAAG,GAAE,OAA8B;IAc5F,MAAM,CAAC,WAAW,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,IAAI;IAI/C;;;OAGG;IACU,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAUxC;;;;;;;;;OASG;IACU,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAmBtC,OAAO,CAAC,oBAAoB;CAiB/B"}
1
+ {"version":3,"file":"telemetry.d.ts","sourceRoot":"","sources":["../../src/telemetry/telemetry.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AACxE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAStD,MAAM,MAAM,wBAAwB,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;AAE3D,MAAM,MAAM,4BAA4B,GAAG;IACvC,MAAM,CAAC,EAAE,iBAAiB,GAAG,SAAS,CAAC;IACvC,WAAW,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAClC,QAAQ,CAAC,EAAE,wBAAwB,GAAG,SAAS,CAAC;CACnD,CAAC;AASF,OAAO,CAAC,MAAM,CAAC;IACX,IAAI,aAAa,EAAE,SAAS,GAAG,SAAS,CAAC;CAC5C;AAED;;;;;;;;GAQG;AACH,qBAAa,SAAS;IACX,MAAM,EAAE,MAAM,CAA4B;IACjD,IAAI,EAAE,MAAM,CAAmB;IAC/B,OAAO,CAAC,cAAc,CAAkB;IACxC,OAAO,CAAC,IAAI,CAAC,CAA0B;IACvC,OAAO,CAAC,gBAAgB,CAAC,CAAuC;IAChE,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,CAAiC;IAC7D,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC,CAA0D;IAEzF,OAAO;mBAWc,kBAAkB;IA0DvC;;;;;OAKG;WACU,IAAI,CACb,MAAM,GAAE,iBAAsB,EAC9B,QAAQ,CAAC,EAAE,OAAO,+BAA+B,EAAE,YAAY,GAChE,OAAO,CAAC,SAAS,CAAC;IAiIrB;;;;OAIG;WACU,cAAc,CAAC,OAAO,GAAE,4BAAiC,GAAG,OAAO,CAAC,SAAS,CAAC;IAiC3F,MAAM,CAAC,aAAa;IAKpB;;;;OAIG;IACH,MAAM,CAAC,GAAG,IAAI,SAAS;IAOvB;;;OAGG;IACH,MAAM,CAAC,iBAAiB,IAAI,OAAO;IAInC;;;;;OAKG;WACU,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC;IAS5C;;;OAGG;IACI,aAAa,IAAI,OAAO;IAI/B,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC,EAAE,GAAG,GAAE,OAA8B;IAc5F,MAAM,CAAC,WAAW,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,IAAI;IAI/C;;;OAGG;IACU,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAUxC;;;;;;;;;OASG;IACU,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAmBtC,OAAO,CAAC,oBAAoB;CAiB/B"}
@@ -1,6 +1,5 @@
1
1
  import "../chunk-C6A6W6XS.js";
2
2
  import { context as otlpContext, trace, propagation } from "@opentelemetry/api";
3
- import { logger } from "../logger/logger.js";
4
3
  import { TelemetryError } from "./errors.js";
5
4
  import { DextoRuntimeError } from "../errors/DextoRuntimeError.js";
6
5
  class Telemetry {
@@ -286,7 +285,7 @@ class Telemetry {
286
285
  }
287
286
  } catch (error) {
288
287
  const errorMsg = error instanceof Error ? error.message : String(error);
289
- logger.warn(`Telemetry shutdown failed to flush spans (non-blocking): ${errorMsg}`);
288
+ console.warn(`Telemetry shutdown failed to flush spans (non-blocking): ${errorMsg}`);
290
289
  } finally {
291
290
  this.cleanupAfterShutdown();
292
291
  }
@@ -294,7 +293,7 @@ class Telemetry {
294
293
  cleanupAfterShutdown() {
295
294
  this._isInitialized = false;
296
295
  globalThis.__TELEMETRY__ = void 0;
297
- if (Telemetry._signalHandlers) {
296
+ if (Telemetry._signalHandlers && typeof process !== "undefined") {
298
297
  process.off("SIGTERM", Telemetry._signalHandlers.sigterm);
299
298
  process.off("SIGINT", Telemetry._signalHandlers.sigint);
300
299
  Telemetry._signalHandlers = void 0;