@microsoft/agents-a365-observability 0.1.0-preview.123 → 0.1.0-preview.125

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 (93) hide show
  1. package/dist/cjs/ObservabilityBuilder.d.ts +8 -0
  2. package/dist/cjs/ObservabilityBuilder.d.ts.map +1 -1
  3. package/dist/cjs/ObservabilityBuilder.js +17 -5
  4. package/dist/cjs/ObservabilityBuilder.js.map +1 -1
  5. package/dist/cjs/index.d.ts +2 -2
  6. package/dist/cjs/index.d.ts.map +1 -1
  7. package/dist/cjs/index.js +5 -6
  8. package/dist/cjs/index.js.map +1 -1
  9. package/dist/cjs/tracing/constants.d.ts +2 -1
  10. package/dist/cjs/tracing/constants.d.ts.map +1 -1
  11. package/dist/cjs/tracing/constants.js +1 -0
  12. package/dist/cjs/tracing/constants.js.map +1 -1
  13. package/dist/cjs/tracing/context/trace-context-propagation.d.ts +7 -7
  14. package/dist/cjs/tracing/context/trace-context-propagation.d.ts.map +1 -1
  15. package/dist/cjs/tracing/context/trace-context-propagation.js +9 -9
  16. package/dist/cjs/tracing/context/trace-context-propagation.js.map +1 -1
  17. package/dist/cjs/tracing/contracts.d.ts +48 -15
  18. package/dist/cjs/tracing/contracts.d.ts.map +1 -1
  19. package/dist/cjs/tracing/contracts.js +2 -3
  20. package/dist/cjs/tracing/contracts.js.map +1 -1
  21. package/dist/cjs/tracing/middleware/BaggageBuilder.d.ts +7 -0
  22. package/dist/cjs/tracing/middleware/BaggageBuilder.d.ts.map +1 -1
  23. package/dist/cjs/tracing/middleware/BaggageBuilder.js +16 -0
  24. package/dist/cjs/tracing/middleware/BaggageBuilder.js.map +1 -1
  25. package/dist/cjs/tracing/scopes/ExecuteToolScope.d.ts +8 -18
  26. package/dist/cjs/tracing/scopes/ExecuteToolScope.d.ts.map +1 -1
  27. package/dist/cjs/tracing/scopes/ExecuteToolScope.js +20 -22
  28. package/dist/cjs/tracing/scopes/ExecuteToolScope.js.map +1 -1
  29. package/dist/cjs/tracing/scopes/InferenceScope.d.ts +8 -14
  30. package/dist/cjs/tracing/scopes/InferenceScope.d.ts.map +1 -1
  31. package/dist/cjs/tracing/scopes/InferenceScope.js +20 -19
  32. package/dist/cjs/tracing/scopes/InferenceScope.js.map +1 -1
  33. package/dist/cjs/tracing/scopes/InvokeAgentScope.d.ts +11 -14
  34. package/dist/cjs/tracing/scopes/InvokeAgentScope.d.ts.map +1 -1
  35. package/dist/cjs/tracing/scopes/InvokeAgentScope.js +42 -41
  36. package/dist/cjs/tracing/scopes/InvokeAgentScope.js.map +1 -1
  37. package/dist/cjs/tracing/scopes/OpenTelemetryScope.d.ts +15 -17
  38. package/dist/cjs/tracing/scopes/OpenTelemetryScope.d.ts.map +1 -1
  39. package/dist/cjs/tracing/scopes/OpenTelemetryScope.js +37 -30
  40. package/dist/cjs/tracing/scopes/OpenTelemetryScope.js.map +1 -1
  41. package/dist/cjs/tracing/scopes/OutputScope.d.ts +7 -13
  42. package/dist/cjs/tracing/scopes/OutputScope.d.ts.map +1 -1
  43. package/dist/cjs/tracing/scopes/OutputScope.js +19 -17
  44. package/dist/cjs/tracing/scopes/OutputScope.js.map +1 -1
  45. package/dist/cjs/version.d.ts +1 -1
  46. package/dist/cjs/version.js +1 -1
  47. package/dist/esm/ObservabilityBuilder.d.ts +8 -0
  48. package/dist/esm/ObservabilityBuilder.d.ts.map +1 -1
  49. package/dist/esm/ObservabilityBuilder.js +18 -6
  50. package/dist/esm/ObservabilityBuilder.js.map +1 -1
  51. package/dist/esm/index.d.ts +2 -2
  52. package/dist/esm/index.d.ts.map +1 -1
  53. package/dist/esm/index.js +3 -4
  54. package/dist/esm/index.js.map +1 -1
  55. package/dist/esm/tracing/constants.d.ts +2 -1
  56. package/dist/esm/tracing/constants.d.ts.map +1 -1
  57. package/dist/esm/tracing/constants.js +1 -0
  58. package/dist/esm/tracing/constants.js.map +1 -1
  59. package/dist/esm/tracing/context/trace-context-propagation.d.ts +7 -7
  60. package/dist/esm/tracing/context/trace-context-propagation.d.ts.map +1 -1
  61. package/dist/esm/tracing/context/trace-context-propagation.js +7 -7
  62. package/dist/esm/tracing/context/trace-context-propagation.js.map +1 -1
  63. package/dist/esm/tracing/contracts.d.ts +48 -15
  64. package/dist/esm/tracing/contracts.d.ts.map +1 -1
  65. package/dist/esm/tracing/contracts.js +2 -3
  66. package/dist/esm/tracing/contracts.js.map +1 -1
  67. package/dist/esm/tracing/middleware/BaggageBuilder.d.ts +7 -0
  68. package/dist/esm/tracing/middleware/BaggageBuilder.d.ts.map +1 -1
  69. package/dist/esm/tracing/middleware/BaggageBuilder.js +16 -0
  70. package/dist/esm/tracing/middleware/BaggageBuilder.js.map +1 -1
  71. package/dist/esm/tracing/scopes/ExecuteToolScope.d.ts +8 -18
  72. package/dist/esm/tracing/scopes/ExecuteToolScope.d.ts.map +1 -1
  73. package/dist/esm/tracing/scopes/ExecuteToolScope.js +20 -22
  74. package/dist/esm/tracing/scopes/ExecuteToolScope.js.map +1 -1
  75. package/dist/esm/tracing/scopes/InferenceScope.d.ts +8 -14
  76. package/dist/esm/tracing/scopes/InferenceScope.d.ts.map +1 -1
  77. package/dist/esm/tracing/scopes/InferenceScope.js +20 -19
  78. package/dist/esm/tracing/scopes/InferenceScope.js.map +1 -1
  79. package/dist/esm/tracing/scopes/InvokeAgentScope.d.ts +11 -14
  80. package/dist/esm/tracing/scopes/InvokeAgentScope.d.ts.map +1 -1
  81. package/dist/esm/tracing/scopes/InvokeAgentScope.js +42 -41
  82. package/dist/esm/tracing/scopes/InvokeAgentScope.js.map +1 -1
  83. package/dist/esm/tracing/scopes/OpenTelemetryScope.d.ts +15 -17
  84. package/dist/esm/tracing/scopes/OpenTelemetryScope.d.ts.map +1 -1
  85. package/dist/esm/tracing/scopes/OpenTelemetryScope.js +38 -31
  86. package/dist/esm/tracing/scopes/OpenTelemetryScope.js.map +1 -1
  87. package/dist/esm/tracing/scopes/OutputScope.d.ts +7 -13
  88. package/dist/esm/tracing/scopes/OutputScope.d.ts.map +1 -1
  89. package/dist/esm/tracing/scopes/OutputScope.js +19 -17
  90. package/dist/esm/tracing/scopes/OutputScope.js.map +1 -1
  91. package/dist/esm/version.d.ts +1 -1
  92. package/dist/esm/version.js +1 -1
  93. package/package.json +2 -2
