@microsoft/agents-a365-observability 0.1.0-preview.126 → 0.1.0-preview.128
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.
- package/dist/cjs/index.d.ts +1 -1
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +6 -2
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/tracing/constants.d.ts +2 -2
- package/dist/cjs/tracing/constants.d.ts.map +1 -1
- package/dist/cjs/tracing/constants.js +1 -1
- package/dist/cjs/tracing/constants.js.map +1 -1
- package/dist/cjs/tracing/contracts.d.ts +151 -25
- package/dist/cjs/tracing/contracts.d.ts.map +1 -1
- package/dist/cjs/tracing/contracts.js +37 -15
- package/dist/cjs/tracing/contracts.js.map +1 -1
- package/dist/cjs/tracing/exporter/Agent365Exporter.d.ts.map +1 -1
- package/dist/cjs/tracing/exporter/Agent365Exporter.js +1 -1
- package/dist/cjs/tracing/exporter/Agent365Exporter.js.map +1 -1
- package/dist/cjs/tracing/exporter/utils.d.ts +14 -0
- package/dist/cjs/tracing/exporter/utils.d.ts.map +1 -1
- package/dist/cjs/tracing/exporter/utils.js +328 -3
- package/dist/cjs/tracing/exporter/utils.js.map +1 -1
- package/dist/cjs/tracing/message-utils.d.ts +36 -0
- package/dist/cjs/tracing/message-utils.d.ts.map +1 -0
- package/dist/cjs/tracing/message-utils.js +90 -0
- package/dist/cjs/tracing/message-utils.js.map +1 -0
- package/dist/cjs/tracing/scopes/ExecuteToolScope.d.ts +3 -3
- package/dist/cjs/tracing/scopes/ExecuteToolScope.d.ts.map +1 -1
- package/dist/cjs/tracing/scopes/ExecuteToolScope.js +7 -6
- package/dist/cjs/tracing/scopes/ExecuteToolScope.js.map +1 -1
- package/dist/cjs/tracing/scopes/InferenceScope.d.ts +13 -11
- package/dist/cjs/tracing/scopes/InferenceScope.d.ts.map +1 -1
- package/dist/cjs/tracing/scopes/InferenceScope.js +16 -14
- package/dist/cjs/tracing/scopes/InferenceScope.js.map +1 -1
- package/dist/cjs/tracing/scopes/InvokeAgentScope.d.ts +7 -5
- package/dist/cjs/tracing/scopes/InvokeAgentScope.d.ts.map +1 -1
- package/dist/cjs/tracing/scopes/InvokeAgentScope.js +11 -5
- package/dist/cjs/tracing/scopes/InvokeAgentScope.js.map +1 -1
- package/dist/cjs/tracing/scopes/OpenTelemetryScope.d.ts +13 -2
- package/dist/cjs/tracing/scopes/OpenTelemetryScope.d.ts.map +1 -1
- package/dist/cjs/tracing/scopes/OpenTelemetryScope.js +19 -1
- package/dist/cjs/tracing/scopes/OpenTelemetryScope.js.map +1 -1
- package/dist/cjs/tracing/scopes/OutputScope.d.ts +11 -9
- package/dist/cjs/tracing/scopes/OutputScope.d.ts.map +1 -1
- package/dist/cjs/tracing/scopes/OutputScope.js +29 -16
- package/dist/cjs/tracing/scopes/OutputScope.js.map +1 -1
- package/dist/cjs/tracing/util.d.ts +9 -0
- package/dist/cjs/tracing/util.d.ts.map +1 -1
- package/dist/cjs/tracing/util.js +32 -0
- package/dist/cjs/tracing/util.js.map +1 -1
- package/dist/cjs/version.d.ts +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/esm/index.d.ts +1 -1
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +3 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/tracing/constants.d.ts +2 -2
- package/dist/esm/tracing/constants.d.ts.map +1 -1
- package/dist/esm/tracing/constants.js +1 -1
- package/dist/esm/tracing/constants.js.map +1 -1
- package/dist/esm/tracing/contracts.d.ts +151 -25
- package/dist/esm/tracing/contracts.d.ts.map +1 -1
- package/dist/esm/tracing/contracts.js +36 -14
- package/dist/esm/tracing/contracts.js.map +1 -1
- package/dist/esm/tracing/exporter/Agent365Exporter.d.ts.map +1 -1
- package/dist/esm/tracing/exporter/Agent365Exporter.js +2 -2
- package/dist/esm/tracing/exporter/Agent365Exporter.js.map +1 -1
- package/dist/esm/tracing/exporter/utils.d.ts +14 -0
- package/dist/esm/tracing/exporter/utils.d.ts.map +1 -1
- package/dist/esm/tracing/exporter/utils.js +326 -3
- package/dist/esm/tracing/exporter/utils.js.map +1 -1
- package/dist/esm/tracing/message-utils.d.ts +36 -0
- package/dist/esm/tracing/message-utils.d.ts.map +1 -0
- package/dist/esm/tracing/message-utils.js +82 -0
- package/dist/esm/tracing/message-utils.js.map +1 -0
- package/dist/esm/tracing/scopes/ExecuteToolScope.d.ts +3 -3
- package/dist/esm/tracing/scopes/ExecuteToolScope.d.ts.map +1 -1
- package/dist/esm/tracing/scopes/ExecuteToolScope.js +7 -6
- package/dist/esm/tracing/scopes/ExecuteToolScope.js.map +1 -1
- package/dist/esm/tracing/scopes/InferenceScope.d.ts +13 -11
- package/dist/esm/tracing/scopes/InferenceScope.d.ts.map +1 -1
- package/dist/esm/tracing/scopes/InferenceScope.js +16 -14
- package/dist/esm/tracing/scopes/InferenceScope.js.map +1 -1
- package/dist/esm/tracing/scopes/InvokeAgentScope.d.ts +7 -5
- package/dist/esm/tracing/scopes/InvokeAgentScope.d.ts.map +1 -1
- package/dist/esm/tracing/scopes/InvokeAgentScope.js +11 -5
- package/dist/esm/tracing/scopes/InvokeAgentScope.js.map +1 -1
- package/dist/esm/tracing/scopes/OpenTelemetryScope.d.ts +13 -2
- package/dist/esm/tracing/scopes/OpenTelemetryScope.d.ts.map +1 -1
- package/dist/esm/tracing/scopes/OpenTelemetryScope.js +19 -1
- package/dist/esm/tracing/scopes/OpenTelemetryScope.js.map +1 -1
- package/dist/esm/tracing/scopes/OutputScope.d.ts +11 -9
- package/dist/esm/tracing/scopes/OutputScope.d.ts.map +1 -1
- package/dist/esm/tracing/scopes/OutputScope.js +29 -16
- package/dist/esm/tracing/scopes/OutputScope.js.map +1 -1
- package/dist/esm/tracing/util.d.ts +9 -0
- package/dist/esm/tracing/util.d.ts.map +1 -1
- package/dist/esm/tracing/util.js +31 -0
- package/dist/esm/tracing/util.js.map +1 -1
- package/dist/esm/version.d.ts +1 -1
- package/dist/esm/version.js +1 -1
- package/package.json +2 -2
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
//
|
|
3
|
-
//
|
|
4
|
-
// ------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) Microsoft Corporation.
|
|
3
|
+
// Licensed under the MIT License.
|
|
5
4
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
6
5
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
7
6
|
};
|
|
8
7
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.MAX_SPAN_SIZE_BYTES = void 0;
|
|
9
9
|
exports.hexTraceId = hexTraceId;
|
|
10
10
|
exports.hexSpanId = hexSpanId;
|
|
11
11
|
exports.asStr = asStr;
|
|
@@ -17,8 +17,10 @@ exports.isPerRequestExportEnabled = isPerRequestExportEnabled;
|
|
|
17
17
|
exports.resolveAgent365Endpoint = resolveAgent365Endpoint;
|
|
18
18
|
exports.getAgent365ObservabilityDomainOverride = getAgent365ObservabilityDomainOverride;
|
|
19
19
|
exports.parseIdentityKey = parseIdentityKey;
|
|
20
|
+
exports.truncateSpan = truncateSpan;
|
|
20
21
|
const api_1 = require("@opentelemetry/api");
|
|
21
22
|
const constants_1 = require("../constants");
|
|
23
|
+
const contracts_1 = require("../contracts");
|
|
22
24
|
const logging_1 = __importDefault(require("../../utils/logging"));
|
|
23
25
|
const ExporterEventNames_1 = require("./ExporterEventNames");
|
|
24
26
|
const configuration_1 = require("../../configuration");
|
|
@@ -172,4 +174,327 @@ function parseIdentityKey(key) {
|
|
|
172
174
|
const [tenantId, agentId] = key.split(':');
|
|
173
175
|
return { tenantId, agentId };
|
|
174
176
|
}
|
|
177
|
+
// ---------------------------------------------------------------------------
|
|
178
|
+
// Span truncation
|
|
179
|
+
// ---------------------------------------------------------------------------
|
|
180
|
+
/** Maximum allowed span size in bytes (250KB). @internal */
|
|
181
|
+
exports.MAX_SPAN_SIZE_BYTES = 250 * 1024;
|
|
182
|
+
const BLOB_SENTINEL = '[blob truncated]';
|
|
183
|
+
const JSON_SENTINEL = '[truncated]';
|
|
184
|
+
const TRUNCATED_SUFFIX = '… [truncated]';
|
|
185
|
+
const TRUNCATED_SUFFIX_BYTES = Buffer.byteLength(TRUNCATED_SUFFIX, 'utf8');
|
|
186
|
+
const OVERLIMIT_SENTINEL = '[overlimit]';
|
|
187
|
+
/**
|
|
188
|
+
* Build a versioned message wrapper indicating the original messages were dropped
|
|
189
|
+
* because the span exceeded the size limit.
|
|
190
|
+
*/
|
|
191
|
+
function serializeOverflowSentinel(totalMessages) {
|
|
192
|
+
return JSON.stringify({
|
|
193
|
+
version: contracts_1.A365_MESSAGE_SCHEMA_VERSION,
|
|
194
|
+
messages: [
|
|
195
|
+
{
|
|
196
|
+
role: contracts_1.MessageRole.SYSTEM,
|
|
197
|
+
parts: [
|
|
198
|
+
{
|
|
199
|
+
type: 'text',
|
|
200
|
+
content: `[truncated: ${totalMessages} ${totalMessages === 1 ? 'message' : 'messages'} exceeded limit]`
|
|
201
|
+
}
|
|
202
|
+
]
|
|
203
|
+
}
|
|
204
|
+
]
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
/** Strings shorter than this (in UTF-8 bytes) are not worth truncating. */
|
|
208
|
+
const MIN_SHRINKABLE_STRING_BYTES = 50;
|
|
209
|
+
const MESSAGE_ATTR_KEYS = new Set([
|
|
210
|
+
constants_1.OpenTelemetryConstants.GEN_AI_INPUT_MESSAGES_KEY,
|
|
211
|
+
constants_1.OpenTelemetryConstants.GEN_AI_OUTPUT_MESSAGES_KEY,
|
|
212
|
+
]);
|
|
213
|
+
/**
|
|
214
|
+
* Trim a string by a target UTF-8 byte budget while preserving whole code points.
|
|
215
|
+
*/
|
|
216
|
+
function trimString(value, bytesToShed) {
|
|
217
|
+
const currentBytes = Buffer.byteLength(value, 'utf8');
|
|
218
|
+
const targetTotalBytes = Math.max(TRUNCATED_SUFFIX_BYTES, currentBytes - Math.max(1, bytesToShed));
|
|
219
|
+
const targetContentBytes = targetTotalBytes - TRUNCATED_SUFFIX_BYTES;
|
|
220
|
+
if (targetContentBytes <= 0) {
|
|
221
|
+
return TRUNCATED_SUFFIX;
|
|
222
|
+
}
|
|
223
|
+
let consumedBytes = 0;
|
|
224
|
+
let endIndex = 0;
|
|
225
|
+
for (const codePoint of value) {
|
|
226
|
+
const codePointBytes = Buffer.byteLength(codePoint, 'utf8');
|
|
227
|
+
if (consumedBytes + codePointBytes > targetContentBytes) {
|
|
228
|
+
break;
|
|
229
|
+
}
|
|
230
|
+
consumedBytes += codePointBytes;
|
|
231
|
+
endIndex += codePoint.length; // length in UTF-16 code units (handles surrogates)
|
|
232
|
+
}
|
|
233
|
+
return value.slice(0, endIndex) + TRUNCATED_SUFFIX;
|
|
234
|
+
}
|
|
235
|
+
function getSerializedSize(value) {
|
|
236
|
+
return Buffer.byteLength(JSON.stringify(value), 'utf8');
|
|
237
|
+
}
|
|
238
|
+
function createBlobShrinkAction(part, sourceKey) {
|
|
239
|
+
const partType = part.type;
|
|
240
|
+
if (partType === 'blob' && typeof part.content === 'string') {
|
|
241
|
+
const contentSize = Buffer.byteLength(part.content, 'utf8');
|
|
242
|
+
if (contentSize <= 0 || part.content === BLOB_SENTINEL) {
|
|
243
|
+
return undefined;
|
|
244
|
+
}
|
|
245
|
+
const action = {
|
|
246
|
+
contentBytes: contentSize,
|
|
247
|
+
sourceKey,
|
|
248
|
+
apply() {
|
|
249
|
+
part.content = BLOB_SENTINEL;
|
|
250
|
+
action.contentBytes = 0;
|
|
251
|
+
}
|
|
252
|
+
};
|
|
253
|
+
return action;
|
|
254
|
+
}
|
|
255
|
+
return undefined;
|
|
256
|
+
}
|
|
257
|
+
/**
|
|
258
|
+
* Collect all shrink candidates from message parts and direct string attributes.
|
|
259
|
+
* Blobs, text, reasoning, json-field, and plain-string actions are all collected
|
|
260
|
+
* uniformly. When a message attribute contains non-JSON content it falls through
|
|
261
|
+
* to regular string trimming.
|
|
262
|
+
*/
|
|
263
|
+
function collectShrinkActions(attributes, parsedMessages) {
|
|
264
|
+
const actions = [];
|
|
265
|
+
for (const key of Object.keys(attributes)) {
|
|
266
|
+
let handledAsMessage = false;
|
|
267
|
+
if (MESSAGE_ATTR_KEYS.has(key)) {
|
|
268
|
+
// Parse and cache the message wrapper if not already done
|
|
269
|
+
if (!parsedMessages.has(key) && typeof attributes[key] === 'string') {
|
|
270
|
+
try {
|
|
271
|
+
const parsed = JSON.parse(attributes[key]);
|
|
272
|
+
if (parsed && typeof parsed === 'object' && typeof parsed.version === 'string' && Array.isArray(parsed.messages)) {
|
|
273
|
+
parsedMessages.set(key, parsed);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
catch {
|
|
277
|
+
// Not valid JSON — will fall through to string trim
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
if (parsedMessages.has(key)) {
|
|
281
|
+
handledAsMessage = true;
|
|
282
|
+
const wrapper = parsedMessages.get(key);
|
|
283
|
+
for (const message of wrapper.messages) {
|
|
284
|
+
if (!Array.isArray(message.parts))
|
|
285
|
+
continue;
|
|
286
|
+
for (const part of message.parts) {
|
|
287
|
+
const partType = part.type;
|
|
288
|
+
// Blob content → sentinel (one-shot)
|
|
289
|
+
const blobAction = createBlobShrinkAction(part, key);
|
|
290
|
+
if (blobAction) {
|
|
291
|
+
actions.push(blobAction);
|
|
292
|
+
continue;
|
|
293
|
+
}
|
|
294
|
+
// Tool/server JSON payload fields → sentinel (one-shot)
|
|
295
|
+
const jsonField = partType === 'tool_call' ? 'arguments'
|
|
296
|
+
: partType === 'tool_call_response' ? 'response'
|
|
297
|
+
: partType === 'server_tool_call' ? 'server_tool_call'
|
|
298
|
+
: partType === 'server_tool_call_response' ? 'server_tool_call_response'
|
|
299
|
+
: undefined;
|
|
300
|
+
if (jsonField && part[jsonField] !== undefined && part[jsonField] !== JSON_SENTINEL) {
|
|
301
|
+
let fieldSize;
|
|
302
|
+
try {
|
|
303
|
+
fieldSize = Buffer.byteLength(JSON.stringify(part[jsonField]), 'utf8');
|
|
304
|
+
}
|
|
305
|
+
catch {
|
|
306
|
+
fieldSize = 0;
|
|
307
|
+
}
|
|
308
|
+
if (fieldSize > 0) {
|
|
309
|
+
const action = {
|
|
310
|
+
contentBytes: fieldSize,
|
|
311
|
+
sourceKey: key,
|
|
312
|
+
apply() {
|
|
313
|
+
part[jsonField] = JSON_SENTINEL;
|
|
314
|
+
action.contentBytes = 0;
|
|
315
|
+
}
|
|
316
|
+
};
|
|
317
|
+
actions.push(action);
|
|
318
|
+
}
|
|
319
|
+
continue;
|
|
320
|
+
}
|
|
321
|
+
// Text/reasoning content → trim (re-shrinkable)
|
|
322
|
+
if ((partType === 'text' || partType === 'reasoning') && typeof part.content === 'string') {
|
|
323
|
+
const contentSize = Buffer.byteLength(part.content, 'utf8');
|
|
324
|
+
if (contentSize > MIN_SHRINKABLE_STRING_BYTES) {
|
|
325
|
+
const action = {
|
|
326
|
+
contentBytes: contentSize,
|
|
327
|
+
sourceKey: key,
|
|
328
|
+
apply(bytesToShed) {
|
|
329
|
+
const cur = Buffer.byteLength(part.content, 'utf8');
|
|
330
|
+
if (cur > TRUNCATED_SUFFIX_BYTES) {
|
|
331
|
+
part.content = trimString(part.content, bytesToShed);
|
|
332
|
+
action.contentBytes = Buffer.byteLength(part.content, 'utf8');
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
};
|
|
336
|
+
actions.push(action);
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
// Non-versioned string attribute → generate shrink action
|
|
344
|
+
if (!handledAsMessage && typeof attributes[key] === 'string') {
|
|
345
|
+
const valueSize = Buffer.byteLength(attributes[key], 'utf8');
|
|
346
|
+
if (valueSize > MIN_SHRINKABLE_STRING_BYTES) {
|
|
347
|
+
// Message key with raw dict JSON → one-shot sentinel replacement (preserves JSON integrity)
|
|
348
|
+
// Other strings → incremental trim
|
|
349
|
+
let isRawJson = false;
|
|
350
|
+
if (MESSAGE_ATTR_KEYS.has(key)) {
|
|
351
|
+
try {
|
|
352
|
+
const p = JSON.parse(attributes[key]);
|
|
353
|
+
isRawJson = p && typeof p === 'object';
|
|
354
|
+
}
|
|
355
|
+
catch { /* not JSON */ }
|
|
356
|
+
}
|
|
357
|
+
const action = isRawJson
|
|
358
|
+
? {
|
|
359
|
+
contentBytes: valueSize,
|
|
360
|
+
apply() {
|
|
361
|
+
attributes[key] = OVERLIMIT_SENTINEL;
|
|
362
|
+
action.contentBytes = Buffer.byteLength(OVERLIMIT_SENTINEL, 'utf8');
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
: {
|
|
366
|
+
contentBytes: valueSize,
|
|
367
|
+
apply(bytesToShed) {
|
|
368
|
+
const cur = Buffer.byteLength(attributes[key], 'utf8');
|
|
369
|
+
if (cur > TRUNCATED_SUFFIX_BYTES) {
|
|
370
|
+
attributes[key] = trimString(attributes[key], bytesToShed);
|
|
371
|
+
action.contentBytes = Buffer.byteLength(attributes[key], 'utf8');
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
};
|
|
375
|
+
actions.push(action);
|
|
376
|
+
}
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
return actions;
|
|
380
|
+
}
|
|
381
|
+
function flushParsedMessages(attributes, parsedMessages) {
|
|
382
|
+
for (const [key, wrapper] of parsedMessages) {
|
|
383
|
+
try {
|
|
384
|
+
attributes[key] = JSON.stringify(wrapper);
|
|
385
|
+
}
|
|
386
|
+
catch {
|
|
387
|
+
// Leave the previous string value intact if serialization fails.
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
function flushParsedMessage(attributes, parsedMessages, key) {
|
|
392
|
+
const wrapper = parsedMessages.get(key);
|
|
393
|
+
if (wrapper) {
|
|
394
|
+
try {
|
|
395
|
+
attributes[key] = JSON.stringify(wrapper);
|
|
396
|
+
}
|
|
397
|
+
catch {
|
|
398
|
+
// Leave the previous string value intact if serialization fails.
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
function runShrinkPhase(span, attributes, parsedMessages, currentSize) {
|
|
403
|
+
let nextSize = currentSize;
|
|
404
|
+
const actions = collectShrinkActions(attributes, parsedMessages);
|
|
405
|
+
while (actions.length > 0 && nextSize > exports.MAX_SPAN_SIZE_BYTES) {
|
|
406
|
+
// Pick the action with the largest contentBytes (accounts for updated sizes)
|
|
407
|
+
let maxIdx = 0;
|
|
408
|
+
for (let j = 1; j < actions.length; j++) {
|
|
409
|
+
if (actions[j].contentBytes > actions[maxIdx].contentBytes)
|
|
410
|
+
maxIdx = j;
|
|
411
|
+
}
|
|
412
|
+
const excess = nextSize - exports.MAX_SPAN_SIZE_BYTES;
|
|
413
|
+
const previousSize = nextSize;
|
|
414
|
+
const action = actions[maxIdx];
|
|
415
|
+
action.apply(excess);
|
|
416
|
+
// Flush only the modified message attribute instead of all parsed messages
|
|
417
|
+
if (action.sourceKey) {
|
|
418
|
+
flushParsedMessage(attributes, parsedMessages, action.sourceKey);
|
|
419
|
+
}
|
|
420
|
+
nextSize = getSerializedSize(span);
|
|
421
|
+
if (nextSize >= previousSize) {
|
|
422
|
+
// Action had no effect — remove it
|
|
423
|
+
actions.splice(maxIdx, 1);
|
|
424
|
+
}
|
|
425
|
+
else if (action.contentBytes <= MIN_SHRINKABLE_STRING_BYTES) {
|
|
426
|
+
// Exhausted (one-shot or fully trimmed) — remove it
|
|
427
|
+
actions.splice(maxIdx, 1);
|
|
428
|
+
}
|
|
429
|
+
}
|
|
430
|
+
// Final flush to ensure all modified message attributes are written back
|
|
431
|
+
flushParsedMessages(attributes, parsedMessages);
|
|
432
|
+
return nextSize;
|
|
433
|
+
}
|
|
434
|
+
/**
|
|
435
|
+
* Truncate span attributes if the serialized span exceeds MAX_SPAN_SIZE_BYTES.
|
|
436
|
+
*
|
|
437
|
+
* Phase 1: iteratively shrink all fields (blobs, text, json, strings) by size
|
|
438
|
+
* priority, remeasuring after each step.
|
|
439
|
+
* Phase 2 (fallback): replace remaining string attributes with overlimit sentinel.
|
|
440
|
+
*/
|
|
441
|
+
function truncateSpan(spanDict) {
|
|
442
|
+
try {
|
|
443
|
+
let currentSize = getSerializedSize(spanDict);
|
|
444
|
+
if (currentSize <= exports.MAX_SPAN_SIZE_BYTES)
|
|
445
|
+
return spanDict;
|
|
446
|
+
logging_1.default.warn(`[Agent365Exporter] Span size (${currentSize} bytes) exceeds limit (${exports.MAX_SPAN_SIZE_BYTES} bytes). Shrinking attributes.`);
|
|
447
|
+
const truncated = { ...spanDict };
|
|
448
|
+
if (truncated.attributes)
|
|
449
|
+
truncated.attributes = { ...truncated.attributes };
|
|
450
|
+
const attributes = truncated.attributes;
|
|
451
|
+
if (!attributes)
|
|
452
|
+
return truncated;
|
|
453
|
+
const parsedMessages = new Map();
|
|
454
|
+
// Phase 1: iteratively shrink all fields by size priority
|
|
455
|
+
currentSize = runShrinkPhase(truncated, attributes, parsedMessages, currentSize);
|
|
456
|
+
if (currentSize > exports.MAX_SPAN_SIZE_BYTES) {
|
|
457
|
+
// Phase 2 (fallback): replace all string attributes with overlimit sentinel, largest first.
|
|
458
|
+
// Message attributes get a structured sentinel preserving the original message count.
|
|
459
|
+
const stringKeys = Object.keys(attributes)
|
|
460
|
+
.filter(k => typeof attributes[k] === 'string' && attributes[k] !== OVERLIMIT_SENTINEL)
|
|
461
|
+
.sort((a, b) => Buffer.byteLength(attributes[b], 'utf8') - Buffer.byteLength(attributes[a], 'utf8'));
|
|
462
|
+
for (const key of stringKeys) {
|
|
463
|
+
if (currentSize <= exports.MAX_SPAN_SIZE_BYTES)
|
|
464
|
+
break;
|
|
465
|
+
if (MESSAGE_ATTR_KEYS.has(key)) {
|
|
466
|
+
let messageCount = 0;
|
|
467
|
+
const cached = parsedMessages.get(key);
|
|
468
|
+
if (cached) {
|
|
469
|
+
messageCount = cached.messages.length;
|
|
470
|
+
}
|
|
471
|
+
else if (typeof attributes[key] === 'string') {
|
|
472
|
+
// Attempt to derive count from current attribute value
|
|
473
|
+
try {
|
|
474
|
+
const parsed = JSON.parse(attributes[key]);
|
|
475
|
+
if (parsed && typeof parsed === 'object' && typeof parsed.version === 'string' && Array.isArray(parsed.messages)) {
|
|
476
|
+
messageCount = parsed.messages.length;
|
|
477
|
+
}
|
|
478
|
+
}
|
|
479
|
+
catch { /* not valid JSON — count stays 0 */ }
|
|
480
|
+
}
|
|
481
|
+
attributes[key] = serializeOverflowSentinel(messageCount);
|
|
482
|
+
parsedMessages.delete(key);
|
|
483
|
+
}
|
|
484
|
+
else {
|
|
485
|
+
attributes[key] = OVERLIMIT_SENTINEL;
|
|
486
|
+
}
|
|
487
|
+
currentSize = getSerializedSize(truncated);
|
|
488
|
+
}
|
|
489
|
+
}
|
|
490
|
+
if (currentSize > exports.MAX_SPAN_SIZE_BYTES) {
|
|
491
|
+
logging_1.default.warn(`[Agent365Exporter] Span still ${currentSize} bytes after exhausting all shrink actions (limit: ${exports.MAX_SPAN_SIZE_BYTES}).`);
|
|
492
|
+
}
|
|
493
|
+
return truncated;
|
|
494
|
+
}
|
|
495
|
+
catch (e) {
|
|
496
|
+
logging_1.default.error(`[Agent365Exporter] Error during span truncation: ${e}`);
|
|
497
|
+
return spanDict;
|
|
498
|
+
}
|
|
499
|
+
}
|
|
175
500
|
//# sourceMappingURL=utils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/tracing/exporter/utils.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/tracing/exporter/utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { ChatMessage, OutputMessage, InputMessages, OutputMessages, InputMessagesParam, OutputMessagesParam } from './contracts';
|
|
2
|
+
/**
|
|
3
|
+
* Type guard that returns `true` when the input is a versioned wrapper
|
|
4
|
+
* object (`InputMessages` or `OutputMessages`).
|
|
5
|
+
*/
|
|
6
|
+
export declare function isWrappedMessages(input: InputMessagesParam | OutputMessagesParam): input is InputMessages | OutputMessages;
|
|
7
|
+
/**
|
|
8
|
+
* Converts plain input strings into OTEL input messages.
|
|
9
|
+
*/
|
|
10
|
+
export declare function toInputMessages(messages: string[]): ChatMessage[];
|
|
11
|
+
/**
|
|
12
|
+
* Converts plain output strings into OTEL output messages.
|
|
13
|
+
*/
|
|
14
|
+
export declare function toOutputMessages(messages: string[]): OutputMessage[];
|
|
15
|
+
/**
|
|
16
|
+
* Normalizes an `InputMessagesParam` to a versioned `InputMessages` wrapper.
|
|
17
|
+
* - `string` / `string[]` → converted to `ChatMessage[]` and wrapped
|
|
18
|
+
* - `InputMessages` → returned as-is
|
|
19
|
+
*/
|
|
20
|
+
export declare function normalizeInputMessages(param: InputMessagesParam): InputMessages;
|
|
21
|
+
/**
|
|
22
|
+
* Normalizes an `OutputMessagesParam` to a versioned `OutputMessages` wrapper.
|
|
23
|
+
* - `string` / `string[]` → converted to `OutputMessage[]` and wrapped
|
|
24
|
+
* - `OutputMessages` → returned as-is
|
|
25
|
+
*/
|
|
26
|
+
export declare function normalizeOutputMessages(param: OutputMessagesParam): OutputMessages;
|
|
27
|
+
/**
|
|
28
|
+
* Serializes a versioned message wrapper to JSON.
|
|
29
|
+
*
|
|
30
|
+
* The output is the full wrapper object: `{"version":"0.1.0","messages":[...]}`.
|
|
31
|
+
*
|
|
32
|
+
* The try/catch ensures telemetry recording is non-throwing even when
|
|
33
|
+
* message parts contain non-JSON-serializable values (e.g. BigInt, circular refs).
|
|
34
|
+
*/
|
|
35
|
+
export declare function serializeMessages(wrapper: InputMessages | OutputMessages): string;
|
|
36
|
+
//# sourceMappingURL=message-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message-utils.d.ts","sourceRoot":"","sources":["../../../src/tracing/message-utils.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,WAAW,EACX,aAAa,EAEb,aAAa,EACb,cAAc,EACd,kBAAkB,EAClB,mBAAmB,EAEpB,MAAM,aAAa,CAAC;AAErB;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,kBAAkB,GAAG,mBAAmB,GAAG,KAAK,IAAI,aAAa,GAAG,cAAc,CAE1H;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,WAAW,EAAE,CAKjE;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,aAAa,EAAE,CAKpE;AAED;;;;GAIG;AACH,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,kBAAkB,GAAG,aAAa,CAM/E;AAED;;;;GAIG;AACH,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,mBAAmB,GAAG,cAAc,CAMlF;AAED;;;;;;;GAOG;AACH,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,aAAa,GAAG,cAAc,GAAG,MAAM,CAmBjF"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Copyright (c) Microsoft Corporation.
|
|
3
|
+
// Licensed under the MIT License.
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.isWrappedMessages = isWrappedMessages;
|
|
6
|
+
exports.toInputMessages = toInputMessages;
|
|
7
|
+
exports.toOutputMessages = toOutputMessages;
|
|
8
|
+
exports.normalizeInputMessages = normalizeInputMessages;
|
|
9
|
+
exports.normalizeOutputMessages = normalizeOutputMessages;
|
|
10
|
+
exports.serializeMessages = serializeMessages;
|
|
11
|
+
const contracts_1 = require("./contracts");
|
|
12
|
+
/**
|
|
13
|
+
* Type guard that returns `true` when the input is a versioned wrapper
|
|
14
|
+
* object (`InputMessages` or `OutputMessages`).
|
|
15
|
+
*/
|
|
16
|
+
function isWrappedMessages(input) {
|
|
17
|
+
return !Array.isArray(input) && typeof input === 'object' && input !== null && 'version' in input && 'messages' in input;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Converts plain input strings into OTEL input messages.
|
|
21
|
+
*/
|
|
22
|
+
function toInputMessages(messages) {
|
|
23
|
+
return messages.map((content) => ({
|
|
24
|
+
role: contracts_1.MessageRole.USER,
|
|
25
|
+
parts: [{ type: 'text', content }]
|
|
26
|
+
}));
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Converts plain output strings into OTEL output messages.
|
|
30
|
+
*/
|
|
31
|
+
function toOutputMessages(messages) {
|
|
32
|
+
return messages.map((content) => ({
|
|
33
|
+
role: contracts_1.MessageRole.ASSISTANT,
|
|
34
|
+
parts: [{ type: 'text', content }]
|
|
35
|
+
}));
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Normalizes an `InputMessagesParam` to a versioned `InputMessages` wrapper.
|
|
39
|
+
* - `string` / `string[]` → converted to `ChatMessage[]` and wrapped
|
|
40
|
+
* - `InputMessages` → returned as-is
|
|
41
|
+
*/
|
|
42
|
+
function normalizeInputMessages(param) {
|
|
43
|
+
if (typeof param === 'string' || Array.isArray(param)) {
|
|
44
|
+
const arr = typeof param === 'string' ? [param] : param;
|
|
45
|
+
return { version: contracts_1.A365_MESSAGE_SCHEMA_VERSION, messages: toInputMessages(arr) };
|
|
46
|
+
}
|
|
47
|
+
return param;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Normalizes an `OutputMessagesParam` to a versioned `OutputMessages` wrapper.
|
|
51
|
+
* - `string` / `string[]` → converted to `OutputMessage[]` and wrapped
|
|
52
|
+
* - `OutputMessages` → returned as-is
|
|
53
|
+
*/
|
|
54
|
+
function normalizeOutputMessages(param) {
|
|
55
|
+
if (typeof param === 'string' || Array.isArray(param)) {
|
|
56
|
+
const arr = typeof param === 'string' ? [param] : param;
|
|
57
|
+
return { version: contracts_1.A365_MESSAGE_SCHEMA_VERSION, messages: toOutputMessages(arr) };
|
|
58
|
+
}
|
|
59
|
+
return param;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Serializes a versioned message wrapper to JSON.
|
|
63
|
+
*
|
|
64
|
+
* The output is the full wrapper object: `{"version":"0.1.0","messages":[...]}`.
|
|
65
|
+
*
|
|
66
|
+
* The try/catch ensures telemetry recording is non-throwing even when
|
|
67
|
+
* message parts contain non-JSON-serializable values (e.g. BigInt, circular refs).
|
|
68
|
+
*/
|
|
69
|
+
function serializeMessages(wrapper) {
|
|
70
|
+
try {
|
|
71
|
+
return JSON.stringify(wrapper);
|
|
72
|
+
}
|
|
73
|
+
catch {
|
|
74
|
+
return JSON.stringify({
|
|
75
|
+
version: contracts_1.A365_MESSAGE_SCHEMA_VERSION,
|
|
76
|
+
messages: [
|
|
77
|
+
{
|
|
78
|
+
role: contracts_1.MessageRole.SYSTEM,
|
|
79
|
+
parts: [
|
|
80
|
+
{
|
|
81
|
+
type: 'text',
|
|
82
|
+
content: `[serialization failed: ${wrapper.messages.length} ${wrapper.messages.length === 1 ? 'message' : 'messages'}]`
|
|
83
|
+
}
|
|
84
|
+
]
|
|
85
|
+
}
|
|
86
|
+
]
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=message-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message-utils.js","sourceRoot":"","sources":["../../../src/tracing/message-utils.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;AAiBlC,8CAEC;AAKD,0CAKC;AAKD,4CAKC;AAOD,wDAMC;AAOD,0DAMC;AAUD,8CAmBC;AA5FD,2CASqB;AAErB;;;GAGG;AACH,SAAgB,iBAAiB,CAAC,KAA+C;IAC/E,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,SAAS,IAAI,KAAK,IAAI,UAAU,IAAI,KAAK,CAAC;AAC3H,CAAC;AAED;;GAEG;AACH,SAAgB,eAAe,CAAC,QAAkB;IAChD,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAChC,IAAI,EAAE,uBAAW,CAAC,IAAI;QACtB,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,OAAO,EAAE,CAAC;KAC5C,CAAC,CAAC,CAAC;AACN,CAAC;AAED;;GAEG;AACH,SAAgB,gBAAgB,CAAC,QAAkB;IACjD,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAChC,IAAI,EAAE,uBAAW,CAAC,SAAS;QAC3B,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,OAAO,EAAE,CAAC;KAC5C,CAAC,CAAC,CAAC;AACN,CAAC;AAED;;;;GAIG;AACH,SAAgB,sBAAsB,CAAC,KAAyB;IAC9D,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACtD,MAAM,GAAG,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACxD,OAAO,EAAE,OAAO,EAAE,uCAA2B,EAAE,QAAQ,EAAE,eAAe,CAAC,GAAG,CAAC,EAAE,CAAC;IAClF,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;;;GAIG;AACH,SAAgB,uBAAuB,CAAC,KAA0B;IAChE,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACtD,MAAM,GAAG,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACxD,OAAO,EAAE,OAAO,EAAE,uCAA2B,EAAE,QAAQ,EAAE,gBAAgB,CAAC,GAAG,CAAC,EAAE,CAAC;IACnF,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,iBAAiB,CAAC,OAAuC;IACvE,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC,SAAS,CAAC;YACpB,OAAO,EAAE,uCAA2B;YACpC,QAAQ,EAAE;gBACR;oBACE,IAAI,EAAE,uBAAW,CAAC,MAAM;oBACxB,KAAK,EAAE;wBACL;4BACE,IAAI,EAAE,MAAM;4BACZ,OAAO,EAAE,0BAA0B,OAAO,CAAC,QAAQ,CAAC,MAAM,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,GAAG;yBACxH;qBACF;iBACF;aACF;SACF,CAAC,CAAC;IACL,CAAC;AACH,CAAC"}
|
|
@@ -11,15 +11,15 @@ export declare class ExecuteToolScope extends OpenTelemetryScope {
|
|
|
11
11
|
* @param details The tool call details (name, type, args, call id, etc.).
|
|
12
12
|
* @param agentDetails The agent executing the tool. Tenant ID is derived from `agentDetails.tenantId`.
|
|
13
13
|
* @param userDetails Optional human caller identity.
|
|
14
|
-
* @param spanDetails Optional span configuration (parentContext, startTime, endTime, spanLinks).
|
|
14
|
+
* @param spanDetails Optional span configuration (parentContext, startTime, endTime, spanLinks, spanKind). Defaults to SpanKind.INTERNAL.
|
|
15
15
|
* @returns A new ExecuteToolScope instance.
|
|
16
16
|
*/
|
|
17
17
|
static start(request: Request, details: ToolCallDetails, agentDetails: AgentDetails, userDetails?: UserDetails, spanDetails?: SpanDetails): ExecuteToolScope;
|
|
18
18
|
private constructor();
|
|
19
19
|
/**
|
|
20
20
|
* Records response information for telemetry tracking.
|
|
21
|
-
* @param response The tool execution response
|
|
21
|
+
* @param response The tool execution response. Objects are serialized to JSON automatically.
|
|
22
22
|
*/
|
|
23
|
-
recordResponse(response: string): void;
|
|
23
|
+
recordResponse(response: Record<string, unknown> | string): void;
|
|
24
24
|
}
|
|
25
25
|
//# sourceMappingURL=ExecuteToolScope.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
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;
|
|
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;AAItB;;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;IAiDP;;;OAGG;IACI,cAAc,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,GAAG,IAAI;CAMxE"}
|
|
@@ -6,6 +6,7 @@ exports.ExecuteToolScope = void 0;
|
|
|
6
6
|
const api_1 = require("@opentelemetry/api");
|
|
7
7
|
const OpenTelemetryScope_1 = require("./OpenTelemetryScope");
|
|
8
8
|
const constants_1 = require("../constants");
|
|
9
|
+
const util_1 = require("../util");
|
|
9
10
|
/**
|
|
10
11
|
* Provides OpenTelemetry tracing scope for AI tool execution operations.
|
|
11
12
|
*/
|
|
@@ -17,7 +18,7 @@ class ExecuteToolScope extends OpenTelemetryScope_1.OpenTelemetryScope {
|
|
|
17
18
|
* @param details The tool call details (name, type, args, call id, etc.).
|
|
18
19
|
* @param agentDetails The agent executing the tool. Tenant ID is derived from `agentDetails.tenantId`.
|
|
19
20
|
* @param userDetails Optional human caller identity.
|
|
20
|
-
* @param spanDetails Optional span configuration (parentContext, startTime, endTime, spanLinks).
|
|
21
|
+
* @param spanDetails Optional span configuration (parentContext, startTime, endTime, spanLinks, spanKind). Defaults to SpanKind.INTERNAL.
|
|
21
22
|
* @returns A new ExecuteToolScope instance.
|
|
22
23
|
*/
|
|
23
24
|
static start(request, details, agentDetails, userDetails, spanDetails) {
|
|
@@ -28,13 +29,13 @@ class ExecuteToolScope extends OpenTelemetryScope_1.OpenTelemetryScope {
|
|
|
28
29
|
if (!agentDetails.tenantId) {
|
|
29
30
|
throw new Error('ExecuteToolScope: tenantId is required on agentDetails');
|
|
30
31
|
}
|
|
31
|
-
//
|
|
32
|
-
const resolvedSpanDetails = {
|
|
32
|
+
// Default to INTERNAL; allow caller override via spanDetails
|
|
33
|
+
const resolvedSpanDetails = { spanKind: api_1.SpanKind.INTERNAL, ...spanDetails };
|
|
33
34
|
super(constants_1.OpenTelemetryConstants.EXECUTE_TOOL_OPERATION_NAME, `${constants_1.OpenTelemetryConstants.EXECUTE_TOOL_OPERATION_NAME} ${details.toolName}`, agentDetails, resolvedSpanDetails, userDetails);
|
|
34
35
|
// Destructure the details object
|
|
35
36
|
const { toolName, arguments: args, toolCallId, description, toolType, endpoint } = details;
|
|
36
37
|
this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_NAME_KEY, toolName);
|
|
37
|
-
this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_ARGS_KEY, args);
|
|
38
|
+
this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_ARGS_KEY, args != null ? (0, util_1.safeSerializeToJson)(args, 'arguments') : undefined);
|
|
38
39
|
this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_TYPE_KEY, toolType);
|
|
39
40
|
this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_CALL_ID_KEY, toolCallId);
|
|
40
41
|
this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_DESCRIPTION_KEY, description);
|
|
@@ -52,10 +53,10 @@ class ExecuteToolScope extends OpenTelemetryScope_1.OpenTelemetryScope {
|
|
|
52
53
|
}
|
|
53
54
|
/**
|
|
54
55
|
* Records response information for telemetry tracking.
|
|
55
|
-
* @param response The tool execution response
|
|
56
|
+
* @param response The tool execution response. Objects are serialized to JSON automatically.
|
|
56
57
|
*/
|
|
57
58
|
recordResponse(response) {
|
|
58
|
-
this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_CALL_RESULT_KEY, response);
|
|
59
|
+
this.setTagMaybe(constants_1.OpenTelemetryConstants.GEN_AI_TOOL_CALL_RESULT_KEY, (0, util_1.safeSerializeToJson)(response, 'result'));
|
|
59
60
|
}
|
|
60
61
|
}
|
|
61
62
|
exports.ExecuteToolScope = ExecuteToolScope;
|
|
@@ -1 +1 @@
|
|
|
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;
|
|
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;AACtD,kCAA8C;AAE9C;;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,6DAA6D;QAC7D,MAAM,mBAAmB,GAAgB,EAAE,QAAQ,EAAE,cAAQ,CAAC,QAAQ,EAAE,GAAG,WAAW,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,CACd,kCAAsB,CAAC,oBAAoB,EAC3C,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,IAAA,0BAAmB,EAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,SAAS,CAClE,CAAC;QACF,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,QAA0C;QAC9D,IAAI,CAAC,WAAW,CACd,kCAAsB,CAAC,2BAA2B,EAClD,IAAA,0BAAmB,EAAC,QAAQ,EAAE,QAAQ,CAAC,CACxC,CAAC;IACJ,CAAC;CACF;AAhFD,4CAgFC"}
|