@amplitude/ai 0.3.4 → 0.3.6

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 (45) hide show
  1. package/AGENTS.md +1 -1
  2. package/README.md +176 -172
  3. package/data/agent_event_catalog.json +18 -3
  4. package/dist/client.d.ts +1 -0
  5. package/dist/client.d.ts.map +1 -1
  6. package/dist/client.js +1 -0
  7. package/dist/client.js.map +1 -1
  8. package/dist/core/constants.d.ts +4 -1
  9. package/dist/core/constants.d.ts.map +1 -1
  10. package/dist/core/constants.js +4 -1
  11. package/dist/core/constants.js.map +1 -1
  12. package/dist/core/privacy.d.ts +7 -1
  13. package/dist/core/privacy.d.ts.map +1 -1
  14. package/dist/core/privacy.js +79 -2
  15. package/dist/core/privacy.js.map +1 -1
  16. package/dist/core/tracking.d.ts +3 -2
  17. package/dist/core/tracking.d.ts.map +1 -1
  18. package/dist/core/tracking.js +4 -2
  19. package/dist/core/tracking.js.map +1 -1
  20. package/dist/index.d.ts +3 -3
  21. package/dist/index.js +3 -3
  22. package/dist/providers/anthropic.d.ts.map +1 -1
  23. package/dist/providers/anthropic.js +9 -1
  24. package/dist/providers/anthropic.js.map +1 -1
  25. package/dist/providers/bedrock.d.ts.map +1 -1
  26. package/dist/providers/bedrock.js +8 -0
  27. package/dist/providers/bedrock.js.map +1 -1
  28. package/dist/providers/gemini.d.ts.map +1 -1
  29. package/dist/providers/gemini.js +6 -0
  30. package/dist/providers/gemini.js.map +1 -1
  31. package/dist/providers/mistral.d.ts.map +1 -1
  32. package/dist/providers/mistral.js +6 -0
  33. package/dist/providers/mistral.js.map +1 -1
  34. package/dist/providers/openai.d.ts +2 -1
  35. package/dist/providers/openai.d.ts.map +1 -1
  36. package/dist/providers/openai.js +24 -3
  37. package/dist/providers/openai.js.map +1 -1
  38. package/dist/types.d.ts +1 -0
  39. package/dist/types.d.ts.map +1 -1
  40. package/dist/types.js.map +1 -1
  41. package/dist/utils/logger.d.ts.map +1 -1
  42. package/llms-full.txt +1 -1
  43. package/llms.txt +1 -1
  44. package/mcp.schema.json +1 -1
  45. package/package.json +1 -1
@@ -1,7 +1,7 @@
1
1
  import { ValidationError } from "../exceptions.js";
2
2
  import { getLogger } from "../utils/logger.js";
3
3
  import { inferModelTier } from "../utils/model-tiers.js";
4
- import { EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, MAX_SERIALIZED_LENGTH, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, SDK_RUNTIME, SDK_VERSION } from "./constants.js";
4
+ import { EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, MAX_SERIALIZED_LENGTH, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_DEFINITIONS, PROP_TOOL_DEFINITIONS_COUNT, PROP_TOOL_DEFINITIONS_HASH, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, SDK_RUNTIME, SDK_VERSION } from "./constants.js";
5
5
  import { PrivacyConfig, getTextFromLlmMessage, sanitizeStructuredContent } from "./privacy.js";
6
6
  import { randomUUID } from "node:crypto";
7
7
 