@@ -1,30 +1,20 @@
1
- import { SpanKind, TimeInput } from '@opentelemetry/api';
2
1
  import { OpenTelemetryScope } from './OpenTelemetryScope';
3
- import { ToolCallDetails, AgentDetails, TenantDetails, Channel, CallerDetails } from '../contracts';
4
- import { ParentContext } from '../context/trace-context-propagation';
2
+ import { ToolCallDetails, AgentDetails, UserDetails, Request, SpanDetails } from '../contracts';
5
3
  /**
6
4
  * Provides OpenTelemetry tracing scope for AI tool execution operations.
7
5
  */
8
6
  export declare class ExecuteToolScope extends OpenTelemetryScope {
9
7
  /**
10
8
  * Creates and starts a new scope for tool execution tracing.
11
- * @param details The tool call details
12
- * @param agentDetails The agent details
13
- * @param tenantDetails The tenant details
14
- * @param conversationId Optional conversation id to tag on the span (`gen_ai.conversation.id`).
15
- * @param channel Optional channel; only `name` (channel name) and `description` (channel link/URL) are used for tagging.
16
- * @param parentContext Optional parent context for cross-async-boundary tracing.
17
- * Accepts a ParentSpanRef (manual traceId/spanId) or an OTel Context (e.g. from extractTraceContext).
18
- * @param startTime Optional explicit start time (ms epoch, Date, or HrTime). Useful when recording a
19
- * tool call after execution has already completed.
20
- * @param endTime Optional explicit end time (ms epoch, Date, or HrTime). When provided, the span will
21
- * use this timestamp when disposed instead of the current wall-clock time.
22
- * @param callerDetails Optional caller details.
23
- * @param spanKind Optional span kind override. Defaults to `SpanKind.INTERNAL`.
24
- * Use `SpanKind.CLIENT` when the tool calls an external service.
9
+ *
10
+ * @param request Request payload (channel, conversationId, content, sessionId).
11
+ * @param details The tool call details (name, type, args, call id, etc.).
12
+ * @param agentDetails The agent executing the tool. Tenant ID is derived from `agentDetails.tenantId`.
13
+ * @param userDetails Optional human caller identity.
14
+ * @param spanDetails Optional span configuration (parentContext, startTime, endTime, spanLinks). Any provided spanKind is ignored; ExecuteToolScope always uses SpanKind.INTERNAL.
25
15
  * @returns A new ExecuteToolScope instance.
26
16
  */
27
- static start(details: ToolCallDetails, agentDetails: AgentDetails, tenantDetails: TenantDetails, conversationId?: string, channel?: Pick<Channel, "name" | "description">, parentContext?: ParentContext, startTime?: TimeInput, endTime?: TimeInput, callerDetails?: CallerDetails, spanKind?: SpanKind): ExecuteToolScope;
17
+ static start(request: Request, details: ToolCallDetails, agentDetails: AgentDetails, userDetails?: UserDetails, spanDetails?: SpanDetails): ExecuteToolScope;
28
18
  private constructor();
29
19
  /**
30
20
  * Records response information for telemetry tracking.
@@ -1 +1 @@
1
- {"version":3,"file":"ExecuteToolScope.d.ts","sourceRoot":"","sources":["../../../../src/tracing/scopes/ExecuteToolScope.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,aAAa,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AACpG,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAGrE;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,kBAAkB;IACtD;;;;;;;;;;;;;;;;;OAiBG;WACW,KAAK,CACjB,OAAO,EAAE,eAAe,EACxB,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAE,aAAa,EAC5B,cAAc,CAAC,EAAE,MAAM,EACvB,OAAO,CAAC,EAAE,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,aAAa,CAAC,EAC/C,aAAa,CAAC,EAAE,aAAa,EAC7B,SAAS,CAAC,EAAE,SAAS,EACrB,OAAO,CAAC,EAAE,SAAS,EACnB,aAAa,CAAC,EAAE,aAAa,EAC7B,QAAQ,CAAC,EAAE,QAAQ,GAClB,gBAAgB;IAInB,OAAO;IAgDP;;;OAGG;IACI,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;CAG9C"}
1
+ {"version":3,"file":"ExecuteToolScope.d.ts","sourceRoot":"","sources":["../../../../src/tracing/scopes/ExecuteToolScope.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EACL,eAAe,EACf,YAAY,EACZ,WAAW,EACX,OAAO,EACP,WAAW,EACZ,MAAM,cAAc,CAAC;AAGtB;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,kBAAkB;IACtD;;;;;;;;;OASG;WACW,KAAK,CACjB,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,eAAe,EACxB,YAAY,EAAE,YAAY,EAC1B,WAAW,CAAC,EAAE,WAAW,EACzB,WAAW,CAAC,EAAE,WAAW,GACxB,gBAAgB;IAInB,OAAO;IA8CP;;;OAGG;IACI,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;CAG9C"}
@@ -12,37 +12,35 @@ const constants_1 = require("../constants");
12
12
  class ExecuteToolScope extends OpenTelemetryScope_1.OpenTelemetryScope {
13
13
  /**
14
14
  * Creates and starts a new scope for tool execution tracing.
15
- * @param details The tool call details
16
- * @param agentDetails The agent details
17
- * @param tenantDetails The tenant details
18
- * @param conversationId Optional conversation id to tag on the span (`gen_ai.conversation.id`).
19
- * @param channel Optional channel; only `name` (channel name) and `description` (channel link/URL) are used for tagging.
20
- * @param parentContext Optional parent context for cross-async-boundary tracing.
21
- * Accepts a ParentSpanRef (manual traceId/spanId) or an OTel Context (e.g. from extractTraceContext).
22
- * @param startTime Optional explicit start time (ms epoch, Date, or HrTime). Useful when recording a
23
- * tool call after execution has already completed.
24
- * @param endTime Optional explicit end time (ms epoch, Date, or HrTime). When provided, the span will
25
- * use this timestamp when disposed instead of the current wall-clock time.
26
- * @param callerDetails Optional caller details.
27
- * @param spanKind Optional span kind override. Defaults to `SpanKind.INTERNAL`.
28
- * Use `SpanKind.CLIENT` when the tool calls an external service.
15
+ *
16
+ * @param request Request payload (channel, conversationId, content, sessionId).
17
+ * @param details The tool call details (name, type, args, call id, etc.).
18
+ * @param agentDetails The agent executing the tool. Tenant ID is derived from `agentDetails.tenantId`.
19
+ * @param userDetails Optional human caller identity.
20
+ * @param spanDetails Optional span configuration (parentContext, startTime, endTime, spanLinks). Any provided spanKind is ignored; ExecuteToolScope always uses SpanKind.INTERNAL.
29
21
  * @returns A new ExecuteToolScope instance.
30
22
  */
31
- static start(details, agentDetails, tenantDetails, conversationId, channel, parentContext, startTime, endTime, callerDetails, spanKind) {
32
- return new ExecuteToolScope(details, agentDetails, tenantDetails, conversationId, channel, parentContext, startTime, endTime, callerDetails, spanKind);
23
+ static start(request, details, agentDetails, userDetails, spanDetails) {
24
+ return new ExecuteToolScope(request, details, agentDetails, userDetails, spanDetails);
33
25
  }
34
- constructor(details, agentDetails, tenantDetails, conversationId, channel, parentContext, startTime, endTime, callerDetails, spanKind) {
35
- super(spanKind ?? api_1.SpanKind.INTERNAL, constants_1.OpenTelemetryConstants.EXECUTE_TOOL_OPERATION_NAME, `${constants_1.OpenTelemetryConstants.EXECUTE_TOOL_OPERATION_NAME} ${details.toolName}`, agentDetails, tenantDetails, parentContext, startTime, endTime, callerDetails);
36
- // Destructure the details object to match C# pattern
26
+ constructor(request, details, agentDetails, userDetails, spanDetails) {
27
+ // Validate tenantId is present (required for telemetry)
28
+ if (!agentDetails.tenantId) {
29
+ throw new Error('ExecuteToolScope: tenantId is required on agentDetails');
30
+ }
31
+ // spanKind for ExecuteToolScope is always INTERNAL
32
+ const resolvedSpanDetails = { ...spanDetails, spanKind: api_1.SpanKind.INTERNAL };
33
+ super(constants_1.OpenTelemetryConstants.EXECUTE_TOOL_OPERATION_NAME, `${constants_1.OpenTelemetryConstants.EXECUTE_TOOL_OPERATION_NAME} ${details.toolName}`, agentDetails, resolvedSpanDetails, userDetails);
34
+ // Destructure the details object
37
35
  const { toolName, arguments: args, toolCallId, description, toolType, endpoint } = details;
38
36
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_NAME_KEY, toolName);
39
37
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_ARGS_KEY, args);
40
38
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_TYPE_KEY, toolType);
41
39
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_CALL_ID_KEY, toolCallId);
42
40
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_DESCRIPTION_KEY, description);
43
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CONVERSATION_ID_KEY, conversationId);
44
- this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_NAME_KEY, channel?.name);
45
- this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_LINK_KEY, channel?.description);
41
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CONVERSATION_ID_KEY, request.conversationId);
42
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_NAME_KEY, request.channel?.name);
43
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_LINK_KEY, request.channel?.description);
46
44
  // Set endpoint information if provided
