@posthog/ai 7.11.1 → 7.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +16 -33
- package/dist/anthropic/index.cjs +1 -1
- package/dist/anthropic/index.mjs +1 -1
- package/dist/gemini/index.cjs +1 -1
- package/dist/gemini/index.mjs +1 -1
- package/dist/index.cjs +29 -841
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +29 -62
- package/dist/index.mjs +29 -839
- package/dist/index.mjs.map +1 -1
- package/dist/langchain/index.cjs +1 -1
- package/dist/langchain/index.mjs +1 -1
- package/dist/openai/index.cjs +1 -1
- package/dist/openai/index.mjs +1 -1
- package/dist/otel/index.cjs +30 -1128
- package/dist/otel/index.cjs.map +1 -1
- package/dist/otel/index.d.ts +29 -72
- package/dist/otel/index.mjs +30 -1125
- package/dist/otel/index.mjs.map +1 -1
- package/dist/vercel/index.cjs +1 -1
- package/dist/vercel/index.mjs +1 -1
- package/package.json +7 -7
package/dist/otel/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../src/typeGuards.ts","../../src/sanitization.ts","../../src/utils.ts","../../src/otel/mappers/aiSdk.ts","../../src/otel/mappers/index.ts","../../src/otel/capture.ts","../../src/otel/processor.ts"],"sourcesContent":["// Type guards for safer type checking\n\nexport const isString = (value: unknown): value is string => {\n return typeof value === 'string'\n}\n\nexport const isObject = (value: unknown): value is Record<string, unknown> => {\n return value !== null && typeof value === 'object' && !Array.isArray(value)\n}\n","import { isString, isObject } from './typeGuards'\n\nconst REDACTED_IMAGE_PLACEHOLDER = '[base64 image redacted]'\n\n// ============================================\n// Multimodal Feature Toggle\n// ============================================\n\nconst isMultimodalEnabled = (): boolean => {\n const val = process.env._INTERNAL_LLMA_MULTIMODAL || ''\n return val.toLowerCase() === 'true' || val === '1' || val.toLowerCase() === 'yes'\n}\n\n// ============================================\n// Base64 Detection Helpers\n// ============================================\n\nconst isBase64DataUrl = (str: string): boolean => {\n return /^data:([^;]+);base64,/.test(str)\n}\n\nconst isValidUrl = (str: string): boolean => {\n try {\n new URL(str)\n return true\n } catch {\n // Not an absolute URL, check if it's a relative URL or path\n return str.startsWith('/') || str.startsWith('./') || str.startsWith('../')\n }\n}\n\nconst isRawBase64 = (str: string): boolean => {\n // Skip if it's a valid URL or path\n if (isValidUrl(str)) {\n return false\n }\n\n // Check if it's a valid base64 string\n // Base64 images are typically at least a few hundred chars, but we'll be conservative\n return str.length > 20 && /^[A-Za-z0-9+/]+=*$/.test(str)\n}\n\nexport function redactBase64DataUrl(str: string): string\nexport function redactBase64DataUrl(str: unknown): unknown\nexport function redactBase64DataUrl(str: unknown): unknown {\n if (isMultimodalEnabled()) return str\n if (!isString(str)) return str\n\n // Check for data URL format\n if (isBase64DataUrl(str)) {\n return REDACTED_IMAGE_PLACEHOLDER\n }\n\n // Check for raw base64 (Vercel sends raw base64 for inline images)\n if (isRawBase64(str)) {\n return REDACTED_IMAGE_PLACEHOLDER\n }\n\n return str\n}\n\n// ============================================\n// Common Message Processing\n// ============================================\n\ntype ContentTransformer = (item: unknown) => unknown\n\nconst processMessages = (messages: unknown, transformContent: ContentTransformer): unknown => {\n if (!messages) return messages\n\n const processContent = (content: unknown): unknown => {\n if (typeof content === 'string') return content\n\n if (!content) return content\n\n if (Array.isArray(content)) {\n return content.map(transformContent)\n }\n\n // Handle single object content\n return transformContent(content)\n }\n\n const processMessage = (msg: unknown): unknown => {\n if (!isObject(msg) || !('content' in msg)) return msg\n return { ...msg, content: processContent(msg.content) }\n }\n\n // Handle both arrays and single messages\n if (Array.isArray(messages)) {\n return messages.map(processMessage)\n }\n\n return processMessage(messages)\n}\n\n// ============================================\n// Provider-Specific Image Sanitizers\n// ============================================\n\nconst sanitizeOpenAIImage = (item: unknown): unknown => {\n if (!isObject(item)) return item\n\n // Handle image_url format\n if (item.type === 'image_url' && 'image_url' in item && isObject(item.image_url) && 'url' in item.image_url) {\n return {\n ...item,\n image_url: {\n ...item.image_url,\n url: redactBase64DataUrl(item.image_url.url),\n },\n }\n }\n\n // Handle video_url format\n if (item.type === 'video_url' && 'video_url' in item && isObject(item.video_url) && 'url' in item.video_url) {\n return {\n ...item,\n video_url: {\n ...item.video_url,\n url: redactBase64DataUrl(item.video_url.url),\n },\n }\n }\n\n // Handle audio format\n if (item.type === 'audio' && 'data' in item) {\n if (isMultimodalEnabled()) return item\n return { ...item, data: REDACTED_IMAGE_PLACEHOLDER }\n }\n\n return item\n}\n\nconst sanitizeOpenAIResponseImage = (item: unknown): unknown => {\n if (!isObject(item)) return item\n\n // Handle input_image format\n if (item.type === 'input_image' && 'image_url' in item) {\n return {\n ...item,\n image_url: redactBase64DataUrl(item.image_url),\n }\n }\n\n return item\n}\n\nconst sanitizeAnthropicImage = (item: unknown): unknown => {\n if (isMultimodalEnabled()) return item\n if (!isObject(item)) return item\n\n // Handle Anthropic's image and document formats (same structure, different type field)\n if (\n (item.type === 'image' || item.type === 'document') &&\n 'source' in item &&\n isObject(item.source) &&\n item.source.type === 'base64' &&\n 'data' in item.source\n ) {\n return {\n ...item,\n source: {\n ...item.source,\n data: REDACTED_IMAGE_PLACEHOLDER,\n },\n }\n }\n\n return item\n}\n\nconst sanitizeGeminiPart = (part: unknown): unknown => {\n if (isMultimodalEnabled()) return part\n if (!isObject(part)) return part\n\n // Handle Gemini's inline data format (images, audio, PDFs all use inlineData)\n if ('inlineData' in part && isObject(part.inlineData) && 'data' in part.inlineData) {\n return {\n ...part,\n inlineData: {\n ...part.inlineData,\n data: REDACTED_IMAGE_PLACEHOLDER,\n },\n }\n }\n\n return part\n}\n\nconst processGeminiItem = (item: unknown): unknown => {\n if (!isObject(item)) return item\n\n // If it has parts, process them\n if ('parts' in item && item.parts) {\n const parts = Array.isArray(item.parts) ? item.parts.map(sanitizeGeminiPart) : sanitizeGeminiPart(item.parts)\n\n return { ...item, parts }\n }\n\n return item\n}\n\nconst sanitizeLangChainImage = (item: unknown): unknown => {\n if (!isObject(item)) return item\n\n // OpenAI style\n if (item.type === 'image_url' && 'image_url' in item && isObject(item.image_url) && 'url' in item.image_url) {\n return {\n ...item,\n image_url: {\n ...item.image_url,\n url: redactBase64DataUrl(item.image_url.url),\n },\n }\n }\n\n // Direct image with data field\n if (item.type === 'image' && 'data' in item) {\n return { ...item, data: redactBase64DataUrl(item.data) }\n }\n\n // Anthropic style\n if (item.type === 'image' && 'source' in item && isObject(item.source) && 'data' in item.source) {\n if (isMultimodalEnabled()) return item\n return {\n ...item,\n source: {\n ...item.source,\n data: redactBase64DataUrl(item.source.data),\n },\n }\n }\n\n // Google style\n if (item.type === 'media' && 'data' in item) {\n return { ...item, data: redactBase64DataUrl(item.data) }\n }\n\n return item\n}\n\n// Export individual sanitizers for tree-shaking\nexport const sanitizeOpenAI = (data: unknown): unknown => {\n return processMessages(data, sanitizeOpenAIImage)\n}\n\nexport const sanitizeOpenAIResponse = (data: unknown): unknown => {\n return processMessages(data, sanitizeOpenAIResponseImage)\n}\n\nexport const sanitizeAnthropic = (data: unknown): unknown => {\n return processMessages(data, sanitizeAnthropicImage)\n}\n\nexport const sanitizeGemini = (data: unknown): unknown => {\n // Gemini has a different structure with 'parts' directly on items instead of 'content'\n // So we need custom processing instead of using processMessages\n if (!data) return data\n\n if (Array.isArray(data)) {\n return data.map(processGeminiItem)\n }\n\n return processGeminiItem(data)\n}\n\nexport const sanitizeLangChain = (data: unknown): unknown => {\n return processMessages(data, sanitizeLangChainImage)\n}\n","import { EventMessage, PostHog } from 'posthog-node'\nimport OpenAIOrignal from 'openai'\nimport AnthropicOriginal from '@anthropic-ai/sdk'\nimport type { ChatCompletionTool } from 'openai/resources/chat/completions'\nimport type { ResponseCreateParamsWithTools } from 'openai/lib/ResponsesParser'\nimport type { Tool as GeminiTool } from '@google/genai'\nimport type { FormattedMessage, FormattedContent, TokenUsage } from './types'\nimport { version } from '../package.json'\nimport { v4 as uuidv4 } from 'uuid'\nimport { isString } from './typeGuards'\nimport { uuidv7, ErrorTracking as CoreErrorTracking } from '@posthog/core'\nimport { redactBase64DataUrl } from './sanitization'\n\ntype ChatCompletionCreateParamsBase = OpenAIOrignal.Chat.Completions.ChatCompletionCreateParams\ntype MessageCreateParams = AnthropicOriginal.Messages.MessageCreateParams\ntype ResponseCreateParams = OpenAIOrignal.Responses.ResponseCreateParams\ntype EmbeddingCreateParams = OpenAIOrignal.EmbeddingCreateParams\ntype TranscriptionCreateParams = OpenAIOrignal.Audio.Transcriptions.TranscriptionCreateParams\ntype AnthropicTool = AnthropicOriginal.Tool\n\nconst TOKEN_PROPERTY_KEYS = new Set([\n '$ai_input_tokens',\n '$ai_output_tokens',\n '$ai_cache_read_input_tokens',\n '$ai_cache_creation_input_tokens',\n '$ai_total_tokens',\n '$ai_reasoning_tokens',\n])\n\nexport function getTokensSource(posthogProperties?: Record<string, unknown>): string {\n if (posthogProperties && Object.keys(posthogProperties).some((key) => TOKEN_PROPERTY_KEYS.has(key))) {\n return 'passthrough'\n }\n return 'sdk'\n}\n\n// limit large outputs by truncating to 200kb (approx 200k bytes)\nexport const MAX_OUTPUT_SIZE = 200000\nconst STRING_FORMAT = 'utf8'\n\n/**\n * Safely converts content to a string, preserving structure for objects/arrays.\n * - If content is already a string, returns it as-is\n * - If content is an object or array, stringifies it with JSON.stringify to preserve structure\n * - Otherwise, converts to string with String()\n *\n * This prevents the \"[object Object]\" bug when objects are naively converted to strings.\n *\n * @param content - The content to convert to a string\n * @returns A string representation that preserves structure for complex types\n */\nexport function toContentString(content: unknown): string {\n if (typeof content === 'string') {\n return content\n }\n if (content !== undefined && content !== null && typeof content === 'object') {\n try {\n return JSON.stringify(content)\n } catch {\n // Fallback for circular refs, BigInt, or objects with throwing toJSON\n return String(content)\n }\n }\n return String(content)\n}\n\nexport interface MonitoringEventPropertiesWithDefaults {\n distinctId?: string\n traceId: string\n properties?: Record<string, any>\n privacyMode: boolean\n groups?: Record<string, any>\n modelOverride?: string\n providerOverride?: string\n costOverride?: CostOverride\n captureImmediate?: boolean\n}\n\nexport type MonitoringEventProperties = Partial<MonitoringEventPropertiesWithDefaults>\n\nexport type MonitoringParams = {\n [K in keyof MonitoringEventProperties as `posthog${Capitalize<string & K>}`]: MonitoringEventProperties[K]\n}\n\nexport interface CostOverride {\n inputCost: number\n outputCost: number\n}\n\nexport const getModelParams = (\n params:\n | ((\n | ChatCompletionCreateParamsBase\n | MessageCreateParams\n | ResponseCreateParams\n | ResponseCreateParamsWithTools\n | EmbeddingCreateParams\n | TranscriptionCreateParams\n ) &\n MonitoringParams)\n | null\n): Record<string, any> => {\n if (!params) {\n return {}\n }\n const modelParams: Record<string, any> = {}\n const paramKeys = [\n 'temperature',\n 'max_tokens',\n 'max_completion_tokens',\n 'top_p',\n 'frequency_penalty',\n 'presence_penalty',\n 'n',\n 'stop',\n 'stream',\n 'streaming',\n 'language',\n 'response_format',\n 'timestamp_granularities',\n ] as const\n\n for (const key of paramKeys) {\n if (key in params && (params as any)[key] !== undefined) {\n modelParams[key] = (params as any)[key]\n }\n }\n return modelParams\n}\n\n/**\n * Helper to format responses (non-streaming) for consumption\n */\nexport const formatResponse = (response: any, provider: string): FormattedMessage[] => {\n if (!response) {\n return []\n }\n if (provider === 'anthropic') {\n return formatResponseAnthropic(response)\n } else if (provider === 'openai') {\n return formatResponseOpenAI(response)\n } else if (provider === 'gemini') {\n return formatResponseGemini(response)\n }\n return []\n}\n\nexport const formatResponseAnthropic = (response: any): FormattedMessage[] => {\n const output: FormattedMessage[] = []\n const content: FormattedContent = []\n\n for (const choice of response.content ?? []) {\n if (choice?.type === 'text' && choice?.text) {\n content.push({ type: 'text', text: choice.text })\n } else if (choice?.type === 'tool_use' && choice?.name && choice?.id) {\n content.push({\n type: 'function',\n id: choice.id,\n function: {\n name: choice.name,\n arguments: choice.input || {},\n },\n })\n }\n }\n\n if (content.length > 0) {\n output.push({\n role: 'assistant',\n content,\n })\n }\n\n return output\n}\n\nexport const formatResponseOpenAI = (response: any): FormattedMessage[] => {\n const output: FormattedMessage[] = []\n\n if (response.choices) {\n for (const choice of response.choices) {\n const content: FormattedContent = []\n let role = 'assistant'\n\n if (choice.message) {\n if (choice.message.role) {\n role = choice.message.role\n }\n\n if (choice.message.content) {\n content.push({ type: 'text', text: choice.message.content })\n }\n\n if (choice.message.tool_calls) {\n for (const toolCall of choice.message.tool_calls) {\n content.push({\n type: 'function',\n id: toolCall.id,\n function: {\n name: toolCall.function.name,\n arguments: toolCall.function.arguments,\n },\n })\n }\n }\n\n // Handle audio output (gpt-4o-audio-preview)\n if (choice.message.audio) {\n content.push({\n type: 'audio',\n ...choice.message.audio,\n })\n }\n }\n\n if (content.length > 0) {\n output.push({\n role,\n content,\n })\n }\n }\n }\n\n // Handle Responses API format\n if (response.output) {\n const content: FormattedContent = []\n let role = 'assistant'\n\n for (const item of response.output) {\n if (item.type === 'message') {\n role = item.role\n\n if (item.content && Array.isArray(item.content)) {\n for (const contentItem of item.content) {\n if (contentItem.type === 'output_text' && contentItem.text) {\n content.push({ type: 'text', text: contentItem.text })\n } else if (contentItem.text) {\n content.push({ type: 'text', text: contentItem.text })\n } else if (contentItem.type === 'input_image' && contentItem.image_url) {\n content.push({\n type: 'image',\n image: contentItem.image_url,\n })\n }\n }\n } else if (item.content) {\n content.push({ type: 'text', text: String(item.content) })\n }\n } else if (item.type === 'function_call') {\n content.push({\n type: 'function',\n id: item.call_id || item.id || '',\n function: {\n name: item.name,\n arguments: item.arguments || {},\n },\n })\n }\n }\n\n if (content.length > 0) {\n output.push({\n role,\n content,\n })\n }\n }\n\n return output\n}\n\nexport const formatResponseGemini = (response: any): FormattedMessage[] => {\n const output: FormattedMessage[] = []\n\n if (response.candidates && Array.isArray(response.candidates)) {\n for (const candidate of response.candidates) {\n if (candidate.content && candidate.content.parts) {\n const content: FormattedContent = []\n\n for (const part of candidate.content.parts) {\n if (part.text) {\n content.push({ type: 'text', text: part.text })\n } else if (part.functionCall) {\n content.push({\n type: 'function',\n function: {\n name: part.functionCall.name,\n arguments: part.functionCall.args,\n },\n })\n } else if (part.inlineData) {\n // Handle audio/media inline data\n const mimeType = part.inlineData.mimeType || 'audio/pcm'\n let data = part.inlineData.data\n\n // Handle binary data (Uint8Array/Buffer -> base64)\n if (data instanceof Uint8Array) {\n if (typeof Buffer !== 'undefined') {\n data = Buffer.from(data).toString('base64')\n } else {\n let binary = ''\n for (let i = 0; i < data.length; i++) {\n binary += String.fromCharCode(data[i])\n }\n data = btoa(binary)\n }\n }\n\n // Sanitize base64 data for images and other large inline data\n data = redactBase64DataUrl(data)\n\n content.push({\n type: 'audio',\n mime_type: mimeType,\n data: data,\n })\n }\n }\n\n if (content.length > 0) {\n output.push({\n role: 'assistant',\n content,\n })\n }\n } else if (candidate.text) {\n output.push({\n role: 'assistant',\n content: [{ type: 'text', text: candidate.text }],\n })\n }\n }\n } else if (response.text) {\n output.push({\n role: 'assistant',\n content: [{ type: 'text', text: response.text }],\n })\n }\n\n return output\n}\n\nexport const mergeSystemPrompt = (params: MessageCreateParams & MonitoringParams, provider: string): any => {\n if (provider == 'anthropic') {\n const messages = params.messages || []\n if (!(params as any).system) {\n return messages\n }\n const systemMessage = (params as any).system\n return [{ role: 'system', content: systemMessage }, ...messages]\n }\n return params.messages\n}\n\nexport const withPrivacyMode = (client: PostHog, privacyMode: boolean, input: any): any => {\n return (client as any).privacy_mode || privacyMode ? null : input\n}\n\nfunction toSafeString(input: unknown): string {\n if (input === undefined || input === null) {\n return ''\n }\n if (typeof input === 'string') {\n return input\n }\n try {\n return JSON.stringify(input)\n } catch {\n console.warn('Failed to stringify input', input)\n return ''\n }\n}\n\nexport const truncate = (input: unknown): string => {\n const str = toSafeString(input)\n if (str === '') {\n return ''\n }\n\n // Check if we need to truncate and ensure STRING_FORMAT is respected\n const encoder = new TextEncoder()\n const buffer = encoder.encode(str)\n if (buffer.length <= MAX_OUTPUT_SIZE) {\n // Ensure STRING_FORMAT is respected\n return new TextDecoder(STRING_FORMAT).decode(buffer)\n }\n\n // Truncate the buffer and ensure a valid string is returned\n const truncatedBuffer = buffer.slice(0, MAX_OUTPUT_SIZE)\n // fatal: false means we get U+FFFD at the end if truncation broke the encoding\n const decoder = new TextDecoder(STRING_FORMAT, { fatal: false })\n let truncatedStr = decoder.decode(truncatedBuffer)\n if (truncatedStr.endsWith('\\uFFFD')) {\n truncatedStr = truncatedStr.slice(0, -1)\n }\n return `${truncatedStr}... [truncated]`\n}\n\n/**\n * Calculate web search count from raw API response.\n *\n * Uses a two-tier detection strategy:\n * Priority 1 (Exact Count): Count actual web search calls when available\n * Priority 2 (Binary Detection): Return 1 if web search indicators are present, 0 otherwise\n *\n * @param result - Raw API response from any provider (OpenAI, Perplexity, OpenRouter, Gemini, etc.)\n * @returns Number of web searches performed (exact count or binary 1/0)\n */\nexport function calculateWebSearchCount(result: unknown): number {\n if (!result || typeof result !== 'object') {\n return 0\n }\n\n // Priority 1: Exact Count\n // Check for OpenAI Responses API web_search_call items\n if ('output' in result && Array.isArray(result.output)) {\n let count = 0\n\n for (const item of result.output) {\n if (typeof item === 'object' && item !== null && 'type' in item && item.type === 'web_search_call') {\n count++\n }\n }\n\n if (count > 0) {\n return count\n }\n }\n\n // Priority 2: Binary Detection (1 or 0)\n\n // Check for citations at root level (Perplexity)\n if ('citations' in result && Array.isArray(result.citations) && result.citations.length > 0) {\n return 1\n }\n\n // Check for search_results at root level (Perplexity via OpenRouter)\n if ('search_results' in result && Array.isArray(result.search_results) && result.search_results.length > 0) {\n return 1\n }\n\n // Check for usage.search_context_size (Perplexity via OpenRouter)\n if ('usage' in result && typeof result.usage === 'object' && result.usage !== null) {\n if ('search_context_size' in result.usage && result.usage.search_context_size) {\n return 1\n }\n }\n\n // Check for annotations with url_citation in choices[].message or choices[].delta (OpenAI/Perplexity)\n if ('choices' in result && Array.isArray(result.choices)) {\n for (const choice of result.choices) {\n if (typeof choice === 'object' && choice !== null) {\n // Check both message (non-streaming) and delta (streaming) for annotations\n const content = ('message' in choice ? choice.message : null) || ('delta' in choice ? choice.delta : null)\n\n if (typeof content === 'object' && content !== null && 'annotations' in content) {\n const annotations = content.annotations\n\n if (Array.isArray(annotations)) {\n const hasUrlCitation = annotations.some((ann: unknown) => {\n return typeof ann === 'object' && ann !== null && 'type' in ann && ann.type === 'url_citation'\n })\n\n if (hasUrlCitation) {\n return 1\n }\n }\n }\n }\n }\n }\n\n // Check for annotations in output[].content[] (OpenAI Responses API)\n if ('output' in result && Array.isArray(result.output)) {\n for (const item of result.output) {\n if (typeof item === 'object' && item !== null && 'content' in item) {\n const content = item.content\n\n if (Array.isArray(content)) {\n for (const contentItem of content) {\n if (typeof contentItem === 'object' && contentItem !== null && 'annotations' in contentItem) {\n const annotations = contentItem.annotations\n\n if (Array.isArray(annotations)) {\n const hasUrlCitation = annotations.some((ann: unknown) => {\n return typeof ann === 'object' && ann !== null && 'type' in ann && ann.type === 'url_citation'\n })\n\n if (hasUrlCitation) {\n return 1\n }\n }\n }\n }\n }\n }\n }\n }\n\n // Check for grounding_metadata (Gemini)\n if ('candidates' in result && Array.isArray(result.candidates)) {\n for (const candidate of result.candidates) {\n if (\n typeof candidate === 'object' &&\n candidate !== null &&\n 'grounding_metadata' in candidate &&\n candidate.grounding_metadata\n ) {\n return 1\n }\n }\n }\n\n return 0\n}\n\n/**\n * Extract available tool calls from the request parameters.\n * These are the tools provided to the LLM, not the tool calls in the response.\n */\nexport const extractAvailableToolCalls = (\n provider: string,\n params: any\n): ChatCompletionTool[] | AnthropicTool[] | GeminiTool[] | null => {\n if (provider === 'anthropic') {\n if (params.tools) {\n return params.tools\n }\n\n return null\n } else if (provider === 'gemini') {\n if (params.config && params.config.tools) {\n return params.config.tools\n }\n\n return null\n } else if (provider === 'openai') {\n if (params.tools) {\n return params.tools\n }\n\n return null\n } else if (provider === 'vercel') {\n if (params.tools) {\n return params.tools\n }\n\n return null\n }\n\n return null\n}\n\nexport enum AIEvent {\n Generation = '$ai_generation',\n Embedding = '$ai_embedding',\n}\n\nexport type SendEventToPosthogParams = {\n client: PostHog\n eventType?: AIEvent\n distinctId?: string\n traceId: string\n model?: string\n provider: string\n input: any\n output: any\n latency: number\n timeToFirstToken?: number\n baseURL: string\n httpStatus: number\n usage?: TokenUsage\n params: (\n | ChatCompletionCreateParamsBase\n | MessageCreateParams\n | ResponseCreateParams\n | ResponseCreateParamsWithTools\n | EmbeddingCreateParams\n | TranscriptionCreateParams\n ) &\n MonitoringParams\n error?: unknown\n exceptionId?: string\n tools?: ChatCompletionTool[] | AnthropicTool[] | GeminiTool[] | null\n captureImmediate?: boolean\n}\n\nfunction sanitizeValues(obj: any): any {\n if (obj === undefined || obj === null) {\n return obj\n }\n const jsonSafe = JSON.parse(JSON.stringify(obj))\n if (typeof jsonSafe === 'string') {\n // Sanitize lone surrogates by round-tripping through UTF-8\n return new TextDecoder().decode(new TextEncoder().encode(jsonSafe))\n } else if (Array.isArray(jsonSafe)) {\n return jsonSafe.map(sanitizeValues)\n } else if (jsonSafe && typeof jsonSafe === 'object') {\n return Object.fromEntries(Object.entries(jsonSafe).map(([k, v]) => [k, sanitizeValues(v)]))\n }\n return jsonSafe\n}\n\nconst POSTHOG_PARAMS_MAP: Record<keyof MonitoringParams, string> = {\n posthogDistinctId: 'distinctId',\n posthogTraceId: 'traceId',\n posthogProperties: 'properties',\n posthogPrivacyMode: 'privacyMode',\n posthogGroups: 'groups',\n posthogModelOverride: 'modelOverride',\n posthogProviderOverride: 'providerOverride',\n posthogCostOverride: 'costOverride',\n posthogCaptureImmediate: 'captureImmediate',\n}\n\nexport function extractPosthogParams<T>(body: T & MonitoringParams): {\n providerParams: T\n posthogParams: MonitoringEventPropertiesWithDefaults\n} {\n const providerParams: Record<string, unknown> = {}\n const posthogParams: Record<string, unknown> = {}\n\n for (const [key, value] of Object.entries(body)) {\n if (POSTHOG_PARAMS_MAP[key as keyof MonitoringParams]) {\n posthogParams[POSTHOG_PARAMS_MAP[key as keyof MonitoringParams]] = value\n } else if (key.startsWith('posthog')) {\n console.warn(`Unknown Posthog parameter ${key}`)\n } else {\n providerParams[key] = value\n }\n }\n\n return {\n providerParams: providerParams as T,\n posthogParams: addDefaults(posthogParams),\n }\n}\n\nfunction addDefaults(params: MonitoringEventProperties): MonitoringEventPropertiesWithDefaults {\n return {\n ...params,\n privacyMode: params.privacyMode ?? false,\n traceId: params.traceId ?? uuidv4(),\n }\n}\n\nexport const sendEventWithErrorToPosthog = async ({\n client,\n traceId,\n error,\n ...args\n}: Omit<SendEventToPosthogParams, 'error' | 'httpStatus'> &\n Required<Pick<SendEventToPosthogParams, 'error'>>): Promise<unknown> => {\n const httpStatus =\n error && typeof error === 'object' && 'status' in error ? ((error as { status?: number }).status ?? 500) : 500\n\n const properties = { client, traceId, httpStatus, error: JSON.stringify(error), ...args }\n const enrichedError = error as CoreErrorTracking.PreviouslyCapturedError\n\n if (client.options?.enableExceptionAutocapture) {\n // assign a uuid that can be used to link the trace and exception events\n const exceptionId = uuidv7()\n client.captureException(error, undefined, { $ai_trace_id: traceId }, exceptionId)\n enrichedError.__posthog_previously_captured_error = true\n properties.exceptionId = exceptionId\n }\n\n await sendEventToPosthog(properties)\n\n return enrichedError\n}\n\nexport const sendEventToPosthog = async ({\n client,\n eventType = AIEvent.Generation,\n distinctId,\n traceId,\n model,\n provider,\n input,\n output,\n latency,\n timeToFirstToken,\n baseURL,\n params,\n httpStatus = 200,\n usage = {},\n error,\n exceptionId,\n tools,\n captureImmediate = false,\n}: SendEventToPosthogParams): Promise<void> => {\n if (!client.capture) {\n return Promise.resolve()\n }\n // sanitize input and output for UTF-8 validity\n const safeInput = sanitizeValues(input)\n const safeOutput = sanitizeValues(output)\n const safeError = sanitizeValues(error)\n\n let errorData = {}\n if (error) {\n errorData = {\n $ai_is_error: true,\n $ai_error: safeError,\n $exception_event_id: exceptionId,\n }\n }\n let costOverrideData = {}\n if (params.posthogCostOverride) {\n const inputCostUSD = (params.posthogCostOverride.inputCost ?? 0) * (usage.inputTokens ?? 0)\n const outputCostUSD = (params.posthogCostOverride.outputCost ?? 0) * (usage.outputTokens ?? 0)\n costOverrideData = {\n $ai_input_cost_usd: inputCostUSD,\n $ai_output_cost_usd: outputCostUSD,\n $ai_total_cost_usd: inputCostUSD + outputCostUSD,\n }\n }\n\n const additionalTokenValues = {\n ...(usage.reasoningTokens ? { $ai_reasoning_tokens: usage.reasoningTokens } : {}),\n ...(usage.cacheReadInputTokens ? { $ai_cache_read_input_tokens: usage.cacheReadInputTokens } : {}),\n ...(usage.cacheCreationInputTokens ? { $ai_cache_creation_input_tokens: usage.cacheCreationInputTokens } : {}),\n ...(usage.webSearchCount ? { $ai_web_search_count: usage.webSearchCount } : {}),\n ...(usage.rawUsage ? { $ai_usage: usage.rawUsage } : {}),\n }\n\n const properties = {\n $ai_lib: 'posthog-ai',\n $ai_lib_version: version,\n $ai_provider: params.posthogProviderOverride ?? provider,\n $ai_model: params.posthogModelOverride ?? model,\n $ai_model_parameters: getModelParams(params),\n $ai_input: withPrivacyMode(client, params.posthogPrivacyMode ?? false, safeInput),\n $ai_output_choices: withPrivacyMode(client, params.posthogPrivacyMode ?? false, safeOutput),\n $ai_http_status: httpStatus,\n $ai_input_tokens: usage.inputTokens ?? 0,\n ...(usage.outputTokens !== undefined ? { $ai_output_tokens: usage.outputTokens } : {}),\n ...additionalTokenValues,\n $ai_latency: latency,\n ...(timeToFirstToken !== undefined ? { $ai_time_to_first_token: timeToFirstToken } : {}),\n $ai_trace_id: traceId,\n $ai_base_url: baseURL,\n ...params.posthogProperties,\n $ai_tokens_source: getTokensSource(params.posthogProperties),\n ...(distinctId ? {} : { $process_person_profile: false }),\n ...(tools ? { $ai_tools: tools } : {}),\n ...errorData,\n ...costOverrideData,\n }\n\n const event: EventMessage = {\n distinctId: distinctId ?? traceId,\n event: eventType,\n properties,\n groups: params.posthogGroups,\n }\n\n if (captureImmediate) {\n // await capture promise to send single event in serverless environments\n await client.captureImmediate(event)\n } else {\n client.capture(event)\n }\n\n return Promise.resolve()\n}\n\nexport function formatOpenAIResponsesInput(input: unknown, instructions?: string | null): FormattedMessage[] {\n const messages: FormattedMessage[] = []\n\n if (instructions) {\n messages.push({\n role: 'system',\n content: instructions,\n })\n }\n\n if (Array.isArray(input)) {\n for (const item of input) {\n if (typeof item === 'string') {\n messages.push({ role: 'user', content: item })\n } else if (item && typeof item === 'object') {\n const obj = item as Record<string, unknown>\n const role = isString(obj.role) ? obj.role : 'user'\n\n // Handle content properly - preserve structure for objects/arrays\n const content = obj.content ?? obj.text ?? item\n messages.push({ role, content: toContentString(content) })\n } else {\n messages.push({ role: 'user', content: toContentString(item) })\n }\n }\n } else if (typeof input === 'string') {\n messages.push({ role: 'user', content: input })\n } else if (input) {\n messages.push({ role: 'user', content: toContentString(input) })\n }\n\n return messages\n}\n","import { AIEvent, truncate } from '../../utils'\nimport { redactBase64DataUrl } from '../../sanitization'\nimport type { ReadableSpan } from '@opentelemetry/sdk-trace-base'\nimport type { PostHogSpanMapper, PostHogSpanMapperResult, UsageData } from '../types'\n\nconst OTEL_STATUS_ERROR = 2\nconst AI_TELEMETRY_METADATA_PREFIX = 'ai.telemetry.metadata.'\n\ntype InstrumentationInfo = {\n version?: unknown\n}\n\ntype ReadableSpanWithInstrumentation = ReadableSpan & {\n instrumentationScope?: InstrumentationInfo\n instrumentationLibrary?: InstrumentationInfo\n}\n\nfunction parseJsonValue<T>(value: unknown): T | null {\n if (value === undefined || value === null) {\n return null\n }\n if (typeof value !== 'string') {\n return value as T\n }\n try {\n return JSON.parse(value) as T\n } catch {\n return null\n }\n}\n\nfunction toNumber(value: unknown): number | undefined {\n if (typeof value === 'number' && Number.isFinite(value)) {\n return value\n }\n if (typeof value === 'string') {\n const parsed = Number(value)\n if (Number.isFinite(parsed)) {\n return parsed\n }\n }\n return undefined\n}\n\nfunction toStringValue(value: unknown): string | undefined {\n return typeof value === 'string' ? value : undefined\n}\n\nfunction toStringArray(value: unknown): string[] {\n if (!Array.isArray(value)) {\n return []\n }\n return value.filter((item): item is string => typeof item === 'string')\n}\n\nfunction toSafeBinaryData(value: unknown): string {\n const asString = typeof value === 'string' ? value : JSON.stringify(value ?? '')\n return truncate(redactBase64DataUrl(asString))\n}\n\nfunction toMimeType(value: unknown): string {\n return typeof value === 'string' && value.length > 0 ? value : 'application/octet-stream'\n}\n\nfunction getSpanLatencySeconds(span: ReadableSpan): number {\n const duration = span.duration\n if (!duration || !Array.isArray(duration) || duration.length !== 2) {\n return 0\n }\n const seconds = Number(duration[0]) || 0\n const nanos = Number(duration[1]) || 0\n return seconds + nanos / 1_000_000_000\n}\n\nfunction getOperationId(span: ReadableSpan): string {\n const attributes = span.attributes || {}\n const operationId = toStringValue(attributes['ai.operationId'])\n if (operationId) {\n return operationId\n }\n return span.name || ''\n}\n\nfunction isDoGenerateSpan(operationId: string): boolean {\n return operationId.endsWith('.doGenerate')\n}\n\nfunction isDoStreamSpan(operationId: string): boolean {\n return operationId.endsWith('.doStream')\n}\n\nfunction isDoEmbedSpan(operationId: string): boolean {\n return operationId.endsWith('.doEmbed')\n}\n\nfunction shouldMapAiSdkSpan(span: ReadableSpan): boolean {\n const operationId = getOperationId(span)\n return isDoGenerateSpan(operationId) || isDoStreamSpan(operationId) || isDoEmbedSpan(operationId)\n}\n\nfunction extractAiSdkTelemetryMetadata(attributes: Record<string, unknown>): Record<string, unknown> {\n const metadata: Record<string, unknown> = {}\n for (const [key, value] of Object.entries(attributes)) {\n if (key.startsWith(AI_TELEMETRY_METADATA_PREFIX)) {\n metadata[key.slice(AI_TELEMETRY_METADATA_PREFIX.length)] = value\n }\n }\n\n if (metadata.traceId && typeof metadata.traceId === 'string') {\n metadata.trace_id = metadata.traceId\n }\n\n return metadata\n}\n\nfunction mapPromptMessagesInput(attributes: Record<string, unknown>): Array<Record<string, unknown>> {\n const promptMessages = parseJsonValue<Array<Record<string, unknown>>>(attributes['ai.prompt.messages']) || []\n if (!Array.isArray(promptMessages)) {\n return []\n }\n\n return promptMessages.map((message) => {\n const role = typeof message?.role === 'string' ? message.role : 'user'\n const content = message?.content\n\n if (typeof content === 'string') {\n return {\n role,\n content: [{ type: 'text', text: truncate(content) }],\n }\n }\n\n if (Array.isArray(content)) {\n return {\n role,\n content: content.map((part) => {\n if (part && typeof part === 'object' && 'type' in part) {\n const typedPart = part as Record<string, unknown>\n if (typedPart.type === 'text' && typeof typedPart.text === 'string') {\n return {\n type: 'text',\n text: truncate(typedPart.text),\n }\n }\n return typedPart\n }\n return { type: 'text', text: truncate(String(part)) }\n }),\n }\n }\n\n return {\n role,\n content: [{ type: 'text', text: truncate(content) }],\n }\n })\n}\n\nfunction mapPromptInput(attributes: Record<string, unknown>, operationId: string): any {\n if (isDoEmbedSpan(operationId)) {\n if (attributes['ai.values'] !== undefined) {\n return attributes['ai.values']\n }\n return attributes['ai.value'] ?? null\n }\n\n const promptMessages = mapPromptMessagesInput(attributes)\n if (promptMessages.length > 0) {\n return promptMessages\n }\n\n if (attributes['ai.prompt'] !== undefined) {\n return [{ role: 'user', content: [{ type: 'text', text: truncate(attributes['ai.prompt']) }] }]\n }\n\n return []\n}\n\nfunction mapOutputPart(part: Record<string, unknown>): Record<string, unknown> | null {\n const partType = toStringValue(part.type)\n\n if (partType === 'text' && typeof part.text === 'string') {\n return { type: 'text', text: truncate(part.text) }\n }\n\n if (partType === 'tool-call') {\n const toolName = toStringValue(part.toolName) || toStringValue((part as any).function?.name) || ''\n const toolCallId = toStringValue(part.toolCallId) || toStringValue(part.id) || ''\n const input = 'input' in part ? part.input : (part as any).function?.arguments\n if (toolName) {\n return {\n type: 'tool-call',\n id: toolCallId,\n function: {\n name: toolName,\n arguments: typeof input === 'string' ? input : JSON.stringify(input ?? {}),\n },\n }\n }\n }\n\n if (partType === 'file') {\n const mediaType = toMimeType(part.mediaType ?? part.mimeType ?? part.contentType)\n const data = part.data ?? part.base64 ?? part.bytes ?? part.url ?? part.uri\n if (data !== undefined) {\n return {\n type: 'file',\n name: 'generated_file',\n mediaType,\n data: toSafeBinaryData(data),\n }\n }\n }\n\n if (partType === 'image') {\n const mediaType = toMimeType(part.mediaType ?? part.mimeType ?? part.contentType ?? 'image/unknown')\n const data =\n part.data ?? part.base64 ?? part.bytes ?? part.url ?? part.uri ?? (part as any).image ?? (part as any).image_url\n if (data !== undefined) {\n return {\n type: 'file',\n name: 'generated_file',\n mediaType,\n data: toSafeBinaryData(data),\n }\n }\n }\n\n const inlineData = (part as any).inlineData ?? (part as any).inline_data\n if (inlineData && typeof inlineData === 'object' && (inlineData as any).data !== undefined) {\n const mediaType = toMimeType((inlineData as any).mimeType ?? (inlineData as any).mime_type)\n return {\n type: 'file',\n name: 'generated_file',\n mediaType,\n data: toSafeBinaryData((inlineData as any).data),\n }\n }\n\n if (partType === 'object' && part.object !== undefined) {\n return {\n type: 'object',\n object: part.object,\n }\n }\n\n return null\n}\n\nfunction mapResponseMessagesOutput(attributes: Record<string, unknown>): Array<Record<string, unknown>> {\n const messagesRaw =\n parseJsonValue<Array<Record<string, unknown>>>(attributes['ai.response.messages']) ??\n parseJsonValue<Record<string, unknown>>(attributes['ai.response.message'])\n\n if (!messagesRaw) {\n return []\n }\n\n const messages = Array.isArray(messagesRaw) ? messagesRaw : [messagesRaw]\n const mappedMessages: Array<Record<string, unknown>> = []\n\n for (const message of messages) {\n if (!message || typeof message !== 'object') {\n continue\n }\n\n const role = toStringValue(message.role) || 'assistant'\n const content = (message as any).content\n\n if (typeof content === 'string') {\n mappedMessages.push({\n role,\n content: [{ type: 'text', text: truncate(content) }],\n })\n continue\n }\n\n if (Array.isArray(content)) {\n const parts = content\n .map((part) => (part && typeof part === 'object' ? mapOutputPart(part as Record<string, unknown>) : null))\n .filter((part): part is Record<string, unknown> => part !== null)\n if (parts.length > 0) {\n mappedMessages.push({\n role,\n content: parts,\n })\n }\n continue\n }\n }\n\n return mappedMessages\n}\n\nfunction mapTextToolObjectOutputParts(attributes: Record<string, unknown>): Array<Record<string, unknown>> {\n const responseText = toStringValue(attributes['ai.response.text']) || ''\n const toolCalls = parseJsonValue<Array<Record<string, unknown>>>(attributes['ai.response.toolCalls']) || []\n const responseObjectRaw = attributes['ai.response.object']\n const responseObject = parseJsonValue(responseObjectRaw)\n const contentParts: Array<Record<string, unknown>> = []\n\n if (responseText) {\n contentParts.push({ type: 'text', text: truncate(responseText) })\n }\n\n if (responseObjectRaw !== undefined) {\n contentParts.push({\n type: 'object',\n object: responseObject ?? responseObjectRaw,\n })\n }\n\n if (Array.isArray(toolCalls)) {\n for (const toolCall of toolCalls) {\n if (!toolCall || typeof toolCall !== 'object') {\n continue\n }\n\n const toolName = typeof toolCall.toolName === 'string' ? toolCall.toolName : ''\n const toolCallId = typeof toolCall.toolCallId === 'string' ? toolCall.toolCallId : ''\n if (!toolName) {\n continue\n }\n\n const input = 'input' in toolCall ? toolCall.input : {}\n contentParts.push({\n type: 'tool-call',\n id: toolCallId,\n function: {\n name: toolName,\n arguments: typeof input === 'string' ? input : JSON.stringify(input),\n },\n })\n }\n }\n\n return contentParts\n}\n\nfunction mapResponseFilesOutput(attributes: Record<string, unknown>): Array<Record<string, unknown>> {\n const responseFiles = parseJsonValue<Array<Record<string, unknown>>>(attributes['ai.response.files']) || []\n if (!Array.isArray(responseFiles)) {\n return []\n }\n\n const mapped: Array<Record<string, unknown>> = []\n for (const file of responseFiles) {\n if (!file || typeof file !== 'object') {\n continue\n }\n\n const mimeType = toMimeType(file.mimeType ?? file.mediaType ?? file.contentType)\n const data = file.data ?? file.base64 ?? file.bytes\n const url = typeof file.url === 'string' ? file.url : typeof file.uri === 'string' ? file.uri : undefined\n\n if (data !== undefined) {\n mapped.push({\n type: 'file',\n name: 'generated_file',\n mediaType: mimeType,\n data: toSafeBinaryData(data),\n })\n continue\n }\n\n if (url) {\n mapped.push({\n type: 'file',\n name: 'generated_file',\n mediaType: mimeType,\n data: truncate(url),\n })\n }\n }\n\n return mapped\n}\n\nfunction extractGeminiParts(providerMetadata: unknown): Array<Record<string, unknown>> {\n const parts: Array<Record<string, unknown>> = []\n const visit = (node: unknown): void => {\n if (!node || typeof node !== 'object') {\n return\n }\n if (Array.isArray(node)) {\n for (const item of node) {\n visit(item)\n }\n return\n }\n\n const objectNode = node as Record<string, unknown>\n const maybeParts = objectNode.parts\n if (Array.isArray(maybeParts)) {\n for (const part of maybeParts) {\n if (part && typeof part === 'object') {\n parts.push(part as Record<string, unknown>)\n }\n }\n }\n\n for (const value of Object.values(objectNode)) {\n visit(value)\n }\n }\n\n visit(providerMetadata)\n return parts\n}\n\nfunction mapProviderMetadataInlineDataOutput(providerMetadata: unknown): Array<Record<string, unknown>> {\n const parts = extractGeminiParts(providerMetadata)\n const mapped: Array<Record<string, unknown>> = []\n\n for (const part of parts) {\n const inlineData = part.inlineData ?? part.inline_data\n if (!inlineData || typeof inlineData !== 'object') {\n continue\n }\n\n const mimeType = toMimeType((inlineData as any).mimeType ?? (inlineData as any).mime_type)\n if ((inlineData as any).data === undefined) {\n continue\n }\n\n mapped.push({\n type: 'file',\n name: 'generated_file',\n mediaType: mimeType,\n data: toSafeBinaryData((inlineData as any).data),\n })\n }\n\n return mapped\n}\n\nfunction mapProviderMetadataTextOutput(providerMetadata: unknown): Array<Record<string, unknown>> {\n const parts = extractGeminiParts(providerMetadata)\n const mapped: Array<Record<string, unknown>> = []\n for (const part of parts) {\n if (typeof part.text === 'string' && part.text.length > 0) {\n mapped.push({\n type: 'text',\n text: truncate(part.text),\n })\n }\n }\n return mapped\n}\n\nfunction extractMediaBlocksFromUnknownNode(node: unknown): Array<Record<string, unknown>> {\n const mapped: Array<Record<string, unknown>> = []\n\n const visit = (value: unknown): void => {\n if (!value || typeof value !== 'object') {\n return\n }\n if (Array.isArray(value)) {\n for (const item of value) {\n visit(item)\n }\n return\n }\n\n const objectValue = value as Record<string, unknown>\n const inlineData = (objectValue as any).inlineData ?? (objectValue as any).inline_data\n if (inlineData && typeof inlineData === 'object' && (inlineData as any).data !== undefined) {\n const mediaType = toMimeType((inlineData as any).mimeType ?? (inlineData as any).mime_type)\n mapped.push({\n type: 'file',\n name: 'generated_file',\n mediaType,\n data: toSafeBinaryData((inlineData as any).data),\n })\n }\n\n if ((objectValue.type === 'file' || 'mediaType' in objectValue || 'mimeType' in objectValue) && objectValue.data) {\n const mediaType = toMimeType((objectValue as any).mediaType ?? (objectValue as any).mimeType)\n mapped.push({\n type: 'file',\n name: 'generated_file',\n mediaType,\n data: toSafeBinaryData(objectValue.data),\n })\n }\n\n for (const child of Object.values(objectValue)) {\n visit(child)\n }\n }\n\n visit(node)\n return mapped\n}\n\nfunction mapUnknownResponseAttributeMediaOutput(attributes: Record<string, unknown>): Array<Record<string, unknown>> {\n const mapped: Array<Record<string, unknown>> = []\n for (const [key, value] of Object.entries(attributes)) {\n if (!key.startsWith('ai.response.')) {\n continue\n }\n if (\n key === 'ai.response.text' ||\n key === 'ai.response.toolCalls' ||\n key === 'ai.response.object' ||\n key === 'ai.response.files' ||\n key === 'ai.response.message' ||\n key === 'ai.response.messages' ||\n key === 'ai.response.providerMetadata'\n ) {\n continue\n }\n\n const parsed = typeof value === 'string' ? (parseJsonValue(value) ?? value) : value\n mapped.push(...extractMediaBlocksFromUnknownNode(parsed))\n }\n return mapped\n}\n\nfunction mapGenericResponseAttributeMediaOutput(attributes: Record<string, unknown>): Array<Record<string, unknown>> {\n const mapped: Array<Record<string, unknown>> = []\n for (const [key, value] of Object.entries(attributes)) {\n if (\n !key.includes('response') ||\n key.startsWith('ai.response.') ||\n key === 'ai.response.providerMetadata' ||\n key.startsWith('ai.prompt.') ||\n key.startsWith('gen_ai.request.')\n ) {\n continue\n }\n\n const parsed = typeof value === 'string' ? parseJsonValue(value) : value\n if (parsed === null || parsed === undefined) {\n continue\n }\n mapped.push(...extractMediaBlocksFromUnknownNode(parsed))\n }\n return mapped\n}\n\nfunction dedupeContentParts(parts: Array<Record<string, unknown>>): Array<Record<string, unknown>> {\n const seen = new Set<string>()\n const deduped: Array<Record<string, unknown>> = []\n for (const part of parts) {\n const key = JSON.stringify(part)\n if (seen.has(key)) {\n continue\n }\n seen.add(key)\n deduped.push(part)\n }\n return deduped\n}\n\nfunction mapOutput(attributes: Record<string, unknown>, operationId: string, providerMetadata: unknown): any {\n if (isDoEmbedSpan(operationId)) {\n // Keep embedding behavior aligned with existing provider wrappers.\n return null\n }\n\n const responseMessages = mapResponseMessagesOutput(attributes)\n if (responseMessages.length > 0) {\n return responseMessages\n }\n\n const textToolObjectParts = mapTextToolObjectOutputParts(attributes)\n const responseFileParts = mapResponseFilesOutput(attributes)\n const unknownMediaParts = mapUnknownResponseAttributeMediaOutput(attributes)\n const genericResponseMediaParts = mapGenericResponseAttributeMediaOutput(attributes)\n const providerMetadataTextParts = mapProviderMetadataTextOutput(providerMetadata)\n const providerMetadataInlineParts = mapProviderMetadataInlineDataOutput(providerMetadata)\n\n const mergedContentParts = dedupeContentParts([\n ...textToolObjectParts,\n ...responseFileParts,\n ...unknownMediaParts,\n ...genericResponseMediaParts,\n ...providerMetadataTextParts,\n ...providerMetadataInlineParts,\n ])\n const contentParts = mergedContentParts\n\n if (contentParts.length === 0) {\n return []\n }\n\n return [\n {\n role: 'assistant',\n content: contentParts,\n },\n ]\n}\n\nfunction mapModelSettings(attributes: Record<string, unknown>, operationId: string): Record<string, unknown> {\n const temperature =\n toNumber(attributes['ai.settings.temperature']) ?? toNumber(attributes['gen_ai.request.temperature'])\n const maxTokens = toNumber(attributes['ai.settings.maxTokens']) ?? toNumber(attributes['gen_ai.request.max_tokens'])\n const maxOutputTokens = toNumber(attributes['ai.settings.maxOutputTokens'])\n const topP = toNumber(attributes['ai.settings.topP']) ?? toNumber(attributes['gen_ai.request.top_p'])\n const frequencyPenalty =\n toNumber(attributes['ai.settings.frequencyPenalty']) ?? toNumber(attributes['gen_ai.request.frequency_penalty'])\n const presencePenalty =\n toNumber(attributes['ai.settings.presencePenalty']) ?? toNumber(attributes['gen_ai.request.presence_penalty'])\n const stopSequences =\n parseJsonValue<string[] | string>(attributes['ai.settings.stopSequences']) ??\n parseJsonValue<string[] | string>(attributes['gen_ai.request.stop_sequences'])\n const stream = isDoStreamSpan(operationId)\n\n return {\n ...(temperature !== undefined ? { temperature } : {}),\n ...(maxTokens !== undefined ? { max_tokens: maxTokens } : {}),\n ...(maxOutputTokens !== undefined ? { max_completion_tokens: maxOutputTokens } : {}),\n ...(topP !== undefined ? { top_p: topP } : {}),\n ...(frequencyPenalty !== undefined ? { frequency_penalty: frequencyPenalty } : {}),\n ...(presencePenalty !== undefined ? { presence_penalty: presencePenalty } : {}),\n ...(stopSequences !== null ? { stop: stopSequences } : {}),\n ...(stream ? { stream: true } : {}),\n }\n}\n\nfunction mapUsage(attributes: Record<string, unknown>, providerMetadata: unknown, operationId: string): UsageData {\n if (isDoEmbedSpan(operationId)) {\n const tokens = toNumber(attributes['ai.usage.tokens']) ?? toNumber(attributes['gen_ai.usage.input_tokens']) ?? 0\n return {\n inputTokens: tokens,\n rawUsage: {\n usage: {\n tokens,\n },\n providerMetadata,\n },\n }\n }\n\n const inputTokens =\n toNumber(attributes['ai.usage.promptTokens']) ?? toNumber(attributes['gen_ai.usage.input_tokens']) ?? 0\n const outputTokens =\n toNumber(attributes['ai.usage.completionTokens']) ?? toNumber(attributes['gen_ai.usage.output_tokens']) ?? 0\n const totalTokens = toNumber(attributes['ai.usage.totalTokens'])\n const reasoningTokens = toNumber(attributes['ai.usage.reasoningTokens'])\n const cachedInputTokens = toNumber(attributes['ai.usage.cachedInputTokens'])\n\n return {\n inputTokens,\n outputTokens,\n ...(reasoningTokens !== undefined ? { reasoningTokens } : {}),\n ...(cachedInputTokens !== undefined ? { cacheReadInputTokens: cachedInputTokens } : {}),\n rawUsage: {\n usage: {\n promptTokens: inputTokens,\n completionTokens: outputTokens,\n ...(totalTokens !== undefined ? { totalTokens } : {}),\n },\n providerMetadata,\n },\n }\n}\n\nfunction parsePromptTools(attributes: Record<string, unknown>): any[] | null {\n const rawTools = attributes['ai.prompt.tools']\n if (!Array.isArray(rawTools)) {\n return null\n }\n\n const parsedTools: any[] = []\n for (const rawTool of rawTools) {\n if (typeof rawTool === 'string') {\n const parsed = parseJsonValue(rawTool)\n if (parsed !== null) {\n parsedTools.push(parsed)\n }\n continue\n }\n if (rawTool && typeof rawTool === 'object') {\n parsedTools.push(rawTool)\n }\n }\n\n return parsedTools.length > 0 ? parsedTools : null\n}\n\nfunction extractProviderMetadata(attributes: Record<string, unknown>): unknown {\n const rawProviderMetadata = attributes['ai.response.providerMetadata']\n return parseJsonValue(rawProviderMetadata) || {}\n}\n\nfunction getAiSdkFrameworkVersion(span: ReadableSpan): string | undefined {\n const instrumentedSpan = span as ReadableSpanWithInstrumentation\n const attributes = span.attributes || {}\n const instrumentationScopeVersion =\n toStringValue(instrumentedSpan.instrumentationScope?.version) ||\n toStringValue(instrumentedSpan.instrumentationLibrary?.version)\n const aiUserAgent = toStringValue(attributes['ai.request.headers.user-agent'])\n const userAgentVersionMatch = aiUserAgent?.match(/\\bai\\/(\\d+(?:\\.\\d+)*)\\b/i)\n const userAgentVersion = userAgentVersionMatch?.[1]\n\n const rawVersion = instrumentationScopeVersion || userAgentVersion\n if (!rawVersion) {\n return undefined\n }\n\n const majorVersionMatch = rawVersion.match(/^v?(\\d+)/i)\n return majorVersionMatch ? majorVersionMatch[1] : rawVersion\n}\n\nfunction buildPosthogProperties(attributes: Record<string, unknown>, operationId: string): Record<string, unknown> {\n const telemetryMetadata = extractAiSdkTelemetryMetadata(attributes)\n const finishReasons = toStringArray(parseJsonValue(attributes['gen_ai.response.finish_reasons']))\n const finishReason = toStringValue(attributes['ai.response.finishReason']) || finishReasons[0]\n const toolChoice = parseJsonValue(attributes['ai.prompt.toolChoice']) ?? attributes['ai.prompt.toolChoice']\n\n return {\n ...telemetryMetadata,\n $ai_framework: 'vercel',\n ai_operation_id: operationId,\n ...(finishReason ? { ai_finish_reason: finishReason } : {}),\n ...(toStringValue(attributes['ai.response.model']) ? { ai_response_model: attributes['ai.response.model'] } : {}),\n ...(toStringValue(attributes['gen_ai.response.model'])\n ? { ai_response_model: attributes['gen_ai.response.model'] }\n : {}),\n ...(toStringValue(attributes['ai.response.id']) ? { ai_response_id: attributes['ai.response.id'] } : {}),\n ...(toStringValue(attributes['gen_ai.response.id']) ? { ai_response_id: attributes['gen_ai.response.id'] } : {}),\n ...(toStringValue(attributes['ai.response.timestamp'])\n ? { ai_response_timestamp: attributes['ai.response.timestamp'] }\n : {}),\n ...(toNumber(attributes['ai.response.msToFinish']) !== undefined\n ? { ai_response_ms_to_finish: toNumber(attributes['ai.response.msToFinish']) }\n : {}),\n ...(toNumber(attributes['ai.response.avgCompletionTokensPerSecond']) !== undefined\n ? {\n ai_response_avg_completion_tokens_per_second: toNumber(\n attributes['ai.response.avgCompletionTokensPerSecond']\n ),\n }\n : {}),\n ...(toStringValue(attributes['ai.telemetry.functionId'])\n ? { ai_telemetry_function_id: attributes['ai.telemetry.functionId'] }\n : {}),\n ...(toNumber(attributes['ai.settings.maxRetries']) !== undefined\n ? { ai_settings_max_retries: toNumber(attributes['ai.settings.maxRetries']) }\n : {}),\n ...(toNumber(attributes['gen_ai.request.top_k']) !== undefined\n ? { ai_request_top_k: toNumber(attributes['gen_ai.request.top_k']) }\n : {}),\n ...(attributes['ai.schema.name'] !== undefined ? { ai_schema_name: attributes['ai.schema.name'] } : {}),\n ...(attributes['ai.schema.description'] !== undefined\n ? { ai_schema_description: attributes['ai.schema.description'] }\n : {}),\n ...(attributes['ai.settings.output'] !== undefined ? { ai_settings_output: attributes['ai.settings.output'] } : {}),\n ...(toolChoice ? { ai_prompt_tool_choice: toolChoice } : {}),\n }\n}\n\nfunction buildAiSdkMapperResult(span: ReadableSpan): PostHogSpanMapperResult | null {\n const attributes = span.attributes || {}\n const operationId = getOperationId(span)\n const providerMetadata = extractProviderMetadata(attributes)\n const model =\n toStringValue(attributes['ai.model.id']) || toStringValue(attributes['gen_ai.request.model']) || 'unknown'\n const provider = (\n toStringValue(attributes['ai.model.provider']) ||\n toStringValue(attributes['gen_ai.system']) ||\n 'unknown'\n ).toLowerCase()\n const latency = getSpanLatencySeconds(span)\n const timeToFirstTokenMs = toNumber(attributes['ai.response.msToFirstChunk'])\n const timeToFirstToken = timeToFirstTokenMs !== undefined ? timeToFirstTokenMs / 1000 : undefined\n const input = mapPromptInput(attributes, operationId)\n const output = mapOutput(attributes, operationId, providerMetadata)\n const usage = mapUsage(attributes, providerMetadata, operationId)\n const modelParams = mapModelSettings(attributes, operationId)\n const tools = parsePromptTools(attributes)\n const httpStatus = toNumber(attributes['http.response.status_code']) || 200\n const eventType = isDoEmbedSpan(operationId) ? AIEvent.Embedding : AIEvent.Generation\n const frameworkVersion = getAiSdkFrameworkVersion(span)\n\n const error =\n span.status?.code === OTEL_STATUS_ERROR ? span.status.message || 'AI SDK span recorded error status' : undefined\n\n return {\n model,\n provider,\n input,\n output,\n latency,\n timeToFirstToken,\n httpStatus,\n eventType,\n usage,\n tools,\n modelParams,\n posthogProperties: {\n ...buildPosthogProperties(attributes, operationId),\n ...(frameworkVersion ? { $ai_framework_version: frameworkVersion } : {}),\n },\n error,\n }\n}\n\nexport const aiSdkSpanMapper: PostHogSpanMapper = {\n name: 'ai-sdk',\n canMap: shouldMapAiSdkSpan,\n map: (span: ReadableSpan): PostHogSpanMapperResult | null => {\n return buildAiSdkMapperResult(span)\n },\n}\n","import { aiSdkSpanMapper } from './aiSdk'\nimport type { PostHogSpanMapper } from '../types'\n\nexport const defaultSpanMappers: PostHogSpanMapper[] = [aiSdkSpanMapper]\nexport { aiSdkSpanMapper }\n","import { v4 as uuidv4 } from 'uuid'\nimport { PostHog } from 'posthog-node'\nimport { sendEventToPosthog, sendEventWithErrorToPosthog } from '../utils'\nimport { defaultSpanMappers } from './mappers'\nimport type { ReadableSpan } from '@opentelemetry/sdk-trace-base'\nimport type { PostHogTelemetryOptions, PostHogSpanMapper, UsageData } from './types'\n\nfunction pickMapper(span: ReadableSpan, mappers: PostHogSpanMapper[]): PostHogSpanMapper | undefined {\n return mappers.find((mapper) => {\n try {\n return mapper.canMap(span)\n } catch {\n return false\n }\n })\n}\n\nfunction getTraceId(span: ReadableSpan, options: PostHogTelemetryOptions, mapperTraceId?: string): string {\n if (mapperTraceId) {\n return mapperTraceId\n }\n if (options.posthogTraceId) {\n return options.posthogTraceId\n }\n const spanTraceId = span.spanContext?.().traceId\n return spanTraceId || uuidv4()\n}\n\nfunction buildPosthogParams(\n options: PostHogTelemetryOptions,\n traceId: string,\n distinctId: string | undefined,\n modelParams: Record<string, unknown>,\n posthogProperties: Record<string, unknown>\n): Record<string, unknown> {\n return {\n ...modelParams,\n posthogDistinctId: distinctId,\n posthogTraceId: traceId,\n posthogProperties,\n posthogPrivacyMode: options.posthogPrivacyMode,\n posthogGroups: options.posthogGroups,\n posthogModelOverride: options.posthogModelOverride,\n posthogProviderOverride: options.posthogProviderOverride,\n posthogCostOverride: options.posthogCostOverride,\n posthogCaptureImmediate: options.posthogCaptureImmediate,\n }\n}\n\nexport async function captureSpan(\n span: ReadableSpan,\n phClient: PostHog,\n options: PostHogTelemetryOptions = {}\n): Promise<void> {\n if (options.shouldExportSpan && options.shouldExportSpan({ otelSpan: span }) === false) {\n return\n }\n\n const mappers = options.mappers ?? defaultSpanMappers\n const mapper = pickMapper(span, mappers)\n if (!mapper) {\n return\n }\n\n const mapped = mapper.map(span, { options })\n if (!mapped) {\n return\n }\n\n const traceId = getTraceId(span, options, mapped.traceId)\n const distinctId = mapped.distinctId ?? options.posthogDistinctId\n const posthogProperties = {\n ...options.posthogProperties,\n ...mapped.posthogProperties,\n }\n\n const params = buildPosthogParams(options, traceId, distinctId, mapped.modelParams ?? {}, posthogProperties)\n const baseURL = mapped.baseURL ?? ''\n const usage: UsageData = mapped.usage ?? {}\n\n if (mapped.error !== undefined) {\n await sendEventWithErrorToPosthog({\n eventType: mapped.eventType,\n client: phClient,\n distinctId,\n traceId,\n model: mapped.model,\n provider: mapped.provider,\n input: mapped.input,\n output: mapped.output,\n latency: mapped.latency,\n baseURL,\n params: params as any,\n usage,\n tools: mapped.tools,\n error: mapped.error,\n captureImmediate: options.posthogCaptureImmediate,\n })\n return\n }\n\n await sendEventToPosthog({\n eventType: mapped.eventType,\n client: phClient,\n distinctId,\n traceId,\n model: mapped.model,\n provider: mapped.provider,\n input: mapped.input,\n output: mapped.output,\n latency: mapped.latency,\n timeToFirstToken: mapped.timeToFirstToken,\n baseURL,\n params: params as any,\n httpStatus: mapped.httpStatus ?? 200,\n usage,\n tools: mapped.tools,\n captureImmediate: options.posthogCaptureImmediate,\n })\n}\n","import { PostHog } from 'posthog-node'\nimport { captureSpan } from './capture'\nimport type { Context, Span } from '@opentelemetry/api'\nimport type { ReadableSpan, SpanProcessor } from '@opentelemetry/sdk-trace-base'\nimport type { PostHogTelemetryOptions } from './types'\n\nexport class PostHogSpanProcessor implements SpanProcessor {\n private readonly pendingCaptures = new Set<Promise<void>>()\n\n constructor(\n private readonly phClient: PostHog,\n private readonly options: PostHogTelemetryOptions = {}\n ) {}\n\n onStart(_span: Span, _parentContext: Context): void {\n // no-op\n }\n\n onEnd(span: ReadableSpan): void {\n const capturePromise = captureSpan(span, this.phClient, this.options)\n .catch((error) => {\n console.error('Failed to capture telemetry span', error)\n })\n .finally(() => {\n this.pendingCaptures.delete(capturePromise)\n })\n\n this.pendingCaptures.add(capturePromise)\n }\n\n async shutdown(): Promise<void> {\n await this.forceFlush()\n }\n\n async forceFlush(): Promise<void> {\n while (this.pendingCaptures.size > 0) {\n await Promise.allSettled([...this.pendingCaptures])\n }\n }\n}\n\nexport function createPostHogSpanProcessor(phClient: PostHog, options: PostHogTelemetryOptions = {}): SpanProcessor {\n return new PostHogSpanProcessor(phClient, options)\n}\n"],"names":["isString","value","REDACTED_IMAGE_PLACEHOLDER","isMultimodalEnabled","val","process","env","_INTERNAL_LLMA_MULTIMODAL","toLowerCase","isBase64DataUrl","str","test","isValidUrl","URL","startsWith","isRawBase64","length","redactBase64DataUrl","TOKEN_PROPERTY_KEYS","Set","getTokensSource","posthogProperties","Object","keys","some","key","has","MAX_OUTPUT_SIZE","STRING_FORMAT","getModelParams","params","modelParams","paramKeys","undefined","withPrivacyMode","client","privacyMode","input","privacy_mode","toSafeString","JSON","stringify","console","warn","truncate","encoder","TextEncoder","buffer","encode","TextDecoder","decode","truncatedBuffer","slice","decoder","fatal","truncatedStr","endsWith","AIEvent","sanitizeValues","obj","jsonSafe","parse","Array","isArray","map","fromEntries","entries","k","v","sendEventWithErrorToPosthog","traceId","error","args","httpStatus","status","properties","enrichedError","options","enableExceptionAutocapture","exceptionId","uuidv7","captureException","$ai_trace_id","__posthog_previously_captured_error","sendEventToPosthog","eventType","Generation","distinctId","model","provider","output","latency","timeToFirstToken","baseURL","usage","tools","captureImmediate","capture","Promise","resolve","safeInput","safeOutput","safeError","errorData","$ai_is_error","$ai_error","$exception_event_id","costOverrideData","posthogCostOverride","inputCostUSD","inputCost","inputTokens","outputCostUSD","outputCost","outputTokens","$ai_input_cost_usd","$ai_output_cost_usd","$ai_total_cost_usd","additionalTokenValues","reasoningTokens","$ai_reasoning_tokens","cacheReadInputTokens","$ai_cache_read_input_tokens","cacheCreationInputTokens","$ai_cache_creation_input_tokens","webSearchCount","$ai_web_search_count","rawUsage","$ai_usage","$ai_lib","$ai_lib_version","version","$ai_provider","posthogProviderOverride","$ai_model","posthogModelOverride","$ai_model_parameters","$ai_input","posthogPrivacyMode","$ai_output_choices","$ai_http_status","$ai_input_tokens","$ai_output_tokens","$ai_latency","$ai_time_to_first_token","$ai_base_url","$ai_tokens_source","$process_person_profile","$ai_tools","event","groups","posthogGroups","OTEL_STATUS_ERROR","AI_TELEMETRY_METADATA_PREFIX","parseJsonValue","toNumber","Number","isFinite","parsed","toStringValue","toStringArray","filter","item","toSafeBinaryData","asString","toMimeType","getSpanLatencySeconds","span","duration","seconds","nanos","getOperationId","attributes","operationId","name","isDoGenerateSpan","isDoStreamSpan","isDoEmbedSpan","shouldMapAiSdkSpan","extractAiSdkTelemetryMetadata","metadata","trace_id","mapPromptMessagesInput","promptMessages","message","role","content","type","text","part","typedPart","String","mapPromptInput","mapOutputPart","partType","toolName","function","toolCallId","id","arguments","mediaType","mimeType","contentType","data","base64","bytes","url","uri","image","image_url","inlineData","inline_data","mime_type","object","mapResponseMessagesOutput","messagesRaw","messages","mappedMessages","push","parts","mapTextToolObjectOutputParts","responseText","toolCalls","responseObjectRaw","responseObject","contentParts","toolCall","mapResponseFilesOutput","responseFiles","mapped","file","extractGeminiParts","providerMetadata","visit","node","objectNode","maybeParts","values","mapProviderMetadataInlineDataOutput","mapProviderMetadataTextOutput","extractMediaBlocksFromUnknownNode","objectValue","child","mapUnknownResponseAttributeMediaOutput","mapGenericResponseAttributeMediaOutput","includes","dedupeContentParts","seen","deduped","add","mapOutput","responseMessages","textToolObjectParts","responseFileParts","unknownMediaParts","genericResponseMediaParts","providerMetadataTextParts","providerMetadataInlineParts","mergedContentParts","mapModelSettings","temperature","maxTokens","maxOutputTokens","topP","frequencyPenalty","presencePenalty","stopSequences","stream","max_tokens","max_completion_tokens","top_p","frequency_penalty","presence_penalty","stop","mapUsage","tokens","totalTokens","cachedInputTokens","promptTokens","completionTokens","parsePromptTools","rawTools","parsedTools","rawTool","extractProviderMetadata","rawProviderMetadata","getAiSdkFrameworkVersion","instrumentedSpan","instrumentationScopeVersion","instrumentationScope","instrumentationLibrary","aiUserAgent","userAgentVersionMatch","match","userAgentVersion","rawVersion","majorVersionMatch","buildPosthogProperties","telemetryMetadata","finishReasons","finishReason","toolChoice","$ai_framework","ai_operation_id","ai_finish_reason","ai_response_model","ai_response_id","ai_response_timestamp","ai_response_ms_to_finish","ai_response_avg_completion_tokens_per_second","ai_telemetry_function_id","ai_settings_max_retries","ai_request_top_k","ai_schema_name","ai_schema_description","ai_settings_output","ai_prompt_tool_choice","buildAiSdkMapperResult","timeToFirstTokenMs","Embedding","frameworkVersion","code","$ai_framework_version","aiSdkSpanMapper","canMap","defaultSpanMappers","pickMapper","mappers","find","mapper","getTraceId","mapperTraceId","posthogTraceId","spanTraceId","spanContext","uuidv4","buildPosthogParams","posthogDistinctId","posthogCaptureImmediate","captureSpan","phClient","shouldExportSpan","otelSpan","PostHogSpanProcessor","pendingCaptures","constructor","onStart","_span","_parentContext","onEnd","capturePromise","catch","finally","delete","shutdown","forceFlush","size","allSettled","createPostHogSpanProcessor"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../src/otel/exporter.ts"],"sourcesContent":["import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http'\n\nexport interface PostHogTraceExporterOptions {\n /**\n * Your PostHog project API key.\n */\n apiKey: string\n\n /**\n * PostHog host URL. Defaults to `https://us.i.posthog.com`.\n */\n host?: string\n}\n\n/**\n * An OpenTelemetry SpanExporter that sends traces to PostHog's OTLP\n * ingestion endpoint. PostHog converts `gen_ai.*` spans into\n * `$ai_generation` events server-side.\n *\n * @example\n * ```ts\n * import { PostHogTraceExporter } from '@posthog/ai/otel'\n * import { NodeSDK } from '@opentelemetry/sdk-node'\n *\n * const sdk = new NodeSDK({\n * traceExporter: new PostHogTraceExporter({ apiKey: 'phc_...' }),\n * })\n * sdk.start()\n * ```\n */\nexport class PostHogTraceExporter extends OTLPTraceExporter {\n constructor(options: PostHogTraceExporterOptions) {\n if (!options.apiKey) {\n throw new Error('PostHogTraceExporter requires an apiKey')\n }\n const host = new URL(options.host || 'https://us.i.posthog.com').origin\n super({\n url: `${host}/i/v0/ai/otel`,\n headers: {\n // The OTLP ingestion endpoint authenticates using the project API key as a Bearer token\n Authorization: `Bearer ${options.apiKey}`,\n },\n })\n }\n}\n"],"names":["PostHogTraceExporter","OTLPTraceExporter","constructor","options","apiKey","Error","host","URL","origin","url","headers","Authorization"],"mappings":";;AAcA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMA,oBAAoB,SAASC,iBAAiB,CAAC;EAC1DC,WAAWA,CAACC,OAAoC,EAAE;AAChD,IAAA,IAAI,CAACA,OAAO,CAACC,MAAM,EAAE;AACnB,MAAA,MAAM,IAAIC,KAAK,CAAC,yCAAyC,CAAC;AAC5D,IAAA;AACA,IAAA,MAAMC,IAAI,GAAG,IAAIC,GAAG,CAACJ,OAAO,CAACG,IAAI,IAAI,0BAA0B,CAAC,CAACE,MAAM;AACvE,IAAA,KAAK,CAAC;MACJC,GAAG,EAAE,CAAA,EAAGH,IAAI,CAAA,aAAA,CAAe;AAC3BI,MAAAA,OAAO,EAAE;AACP;AACAC,QAAAA,aAAa,EAAE,CAAA,OAAA,EAAUR,OAAO,CAACC,MAAM,CAAA;AACzC;AACF,KAAC,CAAC;AACJ,EAAA;AACF;;;;"}
|
package/dist/vercel/index.cjs
CHANGED
package/dist/vercel/index.mjs
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@posthog/ai",
|
|
3
|
-
"version": "7.
|
|
3
|
+
"version": "7.12.0",
|
|
4
4
|
"description": "PostHog Node.js AI integrations",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -14,15 +14,15 @@
|
|
|
14
14
|
"devDependencies": {
|
|
15
15
|
"@ai-sdk/provider": "^3.0.8",
|
|
16
16
|
"@opentelemetry/api": "^1.9.0",
|
|
17
|
-
"@opentelemetry/
|
|
17
|
+
"@opentelemetry/exporter-trace-otlp-http": "^0.200.0",
|
|
18
18
|
"@babel/preset-env": "^7.27.1",
|
|
19
19
|
"@babel/preset-typescript": "^7.27.1",
|
|
20
20
|
"@types/jest": "^29.5.14",
|
|
21
21
|
"jest": "29.7.0",
|
|
22
22
|
"node-fetch": "^3.3.2",
|
|
23
|
+
"@posthog-tooling/rollup-utils": "1.1.1",
|
|
23
24
|
"@posthog-tooling/tsconfig-base": "1.1.1",
|
|
24
|
-
"posthog-node": "5.28.
|
|
25
|
-
"@posthog-tooling/rollup-utils": "1.1.1"
|
|
25
|
+
"posthog-node": "5.28.3"
|
|
26
26
|
},
|
|
27
27
|
"keywords": [
|
|
28
28
|
"posthog",
|
|
@@ -44,11 +44,11 @@
|
|
|
44
44
|
"openai": "^6.25.0",
|
|
45
45
|
"uuid": "^11.1.0",
|
|
46
46
|
"zod": "^4.1.13",
|
|
47
|
-
"@posthog/core": "1.23.
|
|
47
|
+
"@posthog/core": "1.23.4"
|
|
48
48
|
},
|
|
49
49
|
"peerDependencies": {
|
|
50
50
|
"@opentelemetry/api": "^1.9.0",
|
|
51
|
-
"@opentelemetry/
|
|
51
|
+
"@opentelemetry/exporter-trace-otlp-http": "^0.200.0",
|
|
52
52
|
"@ai-sdk/provider": "^2.0.0 || ^3.0.0",
|
|
53
53
|
"posthog-node": "^5.0.0"
|
|
54
54
|
},
|
|
@@ -56,7 +56,7 @@
|
|
|
56
56
|
"@opentelemetry/api": {
|
|
57
57
|
"optional": true
|
|
58
58
|
},
|
|
59
|
-
"@opentelemetry/
|
|
59
|
+
"@opentelemetry/exporter-trace-otlp-http": {
|
|
60
60
|
"optional": true
|
|
61
61
|
},
|
|
62
62
|
"@ai-sdk/provider": {
|