@@ -141,6 +141,8 @@ function trackAiMessage(opts) {
141
141
  Object.assign(properties, reasoningProps);
142
142
  const systemPromptProps = pc.sanitizeSystemPrompt(opts.systemPrompt ?? null);
143
143
  Object.assign(properties, systemPromptProps);
144
+ const toolDefProps = pc.sanitizeToolDefinitions(opts.toolDefinitions);
145
+ Object.assign(properties, toolDefProps);
144
146
  if (opts.temperature != null) properties[PROP_TEMPERATURE] = opts.temperature;
145
147
  if (opts.maxOutputTokens != null) properties[PROP_MAX_OUTPUT_TOKENS] = opts.maxOutputTokens;
146
148
  if (opts.topP != null) properties[PROP_TOP_P] = opts.topP;
@@ -476,5 +478,5 @@ function trackScore(opts) {
476
478
  }
477
479
 
478
480
  //#endregion
479
- export { EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, MAX_SERIALIZED_LENGTH, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, SDK_RUNTIME, SDK_VERSION, serializeToJsonString, trackAiMessage, trackConversation, trackEmbedding, trackScore, trackSessionEnd, trackSessionEnrichment, trackSpan, trackToolCall, trackUserMessage };
481
+ export { EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, MAX_SERIALIZED_LENGTH, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_DEFINITIONS, PROP_TOOL_DEFINITIONS_COUNT, PROP_TOOL_DEFINITIONS_HASH, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, SDK_RUNTIME, SDK_VERSION, serializeToJsonString, trackAiMessage, trackConversation, trackEmbedding, trackScore, trackSessionEnd, trackSessionEnrichment, trackSpan, trackToolCall, trackUserMessage };
480
482
  //# sourceMappingURL=tracking.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tracking.js","names":["serialized: string","properties: Record<string, unknown>","event: AmplitudeEvent"],"sources":["../../src/core/tracking.ts"],"sourcesContent":["import { randomUUID } from 'node:crypto';\nimport { ValidationError } from '../exceptions.js';\nimport type {\n AmplitudeEvent,\n AmplitudeLike,\n Attachment,\n ToolCallShape,\n} from '../types.js';\nimport { getLogger } from '../utils/logger.js';\nimport { inferModelTier } from '../utils/model-tiers.js';\nimport {\n EVENT_AI_RESPONSE,\n EVENT_EMBEDDING,\n EVENT_SCORE,\n EVENT_SESSION_END,\n EVENT_SESSION_ENRICHMENT,\n EVENT_SPAN,\n EVENT_TOOL_CALL,\n EVENT_USER_MESSAGE,\n MAX_SERIALIZED_LENGTH,\n PROP_ABANDONMENT_TURN,\n PROP_AGENT_DESCRIPTION,\n PROP_AGENT_ID,\n PROP_AGENT_VERSION,\n PROP_ATTACHMENT_COUNT,\n PROP_ATTACHMENT_TYPES,\n PROP_ATTACHMENTS,\n PROP_CACHE_CREATION_TOKENS,\n PROP_CACHE_READ_TOKENS,\n PROP_COMMENT,\n PROP_COMPONENT_TYPE,\n PROP_CONTEXT,\n PROP_COST_USD,\n PROP_CUSTOMER_ORG_ID,\n PROP_EDITED_MESSAGE_ID,\n PROP_EMBEDDING_DIMENSIONS,\n PROP_ENRICHMENTS,\n PROP_ENV,\n PROP_ERROR_MESSAGE,\n PROP_EVALUATION_SOURCE,\n PROP_FINISH_REASON,\n PROP_HAS_ATTACHMENTS,\n PROP_IDLE_TIMEOUT_MINUTES,\n PROP_INPUT_STATE,\n PROP_INPUT_TOKENS,\n PROP_INVOCATION_ID,\n PROP_IS_EDIT,\n PROP_IS_ERROR,\n PROP_IS_REGENERATION,\n PROP_IS_STREAMING,\n PROP_LATENCY_MS,\n PROP_LOCALE,\n PROP_MAX_OUTPUT_TOKENS,\n PROP_MESSAGE_ID,\n PROP_MESSAGE_LABELS,\n PROP_MESSAGE_SOURCE,\n PROP_MODEL_NAME,\n PROP_MODEL_TIER,\n PROP_OUTPUT_STATE,\n PROP_OUTPUT_TOKENS,\n PROP_PARENT_AGENT_ID,\n PROP_PARENT_MESSAGE_ID,\n PROP_PARENT_SPAN_ID,\n PROP_PROMPT_ID,\n PROP_PROVIDER,\n PROP_REASONING_TOKENS,\n PROP_RUNTIME,\n PROP_SCORE_NAME,\n PROP_SCORE_VALUE,\n PROP_SDK_VERSION,\n PROP_SESSION_ID,\n PROP_SPAN_ID,\n PROP_SPAN_KIND,\n PROP_SPAN_NAME,\n PROP_TARGET_ID,\n PROP_TARGET_TYPE,\n PROP_TEMPERATURE,\n PROP_TOOL_CALLS,\n PROP_TOOL_INPUT,\n PROP_TOOL_NAME,\n PROP_TOOL_OUTPUT,\n PROP_TOOL_SUCCESS,\n PROP_TOP_P,\n PROP_TOTAL_ATTACHMENT_SIZE,\n PROP_TOTAL_TOKENS,\n PROP_TRACE_ID,\n PROP_TTFB_MS,\n PROP_TURN_ID,\n PROP_WAS_CACHED,\n PROP_WAS_COPIED,\n SDK_RUNTIME,\n SDK_VERSION,\n} from './constants.js';\nimport type { MessageLabel, SessionEnrichments } from './enrichments.js';\nimport {\n getTextFromLlmMessage,\n PrivacyConfig,\n sanitizeStructuredContent,\n} from './privacy.js';\n\n// Re-export constants and SDK_VERSION for public API\nexport * from './constants.js';\n\nfunction validateRequiredStr(value: unknown, fieldName: string): void {\n if (typeof value !== 'string' || !value) {\n throw new ValidationError(\n `${fieldName} must be a non-empty string, got ${String(value)}`,\n );\n }\n}\n\nfunction validateNonNegative(value: unknown, fieldName: string): void {\n if (typeof value === 'number' && value < 0) {\n throw new ValidationError(`${fieldName} must be >= 0, got ${value}`);\n }\n}\n\nfunction validateNumeric(value: unknown, fieldName: string): void {\n if (typeof value !== 'number') {\n throw new ValidationError(\n `${fieldName} must be numeric, got ${typeof value}`,\n );\n }\n}\n\nexport function serializeToJsonString(\n value: unknown,\n maxLength = MAX_SERIALIZED_LENGTH,\n): string {\n let serialized: string;\n try {\n serialized = JSON.stringify(value);\n } catch {\n serialized = String(value);\n }\n\n if (serialized.length > maxLength) {\n const truncateAt = Math.max(0, maxLength - 14);\n return `${serialized.slice(0, truncateAt)}...[truncated]`;\n }\n return serialized;\n}\n\nfunction withSdkManagedProperties(\n eventProperties: Record<string, unknown> | null | undefined,\n managedProperties: Record<string, unknown>,\n): Record<string, unknown> {\n // SDK-managed keys must win over caller-provided eventProperties.\n return { ...(eventProperties ?? {}), ...managedProperties };\n}\n\n// --------------------------------------------------------\n// track_user_message\n// --------------------------------------------------------\n\nexport interface TrackUserMessageOptions {\n amplitude: AmplitudeLike;\n userId: string;\n messageContent: string;\n sessionId?: string | null;\n traceId?: string | null;\n turnId?: number;\n messageId?: string | null;\n conversationId?: string | null;\n env?: string | null;\n locale?: string | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n isRegeneration?: boolean;\n isEdit?: boolean;\n editedMessageId?: string | null;\n attachments?: Attachment[] | null;\n messageSource?: string | null;\n labels?: MessageLabel[] | null;\n eventProperties?: Record<string, unknown> | null;\n userProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackUserMessage(opts: TrackUserMessageOptions): string {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateRequiredStr(opts.sessionId, 'sessionId');\n }\n\n const messageId = opts.messageId || randomUUID();\n const contentData = pc.sanitizeContent(opts.messageContent);\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_TURN_ID]: opts.turnId ?? 1,\n [PROP_MESSAGE_ID]: messageId,\n [PROP_COMPONENT_TYPE]: 'user_input',\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.traceId) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.conversationId && !opts.sessionId)\n properties[PROP_SESSION_ID] = opts.conversationId;\n if (opts.env) properties[PROP_ENV] = opts.env;\n if (opts.locale) properties[PROP_LOCALE] = opts.locale;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.messageSource) properties[PROP_MESSAGE_SOURCE] = opts.messageSource;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n\n if (opts.isRegeneration) properties[PROP_IS_REGENERATION] = true;\n if (opts.isEdit) properties[PROP_IS_EDIT] = true;\n if (opts.editedMessageId)\n properties[PROP_EDITED_MESSAGE_ID] = opts.editedMessageId;\n\n if (opts.attachments?.length) {\n properties[PROP_HAS_ATTACHMENTS] = true;\n properties[PROP_ATTACHMENT_COUNT] = opts.attachments.length;\n const types = [\n ...new Set(opts.attachments.map((a) => String(a.type ?? 'unknown'))),\n ];\n properties[PROP_ATTACHMENT_TYPES] = types;\n const totalSize = opts.attachments.reduce(\n (sum, a) => sum + (typeof a.size_bytes === 'number' ? a.size_bytes : 0),\n 0,\n );\n if (totalSize > 0) properties[PROP_TOTAL_ATTACHMENT_SIZE] = totalSize;\n properties[PROP_ATTACHMENTS] = serializeToJsonString(opts.attachments);\n }\n\n if (opts.labels?.length) {\n properties[PROP_MESSAGE_LABELS] = serializeToJsonString(\n opts.labels.map((lbl) => lbl.toDict()),\n );\n }\n\n Object.assign(properties, contentData);\n\n const event: AmplitudeEvent = {\n event_type: EVENT_USER_MESSAGE,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.userProperties) event.user_properties = opts.userProperties;\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_USER_MESSAGE} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(\n `Failed to track ${EVENT_USER_MESSAGE}: ${e}`,\n );\n }\n\n return messageId;\n}\n\n// --------------------------------------------------------\n// track_ai_message\n// --------------------------------------------------------\n\nexport interface TrackAiMessageOptions {\n amplitude: AmplitudeLike;\n userId: string;\n modelName: string;\n provider: string;\n responseContent: string;\n latencyMs: number;\n sessionId?: string | null;\n traceId?: string | null;\n turnId?: number;\n messageId?: string | null;\n conversationId?: string | null;\n inputTokens?: number | null;\n outputTokens?: number | null;\n totalTokens?: number | null;\n reasoningTokens?: number | null;\n cacheReadInputTokens?: number | null;\n cacheCreationInputTokens?: number | null;\n totalCostUsd?: number | null;\n providerTtfbMs?: number | null;\n isError?: boolean;\n errorMessage?: string | null;\n finishReason?: string | null;\n toolCalls?: Array<ToolCallShape | Record<string, unknown>> | null;\n reasoningContent?: string | null;\n systemPrompt?: string | null;\n temperature?: number | null;\n maxOutputTokens?: number | null;\n topP?: number | null;\n isStreaming?: boolean | null;\n promptId?: string | null;\n wasCopied?: boolean;\n wasCached?: boolean;\n modelTier?: string | null;\n attachments?: Attachment[] | null;\n labels?: MessageLabel[] | null;\n env?: string | null;\n locale?: string | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n spanKind?: string | null;\n eventProperties?: Record<string, unknown> | null;\n userProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackAiMessage(opts: TrackAiMessageOptions): string {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateRequiredStr(opts.modelName, 'model');\n validateNonNegative(opts.latencyMs, 'latencyMs');\n }\n\n const messageId = opts.messageId || randomUUID();\n const contentData = pc.sanitizeContent(opts.responseContent);\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_TURN_ID]: opts.turnId ?? 2,\n [PROP_MESSAGE_ID]: messageId,\n [PROP_MODEL_NAME]: opts.modelName,\n [PROP_PROVIDER]: opts.provider,\n [PROP_LATENCY_MS]: opts.latencyMs,\n [PROP_IS_ERROR]: opts.isError ?? false,\n [PROP_COMPONENT_TYPE]: 'llm',\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.traceId) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.conversationId && !opts.sessionId)\n properties[PROP_SESSION_ID] = opts.conversationId;\n if (opts.env) properties[PROP_ENV] = opts.env;\n if (opts.locale) properties[PROP_LOCALE] = opts.locale;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.spanKind) properties[PROP_SPAN_KIND] = opts.spanKind;\n\n if (opts.wasCopied) properties[PROP_WAS_COPIED] = true;\n if (opts.wasCached) properties[PROP_WAS_CACHED] = true;\n\n // Model tier (user override or auto-inferred)\n if (opts.modelTier != null) {\n properties[PROP_MODEL_TIER] = opts.modelTier;\n } else {\n properties[PROP_MODEL_TIER] = inferModelTier(opts.modelName);\n }\n\n Object.assign(properties, contentData);\n\n // Token usage\n if (opts.inputTokens != null)\n properties[PROP_INPUT_TOKENS] = opts.inputTokens;\n if (opts.outputTokens != null)\n properties[PROP_OUTPUT_TOKENS] = opts.outputTokens;\n if (opts.totalTokens != null)\n properties[PROP_TOTAL_TOKENS] = opts.totalTokens;\n if (opts.reasoningTokens != null)\n properties[PROP_REASONING_TOKENS] = opts.reasoningTokens;\n if (opts.cacheReadInputTokens != null)\n properties[PROP_CACHE_READ_TOKENS] = opts.cacheReadInputTokens;\n if (opts.cacheCreationInputTokens != null)\n properties[PROP_CACHE_CREATION_TOKENS] = opts.cacheCreationInputTokens;\n\n if (opts.totalCostUsd != null) properties[PROP_COST_USD] = opts.totalCostUsd;\n if (opts.providerTtfbMs != null)\n properties[PROP_TTFB_MS] = opts.providerTtfbMs;\n if (opts.finishReason != null)\n properties[PROP_FINISH_REASON] = opts.finishReason;\n if (opts.errorMessage != null)\n properties[PROP_ERROR_MESSAGE] = opts.errorMessage;\n if (opts.toolCalls != null)\n properties[PROP_TOOL_CALLS] = serializeToJsonString(opts.toolCalls);\n\n // Reasoning content\n const reasoningProps = pc.sanitizeReasoningContent(\n opts.reasoningContent ?? null,\n opts.reasoningTokens,\n );\n Object.assign(properties, reasoningProps);\n\n // System prompt\n const systemPromptProps = pc.sanitizeSystemPrompt(opts.systemPrompt ?? null);\n Object.assign(properties, systemPromptProps);\n\n if (opts.temperature != null) properties[PROP_TEMPERATURE] = opts.temperature;\n if (opts.maxOutputTokens != null)\n properties[PROP_MAX_OUTPUT_TOKENS] = opts.maxOutputTokens;\n if (opts.topP != null) properties[PROP_TOP_P] = opts.topP;\n if (opts.isStreaming != null)\n properties[PROP_IS_STREAMING] = opts.isStreaming;\n if (opts.promptId != null) properties[PROP_PROMPT_ID] = opts.promptId;\n\n if (opts.attachments?.length) {\n properties[PROP_HAS_ATTACHMENTS] = true;\n properties[PROP_ATTACHMENT_COUNT] = opts.attachments.length;\n const types = [\n ...new Set(opts.attachments.map((a) => String(a.type ?? 'unknown'))),\n ];\n properties[PROP_ATTACHMENT_TYPES] = types;\n const totalSize = opts.attachments.reduce(\n (sum, a) => sum + (typeof a.size_bytes === 'number' ? a.size_bytes : 0),\n 0,\n );\n if (totalSize > 0) properties[PROP_TOTAL_ATTACHMENT_SIZE] = totalSize;\n properties[PROP_ATTACHMENTS] = serializeToJsonString(opts.attachments);\n }\n\n if (opts.labels?.length) {\n properties[PROP_MESSAGE_LABELS] = serializeToJsonString(\n opts.labels.map((lbl) => lbl.toDict()),\n );\n }\n\n const event: AmplitudeEvent = {\n event_type: EVENT_AI_RESPONSE,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.userProperties) event.user_properties = opts.userProperties;\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_AI_RESPONSE} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(\n `Failed to track ${EVENT_AI_RESPONSE}: ${e}`,\n );\n }\n\n return messageId;\n}\n\n// --------------------------------------------------------\n// track_tool_call\n// --------------------------------------------------------\n\nexport interface TrackToolCallOptions {\n amplitude: AmplitudeLike;\n userId: string;\n toolName: string;\n success: boolean;\n latencyMs: number;\n sessionId?: string | null;\n traceId?: string | null;\n turnId?: number;\n toolInput?: unknown;\n toolOutput?: unknown;\n invocationId?: string | null;\n conversationId?: string | null;\n parentMessageId?: string | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n errorMessage?: string | null;\n env?: string | null;\n locale?: string | null;\n spanKind?: string | null;\n eventProperties?: Record<string, unknown> | null;\n userProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackToolCall(opts: TrackToolCallOptions): string {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateRequiredStr(opts.toolName, 'toolName');\n validateNonNegative(opts.latencyMs, 'latencyMs');\n }\n\n const invocationId = opts.invocationId || randomUUID();\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_TURN_ID]: opts.turnId ?? 1,\n [PROP_INVOCATION_ID]: invocationId,\n [PROP_TOOL_NAME]: opts.toolName,\n [PROP_TOOL_SUCCESS]: opts.success,\n [PROP_IS_ERROR]: !opts.success,\n [PROP_LATENCY_MS]: opts.latencyMs,\n [PROP_COMPONENT_TYPE]: 'tool',\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.traceId) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.conversationId && !opts.sessionId)\n properties[PROP_SESSION_ID] = opts.conversationId;\n if (opts.parentMessageId)\n properties[PROP_PARENT_MESSAGE_ID] = opts.parentMessageId;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.errorMessage) properties[PROP_ERROR_MESSAGE] = opts.errorMessage;\n if (opts.env) properties[PROP_ENV] = opts.env;\n if (opts.locale) properties[PROP_LOCALE] = opts.locale;\n if (opts.spanKind) properties[PROP_SPAN_KIND] = opts.spanKind;\n\n let effectiveMode = pc.contentMode;\n if (effectiveMode == null)\n effectiveMode = pc.privacyMode ? 'metadata_only' : 'full';\n\n if (opts.toolInput != null && effectiveMode === 'full') {\n const sanitized = sanitizeStructuredContent(opts.toolInput, pc.redactPii);\n properties[PROP_TOOL_INPUT] = serializeToJsonString(sanitized);\n }\n\n if (opts.toolOutput != null && effectiveMode === 'full') {\n const sanitized = sanitizeStructuredContent(opts.toolOutput, pc.redactPii);\n properties[PROP_TOOL_OUTPUT] = serializeToJsonString(sanitized);\n }\n\n const event: AmplitudeEvent = {\n event_type: EVENT_TOOL_CALL,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.userProperties) event.user_properties = opts.userProperties;\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_TOOL_CALL} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(`Failed to track ${EVENT_TOOL_CALL}: ${e}`);\n }\n\n return invocationId;\n}\n\n// --------------------------------------------------------\n// track_conversation\n// --------------------------------------------------------\n\nexport interface TrackConversationOptions {\n amplitude: AmplitudeLike;\n userId: string;\n messages: Array<Record<string, unknown>>;\n sessionId?: string | null;\n conversationId?: string | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n eventProperties?: Record<string, unknown> | null;\n userProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackConversation(opts: TrackConversationOptions): void {\n const effectiveSessionId =\n opts.sessionId ?? opts.conversationId ?? randomUUID();\n let turnId = 1;\n\n for (const message of opts.messages) {\n const role = String(message.role ?? '');\n const content = String(message.content ?? '');\n\n if (role === 'user') {\n trackUserMessage({\n amplitude: opts.amplitude,\n userId: opts.userId,\n messageContent: content,\n sessionId: effectiveSessionId,\n turnId,\n agentId: opts.agentId,\n parentAgentId: opts.parentAgentId,\n customerOrgId: opts.customerOrgId,\n agentVersion: opts.agentVersion,\n description: opts.description,\n context: opts.context,\n env: opts.env,\n eventProperties: opts.eventProperties,\n userProperties: opts.userProperties,\n groups: opts.groups,\n privacyConfig: opts.privacyConfig,\n });\n } else if (role === 'assistant' || role === 'ai') {\n trackAiMessage({\n amplitude: opts.amplitude,\n userId: opts.userId,\n modelName: String(message.model ?? 'unknown'),\n provider: String(message.provider ?? 'unknown'),\n responseContent: content,\n latencyMs: Number(message.latency_ms ?? 0),\n sessionId: effectiveSessionId,\n turnId,\n inputTokens: message.input_tokens as number | undefined,\n outputTokens: message.output_tokens as number | undefined,\n totalTokens: message.total_tokens as number | undefined,\n totalCostUsd: message.total_cost_usd as number | undefined,\n agentId: opts.agentId,\n parentAgentId: opts.parentAgentId,\n customerOrgId: opts.customerOrgId,\n agentVersion: opts.agentVersion,\n description: opts.description,\n context: opts.context,\n env: opts.env,\n eventProperties: opts.eventProperties,\n userProperties: opts.userProperties,\n groups: opts.groups,\n privacyConfig: opts.privacyConfig,\n });\n }\n\n turnId++;\n }\n}\n\n// --------------------------------------------------------\n// track_embedding\n// --------------------------------------------------------\n\nexport interface TrackEmbeddingOptions {\n amplitude: AmplitudeLike;\n userId: string;\n model: string;\n provider: string;\n latencyMs: number;\n inputTokens?: number | null;\n dimensions?: number | null;\n totalCostUsd?: number | null;\n sessionId?: string | null;\n traceId?: string | null;\n turnId?: number | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n eventProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackEmbedding(opts: TrackEmbeddingOptions): string {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateNonNegative(opts.latencyMs, 'latencyMs');\n }\n\n const spanId = randomUUID();\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_SPAN_ID]: spanId,\n [PROP_MODEL_NAME]: opts.model,\n [PROP_PROVIDER]: opts.provider,\n [PROP_LATENCY_MS]: opts.latencyMs,\n [PROP_COMPONENT_TYPE]: 'embedding',\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.traceId != null) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.turnId != null) properties[PROP_TURN_ID] = opts.turnId;\n if (opts.inputTokens != null)\n properties[PROP_INPUT_TOKENS] = opts.inputTokens;\n if (opts.dimensions != null)\n properties[PROP_EMBEDDING_DIMENSIONS] = opts.dimensions;\n if (opts.totalCostUsd != null) properties[PROP_COST_USD] = opts.totalCostUsd;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.env) properties[PROP_ENV] = opts.env;\n\n const event: AmplitudeEvent = {\n event_type: EVENT_EMBEDDING,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_EMBEDDING} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(`Failed to track ${EVENT_EMBEDDING}: ${e}`);\n }\n\n return spanId;\n}\n\n// --------------------------------------------------------\n// track_span\n// --------------------------------------------------------\n\nexport interface TrackSpanOptions {\n amplitude: AmplitudeLike;\n userId: string;\n spanName: string;\n traceId: string;\n latencyMs: number;\n inputState?: Record<string, unknown> | null;\n outputState?: Record<string, unknown> | null;\n parentSpanId?: string | null;\n isError?: boolean;\n errorMessage?: string | null;\n sessionId?: string | null;\n turnId?: number | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n eventProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackSpan(opts: TrackSpanOptions): string {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateNonNegative(opts.latencyMs, 'latencyMs');\n }\n\n const spanId = randomUUID();\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_SPAN_ID]: spanId,\n [PROP_SPAN_NAME]: opts.spanName,\n [PROP_TRACE_ID]: opts.traceId,\n [PROP_LATENCY_MS]: opts.latencyMs,\n [PROP_IS_ERROR]: opts.isError ?? false,\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.turnId != null) properties[PROP_TURN_ID] = opts.turnId;\n if (opts.parentSpanId) properties[PROP_PARENT_SPAN_ID] = opts.parentSpanId;\n if (opts.errorMessage) properties[PROP_ERROR_MESSAGE] = opts.errorMessage;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.env) properties[PROP_ENV] = opts.env;\n\n let effectiveMode = pc.contentMode;\n if (effectiveMode == null)\n effectiveMode = pc.privacyMode ? 'metadata_only' : 'full';\n\n if (opts.inputState != null && effectiveMode === 'full') {\n const sanitized = sanitizeStructuredContent(opts.inputState, pc.redactPii);\n properties[PROP_INPUT_STATE] = serializeToJsonString(sanitized);\n }\n\n if (opts.outputState != null && effectiveMode === 'full') {\n const sanitized = sanitizeStructuredContent(opts.outputState, pc.redactPii);\n properties[PROP_OUTPUT_STATE] = serializeToJsonString(sanitized);\n }\n\n const event: AmplitudeEvent = {\n event_type: EVENT_SPAN,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_SPAN} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(`Failed to track ${EVENT_SPAN}: ${e}`);\n }\n\n return spanId;\n}\n\n// --------------------------------------------------------\n// track_session_end\n// --------------------------------------------------------\n\nexport interface TrackSessionEndOptions {\n amplitude: AmplitudeLike;\n userId: string;\n sessionId: string;\n enrichments?: SessionEnrichments | null;\n traceId?: string | null;\n turnId?: number | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n abandonmentTurn?: number | null;\n idleTimeoutMinutes?: number | null;\n eventProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackSessionEnd(opts: TrackSessionEndOptions): void {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateRequiredStr(opts.sessionId, 'sessionId');\n }\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_SESSION_ID]: opts.sessionId,\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.traceId != null) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.turnId != null) properties[PROP_TURN_ID] = opts.turnId;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.env) properties[PROP_ENV] = opts.env;\n if (opts.abandonmentTurn != null)\n properties[PROP_ABANDONMENT_TURN] = opts.abandonmentTurn;\n if (opts.idleTimeoutMinutes != null)\n properties[PROP_IDLE_TIMEOUT_MINUTES] = opts.idleTimeoutMinutes;\n\n if (opts.enrichments != null) {\n const enrichmentDict =\n typeof opts.enrichments.toDict === 'function'\n ? opts.enrichments.toDict()\n : opts.enrichments;\n properties[PROP_ENRICHMENTS] = serializeToJsonString(enrichmentDict);\n }\n\n const event: AmplitudeEvent = {\n event_type: EVENT_SESSION_END,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_SESSION_END} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(\n `Failed to track ${EVENT_SESSION_END}: ${e}`,\n );\n }\n}\n\n// --------------------------------------------------------\n// track_session_enrichment\n// --------------------------------------------------------\n\nexport interface TrackSessionEnrichmentOptions {\n amplitude: AmplitudeLike;\n userId: string;\n sessionId: string;\n enrichments: SessionEnrichments;\n traceId?: string | null;\n turnId?: number | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n eventProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackSessionEnrichment(\n opts: TrackSessionEnrichmentOptions,\n): void {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateRequiredStr(opts.sessionId, 'sessionId');\n }\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_SESSION_ID]: opts.sessionId,\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.traceId != null) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.turnId != null) properties[PROP_TURN_ID] = opts.turnId;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.env) properties[PROP_ENV] = opts.env;\n\n const enrichmentDict =\n typeof opts.enrichments.toDict === 'function'\n ? opts.enrichments.toDict()\n : opts.enrichments;\n properties[PROP_ENRICHMENTS] = serializeToJsonString(enrichmentDict);\n\n const event: AmplitudeEvent = {\n event_type: EVENT_SESSION_ENRICHMENT,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_SESSION_ENRICHMENT} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(\n `Failed to track ${EVENT_SESSION_ENRICHMENT}: ${e}`,\n );\n }\n}\n\n// --------------------------------------------------------\n// track_score\n// --------------------------------------------------------\n\nexport interface TrackScoreOptions {\n amplitude: AmplitudeLike;\n userId: string;\n name: string;\n value: number;\n targetId: string;\n targetType?: string;\n source?: string;\n comment?: string | null;\n sessionId?: string | null;\n traceId?: string | null;\n turnId?: number | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n eventProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackScore(opts: TrackScoreOptions): void {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateNumeric(opts.value, 'value');\n }\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_SCORE_NAME]: opts.name,\n [PROP_SCORE_VALUE]: opts.value,\n [PROP_TARGET_ID]: opts.targetId,\n [PROP_TARGET_TYPE]: opts.targetType ?? 'message',\n [PROP_EVALUATION_SOURCE]: opts.source ?? 'user',\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.traceId != null) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.turnId != null) properties[PROP_TURN_ID] = opts.turnId;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.env) properties[PROP_ENV] = opts.env;\n\n // Comment respects content_mode\n if (opts.comment != null) {\n const commentData = pc.sanitizeContent(opts.comment);\n if ('$llm_message' in commentData) {\n const msg = commentData.$llm_message as Record<string, unknown>;\n properties[PROP_COMMENT] = getTextFromLlmMessage(msg);\n }\n }\n\n const event: AmplitudeEvent = {\n event_type: EVENT_SCORE,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_SCORE} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(`Failed to track ${EVENT_SCORE}: ${e}`);\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"tracking.js","names":["serialized: string","properties: Record<string, unknown>","event: AmplitudeEvent"],"sources":["../../src/core/tracking.ts"],"sourcesContent":["import { randomUUID } from 'node:crypto';\nimport { ValidationError } from '../exceptions.js';\nimport type {\n AmplitudeEvent,\n AmplitudeLike,\n Attachment,\n ToolCallShape,\n} from '../types.js';\nimport { getLogger } from '../utils/logger.js';\nimport { inferModelTier } from '../utils/model-tiers.js';\nimport {\n EVENT_AI_RESPONSE,\n EVENT_EMBEDDING,\n EVENT_SCORE,\n EVENT_SESSION_END,\n EVENT_SESSION_ENRICHMENT,\n EVENT_SPAN,\n EVENT_TOOL_CALL,\n EVENT_USER_MESSAGE,\n MAX_SERIALIZED_LENGTH,\n PROP_ABANDONMENT_TURN,\n PROP_AGENT_DESCRIPTION,\n PROP_AGENT_ID,\n PROP_AGENT_VERSION,\n PROP_ATTACHMENT_COUNT,\n PROP_ATTACHMENT_TYPES,\n PROP_ATTACHMENTS,\n PROP_CACHE_CREATION_TOKENS,\n PROP_CACHE_READ_TOKENS,\n PROP_COMMENT,\n PROP_COMPONENT_TYPE,\n PROP_CONTEXT,\n PROP_COST_USD,\n PROP_CUSTOMER_ORG_ID,\n PROP_EDITED_MESSAGE_ID,\n PROP_EMBEDDING_DIMENSIONS,\n PROP_ENRICHMENTS,\n PROP_ENV,\n PROP_ERROR_MESSAGE,\n PROP_EVALUATION_SOURCE,\n PROP_FINISH_REASON,\n PROP_HAS_ATTACHMENTS,\n PROP_IDLE_TIMEOUT_MINUTES,\n PROP_INPUT_STATE,\n PROP_INPUT_TOKENS,\n PROP_INVOCATION_ID,\n PROP_IS_EDIT,\n PROP_IS_ERROR,\n PROP_IS_REGENERATION,\n PROP_IS_STREAMING,\n PROP_LATENCY_MS,\n PROP_LOCALE,\n PROP_MAX_OUTPUT_TOKENS,\n PROP_MESSAGE_ID,\n PROP_MESSAGE_LABELS,\n PROP_MESSAGE_SOURCE,\n PROP_MODEL_NAME,\n PROP_MODEL_TIER,\n PROP_OUTPUT_STATE,\n PROP_OUTPUT_TOKENS,\n PROP_PARENT_AGENT_ID,\n PROP_PARENT_MESSAGE_ID,\n PROP_PARENT_SPAN_ID,\n PROP_PROMPT_ID,\n PROP_PROVIDER,\n PROP_REASONING_TOKENS,\n PROP_RUNTIME,\n PROP_SCORE_NAME,\n PROP_SCORE_VALUE,\n PROP_SDK_VERSION,\n PROP_SESSION_ID,\n PROP_SPAN_ID,\n PROP_SPAN_KIND,\n PROP_SPAN_NAME,\n PROP_TARGET_ID,\n PROP_TARGET_TYPE,\n PROP_TEMPERATURE,\n PROP_TOOL_CALLS,\n PROP_TOOL_INPUT,\n PROP_TOOL_NAME,\n PROP_TOOL_OUTPUT,\n PROP_TOOL_SUCCESS,\n PROP_TOP_P,\n PROP_TOTAL_ATTACHMENT_SIZE,\n PROP_TOTAL_TOKENS,\n PROP_TRACE_ID,\n PROP_TTFB_MS,\n PROP_TURN_ID,\n PROP_WAS_CACHED,\n PROP_WAS_COPIED,\n SDK_RUNTIME,\n SDK_VERSION,\n} from './constants.js';\nimport type { MessageLabel, SessionEnrichments } from './enrichments.js';\nimport {\n getTextFromLlmMessage,\n PrivacyConfig,\n sanitizeStructuredContent,\n} from './privacy.js';\n\n// Re-export constants and SDK_VERSION for public API\nexport * from './constants.js';\n\nfunction validateRequiredStr(value: unknown, fieldName: string): void {\n if (typeof value !== 'string' || !value) {\n throw new ValidationError(\n `${fieldName} must be a non-empty string, got ${String(value)}`,\n );\n }\n}\n\nfunction validateNonNegative(value: unknown, fieldName: string): void {\n if (typeof value === 'number' && value < 0) {\n throw new ValidationError(`${fieldName} must be >= 0, got ${value}`);\n }\n}\n\nfunction validateNumeric(value: unknown, fieldName: string): void {\n if (typeof value !== 'number') {\n throw new ValidationError(\n `${fieldName} must be numeric, got ${typeof value}`,\n );\n }\n}\n\nexport function serializeToJsonString(\n value: unknown,\n maxLength = MAX_SERIALIZED_LENGTH,\n): string {\n let serialized: string;\n try {\n serialized = JSON.stringify(value);\n } catch {\n serialized = String(value);\n }\n\n if (serialized.length > maxLength) {\n const truncateAt = Math.max(0, maxLength - 14);\n return `${serialized.slice(0, truncateAt)}...[truncated]`;\n }\n return serialized;\n}\n\nfunction withSdkManagedProperties(\n eventProperties: Record<string, unknown> | null | undefined,\n managedProperties: Record<string, unknown>,\n): Record<string, unknown> {\n // SDK-managed keys must win over caller-provided eventProperties.\n return { ...(eventProperties ?? {}), ...managedProperties };\n}\n\n// --------------------------------------------------------\n// track_user_message\n// --------------------------------------------------------\n\nexport interface TrackUserMessageOptions {\n amplitude: AmplitudeLike;\n userId: string;\n messageContent: string;\n sessionId?: string | null;\n traceId?: string | null;\n turnId?: number;\n messageId?: string | null;\n conversationId?: string | null;\n env?: string | null;\n locale?: string | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n isRegeneration?: boolean;\n isEdit?: boolean;\n editedMessageId?: string | null;\n attachments?: Attachment[] | null;\n messageSource?: string | null;\n labels?: MessageLabel[] | null;\n eventProperties?: Record<string, unknown> | null;\n userProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackUserMessage(opts: TrackUserMessageOptions): string {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateRequiredStr(opts.sessionId, 'sessionId');\n }\n\n const messageId = opts.messageId || randomUUID();\n const contentData = pc.sanitizeContent(opts.messageContent);\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_TURN_ID]: opts.turnId ?? 1,\n [PROP_MESSAGE_ID]: messageId,\n [PROP_COMPONENT_TYPE]: 'user_input',\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.traceId) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.conversationId && !opts.sessionId)\n properties[PROP_SESSION_ID] = opts.conversationId;\n if (opts.env) properties[PROP_ENV] = opts.env;\n if (opts.locale) properties[PROP_LOCALE] = opts.locale;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.messageSource) properties[PROP_MESSAGE_SOURCE] = opts.messageSource;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n\n if (opts.isRegeneration) properties[PROP_IS_REGENERATION] = true;\n if (opts.isEdit) properties[PROP_IS_EDIT] = true;\n if (opts.editedMessageId)\n properties[PROP_EDITED_MESSAGE_ID] = opts.editedMessageId;\n\n if (opts.attachments?.length) {\n properties[PROP_HAS_ATTACHMENTS] = true;\n properties[PROP_ATTACHMENT_COUNT] = opts.attachments.length;\n const types = [\n ...new Set(opts.attachments.map((a) => String(a.type ?? 'unknown'))),\n ];\n properties[PROP_ATTACHMENT_TYPES] = types;\n const totalSize = opts.attachments.reduce(\n (sum, a) => sum + (typeof a.size_bytes === 'number' ? a.size_bytes : 0),\n 0,\n );\n if (totalSize > 0) properties[PROP_TOTAL_ATTACHMENT_SIZE] = totalSize;\n properties[PROP_ATTACHMENTS] = serializeToJsonString(opts.attachments);\n }\n\n if (opts.labels?.length) {\n properties[PROP_MESSAGE_LABELS] = serializeToJsonString(\n opts.labels.map((lbl) => lbl.toDict()),\n );\n }\n\n Object.assign(properties, contentData);\n\n const event: AmplitudeEvent = {\n event_type: EVENT_USER_MESSAGE,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.userProperties) event.user_properties = opts.userProperties;\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_USER_MESSAGE} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(\n `Failed to track ${EVENT_USER_MESSAGE}: ${e}`,\n );\n }\n\n return messageId;\n}\n\n// --------------------------------------------------------\n// track_ai_message\n// --------------------------------------------------------\n\nexport interface TrackAiMessageOptions {\n amplitude: AmplitudeLike;\n userId: string;\n modelName: string;\n provider: string;\n responseContent: string;\n latencyMs: number;\n sessionId?: string | null;\n traceId?: string | null;\n turnId?: number;\n messageId?: string | null;\n conversationId?: string | null;\n inputTokens?: number | null;\n outputTokens?: number | null;\n totalTokens?: number | null;\n reasoningTokens?: number | null;\n cacheReadInputTokens?: number | null;\n cacheCreationInputTokens?: number | null;\n totalCostUsd?: number | null;\n providerTtfbMs?: number | null;\n isError?: boolean;\n errorMessage?: string | null;\n finishReason?: string | null;\n toolCalls?: Array<ToolCallShape | Record<string, unknown>> | null;\n reasoningContent?: string | null;\n toolDefinitions?: Array<Record<string, unknown>> | null;\n systemPrompt?: string | null;\n temperature?: number | null;\n maxOutputTokens?: number | null;\n topP?: number | null;\n isStreaming?: boolean | null;\n promptId?: string | null;\n wasCopied?: boolean;\n wasCached?: boolean;\n modelTier?: string | null;\n attachments?: Attachment[] | null;\n labels?: MessageLabel[] | null;\n env?: string | null;\n locale?: string | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n spanKind?: string | null;\n eventProperties?: Record<string, unknown> | null;\n userProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackAiMessage(opts: TrackAiMessageOptions): string {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateRequiredStr(opts.modelName, 'model');\n validateNonNegative(opts.latencyMs, 'latencyMs');\n }\n\n const messageId = opts.messageId || randomUUID();\n const contentData = pc.sanitizeContent(opts.responseContent);\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_TURN_ID]: opts.turnId ?? 2,\n [PROP_MESSAGE_ID]: messageId,\n [PROP_MODEL_NAME]: opts.modelName,\n [PROP_PROVIDER]: opts.provider,\n [PROP_LATENCY_MS]: opts.latencyMs,\n [PROP_IS_ERROR]: opts.isError ?? false,\n [PROP_COMPONENT_TYPE]: 'llm',\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.traceId) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.conversationId && !opts.sessionId)\n properties[PROP_SESSION_ID] = opts.conversationId;\n if (opts.env) properties[PROP_ENV] = opts.env;\n if (opts.locale) properties[PROP_LOCALE] = opts.locale;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.spanKind) properties[PROP_SPAN_KIND] = opts.spanKind;\n\n if (opts.wasCopied) properties[PROP_WAS_COPIED] = true;\n if (opts.wasCached) properties[PROP_WAS_CACHED] = true;\n\n // Model tier (user override or auto-inferred)\n if (opts.modelTier != null) {\n properties[PROP_MODEL_TIER] = opts.modelTier;\n } else {\n properties[PROP_MODEL_TIER] = inferModelTier(opts.modelName);\n }\n\n Object.assign(properties, contentData);\n\n // Token usage\n if (opts.inputTokens != null)\n properties[PROP_INPUT_TOKENS] = opts.inputTokens;\n if (opts.outputTokens != null)\n properties[PROP_OUTPUT_TOKENS] = opts.outputTokens;\n if (opts.totalTokens != null)\n properties[PROP_TOTAL_TOKENS] = opts.totalTokens;\n if (opts.reasoningTokens != null)\n properties[PROP_REASONING_TOKENS] = opts.reasoningTokens;\n if (opts.cacheReadInputTokens != null)\n properties[PROP_CACHE_READ_TOKENS] = opts.cacheReadInputTokens;\n if (opts.cacheCreationInputTokens != null)\n properties[PROP_CACHE_CREATION_TOKENS] = opts.cacheCreationInputTokens;\n\n if (opts.totalCostUsd != null) properties[PROP_COST_USD] = opts.totalCostUsd;\n if (opts.providerTtfbMs != null)\n properties[PROP_TTFB_MS] = opts.providerTtfbMs;\n if (opts.finishReason != null)\n properties[PROP_FINISH_REASON] = opts.finishReason;\n if (opts.errorMessage != null)\n properties[PROP_ERROR_MESSAGE] = opts.errorMessage;\n if (opts.toolCalls != null)\n properties[PROP_TOOL_CALLS] = serializeToJsonString(opts.toolCalls);\n\n // Reasoning content\n const reasoningProps = pc.sanitizeReasoningContent(\n opts.reasoningContent ?? null,\n opts.reasoningTokens,\n );\n Object.assign(properties, reasoningProps);\n\n // System prompt\n const systemPromptProps = pc.sanitizeSystemPrompt(opts.systemPrompt ?? null);\n Object.assign(properties, systemPromptProps);\n\n // Tool definitions (request-side schemas)\n const toolDefProps = pc.sanitizeToolDefinitions(opts.toolDefinitions);\n Object.assign(properties, toolDefProps);\n\n if (opts.temperature != null) properties[PROP_TEMPERATURE] = opts.temperature;\n if (opts.maxOutputTokens != null)\n properties[PROP_MAX_OUTPUT_TOKENS] = opts.maxOutputTokens;\n if (opts.topP != null) properties[PROP_TOP_P] = opts.topP;\n if (opts.isStreaming != null)\n properties[PROP_IS_STREAMING] = opts.isStreaming;\n if (opts.promptId != null) properties[PROP_PROMPT_ID] = opts.promptId;\n\n if (opts.attachments?.length) {\n properties[PROP_HAS_ATTACHMENTS] = true;\n properties[PROP_ATTACHMENT_COUNT] = opts.attachments.length;\n const types = [\n ...new Set(opts.attachments.map((a) => String(a.type ?? 'unknown'))),\n ];\n properties[PROP_ATTACHMENT_TYPES] = types;\n const totalSize = opts.attachments.reduce(\n (sum, a) => sum + (typeof a.size_bytes === 'number' ? a.size_bytes : 0),\n 0,\n );\n if (totalSize > 0) properties[PROP_TOTAL_ATTACHMENT_SIZE] = totalSize;\n properties[PROP_ATTACHMENTS] = serializeToJsonString(opts.attachments);\n }\n\n if (opts.labels?.length) {\n properties[PROP_MESSAGE_LABELS] = serializeToJsonString(\n opts.labels.map((lbl) => lbl.toDict()),\n );\n }\n\n const event: AmplitudeEvent = {\n event_type: EVENT_AI_RESPONSE,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.userProperties) event.user_properties = opts.userProperties;\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_AI_RESPONSE} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(\n `Failed to track ${EVENT_AI_RESPONSE}: ${e}`,\n );\n }\n\n return messageId;\n}\n\n// --------------------------------------------------------\n// track_tool_call\n// --------------------------------------------------------\n\nexport interface TrackToolCallOptions {\n amplitude: AmplitudeLike;\n userId: string;\n toolName: string;\n success: boolean;\n latencyMs: number;\n sessionId?: string | null;\n traceId?: string | null;\n turnId?: number;\n toolInput?: unknown;\n toolOutput?: unknown;\n invocationId?: string | null;\n conversationId?: string | null;\n parentMessageId?: string | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n errorMessage?: string | null;\n env?: string | null;\n locale?: string | null;\n spanKind?: string | null;\n eventProperties?: Record<string, unknown> | null;\n userProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackToolCall(opts: TrackToolCallOptions): string {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateRequiredStr(opts.toolName, 'toolName');\n validateNonNegative(opts.latencyMs, 'latencyMs');\n }\n\n const invocationId = opts.invocationId || randomUUID();\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_TURN_ID]: opts.turnId ?? 1,\n [PROP_INVOCATION_ID]: invocationId,\n [PROP_TOOL_NAME]: opts.toolName,\n [PROP_TOOL_SUCCESS]: opts.success,\n [PROP_IS_ERROR]: !opts.success,\n [PROP_LATENCY_MS]: opts.latencyMs,\n [PROP_COMPONENT_TYPE]: 'tool',\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.traceId) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.conversationId && !opts.sessionId)\n properties[PROP_SESSION_ID] = opts.conversationId;\n if (opts.parentMessageId)\n properties[PROP_PARENT_MESSAGE_ID] = opts.parentMessageId;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.errorMessage) properties[PROP_ERROR_MESSAGE] = opts.errorMessage;\n if (opts.env) properties[PROP_ENV] = opts.env;\n if (opts.locale) properties[PROP_LOCALE] = opts.locale;\n if (opts.spanKind) properties[PROP_SPAN_KIND] = opts.spanKind;\n\n let effectiveMode = pc.contentMode;\n if (effectiveMode == null)\n effectiveMode = pc.privacyMode ? 'metadata_only' : 'full';\n\n if (opts.toolInput != null && effectiveMode === 'full') {\n const sanitized = sanitizeStructuredContent(opts.toolInput, pc.redactPii);\n properties[PROP_TOOL_INPUT] = serializeToJsonString(sanitized);\n }\n\n if (opts.toolOutput != null && effectiveMode === 'full') {\n const sanitized = sanitizeStructuredContent(opts.toolOutput, pc.redactPii);\n properties[PROP_TOOL_OUTPUT] = serializeToJsonString(sanitized);\n }\n\n const event: AmplitudeEvent = {\n event_type: EVENT_TOOL_CALL,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.userProperties) event.user_properties = opts.userProperties;\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_TOOL_CALL} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(`Failed to track ${EVENT_TOOL_CALL}: ${e}`);\n }\n\n return invocationId;\n}\n\n// --------------------------------------------------------\n// track_conversation\n// --------------------------------------------------------\n\nexport interface TrackConversationOptions {\n amplitude: AmplitudeLike;\n userId: string;\n messages: Array<Record<string, unknown>>;\n sessionId?: string | null;\n conversationId?: string | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n eventProperties?: Record<string, unknown> | null;\n userProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackConversation(opts: TrackConversationOptions): void {\n const effectiveSessionId =\n opts.sessionId ?? opts.conversationId ?? randomUUID();\n let turnId = 1;\n\n for (const message of opts.messages) {\n const role = String(message.role ?? '');\n const content = String(message.content ?? '');\n\n if (role === 'user') {\n trackUserMessage({\n amplitude: opts.amplitude,\n userId: opts.userId,\n messageContent: content,\n sessionId: effectiveSessionId,\n turnId,\n agentId: opts.agentId,\n parentAgentId: opts.parentAgentId,\n customerOrgId: opts.customerOrgId,\n agentVersion: opts.agentVersion,\n description: opts.description,\n context: opts.context,\n env: opts.env,\n eventProperties: opts.eventProperties,\n userProperties: opts.userProperties,\n groups: opts.groups,\n privacyConfig: opts.privacyConfig,\n });\n } else if (role === 'assistant' || role === 'ai') {\n trackAiMessage({\n amplitude: opts.amplitude,\n userId: opts.userId,\n modelName: String(message.model ?? 'unknown'),\n provider: String(message.provider ?? 'unknown'),\n responseContent: content,\n latencyMs: Number(message.latency_ms ?? 0),\n sessionId: effectiveSessionId,\n turnId,\n inputTokens: message.input_tokens as number | undefined,\n outputTokens: message.output_tokens as number | undefined,\n totalTokens: message.total_tokens as number | undefined,\n totalCostUsd: message.total_cost_usd as number | undefined,\n agentId: opts.agentId,\n parentAgentId: opts.parentAgentId,\n customerOrgId: opts.customerOrgId,\n agentVersion: opts.agentVersion,\n description: opts.description,\n context: opts.context,\n env: opts.env,\n eventProperties: opts.eventProperties,\n userProperties: opts.userProperties,\n groups: opts.groups,\n privacyConfig: opts.privacyConfig,\n });\n }\n\n turnId++;\n }\n}\n\n// --------------------------------------------------------\n// track_embedding\n// --------------------------------------------------------\n\nexport interface TrackEmbeddingOptions {\n amplitude: AmplitudeLike;\n userId: string;\n model: string;\n provider: string;\n latencyMs: number;\n inputTokens?: number | null;\n dimensions?: number | null;\n totalCostUsd?: number | null;\n sessionId?: string | null;\n traceId?: string | null;\n turnId?: number | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n eventProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackEmbedding(opts: TrackEmbeddingOptions): string {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateNonNegative(opts.latencyMs, 'latencyMs');\n }\n\n const spanId = randomUUID();\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_SPAN_ID]: spanId,\n [PROP_MODEL_NAME]: opts.model,\n [PROP_PROVIDER]: opts.provider,\n [PROP_LATENCY_MS]: opts.latencyMs,\n [PROP_COMPONENT_TYPE]: 'embedding',\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.traceId != null) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.turnId != null) properties[PROP_TURN_ID] = opts.turnId;\n if (opts.inputTokens != null)\n properties[PROP_INPUT_TOKENS] = opts.inputTokens;\n if (opts.dimensions != null)\n properties[PROP_EMBEDDING_DIMENSIONS] = opts.dimensions;\n if (opts.totalCostUsd != null) properties[PROP_COST_USD] = opts.totalCostUsd;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.env) properties[PROP_ENV] = opts.env;\n\n const event: AmplitudeEvent = {\n event_type: EVENT_EMBEDDING,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_EMBEDDING} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(`Failed to track ${EVENT_EMBEDDING}: ${e}`);\n }\n\n return spanId;\n}\n\n// --------------------------------------------------------\n// track_span\n// --------------------------------------------------------\n\nexport interface TrackSpanOptions {\n amplitude: AmplitudeLike;\n userId: string;\n spanName: string;\n traceId: string;\n latencyMs: number;\n inputState?: Record<string, unknown> | null;\n outputState?: Record<string, unknown> | null;\n parentSpanId?: string | null;\n isError?: boolean;\n errorMessage?: string | null;\n sessionId?: string | null;\n turnId?: number | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n eventProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackSpan(opts: TrackSpanOptions): string {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateNonNegative(opts.latencyMs, 'latencyMs');\n }\n\n const spanId = randomUUID();\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_SPAN_ID]: spanId,\n [PROP_SPAN_NAME]: opts.spanName,\n [PROP_TRACE_ID]: opts.traceId,\n [PROP_LATENCY_MS]: opts.latencyMs,\n [PROP_IS_ERROR]: opts.isError ?? false,\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.turnId != null) properties[PROP_TURN_ID] = opts.turnId;\n if (opts.parentSpanId) properties[PROP_PARENT_SPAN_ID] = opts.parentSpanId;\n if (opts.errorMessage) properties[PROP_ERROR_MESSAGE] = opts.errorMessage;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.env) properties[PROP_ENV] = opts.env;\n\n let effectiveMode = pc.contentMode;\n if (effectiveMode == null)\n effectiveMode = pc.privacyMode ? 'metadata_only' : 'full';\n\n if (opts.inputState != null && effectiveMode === 'full') {\n const sanitized = sanitizeStructuredContent(opts.inputState, pc.redactPii);\n properties[PROP_INPUT_STATE] = serializeToJsonString(sanitized);\n }\n\n if (opts.outputState != null && effectiveMode === 'full') {\n const sanitized = sanitizeStructuredContent(opts.outputState, pc.redactPii);\n properties[PROP_OUTPUT_STATE] = serializeToJsonString(sanitized);\n }\n\n const event: AmplitudeEvent = {\n event_type: EVENT_SPAN,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_SPAN} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(`Failed to track ${EVENT_SPAN}: ${e}`);\n }\n\n return spanId;\n}\n\n// --------------------------------------------------------\n// track_session_end\n// --------------------------------------------------------\n\nexport interface TrackSessionEndOptions {\n amplitude: AmplitudeLike;\n userId: string;\n sessionId: string;\n enrichments?: SessionEnrichments | null;\n traceId?: string | null;\n turnId?: number | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n abandonmentTurn?: number | null;\n idleTimeoutMinutes?: number | null;\n eventProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackSessionEnd(opts: TrackSessionEndOptions): void {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateRequiredStr(opts.sessionId, 'sessionId');\n }\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_SESSION_ID]: opts.sessionId,\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.traceId != null) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.turnId != null) properties[PROP_TURN_ID] = opts.turnId;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.env) properties[PROP_ENV] = opts.env;\n if (opts.abandonmentTurn != null)\n properties[PROP_ABANDONMENT_TURN] = opts.abandonmentTurn;\n if (opts.idleTimeoutMinutes != null)\n properties[PROP_IDLE_TIMEOUT_MINUTES] = opts.idleTimeoutMinutes;\n\n if (opts.enrichments != null) {\n const enrichmentDict =\n typeof opts.enrichments.toDict === 'function'\n ? opts.enrichments.toDict()\n : opts.enrichments;\n properties[PROP_ENRICHMENTS] = serializeToJsonString(enrichmentDict);\n }\n\n const event: AmplitudeEvent = {\n event_type: EVENT_SESSION_END,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_SESSION_END} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(\n `Failed to track ${EVENT_SESSION_END}: ${e}`,\n );\n }\n}\n\n// --------------------------------------------------------\n// track_session_enrichment\n// --------------------------------------------------------\n\nexport interface TrackSessionEnrichmentOptions {\n amplitude: AmplitudeLike;\n userId: string;\n sessionId: string;\n enrichments: SessionEnrichments;\n traceId?: string | null;\n turnId?: number | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n eventProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackSessionEnrichment(\n opts: TrackSessionEnrichmentOptions,\n): void {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateRequiredStr(opts.sessionId, 'sessionId');\n }\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_SESSION_ID]: opts.sessionId,\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.traceId != null) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.turnId != null) properties[PROP_TURN_ID] = opts.turnId;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.env) properties[PROP_ENV] = opts.env;\n\n const enrichmentDict =\n typeof opts.enrichments.toDict === 'function'\n ? opts.enrichments.toDict()\n : opts.enrichments;\n properties[PROP_ENRICHMENTS] = serializeToJsonString(enrichmentDict);\n\n const event: AmplitudeEvent = {\n event_type: EVENT_SESSION_ENRICHMENT,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_SESSION_ENRICHMENT} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(\n `Failed to track ${EVENT_SESSION_ENRICHMENT}: ${e}`,\n );\n }\n}\n\n// --------------------------------------------------------\n// track_score\n// --------------------------------------------------------\n\nexport interface TrackScoreOptions {\n amplitude: AmplitudeLike;\n userId: string;\n name: string;\n value: number;\n targetId: string;\n targetType?: string;\n source?: string;\n comment?: string | null;\n sessionId?: string | null;\n traceId?: string | null;\n turnId?: number | null;\n agentId?: string | null;\n parentAgentId?: string | null;\n customerOrgId?: string | null;\n agentVersion?: string | null;\n description?: string | null;\n context?: Record<string, unknown> | null;\n env?: string | null;\n eventProperties?: Record<string, unknown> | null;\n groups?: Record<string, unknown> | null;\n privacyConfig?: PrivacyConfig | null;\n}\n\nexport function trackScore(opts: TrackScoreOptions): void {\n const pc = opts.privacyConfig ?? new PrivacyConfig();\n if (pc.validate) {\n validateRequiredStr(opts.userId, 'userId');\n validateNumeric(opts.value, 'value');\n }\n\n const properties: Record<string, unknown> = withSdkManagedProperties(\n opts.eventProperties,\n {\n [PROP_SCORE_NAME]: opts.name,\n [PROP_SCORE_VALUE]: opts.value,\n [PROP_TARGET_ID]: opts.targetId,\n [PROP_TARGET_TYPE]: opts.targetType ?? 'message',\n [PROP_EVALUATION_SOURCE]: opts.source ?? 'user',\n [PROP_SDK_VERSION]: SDK_VERSION,\n [PROP_RUNTIME]: SDK_RUNTIME,\n },\n );\n\n if (opts.sessionId) properties[PROP_SESSION_ID] = opts.sessionId;\n if (opts.traceId != null) properties[PROP_TRACE_ID] = opts.traceId;\n if (opts.turnId != null) properties[PROP_TURN_ID] = opts.turnId;\n if (opts.agentId) properties[PROP_AGENT_ID] = opts.agentId;\n if (opts.parentAgentId) properties[PROP_PARENT_AGENT_ID] = opts.parentAgentId;\n if (opts.customerOrgId) properties[PROP_CUSTOMER_ORG_ID] = opts.customerOrgId;\n if (opts.agentVersion) properties[PROP_AGENT_VERSION] = opts.agentVersion;\n if (opts.description) properties[PROP_AGENT_DESCRIPTION] = opts.description;\n if (opts.context)\n properties[PROP_CONTEXT] = serializeToJsonString(opts.context);\n if (opts.env) properties[PROP_ENV] = opts.env;\n\n // Comment respects content_mode\n if (opts.comment != null) {\n const commentData = pc.sanitizeContent(opts.comment);\n if ('$llm_message' in commentData) {\n const msg = commentData.$llm_message as Record<string, unknown>;\n properties[PROP_COMMENT] = getTextFromLlmMessage(msg);\n }\n }\n\n const event: AmplitudeEvent = {\n event_type: EVENT_SCORE,\n user_id: opts.userId,\n event_properties: properties,\n };\n if (opts.groups) event.groups = opts.groups;\n\n try {\n opts.amplitude.track(event);\n getLogger(opts.amplitude).debug(\n `Tracked ${EVENT_SCORE} for user ${opts.userId}`,\n );\n } catch (e) {\n getLogger(opts.amplitude).error(`Failed to track ${EVENT_SCORE}: ${e}`);\n }\n}\n"],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { PrivacyConfig } from "./core/privacy.js";
1
+ import { PrivacyConfig, normalizeToolDefinitions } from "./core/privacy.js";
2
2
  import { AIConfig, AIConfigOptions, ContentMode } from "./config.js";
3
3
  import { EvidenceQuote, MessageLabel, RubricScore, SessionEnrichments, TopicClassification } from "./core/enrichments.js";
4
4
  import { TenantHandle } from "./tenant.js";
@@ -7,7 +7,7 @@ import { AmplitudeAI } from "./client.js";
7
7
  import { Session, SessionOptions } from "./session.js";
8
8
  import { AgentOptions, AiMessageOpts, BoundAgent, EmbeddingOpts, ScoreOpts, SessionEndOpts, SessionEnrichmentOpts, SpanOpts, ToolCallOpts, UserMessageOpts } from "./bound-agent.js";
9
9
  import { SessionContext, getActiveContext, runWithContext, runWithContextAsync } from "./context.js";
10
- import { EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, MAX_SERIALIZED_LENGTH, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, SDK_RUNTIME, SDK_VERSION } from "./core/constants.js";
10
+ import { EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, MAX_SERIALIZED_LENGTH, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_DEFINITIONS, PROP_TOOL_DEFINITIONS_COUNT, PROP_TOOL_DEFINITIONS_HASH, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, SDK_RUNTIME, SDK_VERSION } from "./core/constants.js";
11
11
  import { serializeToJsonString, trackAiMessage, trackConversation, trackEmbedding, trackScore, trackSessionEnd, trackSessionEnrichment, trackSpan, trackToolCall, trackUserMessage } from "./core/tracking.js";
12
12
  import { ObserveWrapped, ToolCallTracker, ToolWrapped, observe, tool } from "./decorators.js";
13
13
  import { AmplitudeAIError, ConfigurationError, ProviderError, TrackingError, ValidationError } from "./exceptions.js";
@@ -37,4 +37,4 @@ import { inferProviderFromModel } from "./utils/providers.js";
37
37
  import { calculateCost, enableLivePriceUpdates, getGenaiPriceLookupCandidates, inferProvider, stripProviderPrefix } from "./utils/costs.js";
38
38
  import { countMessageTokens, countTokens, estimateTokens } from "./utils/tokens.js";
39
39
  import { TIER_FAST, TIER_REASONING, TIER_STANDARD, inferModelTier } from "./utils/model-tiers.js";
40
- export { AIConfig, type AIConfigOptions, ANTHROPIC_AVAILABLE, OPENAI_AVAILABLE as AZURE_OPENAI_AVAILABLE, type AgentOptions, type AiMessageOpts, AmplitudeAI, AmplitudeAIError, type AmplitudeAILike, AmplitudeAIWrapError, AmplitudeAgentExporter, AmplitudeCallbackHandler, type AmplitudeClientLike, AmplitudeCrewAIHooks, type AmplitudeEvent, AmplitudeGenAIExporter, type AmplitudeLike, AmplitudeLlamaIndexHandler, type AmplitudeOrAI, AmplitudeSpanExporter, AmplitudeToolLoop, AmplitudeTracingProcessor, Anthropic, type AnthropicParams, type AnthropicResponse, type Attachment, AzureOpenAI, BEDROCK_AVAILABLE, Bedrock, type BedrockConverseParams, type BedrockConverseResponse, BoundAgent, type ChatCompletionParams, type ChatCompletionResponse, type ChatMessage, ConfigurationError, type ContentBlock, ContentMode, EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, type EmbeddingOpts, EvidenceQuote, GEMINI_AVAILABLE, GENERATED_FILES, Gemini, type InstrumentFileOptions, MAX_SERIALIZED_LENGTH, MCP_PROMPTS, MCP_RESOURCES, MCP_SERVER_NAME, MCP_TOOLS, MISTRAL_AVAILABLE, MessageLabel, type MiddlewareOptions, Mistral, type MistralChatParams, type MistralChatResponse, MockAmplitudeAI, OPENAI_AVAILABLE, type ObserveWrapped, OpenAI, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, PrivacyConfig, ProviderError, RubricScore, SDK_RUNTIME, SDK_VERSION, type ScoreOpts, Session, SessionContext, type SessionEndOpts, type SessionEnrichmentOpts, SessionEnrichments, type SessionOptions, type SpanOpts, StreamingAccumulator, TIER_FAST, TIER_REASONING, TIER_STANDARD, TenantHandle, type ToolCallOpts, type ToolCallShape, ToolCallTracker, type ToolWrapped, TopicClassification, type TrackCallOptions, type TrackFn, TrackingError, type UserMessageOpts, ValidationError, WrappedResponses, calculateCost, countMessageTokens, countTokens, createAmplitudeAIMiddleware, createAmplitudeCallback, createAmplitudeLlamaIndexHandler, enableLivePriceUpdates, estimateTokens, extractAnthropicContent, extractAnthropicSystemPrompt, extractBedrockResponse, extractContext, extractGeminiResponse, extractSystemPrompt, generateVerifyTest, getActiveContext, getGenaiPriceLookupCandidates, inferModelTier, inferProvider, inferProviderFromModel, injectContext, instrumentFile, isServerless, observe, patch, patchAnthropic, patchAzureOpenAI, patchBedrock, patchGemini, patchMistral, patchOpenAI, patchedProviders, resolveAmplitude, runWithContext, runWithContextAsync, serializeToJsonString, stripProviderPrefix, tool, trackAiMessage, trackConversation, trackEmbedding, trackScore, trackSessionEnd, trackSessionEnrichment, trackSpan, trackToolCall, trackUserMessage, unpatch, unpatchAnthropic, unpatchAzureOpenAI, unpatchBedrock, unpatchGemini, unpatchMistral, unpatchOpenAI, wrap };
40
+ export { AIConfig, type AIConfigOptions, ANTHROPIC_AVAILABLE, OPENAI_AVAILABLE as AZURE_OPENAI_AVAILABLE, type AgentOptions, type AiMessageOpts, AmplitudeAI, AmplitudeAIError, type AmplitudeAILike, AmplitudeAIWrapError, AmplitudeAgentExporter, AmplitudeCallbackHandler, type AmplitudeClientLike, AmplitudeCrewAIHooks, type AmplitudeEvent, AmplitudeGenAIExporter, type AmplitudeLike, AmplitudeLlamaIndexHandler, type AmplitudeOrAI, AmplitudeSpanExporter, AmplitudeToolLoop, AmplitudeTracingProcessor, Anthropic, type AnthropicParams, type AnthropicResponse, type Attachment, AzureOpenAI, BEDROCK_AVAILABLE, Bedrock, type BedrockConverseParams, type BedrockConverseResponse, BoundAgent, type ChatCompletionParams, type ChatCompletionResponse, type ChatMessage, ConfigurationError, type ContentBlock, ContentMode, EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, type EmbeddingOpts, EvidenceQuote, GEMINI_AVAILABLE, GENERATED_FILES, Gemini, type InstrumentFileOptions, MAX_SERIALIZED_LENGTH, MCP_PROMPTS, MCP_RESOURCES, MCP_SERVER_NAME, MCP_TOOLS, MISTRAL_AVAILABLE, MessageLabel, type MiddlewareOptions, Mistral, type MistralChatParams, type MistralChatResponse, MockAmplitudeAI, OPENAI_AVAILABLE, type ObserveWrapped, OpenAI, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_DEFINITIONS, PROP_TOOL_DEFINITIONS_COUNT, PROP_TOOL_DEFINITIONS_HASH, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, PrivacyConfig, ProviderError, RubricScore, SDK_RUNTIME, SDK_VERSION, type ScoreOpts, Session, SessionContext, type SessionEndOpts, type SessionEnrichmentOpts, SessionEnrichments, type SessionOptions, type SpanOpts, StreamingAccumulator, TIER_FAST, TIER_REASONING, TIER_STANDARD, TenantHandle, type ToolCallOpts, type ToolCallShape, ToolCallTracker, type ToolWrapped, TopicClassification, type TrackCallOptions, type TrackFn, TrackingError, type UserMessageOpts, ValidationError, WrappedResponses, calculateCost, countMessageTokens, countTokens, createAmplitudeAIMiddleware, createAmplitudeCallback, createAmplitudeLlamaIndexHandler, enableLivePriceUpdates, estimateTokens, extractAnthropicContent, extractAnthropicSystemPrompt, extractBedrockResponse, extractContext, extractGeminiResponse, extractSystemPrompt, generateVerifyTest, getActiveContext, getGenaiPriceLookupCandidates, inferModelTier, inferProvider, inferProviderFromModel, injectContext, instrumentFile, isServerless, normalizeToolDefinitions, observe, patch, patchAnthropic, patchAzureOpenAI, patchBedrock, patchGemini, patchMistral, patchOpenAI, patchedProviders, resolveAmplitude, runWithContext, runWithContextAsync, serializeToJsonString, stripProviderPrefix, tool, trackAiMessage, trackConversation, trackEmbedding, trackScore, trackSessionEnd, trackSessionEnrichment, trackSpan, trackToolCall, trackUserMessage, unpatch, unpatchAnthropic, unpatchAzureOpenAI, unpatchBedrock, unpatchGemini, unpatchMistral, unpatchOpenAI, wrap };
package/dist/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { AmplitudeAIError, ConfigurationError, ProviderError, TrackingError, ValidationError } from "./exceptions.js";
2
2
  import { TIER_FAST, TIER_REASONING, TIER_STANDARD, inferModelTier } from "./utils/model-tiers.js";
3
- import { EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, MAX_SERIALIZED_LENGTH, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, SDK_RUNTIME, SDK_VERSION } from "./core/constants.js";
4
- import { PrivacyConfig } from "./core/privacy.js";
3
+ import { EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, MAX_SERIALIZED_LENGTH, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_DEFINITIONS, PROP_TOOL_DEFINITIONS_COUNT, PROP_TOOL_DEFINITIONS_HASH, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, SDK_RUNTIME, SDK_VERSION } from "./core/constants.js";
4
+ import { PrivacyConfig, normalizeToolDefinitions } from "./core/privacy.js";
5
5
  import { serializeToJsonString, trackAiMessage, trackConversation, trackEmbedding, trackScore, trackSessionEnd, trackSessionEnrichment, trackSpan, trackToolCall, trackUserMessage } from "./core/tracking.js";
6
6
  import { SessionContext, getActiveContext, runWithContext, runWithContextAsync } from "./context.js";
7
7
  import { isServerless } from "./serverless.js";
@@ -38,4 +38,4 @@ import { AmplitudeToolLoop } from "./integrations/anthropic-tools.js";
38
38
  import { AmplitudeCrewAIHooks } from "./integrations/crewai.js";
39
39
  import { countMessageTokens, countTokens, estimateTokens } from "./utils/tokens.js";
40
40
 
41
- export { AIConfig, ANTHROPIC_AVAILABLE, OPENAI_AVAILABLE as AZURE_OPENAI_AVAILABLE, AmplitudeAI, AmplitudeAIError, AmplitudeAIWrapError, AmplitudeAgentExporter, AmplitudeCallbackHandler, AmplitudeCrewAIHooks, AmplitudeGenAIExporter, AmplitudeLlamaIndexHandler, AmplitudeSpanExporter, AmplitudeToolLoop, AmplitudeTracingProcessor, Anthropic, AzureOpenAI, BEDROCK_AVAILABLE, Bedrock, BoundAgent, ConfigurationError, ContentMode, EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, EvidenceQuote, GEMINI_AVAILABLE, GENERATED_FILES, Gemini, MAX_SERIALIZED_LENGTH, MCP_PROMPTS, MCP_RESOURCES, MCP_SERVER_NAME, MCP_TOOLS, MISTRAL_AVAILABLE, MessageLabel, Mistral, MockAmplitudeAI, OPENAI_AVAILABLE, OpenAI, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, PrivacyConfig, ProviderError, RubricScore, SDK_RUNTIME, SDK_VERSION, Session, SessionContext, SessionEnrichments, StreamingAccumulator, TIER_FAST, TIER_REASONING, TIER_STANDARD, TenantHandle, ToolCallTracker, TopicClassification, TrackingError, ValidationError, WrappedResponses, calculateCost, countMessageTokens, countTokens, createAmplitudeAIMiddleware, createAmplitudeCallback, createAmplitudeLlamaIndexHandler, enableLivePriceUpdates, estimateTokens, extractAnthropicContent, extractAnthropicSystemPrompt, extractBedrockResponse, extractContext, extractGeminiResponse, extractSystemPrompt, generateVerifyTest, getActiveContext, getGenaiPriceLookupCandidates, inferModelTier, inferProvider, inferProviderFromModel, injectContext, instrumentFile, isServerless, observe, patch, patchAnthropic, patchAzureOpenAI, patchBedrock, patchGemini, patchMistral, patchOpenAI, patchedProviders, resolveAmplitude, runWithContext, runWithContextAsync, serializeToJsonString, stripProviderPrefix, tool, trackAiMessage, trackConversation, trackEmbedding, trackScore, trackSessionEnd, trackSessionEnrichment, trackSpan, trackToolCall, trackUserMessage, unpatch, unpatchAnthropic, unpatchAzureOpenAI, unpatchBedrock, unpatchGemini, unpatchMistral, unpatchOpenAI, wrap };
41
+ export { AIConfig, ANTHROPIC_AVAILABLE, OPENAI_AVAILABLE as AZURE_OPENAI_AVAILABLE, AmplitudeAI, AmplitudeAIError, AmplitudeAIWrapError, AmplitudeAgentExporter, AmplitudeCallbackHandler, AmplitudeCrewAIHooks, AmplitudeGenAIExporter, AmplitudeLlamaIndexHandler, AmplitudeSpanExporter, AmplitudeToolLoop, AmplitudeTracingProcessor, Anthropic, AzureOpenAI, BEDROCK_AVAILABLE, Bedrock, BoundAgent, ConfigurationError, ContentMode, EVENT_AI_RESPONSE, EVENT_EMBEDDING, EVENT_SCORE, EVENT_SESSION_END, EVENT_SESSION_ENRICHMENT, EVENT_SPAN, EVENT_TOOL_CALL, EVENT_USER_MESSAGE, EvidenceQuote, GEMINI_AVAILABLE, GENERATED_FILES, Gemini, MAX_SERIALIZED_LENGTH, MCP_PROMPTS, MCP_RESOURCES, MCP_SERVER_NAME, MCP_TOOLS, MISTRAL_AVAILABLE, MessageLabel, Mistral, MockAmplitudeAI, OPENAI_AVAILABLE, OpenAI, PROP_ABANDONMENT_TURN, PROP_AGENT_CHAIN, PROP_AGENT_DESCRIPTION, PROP_AGENT_ID, PROP_AGENT_VERSION, PROP_ATTACHMENTS, PROP_ATTACHMENT_COUNT, PROP_ATTACHMENT_TYPES, PROP_CACHE_CREATION_TOKENS, PROP_CACHE_READ_TOKENS, PROP_COMMENT, PROP_COMPONENT_TYPE, PROP_CONTEXT, PROP_COST_USD, PROP_CUSTOMER_ORG_ID, PROP_EDITED_MESSAGE_ID, PROP_EMBEDDING_DIMENSIONS, PROP_ENRICHMENTS, PROP_ENV, PROP_ERROR_MESSAGE, PROP_EVALUATION_SOURCE, PROP_FINISH_REASON, PROP_HAS_ATTACHMENTS, PROP_HAS_REASONING, PROP_IDLE_TIMEOUT_MINUTES, PROP_INPUT_STATE, PROP_INPUT_TOKENS, PROP_INVOCATION_ID, PROP_IS_EDIT, PROP_IS_ERROR, PROP_IS_REGENERATION, PROP_IS_STREAMING, PROP_LATENCY_MS, PROP_LOCALE, PROP_MAX_OUTPUT_TOKENS, PROP_MESSAGE_ID, PROP_MESSAGE_LABELS, PROP_MESSAGE_LABEL_MAP, PROP_MESSAGE_SOURCE, PROP_MODEL_NAME, PROP_MODEL_TIER, PROP_OUTPUT_STATE, PROP_OUTPUT_TOKENS, PROP_PARENT_AGENT_ID, PROP_PARENT_MESSAGE_ID, PROP_PARENT_SPAN_ID, PROP_PROMPT_ID, PROP_PROVIDER, PROP_QUALITY_SCORE, PROP_REASONING_CONTENT, PROP_REASONING_TOKENS, PROP_REQUEST_COMPLEXITY, PROP_ROOT_AGENT_NAME, PROP_RUNTIME, PROP_SCORE_NAME, PROP_SCORE_VALUE, PROP_SDK_VERSION, PROP_SENTIMENT_SCORE, PROP_SESSION_ID, PROP_SESSION_REPLAY_ID, PROP_SPAN_ID, PROP_SPAN_KIND, PROP_SPAN_NAME, PROP_SYSTEM_PROMPT, PROP_SYSTEM_PROMPT_LENGTH, PROP_TARGET_ID, PROP_TARGET_TYPE, PROP_TASK_FAILURE_REASON, PROP_TASK_FAILURE_TYPE, PROP_TEMPERATURE, PROP_TOOL_CALLS, PROP_TOOL_DEFINITIONS, PROP_TOOL_DEFINITIONS_COUNT, PROP_TOOL_DEFINITIONS_HASH, PROP_TOOL_INPUT, PROP_TOOL_NAME, PROP_TOOL_OUTPUT, PROP_TOOL_SUCCESS, PROP_TOP_P, PROP_TOTAL_ATTACHMENT_SIZE, PROP_TOTAL_TOKENS, PROP_TRACE_ID, PROP_TTFB_MS, PROP_TURN_ID, PROP_WAS_CACHED, PROP_WAS_COPIED, PrivacyConfig, ProviderError, RubricScore, SDK_RUNTIME, SDK_VERSION, Session, SessionContext, SessionEnrichments, StreamingAccumulator, TIER_FAST, TIER_REASONING, TIER_STANDARD, TenantHandle, ToolCallTracker, TopicClassification, TrackingError, ValidationError, WrappedResponses, calculateCost, countMessageTokens, countTokens, createAmplitudeAIMiddleware, createAmplitudeCallback, createAmplitudeLlamaIndexHandler, enableLivePriceUpdates, estimateTokens, extractAnthropicContent, extractAnthropicSystemPrompt, extractBedrockResponse, extractContext, extractGeminiResponse, extractSystemPrompt, generateVerifyTest, getActiveContext, getGenaiPriceLookupCandidates, inferModelTier, inferProvider, inferProviderFromModel, injectContext, instrumentFile, isServerless, normalizeToolDefinitions, observe, patch, patchAnthropic, patchAzureOpenAI, patchBedrock, patchGemini, patchMistral, patchOpenAI, patchedProviders, resolveAmplitude, runWithContext, runWithContextAsync, serializeToJsonString, stripProviderPrefix, tool, trackAiMessage, trackConversation, trackEmbedding, trackScore, trackSessionEnd, trackSessionEnrichment, trackSpan, trackToolCall, trackUserMessage, unpatch, unpatchAnthropic, unpatchAzureOpenAI, unpatchBedrock, unpatchGemini, unpatchMistral, unpatchOpenAI, wrap };
@@ -1 +1 @@
1
- {"version":3,"file":"anthropic.d.ts","names":[],"sources":["../../src/providers/anthropic.ts"],"sourcesContent":[],"mappings":";;;;;;AAyBM,cADO,mBACW,EAAM,OAAA;AAI9B,cAJM,gBAI2B,EAJT,MAKX,CAAA,MAAA,EAAA,OAEK,CAAA,GAAA,IAAA;AAOA,UAVD,gBAAA,CAUC;EAA0B,SAAA,EAT/B,aAS+B;EAGvB,MAAA,CAAA,EAAA,MAAA;EAGE,aAAA,CAAA,EAbL,aAaK,GAAA,IAAA;EAmCP,gBAAA,CAAA,EAAA,OAAA;EAxCN;EAAc,eAAA,CAAA,EAAA,OAAA;AA6CxB;AACa,cAhDA,SAgDA,CAAA,gBA/CK,MA+CL,CAAA,MAAA,EAAA,OAAA,CAAA,GA/C+B,MA+C/B,CAAA,MAAA,EAAA,OAAA,CAAA,CAAA,SA9CH,cAAA,CA8CG;EAQA,QAAA,OAAA;EACE,SAAA,QAAA,EArDM,eAqDN;EACI,QAAA,iBAAA;EAeP,WAAA,CAAA,OAAA,EAlEW,gBAkEX;EACa,IAAA,MAAA,CAAA,CAAA,EAhCT,OAgCS;;AACQ,cA5BpB,eAAA,CA4BoB;EAA5B,SAAA,EA3BQ,MA2BR,CAAA,MAAA,EAAA,OAAA,CAAA;EAAO,QAAA,QAAA;EAuSI,QAAA,UAAA;EAmBA,QAAA,cAAA;EACC,QAAA,iBAAA;EAAN,WAAA,CAAA,MAAA,EAAA,OAAA,EAAA,OAAA,EA9UE,OA8UF,EAAA,SAAA,EA7UI,aA6UJ,EAAA,aAAA,EA5UQ,aA4UR,GAAA,IAAA,EAAA,gBAAA,EAAA,OAAA;EAIQ,MAAA,CAAA,MAAA,EAjUP,MAiUO,CAAA,MAAA,EAAA,OAAA,CAAA,EAAA,kBAAA,CAAA,EAhUM,oBAgUN,CAAA,EA/Td,OA+Tc,CA/TN,iBA+TM,GA/Tc,aA+Td,CAAA,OAAA,CAAA,CAAA;EAAN,QAAA,WAAA;EAAK,QAAA,mBAAA;;;iBAxBF,4BAAA;iBAmBA,uBAAA,UACL,MAAM;;;aAIJ,MAAM"}
1
+ {"version":3,"file":"anthropic.d.ts","names":[],"sources":["../../src/providers/anthropic.ts"],"sourcesContent":[],"mappings":";;;;;;AAyBM,cADO,mBACW,EAAM,OAAA;AAI9B,cAJM,gBAI2B,EAJT,MAKX,CAAA,MAAA,EAAA,OAEK,CAAA,GAAA,IAAA;AAOA,UAVD,gBAAA,CAUC;EAA0B,SAAA,EAT/B,aAS+B;EAGvB,MAAA,CAAA,EAAA,MAAA;EAGE,aAAA,CAAA,EAbL,aAaK,GAAA,IAAA;EAmCP,gBAAA,CAAA,EAAA,OAAA;EAxCN;EAAc,eAAA,CAAA,EAAA,OAAA;AA6CxB;AACa,cAhDA,SAgDA,CAAA,gBA/CK,MA+CL,CAAA,MAAA,EAAA,OAAA,CAAA,GA/C+B,MA+C/B,CAAA,MAAA,EAAA,OAAA,CAAA,CAAA,SA9CH,cAAA,CA8CG;EAQA,QAAA,OAAA;EACE,SAAA,QAAA,EArDM,eAqDN;EACI,QAAA,iBAAA;EAeP,WAAA,CAAA,OAAA,EAlEW,gBAkEX;EACa,IAAA,MAAA,CAAA,CAAA,EAhCT,OAgCS;;AACQ,cA5BpB,eAAA,CA4BoB;EAA5B,SAAA,EA3BQ,MA2BR,CAAA,MAAA,EAAA,OAAA,CAAA;EAAO,QAAA,QAAA;EAkTI,QAAA,UAAA;EAmBA,QAAA,cAAA;EACC,QAAA,iBAAA;EAAN,WAAA,CAAA,MAAA,EAAA,OAAA,EAAA,OAAA,EAzVE,OAyVF,EAAA,SAAA,EAxVI,aAwVJ,EAAA,aAAA,EAvVQ,aAuVR,GAAA,IAAA,EAAA,gBAAA,EAAA,OAAA;EAIQ,MAAA,CAAA,MAAA,EA5UP,MA4UO,CAAA,MAAA,EAAA,OAAA,CAAA,EAAA,kBAAA,CAAA,EA3UM,oBA2UN,CAAA,EA1Ud,OA0Uc,CA1UN,iBA0UM,GA1Uc,aA0Ud,CAAA,OAAA,CAAA,CAAA;EAAN,QAAA,WAAA;EAAK,QAAA,mBAAA;;;iBAxBF,4BAAA;iBAmBA,uBAAA,UACL,MAAM;;;aAIJ,MAAM"}
@@ -90,6 +90,7 @@ var WrappedMessages = class {
90
90
  finishReason: resp.stop_reason,
91
91
  toolCalls: extracted.toolCalls.length > 0 ? extracted.toolCalls : void 0,
92
92
  isStreaming: false,
93
+ toolDefinitions: extractAnthropicToolDefinitions(requestParams),
93
94
  systemPrompt: extractAnthropicSystemPrompt(requestParams.system),
94
95
  temperature: requestParams.temperature,
95
96
  maxOutputTokens: requestParams.max_tokens,
@@ -188,6 +189,7 @@ var WrappedMessages = class {
188
189
  isError: state.isError,
189
190
  errorMessage: state.errorMessage,
190
191
  reasoningContent: reasoningContent || void 0,
192
+ toolDefinitions: extractAnthropicToolDefinitions(params),
191
193
  systemPrompt: extractAnthropicSystemPrompt(params.system),
192
194
  temperature: params.temperature,
193
195
  maxOutputTokens: params.max_tokens,
@@ -207,7 +209,9 @@ var WrappedMessages = class {
207
209
  if (!shouldTrackInputMessages) return;
208
210
  if (ctx.userId == null || ctx.sessionId == null) return;
209
211
  if (!Array.isArray(messages)) return;
210
- for (const msg of messages) {
212
+ const lastReplyIdx = messages.findLastIndex((m) => m?.role === "assistant");
213
+ const newMessages = messages.slice(lastReplyIdx + 1);
214
+ for (const msg of newMessages) {
211
215
  if (msg?.role !== "user") continue;
212
216
  const rawContent = msg?.content;
213
217
  const content = Array.isArray(rawContent) ? rawContent.map((part) => {
@@ -273,6 +277,10 @@ function extractAnthropicContent(content) {
273
277
  toolCalls
274
278
  };
275
279
  }
280
+ function extractAnthropicToolDefinitions(params) {
281
+ const tools = params.tools;
282
+ return Array.isArray(tools) && tools.length > 0 ? tools : void 0;
283
+ }
276
284
 
277
285
  //#endregion
278
286
  export { ANTHROPIC_AVAILABLE, Anthropic, WrappedMessages, _AnthropicModule, extractAnthropicContent, extractAnthropicSystemPrompt };
@@ -1 +1 @@
1
- {"version":3,"file":"anthropic.js","names":["_AnthropicModule: Record<string, unknown> | null","clientOpts: Record<string, unknown>","costUsd: number | null","reasoning: string | undefined","toolCalls: Array<Record<string, unknown>>"],"sources":["../../src/providers/anthropic.ts"],"sourcesContent":["/**\n * Anthropic provider wrapper with automatic tracking.\n */\n\nimport type { PrivacyConfig } from '../core/privacy.js';\nimport { trackUserMessage } from '../core/tracking.js';\nimport { getDefaultPropagateContext, injectContext } from '../propagation.js';\nimport type {\n AmplitudeLike,\n AmplitudeOrAI,\n AnthropicResponse,\n TrackFn,\n} from '../types.js';\nimport { calculateCost } from '../utils/costs.js';\nimport { tryRequire } from '../utils/resolve-module.js';\nimport { StreamingAccumulator } from '../utils/streaming.js';\nimport {\n applySessionContext,\n BaseAIProvider,\n contextFields,\n type ProviderTrackOptions,\n} from './base.js';\n\nconst _resolved = tryRequire('@anthropic-ai/sdk');\nexport const ANTHROPIC_AVAILABLE = _resolved != null;\nconst _AnthropicModule: Record<string, unknown> | null = _resolved;\n\nexport { _AnthropicModule };\n\nexport interface AnthropicOptions {\n amplitude: AmplitudeOrAI;\n apiKey?: string;\n privacyConfig?: PrivacyConfig | null;\n propagateContext?: boolean;\n /** Pass the `@anthropic-ai/sdk` module directly to bypass `tryRequire` (required in bundler environments). */\n anthropicModule?: unknown;\n}\n\nexport class Anthropic<\n TClient extends Record<string, unknown> = Record<string, unknown>,\n> extends BaseAIProvider {\n private _client: TClient;\n readonly messages: WrappedMessages;\n private _propagateContext: boolean;\n\n constructor(options: AnthropicOptions) {\n super({\n amplitude: options.amplitude,\n privacyConfig: options.privacyConfig,\n providerName: 'anthropic',\n });\n\n const mod =\n (options.anthropicModule as Record<string, unknown> | null) ??\n _AnthropicModule;\n if (mod == null) {\n throw new Error(\n '@anthropic-ai/sdk package is required. Install it with: npm install @anthropic-ai/sdk — or pass the module directly via the anthropicModule option.',\n );\n }\n\n const AnthropicSDK = mod.Anthropic as new (\n opts: Record<string, unknown>,\n ) => unknown;\n\n const clientOpts: Record<string, unknown> = {};\n if (options.apiKey) clientOpts.apiKey = options.apiKey;\n\n this._client = new AnthropicSDK(clientOpts) as TClient;\n this._propagateContext =\n options.propagateContext ?? getDefaultPropagateContext();\n this.messages = new WrappedMessages(\n this._client,\n this.trackFn(),\n this._amplitude,\n this._privacyConfig,\n this._propagateContext,\n );\n }\n\n get client(): TClient {\n return this._client;\n }\n}\n\nexport class WrappedMessages {\n _original: Record<string, unknown>;\n private _trackFn: TrackFn;\n private _amplitude: AmplitudeLike;\n private _privacyConfig: PrivacyConfig | null;\n private _propagateContext: boolean;\n\n constructor(\n client: unknown,\n trackFn: TrackFn,\n amplitude: AmplitudeLike,\n privacyConfig: PrivacyConfig | null,\n propagateContext: boolean,\n ) {\n const clientObj = client as Record<string, unknown>;\n this._original = clientObj.messages as Record<string, unknown>;\n this._trackFn =\n typeof trackFn === 'function'\n ? trackFn\n : (trackFn as unknown as { trackFn(): TrackFn }).trackFn();\n this._amplitude = amplitude;\n this._privacyConfig = privacyConfig;\n this._propagateContext = propagateContext;\n }\n\n async create(\n params: Record<string, unknown>,\n amplitudeOverrides?: ProviderTrackOptions,\n ): Promise<AnthropicResponse | AsyncIterable<unknown>> {\n const createFn = this._original.create as (\n ...args: unknown[]\n ) => Promise<unknown>;\n const startTime = performance.now();\n const requestParams = this._withContextHeaders(params);\n const ctx = applySessionContext(amplitudeOverrides);\n\n try {\n this._trackInputMessages(\n requestParams.messages as unknown,\n ctx,\n amplitudeOverrides?.trackInputMessages ?? true,\n );\n const response = await createFn.call(this._original, requestParams);\n\n if (requestParams.stream === true && _isAsyncIterable(response)) {\n return this._wrapStream(\n response as AsyncIterable<unknown>,\n requestParams,\n startTime,\n ctx,\n );\n }\n\n const latencyMs = performance.now() - startTime;\n\n const resp = response as AnthropicResponse;\n const usage = resp.usage;\n const extracted = extractAnthropicContent(\n resp.content as unknown as Array<Record<string, unknown>> | undefined,\n );\n const firstTextBlock = resp.content?.find((b) => b.type === 'text');\n const modelName = String(resp.model ?? requestParams.model ?? 'unknown');\n\n const cacheRead = usage?.cache_read_input_tokens ?? 0;\n const cacheCreation = usage?.cache_creation_input_tokens ?? 0;\n const rawInput = usage?.input_tokens ?? 0;\n const normalizedInput =\n cacheRead || cacheCreation\n ? rawInput + cacheRead + cacheCreation\n : rawInput;\n\n let costUsd: number | null = null;\n if (usage?.input_tokens != null && usage?.output_tokens != null) {\n try {\n costUsd = calculateCost({\n modelName,\n inputTokens: normalizedInput,\n outputTokens: usage.output_tokens,\n cacheReadInputTokens: cacheRead,\n cacheCreationInputTokens: cacheCreation,\n defaultProvider: 'anthropic',\n });\n } catch {\n // cost calculation is best-effort\n }\n }\n\n this._trackFn({\n ...contextFields(ctx),\n modelName,\n provider: 'anthropic',\n responseContent: String(firstTextBlock?.text ?? ''),\n reasoningContent: extracted.reasoning,\n latencyMs,\n inputTokens: normalizedInput || undefined,\n outputTokens: usage?.output_tokens,\n cacheReadInputTokens: cacheRead || undefined,\n cacheCreationInputTokens: cacheCreation || undefined,\n totalCostUsd: costUsd,\n finishReason: resp.stop_reason,\n toolCalls:\n extracted.toolCalls.length > 0 ? extracted.toolCalls : undefined,\n isStreaming: false,\n systemPrompt: extractAnthropicSystemPrompt(requestParams.system),\n temperature: requestParams.temperature as number | undefined,\n maxOutputTokens: requestParams.max_tokens as number | undefined,\n topP: requestParams.top_p as number | undefined,\n });\n\n return response as AnthropicResponse;\n } catch (error) {\n const latencyMs = performance.now() - startTime;\n this._trackFn({\n ...contextFields(ctx),\n modelName: String(requestParams.model ?? 'unknown'),\n provider: 'anthropic',\n responseContent: '',\n latencyMs,\n isError: true,\n errorMessage: error instanceof Error ? error.message : String(error),\n });\n\n throw error;\n }\n }\n\n private async *_wrapStream(\n stream: AsyncIterable<unknown>,\n params: Record<string, unknown>,\n _startTime: number,\n sessionCtx: ProviderTrackOptions,\n ): AsyncGenerator<unknown> {\n const accumulator = new StreamingAccumulator();\n accumulator.model = String(params.model ?? 'unknown');\n let reasoningContent = '';\n\n try {\n for await (const event of stream) {\n const evt = event as Record<string, unknown>;\n const type = evt.type as string | undefined;\n\n if (type === 'content_block_delta') {\n const delta = evt.delta as Record<string, unknown> | undefined;\n if (delta?.type === 'text_delta' && delta.text != null) {\n accumulator.addContent(String(delta.text));\n } else if (\n delta?.type === 'thinking_delta' &&\n delta.thinking != null\n ) {\n reasoningContent += String(delta.thinking);\n }\n } else if (type === 'content_block_start') {\n const block = evt.content_block as\n | Record<string, unknown>\n | undefined;\n if (block?.type === 'tool_use') {\n accumulator.addToolCall({\n type: 'function',\n id: block.id,\n function: {\n name: String(block.name ?? ''),\n arguments:\n typeof block.input === 'string'\n ? block.input\n : JSON.stringify(block.input ?? {}),\n },\n });\n }\n } else if (type === 'message_delta') {\n const delta = evt.delta as Record<string, unknown> | undefined;\n if (delta?.stop_reason != null) {\n accumulator.finishReason = String(delta.stop_reason);\n }\n const usage = evt.usage as Record<string, number> | undefined;\n if (usage != null) {\n accumulator.setUsage({\n outputTokens: usage.output_tokens,\n });\n }\n } else if (type === 'message_start') {\n const message = evt.message as Record<string, unknown> | undefined;\n if (message?.model != null) {\n accumulator.model = String(message.model);\n }\n const usage = message?.usage as Record<string, number> | undefined;\n if (usage != null) {\n accumulator.setUsage({\n inputTokens: usage.input_tokens,\n cacheReadTokens: usage.cache_read_input_tokens,\n cacheCreationTokens: usage.cache_creation_input_tokens,\n });\n }\n }\n\n yield event;\n }\n } catch (error) {\n accumulator.setError(\n error instanceof Error ? error.message : String(error),\n );\n throw error;\n } finally {\n const state = accumulator.getState();\n const modelName = String(accumulator.model ?? params.model ?? 'unknown');\n\n const streamCacheRead = state.cacheReadTokens ?? 0;\n const streamCacheCreation = state.cacheCreationTokens ?? 0;\n const streamRawInput = state.inputTokens ?? 0;\n const streamNormalizedInput =\n streamCacheRead || streamCacheCreation\n ? streamRawInput + streamCacheRead + streamCacheCreation\n : streamRawInput;\n\n let costUsd: number | null = null;\n if (state.inputTokens != null && state.outputTokens != null) {\n try {\n costUsd = calculateCost({\n modelName,\n inputTokens: streamNormalizedInput,\n outputTokens: state.outputTokens,\n cacheReadInputTokens: streamCacheRead,\n cacheCreationInputTokens: streamCacheCreation,\n defaultProvider: 'anthropic',\n });\n } catch {\n // cost calculation is best-effort\n }\n }\n\n this._trackFn({\n ...contextFields(sessionCtx),\n modelName,\n provider: 'anthropic',\n responseContent: state.content,\n latencyMs: accumulator.elapsedMs,\n inputTokens: streamNormalizedInput || undefined,\n outputTokens: state.outputTokens,\n cacheReadInputTokens: streamCacheRead || undefined,\n cacheCreationInputTokens: streamCacheCreation || undefined,\n totalCostUsd: costUsd,\n finishReason: state.finishReason,\n toolCalls: state.toolCalls.length > 0 ? state.toolCalls : undefined,\n providerTtfbMs: state.ttfbMs,\n isStreaming: true,\n isError: state.isError,\n errorMessage: state.errorMessage,\n reasoningContent: reasoningContent || undefined,\n systemPrompt: extractAnthropicSystemPrompt(params.system),\n temperature: params.temperature as number | undefined,\n maxOutputTokens: params.max_tokens as number | undefined,\n topP: params.top_p as number | undefined,\n });\n }\n }\n\n private _withContextHeaders(\n params: Record<string, unknown>,\n ): Record<string, unknown> {\n if (!this._propagateContext) return params;\n const existing = (params.extra_headers ?? params.headers) as\n | Record<string, string>\n | undefined;\n const injected = injectContext(existing);\n return {\n ...params,\n extra_headers: injected,\n };\n }\n\n private _trackInputMessages(\n messages: unknown,\n ctx: ProviderTrackOptions,\n shouldTrackInputMessages: boolean,\n ): void {\n if (!shouldTrackInputMessages) return;\n if (ctx.userId == null || ctx.sessionId == null) return;\n if (!Array.isArray(messages)) return;\n for (const msg of messages) {\n const role = (msg as Record<string, unknown>)?.role;\n if (role !== 'user') continue;\n const rawContent = (msg as Record<string, unknown>)?.content;\n const content = Array.isArray(rawContent)\n ? rawContent\n .map((part) => {\n if (typeof part === 'string') return part;\n const text = (part as Record<string, unknown>)?.text;\n return typeof text === 'string' ? text : '';\n })\n .join('')\n : typeof rawContent === 'string'\n ? rawContent\n : '';\n if (!content) continue;\n trackUserMessage({\n amplitude: this._amplitude,\n userId: ctx.userId,\n messageContent: content,\n sessionId: ctx.sessionId,\n traceId: ctx.traceId,\n turnId: ctx.turnId ?? undefined,\n messageSource: ctx.parentAgentId ? 'agent' : 'user',\n agentId: ctx.agentId,\n parentAgentId: ctx.parentAgentId,\n customerOrgId: ctx.customerOrgId,\n agentVersion: ctx.agentVersion,\n context: ctx.context,\n env: ctx.env,\n groups: ctx.groups,\n eventProperties: ctx.eventProperties,\n privacyConfig: this._privacyConfig,\n });\n }\n }\n}\n\nfunction _isAsyncIterable(value: unknown): value is AsyncIterable<unknown> {\n return (\n value != null &&\n typeof (value as Record<symbol, unknown>)[Symbol.asyncIterator] ===\n 'function'\n );\n}\n\nexport function extractAnthropicSystemPrompt(\n system: unknown,\n): string | undefined {\n if (typeof system === 'string') return system;\n if (Array.isArray(system)) {\n return system\n .map((block) => {\n if (typeof block === 'string') return block;\n if (typeof block === 'object' && block != null) {\n return String((block as Record<string, unknown>).text ?? '');\n }\n return '';\n })\n .filter(Boolean)\n .join('\\n');\n }\n return undefined;\n}\n\nexport function extractAnthropicContent(\n content: Array<Record<string, unknown>> | undefined,\n): {\n text: string;\n reasoning: string | undefined;\n toolCalls: Array<Record<string, unknown>>;\n} {\n let text = '';\n let reasoning: string | undefined;\n const toolCalls: Array<Record<string, unknown>> = [];\n\n if (!content) return { text, reasoning, toolCalls };\n\n for (const block of content) {\n if (block.type === 'text') {\n text += String(block.text ?? '');\n } else if (block.type === 'thinking') {\n reasoning = String(block.thinking ?? '');\n } else if (block.type === 'tool_use') {\n toolCalls.push({\n type: 'function',\n id: block.id,\n function: {\n name: String(block.name ?? ''),\n arguments:\n typeof block.input === 'string'\n ? block.input\n : JSON.stringify(block.input ?? {}),\n },\n });\n }\n }\n\n return { text, reasoning, toolCalls };\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"anthropic.js","names":["_AnthropicModule: Record<string, unknown> | null","clientOpts: Record<string, unknown>","costUsd: number | null","reasoning: string | undefined","toolCalls: Array<Record<string, unknown>>"],"sources":["../../src/providers/anthropic.ts"],"sourcesContent":["/**\n * Anthropic provider wrapper with automatic tracking.\n */\n\nimport type { PrivacyConfig } from '../core/privacy.js';\nimport { trackUserMessage } from '../core/tracking.js';\nimport { getDefaultPropagateContext, injectContext } from '../propagation.js';\nimport type {\n AmplitudeLike,\n AmplitudeOrAI,\n AnthropicResponse,\n TrackFn,\n} from '../types.js';\nimport { calculateCost } from '../utils/costs.js';\nimport { tryRequire } from '../utils/resolve-module.js';\nimport { StreamingAccumulator } from '../utils/streaming.js';\nimport {\n applySessionContext,\n BaseAIProvider,\n contextFields,\n type ProviderTrackOptions,\n} from './base.js';\n\nconst _resolved = tryRequire('@anthropic-ai/sdk');\nexport const ANTHROPIC_AVAILABLE = _resolved != null;\nconst _AnthropicModule: Record<string, unknown> | null = _resolved;\n\nexport { _AnthropicModule };\n\nexport interface AnthropicOptions {\n amplitude: AmplitudeOrAI;\n apiKey?: string;\n privacyConfig?: PrivacyConfig | null;\n propagateContext?: boolean;\n /** Pass the `@anthropic-ai/sdk` module directly to bypass `tryRequire` (required in bundler environments). */\n anthropicModule?: unknown;\n}\n\nexport class Anthropic<\n TClient extends Record<string, unknown> = Record<string, unknown>,\n> extends BaseAIProvider {\n private _client: TClient;\n readonly messages: WrappedMessages;\n private _propagateContext: boolean;\n\n constructor(options: AnthropicOptions) {\n super({\n amplitude: options.amplitude,\n privacyConfig: options.privacyConfig,\n providerName: 'anthropic',\n });\n\n const mod =\n (options.anthropicModule as Record<string, unknown> | null) ??\n _AnthropicModule;\n if (mod == null) {\n throw new Error(\n '@anthropic-ai/sdk package is required. Install it with: npm install @anthropic-ai/sdk — or pass the module directly via the anthropicModule option.',\n );\n }\n\n const AnthropicSDK = mod.Anthropic as new (\n opts: Record<string, unknown>,\n ) => unknown;\n\n const clientOpts: Record<string, unknown> = {};\n if (options.apiKey) clientOpts.apiKey = options.apiKey;\n\n this._client = new AnthropicSDK(clientOpts) as TClient;\n this._propagateContext =\n options.propagateContext ?? getDefaultPropagateContext();\n this.messages = new WrappedMessages(\n this._client,\n this.trackFn(),\n this._amplitude,\n this._privacyConfig,\n this._propagateContext,\n );\n }\n\n get client(): TClient {\n return this._client;\n }\n}\n\nexport class WrappedMessages {\n _original: Record<string, unknown>;\n private _trackFn: TrackFn;\n private _amplitude: AmplitudeLike;\n private _privacyConfig: PrivacyConfig | null;\n private _propagateContext: boolean;\n\n constructor(\n client: unknown,\n trackFn: TrackFn,\n amplitude: AmplitudeLike,\n privacyConfig: PrivacyConfig | null,\n propagateContext: boolean,\n ) {\n const clientObj = client as Record<string, unknown>;\n this._original = clientObj.messages as Record<string, unknown>;\n this._trackFn =\n typeof trackFn === 'function'\n ? trackFn\n : (trackFn as unknown as { trackFn(): TrackFn }).trackFn();\n this._amplitude = amplitude;\n this._privacyConfig = privacyConfig;\n this._propagateContext = propagateContext;\n }\n\n async create(\n params: Record<string, unknown>,\n amplitudeOverrides?: ProviderTrackOptions,\n ): Promise<AnthropicResponse | AsyncIterable<unknown>> {\n const createFn = this._original.create as (\n ...args: unknown[]\n ) => Promise<unknown>;\n const startTime = performance.now();\n const requestParams = this._withContextHeaders(params);\n const ctx = applySessionContext(amplitudeOverrides);\n\n try {\n this._trackInputMessages(\n requestParams.messages as unknown,\n ctx,\n amplitudeOverrides?.trackInputMessages ?? true,\n );\n const response = await createFn.call(this._original, requestParams);\n\n if (requestParams.stream === true && _isAsyncIterable(response)) {\n return this._wrapStream(\n response as AsyncIterable<unknown>,\n requestParams,\n startTime,\n ctx,\n );\n }\n\n const latencyMs = performance.now() - startTime;\n\n const resp = response as AnthropicResponse;\n const usage = resp.usage;\n const extracted = extractAnthropicContent(\n resp.content as unknown as Array<Record<string, unknown>> | undefined,\n );\n const firstTextBlock = resp.content?.find((b) => b.type === 'text');\n const modelName = String(resp.model ?? requestParams.model ?? 'unknown');\n\n const cacheRead = usage?.cache_read_input_tokens ?? 0;\n const cacheCreation = usage?.cache_creation_input_tokens ?? 0;\n const rawInput = usage?.input_tokens ?? 0;\n const normalizedInput =\n cacheRead || cacheCreation\n ? rawInput + cacheRead + cacheCreation\n : rawInput;\n\n let costUsd: number | null = null;\n if (usage?.input_tokens != null && usage?.output_tokens != null) {\n try {\n costUsd = calculateCost({\n modelName,\n inputTokens: normalizedInput,\n outputTokens: usage.output_tokens,\n cacheReadInputTokens: cacheRead,\n cacheCreationInputTokens: cacheCreation,\n defaultProvider: 'anthropic',\n });\n } catch {\n // cost calculation is best-effort\n }\n }\n\n this._trackFn({\n ...contextFields(ctx),\n modelName,\n provider: 'anthropic',\n responseContent: String(firstTextBlock?.text ?? ''),\n reasoningContent: extracted.reasoning,\n latencyMs,\n inputTokens: normalizedInput || undefined,\n outputTokens: usage?.output_tokens,\n cacheReadInputTokens: cacheRead || undefined,\n cacheCreationInputTokens: cacheCreation || undefined,\n totalCostUsd: costUsd,\n finishReason: resp.stop_reason,\n toolCalls:\n extracted.toolCalls.length > 0 ? extracted.toolCalls : undefined,\n isStreaming: false,\n toolDefinitions: extractAnthropicToolDefinitions(requestParams),\n systemPrompt: extractAnthropicSystemPrompt(requestParams.system),\n temperature: requestParams.temperature as number | undefined,\n maxOutputTokens: requestParams.max_tokens as number | undefined,\n topP: requestParams.top_p as number | undefined,\n });\n\n return response as AnthropicResponse;\n } catch (error) {\n const latencyMs = performance.now() - startTime;\n this._trackFn({\n ...contextFields(ctx),\n modelName: String(requestParams.model ?? 'unknown'),\n provider: 'anthropic',\n responseContent: '',\n latencyMs,\n isError: true,\n errorMessage: error instanceof Error ? error.message : String(error),\n });\n\n throw error;\n }\n }\n\n private async *_wrapStream(\n stream: AsyncIterable<unknown>,\n params: Record<string, unknown>,\n _startTime: number,\n sessionCtx: ProviderTrackOptions,\n ): AsyncGenerator<unknown> {\n const accumulator = new StreamingAccumulator();\n accumulator.model = String(params.model ?? 'unknown');\n let reasoningContent = '';\n\n try {\n for await (const event of stream) {\n const evt = event as Record<string, unknown>;\n const type = evt.type as string | undefined;\n\n if (type === 'content_block_delta') {\n const delta = evt.delta as Record<string, unknown> | undefined;\n if (delta?.type === 'text_delta' && delta.text != null) {\n accumulator.addContent(String(delta.text));\n } else if (\n delta?.type === 'thinking_delta' &&\n delta.thinking != null\n ) {\n reasoningContent += String(delta.thinking);\n }\n } else if (type === 'content_block_start') {\n const block = evt.content_block as\n | Record<string, unknown>\n | undefined;\n if (block?.type === 'tool_use') {\n accumulator.addToolCall({\n type: 'function',\n id: block.id,\n function: {\n name: String(block.name ?? ''),\n arguments:\n typeof block.input === 'string'\n ? block.input\n : JSON.stringify(block.input ?? {}),\n },\n });\n }\n } else if (type === 'message_delta') {\n const delta = evt.delta as Record<string, unknown> | undefined;\n if (delta?.stop_reason != null) {\n accumulator.finishReason = String(delta.stop_reason);\n }\n const usage = evt.usage as Record<string, number> | undefined;\n if (usage != null) {\n accumulator.setUsage({\n outputTokens: usage.output_tokens,\n });\n }\n } else if (type === 'message_start') {\n const message = evt.message as Record<string, unknown> | undefined;\n if (message?.model != null) {\n accumulator.model = String(message.model);\n }\n const usage = message?.usage as Record<string, number> | undefined;\n if (usage != null) {\n accumulator.setUsage({\n inputTokens: usage.input_tokens,\n cacheReadTokens: usage.cache_read_input_tokens,\n cacheCreationTokens: usage.cache_creation_input_tokens,\n });\n }\n }\n\n yield event;\n }\n } catch (error) {\n accumulator.setError(\n error instanceof Error ? error.message : String(error),\n );\n throw error;\n } finally {\n const state = accumulator.getState();\n const modelName = String(accumulator.model ?? params.model ?? 'unknown');\n\n const streamCacheRead = state.cacheReadTokens ?? 0;\n const streamCacheCreation = state.cacheCreationTokens ?? 0;\n const streamRawInput = state.inputTokens ?? 0;\n const streamNormalizedInput =\n streamCacheRead || streamCacheCreation\n ? streamRawInput + streamCacheRead + streamCacheCreation\n : streamRawInput;\n\n let costUsd: number | null = null;\n if (state.inputTokens != null && state.outputTokens != null) {\n try {\n costUsd = calculateCost({\n modelName,\n inputTokens: streamNormalizedInput,\n outputTokens: state.outputTokens,\n cacheReadInputTokens: streamCacheRead,\n cacheCreationInputTokens: streamCacheCreation,\n defaultProvider: 'anthropic',\n });\n } catch {\n // cost calculation is best-effort\n }\n }\n\n this._trackFn({\n ...contextFields(sessionCtx),\n modelName,\n provider: 'anthropic',\n responseContent: state.content,\n latencyMs: accumulator.elapsedMs,\n inputTokens: streamNormalizedInput || undefined,\n outputTokens: state.outputTokens,\n cacheReadInputTokens: streamCacheRead || undefined,\n cacheCreationInputTokens: streamCacheCreation || undefined,\n totalCostUsd: costUsd,\n finishReason: state.finishReason,\n toolCalls: state.toolCalls.length > 0 ? state.toolCalls : undefined,\n providerTtfbMs: state.ttfbMs,\n isStreaming: true,\n isError: state.isError,\n errorMessage: state.errorMessage,\n reasoningContent: reasoningContent || undefined,\n toolDefinitions: extractAnthropicToolDefinitions(params),\n systemPrompt: extractAnthropicSystemPrompt(params.system),\n temperature: params.temperature as number | undefined,\n maxOutputTokens: params.max_tokens as number | undefined,\n topP: params.top_p as number | undefined,\n });\n }\n }\n\n private _withContextHeaders(\n params: Record<string, unknown>,\n ): Record<string, unknown> {\n if (!this._propagateContext) return params;\n const existing = (params.extra_headers ?? params.headers) as\n | Record<string, string>\n | undefined;\n const injected = injectContext(existing);\n return {\n ...params,\n extra_headers: injected,\n };\n }\n\n private _trackInputMessages(\n messages: unknown,\n ctx: ProviderTrackOptions,\n shouldTrackInputMessages: boolean,\n ): void {\n if (!shouldTrackInputMessages) return;\n if (ctx.userId == null || ctx.sessionId == null) return;\n if (!Array.isArray(messages)) return;\n\n // In agent loops each create() re-sends the full conversation.\n // Only track user messages appended after the last assistant reply\n // so the same message isn't autotracked on every iteration.\n const lastReplyIdx = (messages as Record<string, unknown>[]).findLastIndex(\n (m) => m?.role === 'assistant',\n );\n const newMessages = (messages as Record<string, unknown>[]).slice(lastReplyIdx + 1);\n\n for (const msg of newMessages) {\n const role = (msg as Record<string, unknown>)?.role;\n if (role !== 'user') continue;\n const rawContent = (msg as Record<string, unknown>)?.content;\n const content = Array.isArray(rawContent)\n ? rawContent\n .map((part) => {\n if (typeof part === 'string') return part;\n const text = (part as Record<string, unknown>)?.text;\n return typeof text === 'string' ? text : '';\n })\n .join('')\n : typeof rawContent === 'string'\n ? rawContent\n : '';\n if (!content) continue;\n trackUserMessage({\n amplitude: this._amplitude,\n userId: ctx.userId,\n messageContent: content,\n sessionId: ctx.sessionId,\n traceId: ctx.traceId,\n turnId: ctx.turnId ?? undefined,\n messageSource: ctx.parentAgentId ? 'agent' : 'user',\n agentId: ctx.agentId,\n parentAgentId: ctx.parentAgentId,\n customerOrgId: ctx.customerOrgId,\n agentVersion: ctx.agentVersion,\n context: ctx.context,\n env: ctx.env,\n groups: ctx.groups,\n eventProperties: ctx.eventProperties,\n privacyConfig: this._privacyConfig,\n });\n }\n }\n}\n\nfunction _isAsyncIterable(value: unknown): value is AsyncIterable<unknown> {\n return (\n value != null &&\n typeof (value as Record<symbol, unknown>)[Symbol.asyncIterator] ===\n 'function'\n );\n}\n\nexport function extractAnthropicSystemPrompt(\n system: unknown,\n): string | undefined {\n if (typeof system === 'string') return system;\n if (Array.isArray(system)) {\n return system\n .map((block) => {\n if (typeof block === 'string') return block;\n if (typeof block === 'object' && block != null) {\n return String((block as Record<string, unknown>).text ?? '');\n }\n return '';\n })\n .filter(Boolean)\n .join('\\n');\n }\n return undefined;\n}\n\nexport function extractAnthropicContent(\n content: Array<Record<string, unknown>> | undefined,\n): {\n text: string;\n reasoning: string | undefined;\n toolCalls: Array<Record<string, unknown>>;\n} {\n let text = '';\n let reasoning: string | undefined;\n const toolCalls: Array<Record<string, unknown>> = [];\n\n if (!content) return { text, reasoning, toolCalls };\n\n for (const block of content) {\n if (block.type === 'text') {\n text += String(block.text ?? '');\n } else if (block.type === 'thinking') {\n reasoning = String(block.thinking ?? '');\n } else if (block.type === 'tool_use') {\n toolCalls.push({\n type: 'function',\n id: block.id,\n function: {\n name: String(block.name ?? ''),\n arguments:\n typeof block.input === 'string'\n ? block.input\n : JSON.stringify(block.input ?? {}),\n },\n });\n }\n }\n\n return { text, reasoning, toolCalls };\n}\n\nfunction extractAnthropicToolDefinitions(\n params: Record<string, unknown>,\n): Array<Record<string, unknown>> | undefined {\n const tools = params.tools;\n return Array.isArray(tools) && tools.length > 0\n ? (tools as Array<Record<string, unknown>>)\n : undefined;\n}\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"bedrock.d.ts","names":[],"sources":["../../src/providers/bedrock.ts"],"sourcesContent":[],"mappings":";;;;;;AA2Ba,cAbA,iBAaQ,EAAA,OAAA;cAZf,cAgBiB,EAhBD,MAgBC,CAAA,MAAA,EAAA,OAAA,CAAA,GAAA,IAAA;AAY4B,UAxBlC,cAAA,CAwBkC;EAgFpB,SAAA,EAvGlB,aAuGkB;EAA0B,MAAA,EAAA,OAAA;EAhG5B,aAAA,CAAA,EALX,aAKW,GAAA,IAAA;EAAc;EAmQ3B,aAAA,CAAA,EAAA,OAAA;;cAnQH,OAAA,SAAgB,cAAA;;;uBAIN;mBAYE,0BAA0B;yBAgFpB,0BAA0B;;;;iBAmKzC,sBAAA;;;;;;;;aAQH,MAAM"}
1
+ {"version":3,"file":"bedrock.d.ts","names":[],"sources":["../../src/providers/bedrock.ts"],"sourcesContent":[],"mappings":";;;;;;AA2Ba,cAbA,iBAaQ,EAAA,OAAA;cAZf,cAgBiB,EAhBD,MAgBC,CAAA,MAAA,EAAA,OAAA,CAAA,GAAA,IAAA;AAY4B,UAxBlC,cAAA,CAwBkC;EAiFpB,SAAA,EAxGlB,aAwGkB;EAA0B,MAAA,EAAA,OAAA;EAjG5B,aAAA,CAAA,EALX,aAKW,GAAA,IAAA;EAAc;EAqQ3B,aAAA,CAAA,EAAA,OAAA;;cArQH,OAAA,SAAgB,cAAA;;;uBAIN;mBAYE,0BAA0B;yBAiFpB,0BAA0B;;;;iBAoKzC,sBAAA;;;;;;;;aAQH,MAAM"}
@@ -54,6 +54,7 @@ var Bedrock = class extends BaseAIProvider {
54
54
  totalCostUsd: costUsd,
55
55
  finishReason: extracted.stopReason,
56
56
  toolCalls: extracted.toolCalls.length > 0 ? extracted.toolCalls : void 0,
57
+ toolDefinitions: extractBedrockToolDefinitions(params),
57
58
  systemPrompt: extracted.systemPrompt,
58
59
  temperature: extracted.temperature,
59
60
  topP: extracted.topP,
@@ -163,6 +164,7 @@ var Bedrock = class extends BaseAIProvider {
163
164
  totalCostUsd: costUsd,
164
165
  finishReason: state.finishReason,
165
166
  toolCalls: state.toolCalls.length > 0 ? state.toolCalls : void 0,
167
+ toolDefinitions: extractBedrockToolDefinitions(params),
166
168
  systemPrompt: extractSystemPromptFromParams(params),
167
169
  temperature: params.inferenceConfig?.temperature,
168
170
  topP: params.inferenceConfig?.topP,
@@ -207,6 +209,12 @@ function extractSystemPromptFromParams(params) {
207
209
  if (!Array.isArray(system) || system.length === 0) return void 0;
208
210
  return system.map((s) => String(s.text ?? "")).join("");
209
211
  }
212
+ function extractBedrockToolDefinitions(params) {
213
+ const toolConfig = params.toolConfig;
214
+ if (toolConfig == null) return void 0;
215
+ const tools = toolConfig.tools;
216
+ return Array.isArray(tools) && tools.length > 0 ? tools : void 0;
217
+ }
210
218
  function _isAsyncIterable(value) {
211
219
  return value != null && typeof value[Symbol.asyncIterator] === "function";
212
220
  }