47
45
  if (endpoint) {
48
46
  this.setTagMaybe(constants_1.OpenTelemetryConstants.SERVER_ADDRESS_KEY, endpoint.host);
@@ -1 +1 @@
1
- {"version":3,"file":"ExecuteToolScope.js","sourceRoot":"","sources":["../../../../src/tracing/scopes/ExecuteToolScope.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;;AAElC,4CAAyD;AACzD,6DAA0D;AAG1D,4CAAsD;AAEtD;;GAEG;AACH,MAAa,gBAAiB,SAAQ,uCAAkB;IACtD;;;;;;;;;;;;;;;;;OAiBG;IACI,MAAM,CAAC,KAAK,CACjB,OAAwB,EACxB,YAA0B,EAC1B,aAA4B,EAC5B,cAAuB,EACvB,OAA+C,EAC/C,aAA6B,EAC7B,SAAqB,EACrB,OAAmB,EACnB,aAA6B,EAC7B,QAAmB;QAEnB,OAAO,IAAI,gBAAgB,CAAC,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,cAAc,EAAE,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,OAAO,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;IACzJ,CAAC;IAED,YACE,OAAwB,EACxB,YAA0B,EAC1B,aAA4B,EAC5B,cAAuB,EACvB,OAA+C,EAC/C,aAA6B,EAC7B,SAAqB,EACrB,OAAmB,EACnB,aAA6B,EAC7B,QAAmB;QAEnB,KAAK,CACH,QAAQ,IAAI,cAAQ,CAAC,QAAQ,EAC7B,kCAAsB,CAAC,2BAA2B,EAClD,GAAG,kCAAsB,CAAC,2BAA2B,IAAI,OAAO,CAAC,QAAQ,EAAE,EAC3E,YAAY,EACZ,aAAa,EACb,aAAa,EACb,SAAS,EACT,OAAO,EACP,aAAa,CACd,CAAC;QAEF,qDAAqD;QACrD,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;QAE3F,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,oBAAoB,EAAE,QAAQ,CAAC,CAAC;QACxE,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,oBAAoB,EAAE,IAAI,CAAC,CAAC;QACpE,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,oBAAoB,EAAE,QAAQ,CAAC,CAAC;QACxE,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,uBAAuB,EAAE,UAAU,CAAC,CAAC;QAC7E,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,2BAA2B,EAAE,WAAW,CAAC,CAAC;QAClF,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,0BAA0B,EAAE,cAAc,CAAC,CAAC;QACpF,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,gBAAgB,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;QACzE,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,gBAAgB,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;QAGhF,uCAAuC;QACvC,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,kBAAkB,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;YAE3E,oEAAoE;YACpE,IAAI,QAAQ,CAAC,IAAI,IAAI,QAAQ,CAAC,IAAI,KAAK,GAAG,EAAE,CAAC;gBAC3C,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,eAAe,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC1E,CAAC;QACH,CAAC;IACH,CAAC;IAED;;;OAGG;IACI,cAAc,CAAC,QAAgB;QACpC,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,2BAA2B,EAAE,QAAQ,CAAC,CAAC;IACjF,CAAC;CACF;AAzFD,4CAyFC"}
1
+ {"version":3,"file":"ExecuteToolScope.js","sourceRoot":"","sources":["../../../../src/tracing/scopes/ExecuteToolScope.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;;AAElC,4CAA8C;AAC9C,6DAA0D;AAQ1D,4CAAsD;AAEtD;;GAEG;AACH,MAAa,gBAAiB,SAAQ,uCAAkB;IACtD;;;;;;;;;OASG;IACI,MAAM,CAAC,KAAK,CACjB,OAAgB,EAChB,OAAwB,EACxB,YAA0B,EAC1B,WAAyB,EACzB,WAAyB;QAEzB,OAAO,IAAI,gBAAgB,CAAC,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;IACxF,CAAC;IAED,YACE,OAAgB,EAChB,OAAwB,EACxB,YAA0B,EAC1B,WAAyB,EACzB,WAAyB;QAEzB,wDAAwD;QACxD,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;YAC3B,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;QAC5E,CAAC;QAED,mDAAmD;QACnD,MAAM,mBAAmB,GAAgB,EAAE,GAAG,WAAW,EAAE,QAAQ,EAAE,cAAQ,CAAC,QAAQ,EAAE,CAAC;QAEzF,KAAK,CACH,kCAAsB,CAAC,2BAA2B,EAClD,GAAG,kCAAsB,CAAC,2BAA2B,IAAI,OAAO,CAAC,QAAQ,EAAE,EAC3E,YAAY,EACZ,mBAAmB,EACnB,WAAW,CACZ,CAAC;QAEF,iCAAiC;QACjC,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;QAE3F,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,oBAAoB,EAAE,QAAQ,CAAC,CAAC;QACxE,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,oBAAoB,EAAE,IAAI,CAAC,CAAC;QACpE,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,oBAAoB,EAAE,QAAQ,CAAC,CAAC;QACxE,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,uBAAuB,EAAE,UAAU,CAAC,CAAC;QAC7E,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,2BAA2B,EAAE,WAAW,CAAC,CAAC;QAClF,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,0BAA0B,EAAE,OAAO,CAAC,cAAc,CAAC,CAAC;QAC5F,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,gBAAgB,EAAE,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACjF,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,gBAAgB,EAAE,OAAO,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAExF,uCAAuC;QACvC,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,kBAAkB,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;YAE3E,oEAAoE;YACpE,IAAI,QAAQ,CAAC,IAAI,IAAI,QAAQ,CAAC,IAAI,KAAK,GAAG,EAAE,CAAC;gBAC3C,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,eAAe,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC1E,CAAC;QACH,CAAC;IACH,CAAC;IAED;;;OAGG;IACI,cAAc,CAAC,QAAgB;QACpC,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,2BAA2B,EAAE,QAAQ,CAAC,CAAC;IACjF,CAAC;CACF;AA1ED,4CA0EC"}
@@ -1,26 +1,20 @@
1
- import { TimeInput } from '@opentelemetry/api';
2
1
  import { OpenTelemetryScope } from './OpenTelemetryScope';
3
- import { InferenceDetails, AgentDetails, TenantDetails, Channel, CallerDetails } from '../contracts';
4
- import { ParentContext } from '../context/trace-context-propagation';
2
+ import { InferenceDetails, AgentDetails, UserDetails, Request, SpanDetails } from '../contracts';
5
3
  /**
6
4
  * Provides OpenTelemetry tracing scope for generative AI inference operations.
7
5
  */
8
6
  export declare class InferenceScope extends OpenTelemetryScope {
9
7
  /**
10
8
  * Creates and starts a new scope for inference tracing.
11
- * @param details The inference call details
12
- * @param agentDetails The agent details
13
- * @param tenantDetails The tenant details
14
- * @param conversationId Optional conversation id to tag on the span (`gen_ai.conversation.id`).
15
- * @param channel Optional channel; only `name` (channel name) and `description` (channel link/URL) are used for tagging.
16
- * @param parentContext Optional parent context for cross-async-boundary tracing.
17
- * Accepts a ParentSpanRef (manual traceId/spanId) or an OTel Context (e.g. from extractTraceContext).
18
- * @param startTime Optional explicit start time (ms epoch, Date, or HrTime).
19
- * @param endTime Optional explicit end time (ms epoch, Date, or HrTime).
20
- * @param callerDetails Optional caller details.
9
+ *
10
+ * @param request Request payload (channel, conversationId, content, sessionId).
11
+ * @param details The inference call details (model, provider, tokens, etc.).
12
+ * @param agentDetails The agent performing the inference. Tenant ID is derived from `agentDetails.tenantId`.
13
+ * @param userDetails Optional human caller identity.
14
+ * @param spanDetails Optional span configuration (parentContext, startTime, endTime, spanLinks). Note: `spanKind` is ignored; InferenceScope always uses `SpanKind.CLIENT`.
21
15
  * @returns A new InferenceScope instance
22
16
  */
23
- static start(details: InferenceDetails, agentDetails: AgentDetails, tenantDetails: TenantDetails, conversationId?: string, channel?: Pick<Channel, "name" | "description">, parentContext?: ParentContext, startTime?: TimeInput, endTime?: TimeInput, callerDetails?: CallerDetails): InferenceScope;
17
+ static start(request: Request, details: InferenceDetails, agentDetails: AgentDetails, userDetails?: UserDetails, spanDetails?: SpanDetails): InferenceScope;
24
18
  private constructor();
25
19
  /**
26
20
  * Records the input messages for telemetry tracking.
@@ -1 +1 @@
1
- {"version":3,"file":"InferenceScope.d.ts","sourceRoot":"","sources":["../../../../src/tracing/scopes/InferenceScope.ts"],"names":[],"mappings":"AAGA,OAAO,EAAY,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE1D,OAAO,EACL,gBAAgB,EAChB,YAAY,EACZ,aAAa,EACb,OAAO,EACP,aAAa,EACd,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAErE;;GAEG;AACH,qBAAa,cAAe,SAAQ,kBAAkB;IACpD;;;;;;;;;;;;;OAaG;WACW,KAAK,CACjB,OAAO,EAAE,gBAAgB,EACzB,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAE,aAAa,EAC5B,cAAc,CAAC,EAAE,MAAM,EACvB,OAAO,CAAC,EAAE,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,aAAa,CAAC,EAC/C,aAAa,CAAC,EAAE,aAAa,EAC7B,SAAS,CAAC,EAAE,SAAS,EACrB,OAAO,CAAC,EAAE,SAAS,EACnB,aAAa,CAAC,EAAE,aAAa,GAC5B,cAAc;IAIjB,OAAO;IA8CP;;;OAGG;IACI,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI;IAIpD;;;OAGG;IACI,oBAAoB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI;IAIrD;;;OAGG;IACI,iBAAiB,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI;IAInD;;;OAGG;IACI,kBAAkB,CAAC,YAAY,EAAE,MAAM,GAAG,IAAI;IAIrD;;;OAGG;IACI,mBAAmB,CAAC,aAAa,EAAE,MAAM,EAAE,GAAG,IAAI;CAM1D"}
1
+ {"version":3,"file":"InferenceScope.d.ts","sourceRoot":"","sources":["../../../../src/tracing/scopes/InferenceScope.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE1D,OAAO,EACL,gBAAgB,EAChB,YAAY,EACZ,WAAW,EACX,OAAO,EACP,WAAW,EACZ,MAAM,cAAc,CAAC;AAEtB;;GAEG;AACH,qBAAa,cAAe,SAAQ,kBAAkB;IACpD;;;;;;;;;OASG;WACW,KAAK,CACjB,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,gBAAgB,EACzB,YAAY,EAAE,YAAY,EAC1B,WAAW,CAAC,EAAE,WAAW,EACzB,WAAW,CAAC,EAAE,WAAW,GACxB,cAAc;IAIjB,OAAO;IA6CP;;;OAGG;IACI,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI;IAIpD;;;OAGG;IACI,oBAAoB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI;IAIrD;;;OAGG;IACI,iBAAiB,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI;IAInD;;;OAGG;IACI,kBAAkB,CAAC,YAAY,EAAE,MAAM,GAAG,IAAI;IAIrD;;;OAGG;IACI,mBAAmB,CAAC,aAAa,EAAE,MAAM,EAAE,GAAG,IAAI;CAM1D"}
@@ -12,34 +12,35 @@ const constants_1 = require("../constants");
12
12
  class InferenceScope extends OpenTelemetryScope_1.OpenTelemetryScope {
13
13
  /**
14
14
  * Creates and starts a new scope for inference tracing.
15
- * @param details The inference call details
16
- * @param agentDetails The agent details
17
- * @param tenantDetails The tenant details
18
- * @param conversationId Optional conversation id to tag on the span (`gen_ai.conversation.id`).
19
- * @param channel Optional channel; only `name` (channel name) and `description` (channel link/URL) are used for tagging.
20
- * @param parentContext Optional parent context for cross-async-boundary tracing.
21
- * Accepts a ParentSpanRef (manual traceId/spanId) or an OTel Context (e.g. from extractTraceContext).
22
- * @param startTime Optional explicit start time (ms epoch, Date, or HrTime).
23
- * @param endTime Optional explicit end time (ms epoch, Date, or HrTime).
24
- * @param callerDetails Optional caller details.
15
+ *
16
+ * @param request Request payload (channel, conversationId, content, sessionId).
17
+ * @param details The inference call details (model, provider, tokens, etc.).
18
+ * @param agentDetails The agent performing the inference. Tenant ID is derived from `agentDetails.tenantId`.
19
+ * @param userDetails Optional human caller identity.
20
+ * @param spanDetails Optional span configuration (parentContext, startTime, endTime, spanLinks). Note: `spanKind` is ignored; InferenceScope always uses `SpanKind.CLIENT`.
25
21
  * @returns A new InferenceScope instance
26
22
  */
27
- static start(details, agentDetails, tenantDetails, conversationId, channel, parentContext, startTime, endTime, callerDetails) {
28
- return new InferenceScope(details, agentDetails, tenantDetails, conversationId, channel, parentContext, startTime, endTime, callerDetails);
23
+ static start(request, details, agentDetails, userDetails, spanDetails) {
24
+ return new InferenceScope(request, details, agentDetails, userDetails, spanDetails);
29
25
  }
30
- constructor(details, agentDetails, tenantDetails, conversationId, channel, parentContext, startTime, endTime, callerDetails) {
31
- super(api_1.SpanKind.CLIENT, details.operationName.toString(), `${details.operationName} ${details.model}`, agentDetails, tenantDetails, parentContext, startTime, endTime, callerDetails);
32
- // Set core inference information matching C# implementation
33
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_OPERATION_NAME_KEY, details.operationName.toString());
26
+ constructor(request, details, agentDetails, userDetails, spanDetails) {
27
+ // Validate tenantId is present (required for telemetry)
28
+ if (!agentDetails.tenantId) {
29
+ throw new Error('InferenceScope: tenantId is required on agentDetails');
30
+ }
31
+ // spanKind for InferenceScope is always CLIENT
32
+ const resolvedSpanDetails = { ...spanDetails, spanKind: api_1.SpanKind.CLIENT };
33
+ super(details.operationName.toString(), `${details.operationName} ${details.model}`, agentDetails, resolvedSpanDetails, userDetails);
34
+ // Set core inference information
34
35
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_REQUEST_MODEL_KEY, details.model);
35
36
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_PROVIDER_NAME_KEY, details.providerName);
36
37
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_USAGE_INPUT_TOKENS_KEY, details.inputTokens);
37
38
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_USAGE_OUTPUT_TOKENS_KEY, details.outputTokens);
38
39
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_RESPONSE_FINISH_REASONS_KEY, details.finishReasons);
39
40
  this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_AGENT_THOUGHT_PROCESS_KEY, details.thoughtProcess);
