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