40
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CONVERSATION_ID_KEY, conversationId);
41
- this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_NAME_KEY, channel?.name);
42
- this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_LINK_KEY, channel?.description);
41
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CONVERSATION_ID_KEY, request.conversationId);
42
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_NAME_KEY, request.channel?.name);
43
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_LINK_KEY, request.channel?.description);
43
44
  // Set endpoint information if provided
44
45
  if (details.endpoint) {
45
46
  this.setTagMaybe(constants_1.OpenTelemetryConstants.SERVER_ADDRESS_KEY, details.endpoint.host);
@@ -1 +1 @@
1
- {"version":3,"file":"InferenceScope.js","sourceRoot":"","sources":["../../../../src/tracing/scopes/InferenceScope.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"InferenceScope.js","sourceRoot":"","sources":["../../../../src/tracing/scopes/InferenceScope.ts"],"names":[],"mappings":"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"}
@@ -1,26 +1,23 @@
1
- import { SpanKind, TimeInput } from '@opentelemetry/api';
2
1
  import { OpenTelemetryScope } from './OpenTelemetryScope';
3
- import { InvokeAgentDetails, TenantDetails, CallerDetails, AgentDetails } from '../contracts';
4
- import { ParentContext } from '../context/trace-context-propagation';
2
+ import { InvokeAgentScopeDetails, CallerDetails, Request, SpanDetails, AgentDetails } from '../contracts';
5
3
  /**
6
4
  * Provides OpenTelemetry tracing scope for AI agent invocation operations.
7
5
  */
8
6
  export declare class InvokeAgentScope extends OpenTelemetryScope {
9
7
  /**
10
8
  * Creates and starts a new scope for agent invocation tracing.
11
- * @param invokeAgentDetails The details of the agent invocation including endpoint, agent information, and conversation context.
12
- * @param tenantDetails The tenant details.
13
- * @param callerAgentDetails The details of the caller agent.
14
- * @param callerDetails The details of the non-agentic caller.
15
- * @param parentContext Optional parent context for cross-async-boundary tracing.
16
- * Accepts a ParentSpanRef (manual traceId/spanId) or an OTel Context (e.g. from extractTraceContext).
17
- * @param startTime Optional explicit start time (ms epoch, Date, or HrTime).
18
- * @param endTime Optional explicit end time (ms epoch, Date, or HrTime).
19
- * @param spanKind Optional span kind override. Defaults to `SpanKind.CLIENT`.
20
- * Use `SpanKind.SERVER` when the agent is receiving an inbound request.
9
+ *
10
+ * @param request Request payload (channel, conversationId, content, sessionId).
11
+ * @param invokeScopeDetails Scope-level details
12
+ * @param agentDetails The agent identity. Tenant ID is derived from `agentDetails.tenantId` (required).
13
+ * @param callerDetails Optional caller information. Supports three scenarios:
14
+ * - Human caller only: `{ userDetails: { userId, userName, ... } }`
15
+ * - Agent caller only: `{ callerAgentDetails: { agentId, agentName, ... } }`
16
+ * - Both (A2A with human in chain): `{ userDetails: { ... }, callerAgentDetails: { ... } }`
17
+ * @param spanDetails Optional span configuration (parentContext, startTime, endTime, spanKind, spanLinks).
21
18
  * @returns A new InvokeAgentScope instance.
22
19
  */
23
- static start(invokeAgentDetails: InvokeAgentDetails, tenantDetails: TenantDetails, callerAgentDetails?: AgentDetails, callerDetails?: CallerDetails, parentContext?: ParentContext, startTime?: TimeInput, endTime?: TimeInput, spanKind?: SpanKind): InvokeAgentScope;
20
+ static start(request: Request, invokeScopeDetails: InvokeAgentScopeDetails, agentDetails: AgentDetails, callerDetails?: CallerDetails, spanDetails?: SpanDetails): InvokeAgentScope;
24
21
  private constructor();
25
22
  /**
26
23
  * Records response information for telemetry tracking.
@@ -1 +1 @@
1
- {"version":3,"file":"InvokeAgentScope.d.ts","sourceRoot":"","sources":["../../../../src/tracing/scopes/InvokeAgentScope.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EACL,kBAAkB,EAClB,aAAa,EACb,aAAa,EACb,YAAY,EACb,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAGrE;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,kBAAkB;IACtD;;;;;;;;;;;;;OAaG;WACW,KAAK,CACjB,kBAAkB,EAAE,kBAAkB,EACtC,aAAa,EAAE,aAAa,EAC5B,kBAAkB,CAAC,EAAE,YAAY,EACjC,aAAa,CAAC,EAAE,aAAa,EAC7B,aAAa,CAAC,EAAE,aAAa,EAC7B,SAAS,CAAC,EAAE,SAAS,EACrB,OAAO,CAAC,EAAE,SAAS,EACnB,QAAQ,CAAC,EAAE,QAAQ,GAClB,gBAAgB;IAInB,OAAO;IA+DP;;;OAGG;IACI,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAI7C;;;OAGG;IACI,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI;IAIpD;;;OAGG;IACI,oBAAoB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI;CAGtD"}
1
+ {"version":3,"file":"InvokeAgentScope.d.ts","sourceRoot":"","sources":["../../../../src/tracing/scopes/InvokeAgentScope.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EACL,uBAAuB,EACvB,aAAa,EACb,OAAO,EACP,WAAW,EACX,YAAY,EACb,MAAM,cAAc,CAAC;AAGtB;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,kBAAkB;IACtD;;;;;;;;;;;;OAYG;WACW,KAAK,CACjB,OAAO,EAAE,OAAO,EAChB,kBAAkB,EAAE,uBAAuB,EAC3C,YAAY,EAAE,YAAY,EAC1B,aAAa,CAAC,EAAE,aAAa,EAC7B,WAAW,CAAC,EAAE,WAAW,GACxB,gBAAgB;IAInB,OAAO;IA2DP;;;OAGG;IACI,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAI7C;;;OAGG;IACI,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI;IAIpD;;;OAGG;IACI,oBAAoB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI;CAGtD"}
@@ -12,54 +12,55 @@ const constants_1 = require("../constants");
12
12
  class InvokeAgentScope extends OpenTelemetryScope_1.OpenTelemetryScope {
13
13
  /**
14
14
  * Creates and starts a new scope for agent invocation tracing.
15
- * @param invokeAgentDetails The details of the agent invocation including endpoint, agent information, and conversation context.
16
- * @param tenantDetails The tenant details.
17
- * @param callerAgentDetails The details of the caller agent.
18
- * @param callerDetails The details of the non-agentic caller.
19
- * @param parentContext Optional parent context for cross-async-boundary tracing.
20
- * Accepts a ParentSpanRef (manual traceId/spanId) or an OTel Context (e.g. from extractTraceContext).
21
- * @param startTime Optional explicit start time (ms epoch, Date, or HrTime).
22
- * @param endTime Optional explicit end time (ms epoch, Date, or HrTime).
23
- * @param spanKind Optional span kind override. Defaults to `SpanKind.CLIENT`.
24
- * Use `SpanKind.SERVER` when the agent is receiving an inbound request.
15
+ *
16
+ * @param request Request payload (channel, conversationId, content, sessionId).
17
+ * @param invokeScopeDetails Scope-level details
18
+ * @param agentDetails The agent identity. Tenant ID is derived from `agentDetails.tenantId` (required).
19
+ * @param callerDetails Optional caller information. Supports three scenarios:
20
+ * - Human caller only: `{ userDetails: { userId, userName, ... } }`
21
+ * - Agent caller only: `{ callerAgentDetails: { agentId, agentName, ... } }`
22
+ * - Both (A2A with human in chain): `{ userDetails: { ... }, callerAgentDetails: { ... } }`
23
+ * @param spanDetails Optional span configuration (parentContext, startTime, endTime, spanKind, spanLinks).
25
24
  * @returns A new InvokeAgentScope instance.
26
25
  */
27
- static start(invokeAgentDetails, tenantDetails, callerAgentDetails, callerDetails, parentContext, startTime, endTime, spanKind) {
28
- return new InvokeAgentScope(invokeAgentDetails, tenantDetails, callerAgentDetails, callerDetails, parentContext, startTime, endTime, spanKind);
26
+ static start(request, invokeScopeDetails, agentDetails, callerDetails, spanDetails) {
27
+ return new InvokeAgentScope(request, invokeScopeDetails, agentDetails, callerDetails, spanDetails);
29
28
  }
30
- constructor(invokeAgentDetails, tenantDetails, callerAgentDetails, callerDetails, parentContext, startTime, endTime, spanKind) {
31
- super(spanKind ?? api_1.SpanKind.CLIENT, constants_1.OpenTelemetryConstants.INVOKE_AGENT_OPERATION_NAME, invokeAgentDetails.agentName
32
- ? `${constants_1.OpenTelemetryConstants.INVOKE_AGENT_OPERATION_NAME} ${invokeAgentDetails.agentName}`
33
- : constants_1.OpenTelemetryConstants.INVOKE_AGENT_OPERATION_NAME, invokeAgentDetails, tenantDetails, parentContext, startTime, endTime, callerDetails);
34
- // Set provider name for agent invocation
35
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_PROVIDER_NAME_KEY, invokeAgentDetails.providerName);
36
- // Set session ID and endpoint information
37
- this.setTagMaybe(constants_1.OpenTelemetryConstants.SESSION_ID_KEY, invokeAgentDetails.sessionId);
38
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_AGENT_BLUEPRINT_ID_KEY, invokeAgentDetails.agentBlueprintId);
39
- if (invokeAgentDetails.endpoint) {
40
- this.setTagMaybe(constants_1.OpenTelemetryConstants.SERVER_ADDRESS_KEY, invokeAgentDetails.endpoint.host);
29
+ constructor(request, invokeScopeDetails, agentDetails, callerDetails, spanDetails) {
30
+ // Validate tenantId is present (required for telemetry)
31
+ if (!agentDetails.tenantId) {
32
+ throw new Error('InvokeAgentScope: tenantId is required on agentDetails');
33
+ }
34
+ const resolvedSpanDetails = { ...spanDetails, spanKind: spanDetails?.spanKind ?? api_1.SpanKind.CLIENT };
35
+ super(constants_1.OpenTelemetryConstants.INVOKE_AGENT_OPERATION_NAME, agentDetails.agentName
36
+ ? `${constants_1.OpenTelemetryConstants.INVOKE_AGENT_OPERATION_NAME} ${agentDetails.agentName}`
37
+ : constants_1.OpenTelemetryConstants.INVOKE_AGENT_OPERATION_NAME, agentDetails, resolvedSpanDetails, callerDetails?.userDetails);
38
+ // Set provider name from agent details
39
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_PROVIDER_NAME_KEY, agentDetails.providerName);
40
+ // Set session ID from request
41
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.SESSION_ID_KEY, request.sessionId);
42
+ if (invokeScopeDetails.endpoint) {
43
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.SERVER_ADDRESS_KEY, invokeScopeDetails.endpoint.host);
41
44
  // Only record port if it is different from 443 (default HTTPS port)
42
- if (invokeAgentDetails.endpoint.port && invokeAgentDetails.endpoint.port !== 443) {
43
- this.setTagMaybe(constants_1.OpenTelemetryConstants.SERVER_PORT_KEY, invokeAgentDetails.endpoint.port);
45
+ if (invokeScopeDetails.endpoint.port && invokeScopeDetails.endpoint.port !== 443) {
46
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.SERVER_PORT_KEY, invokeScopeDetails.endpoint.port);
44
47
  }
45
48
  }
46
- // Set request-related tags
47
- const requestToUse = invokeAgentDetails.request;
48
- if (requestToUse) {
49
- if (requestToUse.channel) {
50
- this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_NAME_KEY, requestToUse.channel.name);
51
- this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_LINK_KEY, requestToUse.channel.description);
52
- }
49
+ // Set channel tags from request
50
+ if (request.channel) {
51
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_NAME_KEY, request.channel.name);
52
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.CHANNEL_LINK_KEY, request.channel.description);
53
53
  }
54
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CONVERSATION_ID_KEY, invokeAgentDetails.conversationId);
55
- // Set caller agent details tags
56
- if (callerAgentDetails) {
57
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_NAME_KEY, callerAgentDetails.agentName);
58
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_ID_KEY, callerAgentDetails.agentId);
59
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_APPLICATION_ID_KEY, callerAgentDetails.agentBlueprintId);
60
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_USER_ID_KEY, callerAgentDetails.agentAUID);
61
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_EMAIL_KEY, callerAgentDetails.agentEmail);
62
- this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_PLATFORM_ID_KEY, callerAgentDetails.platformId);
54
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CONVERSATION_ID_KEY, request.conversationId);
55
+ // Set caller agent details tags for A2A scenarios
56
+ const callerAgent = callerDetails?.callerAgentDetails;
57
+ if (callerAgent) {
58
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_NAME_KEY, callerAgent.agentName);
59
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_ID_KEY, callerAgent.agentId);
60
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_APPLICATION_ID_KEY, callerAgent.agentBlueprintId);
61
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_USER_ID_KEY, callerAgent.agentAUID);
62
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_EMAIL_KEY, callerAgent.agentEmail);
63
+ this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_CALLER_AGENT_PLATFORM_ID_KEY, callerAgent.platformId);
63
64
  }
64
65
  }
65
66
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"InvokeAgentScope.js","sourceRoot":"","sources":["../../../../src/tracing/scopes/InvokeAgentScope.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"InvokeAgentScope.js","sourceRoot":"","sources":["../../../../src/tracing/scopes/InvokeAgentScope.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;;AAElC,4CAA8C;AAC9C,6DAA0D;AAQ1D,4CAAsD;AAEtD;;GAEG;AACH,MAAa,gBAAiB,SAAQ,uCAAkB;IACtD;;;;;;;;;;;;OAYG;IACI,MAAM,CAAC,KAAK,CACjB,OAAgB,EAChB,kBAA2C,EAC3C,YAA0B,EAC1B,aAA6B,EAC7B,WAAyB;QAEzB,OAAO,IAAI,gBAAgB,CAAC,OAAO,EAAE,kBAAkB,EAAE,YAAY,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;IACrG,CAAC;IAED,YACE,OAAgB,EAChB,kBAA2C,EAC3C,YAA0B,EAC1B,aAA6B,EAC7B,WAAyB;QAEzB,wDAAwD;QACxD,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;YAC3B,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;QAC5E,CAAC;QAED,MAAM,mBAAmB,GAAgB,EAAE,GAAG,WAAW,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,IAAI,cAAQ,CAAC,MAAM,EAAE,CAAC;QAEhH,KAAK,CACH,kCAAsB,CAAC,2BAA2B,EAClD,YAAY,CAAC,SAAS;YACpB,CAAC,CAAC,GAAG,kCAAsB,CAAC,2BAA2B,IAAI,YAAY,CAAC,SAAS,EAAE;YACnF,CAAC,CAAC,kCAAsB,CAAC,2BAA2B,EACtD,YAAY,EACZ,mBAAmB,EACnB,aAAa,EAAE,WAAW,CAC3B,CAAC;QAEF,uCAAuC;QACvC,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,wBAAwB,EAAE,YAAY,CAAC,YAAY,CAAC,CAAC;QAE7F,8BAA8B;QAC9B,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,cAAc,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;QAE3E,IAAI,kBAAkB,CAAC,QAAQ,EAAE,CAAC;YAChC,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAE9F,oEAAoE;YACpE,IAAI,kBAAkB,CAAC,QAAQ,CAAC,IAAI,IAAI,kBAAkB,CAAC,QAAQ,CAAC,IAAI,KAAK,GAAG,EAAE,CAAC;gBACjF,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,eAAe,EAAE,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC7F,CAAC;QACH,CAAC;QAED,gCAAgC;QAChC,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YACpB,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,gBAAgB,EAAE,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAChF,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,gBAAgB,EAAE,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACzF,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,0BAA0B,EAAE,OAAO,CAAC,cAAc,CAAC,CAAC;QAE5F,kDAAkD;QAClD,MAAM,WAAW,GAAG,aAAa,EAAE,kBAAkB,CAAC;QACtD,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,4BAA4B,EAAE,WAAW,CAAC,SAAS,CAAC,CAAC;YAC7F,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,0BAA0B,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC;YACzF,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,sCAAsC,EAAE,WAAW,CAAC,gBAAgB,CAAC,CAAC;YAC9G,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,+BAA+B,EAAE,WAAW,CAAC,SAAS,CAAC,CAAC;YAChG,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,6BAA6B,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC;YAC/F,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,mCAAmC,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC;QACvG,CAAC;IACH,CAAC;IAED;;;OAGG;IACI,cAAc,CAAC,QAAgB;QACpC,IAAI,CAAC,oBAAoB,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;IACxC,CAAC;IAED;;;OAGG;IACI,mBAAmB,CAAC,QAAkB;QAC3C,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,yBAAyB,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC/F,CAAC;IAED;;;OAGG;IACI,oBAAoB,CAAC,QAAkB;QAC5C,IAAI,CAAC,WAAW,CAAC,kCAAsB,CAAC,0BAA0B,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;IAChG,CAAC;CACF;AA1GD,4CA0GC"}
@@ -1,6 +1,5 @@
1
- import { SpanKind, Span, AttributeValue, SpanContext, TimeInput } from '@opentelemetry/api';
2
- import { AgentDetails, TenantDetails, CallerDetails } from '../contracts';
3
- import { ParentContext } from '../context/trace-context-propagation';
1
+ import { Span, AttributeValue, SpanContext, TimeInput } from '@opentelemetry/api';
2
+ import { AgentDetails, UserDetails, SpanDetails } from '../contracts';
4
3
  /**
5
4
  * Base class for OpenTelemetry tracing scopes
6
5
  */
@@ -15,22 +14,15 @@ export declare abstract class OpenTelemetryScope implements Disposable {
15
14
  private hasEnded;
16
15
  /**
17
16
  * Initializes a new instance of the OpenTelemetryScope class
18
- * @param kind The kind of span (CLIENT, SERVER, INTERNAL, etc.)
19
17
  * @param operationName The name of the operation being traced
20
18
  * @param spanName The name of the span for display purposes
21
- * @param agentDetails Optional agent details
22
- * @param tenantDetails Optional tenant details
23
- * @param parentContext Optional parent context for cross-async-boundary tracing.
24
- * Accepts a {@link ParentSpanRef} (manual traceId/spanId) or an OTel {@link Context}
25
- * (e.g. from {@link extractTraceContext} for W3C header propagation).
26
- * @param startTime Optional explicit start time (ms epoch, Date, or HrTime). When provided the span
27
- * records this timestamp instead of "now", which is useful when recording an operation after it
28
- * has already completed (e.g. a tool call whose start time was captured earlier).
29
- * @param endTime Optional explicit end time (ms epoch, Date, or HrTime). When provided the span will
30
- * use this timestamp when {@link dispose} is called instead of the current wall-clock time.
31
- * @param callerDetails Optional caller identity details (id, upn, name, client ip).
19
+ * @param agentDetails Optional agent details. Tenant ID is read from `agentDetails.tenantId`.
20
+ * @param spanDetails Optional span configuration including parent context, start/end times,
21
+ * span kind, and span links. Subclasses may override `spanDetails.spanKind` before
22
+ * calling this constructor; defaults to `SpanKind.CLIENT`.
23
+ * @param userDetails Optional human caller identity details (id, upn, name, client ip).
32
24
  */
33
- protected constructor(kind: SpanKind, operationName: string, spanName: string, agentDetails?: AgentDetails, tenantDetails?: TenantDetails, parentContext?: ParentContext, startTime?: TimeInput, endTime?: TimeInput, callerDetails?: CallerDetails);
25
+ protected constructor(operationName: string, spanName: string, agentDetails?: AgentDetails, spanDetails?: SpanDetails, userDetails?: UserDetails);
34
26
  /**
35
27
  * Makes this span active for the duration of the async callback execution
36
28
  */
@@ -52,7 +44,7 @@ export declare abstract class OpenTelemetryScope implements Disposable {
52
44
  */
53
45
  recordAttributes(attributes: Iterable<[string, AttributeValue]> | Record<string, AttributeValue> | null | undefined): void;
54
46
  /**
55
- * Sets a tag on the span if telemetry is enabled
47
+ * Sets a tag on the span if the value is not null or undefined.
56
48
  * @param name The tag name
57
49
  * @param value The tag value
58
50
  */
@@ -75,6 +67,12 @@ export declare abstract class OpenTelemetryScope implements Disposable {
75
67
  * @param endTime The end time as milliseconds since epoch, a Date, or an HrTime tuple.
76
68
  */
77
69
  setEndTime(endTime: TimeInput): void;
70
+ /**
71
+ * Records a cancellation event on the span.
72
+ * Sets the span status to ERROR with the cancellation reason and marks the error type as 'TaskCanceledException'.
73
+ * @param reason Optional cancellation reason. Defaults to 'Task was cancelled'.
74
+ */
75
+ recordCancellation(reason?: string): void;
78
76
  /**
79
77
  * Finalizes the scope and records metrics
80
78
  */
@@ -1 +1 @@
1
- {"version":3,"file":"OpenTelemetryScope.d.ts","sourceRoot":"","sources":["../../../../src/tracing/scopes/OpenTelemetryScope.ts"],"names":[],"mappings":"AAGA,OAAO,EAAS,QAAQ,EAAE,IAAI,EAAuC,cAAc,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAExI,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAE1E,OAAO,EAAE,aAAa,EAAmB,MAAM,sCAAsC,CAAC;AAGtF;;GAEG;AACH,8BAAsB,kBAAmB,YAAW,UAAU;IAC5D,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAuD;IAErF,SAAS,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC;IAC9B,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;IAC1C,OAAO,CAAC,eAAe,CAAC,CAAY;IACpC,OAAO,CAAC,aAAa,CAAC,CAAY;IAClC,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,SAAS,CAAC,CAAQ;IAC1B,OAAO,CAAC,QAAQ,CAAS;IAEzB;;;;;;;;;;;;;;;;OAgBG;IACH,SAAS,aACP,IAAI,EAAE,QAAQ,EACd,aAAa,EAAE,MAAM,EACrB,QAAQ,EAAE,MAAM,EAChB,YAAY,CAAC,EAAE,YAAY,EAC3B,aAAa,CAAC,EAAE,aAAa,EAC7B,aAAa,CAAC,EAAE,aAAa,EAC7B,SAAS,CAAC,EAAE,SAAS,EACrB,OAAO,CAAC,EAAE,SAAS,EACnB,aAAa,CAAC,EAAE,aAAa;IA6D/B;;OAEG;IACI,mBAAmB,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAKrE;;;;OAIG;IACI,cAAc,IAAI,WAAW;IAIpC;;;OAGG;IACI,WAAW,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI;IAkBtC;;;OAGG;IACI,gBAAgB,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,GAAG,IAAI,GAAG,SAAS,GAAG,IAAI;IA2BjI;;;;OAIG;IACH,SAAS,CAAC,WAAW,CAAC,CAAC,SAAS,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,EAAE,GAAG,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI,GAAG,SAAS,GAAG,IAAI;IAMjI;;;;OAIG;IACH,SAAS,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAMtD;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,aAAa;IAQ5B;;;;;OAKG;IACI,UAAU,CAAC,OAAO,EAAE,SAAS,GAAG,IAAI;IAI3C;;OAEG;IACH,OAAO,CAAC,GAAG;IA0BX;;OAEG;IACI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI;IAW/B;;OAEG;IACI,OAAO,IAAI,IAAI;CAIvB"}
1
+ {"version":3,"file":"OpenTelemetryScope.d.ts","sourceRoot":"","sources":["../../../../src/tracing/scopes/OpenTelemetryScope.ts"],"names":[],"mappings":"AAGA,OAAO,EAAmB,IAAI,EAA2B,cAAc,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAE5H,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAKtE;;GAEG;AACH,8BAAsB,kBAAmB,YAAW,UAAU;IAC5D,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAuD;IAErF,SAAS,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC;IAC9B,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;IAC1C,OAAO,CAAC,eAAe,CAAC,CAAY;IACpC,OAAO,CAAC,aAAa,CAAC,CAAY;IAClC,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,SAAS,CAAC,CAAQ;IAC1B,OAAO,CAAC,QAAQ,CAAS;IAEzB;;;;;;;;;OASG;IACH,SAAS,aACP,aAAa,EAAE,MAAM,EACrB,QAAQ,EAAE,MAAM,EAChB,YAAY,CAAC,EAAE,YAAY,EAC3B,WAAW,CAAC,EAAE,WAAW,EACzB,WAAW,CAAC,EAAE,WAAW;IAiE3B;;OAEG;IACI,mBAAmB,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAKrE;;;;OAIG;IACI,cAAc,IAAI,WAAW;IAIpC;;;OAGG;IACI,WAAW,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI;IAkBtC;;;OAGG;IACI,gBAAgB,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,GAAG,IAAI,GAAG,SAAS,GAAG,IAAI;IA2BjI;;;;OAIG;IACH,SAAS,CAAC,WAAW,CAAC,CAAC,SAAS,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,EAAE,GAAG,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI,GAAG,SAAS,GAAG,IAAI;IAMjI;;;;OAIG;IACH,SAAS,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAMtD;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,aAAa;IAQ5B;;;;;OAKG;IACI,UAAU,CAAC,OAAO,EAAE,SAAS,GAAG,IAAI;IAI3C;;;;OAIG;IACI,kBAAkB,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI;IAUhD;;OAEG;IACH,OAAO,CAAC,GAAG;IAuBX;;OAEG;IACI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI;IAW/B;;OAEG;IACI,OAAO,IAAI,IAAI;CAIvB"}