langwatch 0.2.0 → 0.3.0-prerelease.1
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/.editorconfig +16 -0
- package/LICENSE +7 -0
- package/README.md +268 -1
- package/copy-types.sh +19 -8
- package/examples/langchain/.env.example +2 -0
- package/examples/langchain/README.md +42 -0
- package/examples/langchain/package-lock.json +2930 -0
- package/examples/langchain/package.json +27 -0
- package/examples/langchain/src/cli-markdown.d.ts +137 -0
- package/examples/langchain/src/index.ts +109 -0
- package/examples/langchain/tsconfig.json +25 -0
- package/examples/langgraph/.env.example +2 -0
- package/examples/langgraph/README.md +42 -0
- package/examples/langgraph/package-lock.json +3031 -0
- package/examples/langgraph/package.json +28 -0
- package/examples/langgraph/src/cli-markdown.d.ts +137 -0
- package/examples/langgraph/src/index.ts +196 -0
- package/examples/langgraph/tsconfig.json +25 -0
- package/examples/mastra/.env.example +2 -0
- package/examples/mastra/README.md +57 -0
- package/examples/mastra/package-lock.json +5296 -0
- package/examples/mastra/package.json +32 -0
- package/examples/mastra/src/cli-markdown.d.ts +137 -0
- package/examples/mastra/src/index.ts +120 -0
- package/examples/mastra/src/mastra/agents/weather-agent.ts +30 -0
- package/examples/mastra/src/mastra/index.ts +21 -0
- package/examples/mastra/src/mastra/tools/weather-tool.ts +102 -0
- package/examples/mastra/tsconfig.json +25 -0
- package/examples/vercel-ai/.env.example +2 -0
- package/examples/vercel-ai/README.md +38 -0
- package/examples/vercel-ai/package-lock.json +2571 -0
- package/examples/vercel-ai/package.json +27 -0
- package/examples/vercel-ai/src/cli-markdown.d.ts +137 -0
- package/examples/vercel-ai/src/index.ts +110 -0
- package/examples/vercel-ai/src/instrumentation.ts +9 -0
- package/examples/vercel-ai/tsconfig.json +25 -0
- package/package.json +78 -34
- package/src/__tests__/client-browser.test.ts +92 -0
- package/src/__tests__/client-node.test.ts +76 -0
- package/src/__tests__/client.test.ts +71 -0
- package/src/__tests__/integration/client-browser.test.ts +46 -0
- package/src/__tests__/integration/client-node.test.ts +46 -0
- package/src/client-browser.ts +70 -0
- package/src/client-node.ts +82 -0
- package/src/client-shared.ts +72 -0
- package/src/client.ts +119 -0
- package/src/evaluation/__tests__/record-evaluation.test.ts +112 -0
- package/src/evaluation/__tests__/run-evaluation.test.ts +171 -0
- package/src/evaluation/index.ts +2 -0
- package/src/evaluation/record-evaluation.ts +101 -0
- package/src/evaluation/run-evaluation.ts +133 -0
- package/src/evaluation/tracer.ts +3 -0
- package/src/evaluation/types.ts +23 -0
- package/src/index.ts +10 -593
- package/src/internal/api/__tests__/errors.test.ts +98 -0
- package/src/internal/api/client.ts +30 -0
- package/src/internal/api/errors.ts +32 -0
- package/src/internal/generated/types/.gitkeep +0 -0
- package/src/observability/__tests__/integration/base.test.ts +74 -0
- package/src/observability/__tests__/integration/browser-setup-ordering.test.ts +60 -0
- package/src/observability/__tests__/integration/complex-nested-spans.test.ts +29 -0
- package/src/observability/__tests__/integration/error-handling.test.ts +24 -0
- package/src/observability/__tests__/integration/langwatch-disabled-otel.test.ts +24 -0
- package/src/observability/__tests__/integration/langwatch-first-then-vercel.test.ts +24 -0
- package/src/observability/__tests__/integration/multiple-setup-attempts.test.ts +27 -0
- package/src/observability/__tests__/integration/otel-ordering.test.ts +27 -0
- package/src/observability/__tests__/integration/vercel-configurations.test.ts +20 -0
- package/src/observability/__tests__/integration/vercel-first-then-langwatch.test.ts +27 -0
- package/src/observability/__tests__/span.test.ts +214 -0
- package/src/observability/__tests__/trace.test.ts +180 -0
- package/src/observability/exporters/index.ts +1 -0
- package/src/observability/exporters/langwatch-exporter.ts +53 -0
- package/src/observability/index.ts +4 -0
- package/src/observability/instrumentation/langchain/__tests__/integration/langchain-chatbot.test.ts +112 -0
- package/src/observability/instrumentation/langchain/__tests__/langchain.test.ts +284 -0
- package/src/observability/instrumentation/langchain/index.ts +624 -0
- package/src/observability/processors/__tests__/filterable-batch-span-exporter.test.ts +98 -0
- package/src/observability/processors/filterable-batch-span-processor.ts +99 -0
- package/src/observability/processors/index.ts +1 -0
- package/src/observability/semconv/attributes.ts +185 -0
- package/src/observability/semconv/events.ts +42 -0
- package/src/observability/semconv/index.ts +16 -0
- package/src/observability/semconv/values.ts +159 -0
- package/src/observability/span.ts +728 -0
- package/src/observability/trace.ts +301 -0
- package/src/prompt/__tests__/prompt.test.ts +139 -0
- package/src/prompt/get-prompt-version.ts +49 -0
- package/src/prompt/get-prompt.ts +44 -0
- package/src/prompt/index.ts +3 -0
- package/src/prompt/prompt.ts +133 -0
- package/src/prompt/service.ts +221 -0
- package/src/prompt/tracer.ts +3 -0
- package/src/prompt/types.ts +0 -0
- package/ts-to-zod.config.js +11 -0
- package/tsconfig.json +3 -9
- package/tsup.config.ts +11 -1
- package/vitest.config.ts +1 -0
- package/dist/chunk-LKD2K67J.mjs +0 -717
- package/dist/chunk-LKD2K67J.mjs.map +0 -1
- package/dist/index.d.mts +0 -1030
- package/dist/index.d.ts +0 -1030
- package/dist/index.js +0 -27310
- package/dist/index.js.map +0 -1
- package/dist/index.mjs +0 -963
- package/dist/index.mjs.map +0 -1
- package/dist/utils-Cv-rUjJ1.d.mts +0 -313
- package/dist/utils-Cv-rUjJ1.d.ts +0 -313
- package/dist/utils.d.mts +0 -2
- package/dist/utils.d.ts +0 -2
- package/dist/utils.js +0 -709
- package/dist/utils.js.map +0 -1
- package/dist/utils.mjs +0 -11
- package/dist/utils.mjs.map +0 -1
- package/example/.env.example +0 -12
- package/example/.eslintrc.json +0 -26
- package/example/LICENSE +0 -13
- package/example/README.md +0 -12
- package/example/app/(chat)/chat/[id]/page.tsx +0 -60
- package/example/app/(chat)/layout.tsx +0 -14
- package/example/app/(chat)/page.tsx +0 -27
- package/example/app/actions.ts +0 -156
- package/example/app/globals.css +0 -76
- package/example/app/guardrails/page.tsx +0 -26
- package/example/app/langchain/page.tsx +0 -27
- package/example/app/langchain-rag/page.tsx +0 -28
- package/example/app/late-update/page.tsx +0 -27
- package/example/app/layout.tsx +0 -64
- package/example/app/login/actions.ts +0 -71
- package/example/app/login/page.tsx +0 -18
- package/example/app/manual/page.tsx +0 -27
- package/example/app/new/page.tsx +0 -5
- package/example/app/opengraph-image.png +0 -0
- package/example/app/share/[id]/page.tsx +0 -58
- package/example/app/signup/actions.ts +0 -111
- package/example/app/signup/page.tsx +0 -18
- package/example/app/twitter-image.png +0 -0
- package/example/auth.config.ts +0 -42
- package/example/auth.ts +0 -45
- package/example/components/button-scroll-to-bottom.tsx +0 -36
- package/example/components/chat-history.tsx +0 -49
- package/example/components/chat-list.tsx +0 -52
- package/example/components/chat-message-actions.tsx +0 -40
- package/example/components/chat-message.tsx +0 -80
- package/example/components/chat-panel.tsx +0 -139
- package/example/components/chat-share-dialog.tsx +0 -95
- package/example/components/chat.tsx +0 -84
- package/example/components/clear-history.tsx +0 -75
- package/example/components/empty-screen.tsx +0 -38
- package/example/components/external-link.tsx +0 -29
- package/example/components/footer.tsx +0 -19
- package/example/components/header.tsx +0 -114
- package/example/components/login-button.tsx +0 -42
- package/example/components/login-form.tsx +0 -97
- package/example/components/markdown.tsx +0 -9
- package/example/components/prompt-form.tsx +0 -115
- package/example/components/providers.tsx +0 -17
- package/example/components/sidebar-actions.tsx +0 -125
- package/example/components/sidebar-desktop.tsx +0 -19
- package/example/components/sidebar-footer.tsx +0 -16
- package/example/components/sidebar-item.tsx +0 -124
- package/example/components/sidebar-items.tsx +0 -42
- package/example/components/sidebar-list.tsx +0 -38
- package/example/components/sidebar-mobile.tsx +0 -31
- package/example/components/sidebar-toggle.tsx +0 -24
- package/example/components/sidebar.tsx +0 -21
- package/example/components/signup-form.tsx +0 -95
- package/example/components/stocks/events-skeleton.tsx +0 -31
- package/example/components/stocks/events.tsx +0 -30
- package/example/components/stocks/index.tsx +0 -36
- package/example/components/stocks/message.tsx +0 -134
- package/example/components/stocks/spinner.tsx +0 -16
- package/example/components/stocks/stock-purchase.tsx +0 -146
- package/example/components/stocks/stock-skeleton.tsx +0 -22
- package/example/components/stocks/stock.tsx +0 -210
- package/example/components/stocks/stocks-skeleton.tsx +0 -9
- package/example/components/stocks/stocks.tsx +0 -67
- package/example/components/tailwind-indicator.tsx +0 -14
- package/example/components/theme-toggle.tsx +0 -31
- package/example/components/ui/alert-dialog.tsx +0 -141
- package/example/components/ui/badge.tsx +0 -36
- package/example/components/ui/button.tsx +0 -57
- package/example/components/ui/codeblock.tsx +0 -148
- package/example/components/ui/dialog.tsx +0 -122
- package/example/components/ui/dropdown-menu.tsx +0 -205
- package/example/components/ui/icons.tsx +0 -507
- package/example/components/ui/input.tsx +0 -25
- package/example/components/ui/label.tsx +0 -26
- package/example/components/ui/select.tsx +0 -164
- package/example/components/ui/separator.tsx +0 -31
- package/example/components/ui/sheet.tsx +0 -140
- package/example/components/ui/sonner.tsx +0 -31
- package/example/components/ui/switch.tsx +0 -29
- package/example/components/ui/textarea.tsx +0 -24
- package/example/components/ui/tooltip.tsx +0 -30
- package/example/components/user-menu.tsx +0 -53
- package/example/components.json +0 -17
- package/example/instrumentation.ts +0 -11
- package/example/lib/chat/guardrails.tsx +0 -181
- package/example/lib/chat/langchain-rag.tsx +0 -191
- package/example/lib/chat/langchain.tsx +0 -112
- package/example/lib/chat/late-update.tsx +0 -208
- package/example/lib/chat/manual.tsx +0 -605
- package/example/lib/chat/vercel-ai.tsx +0 -576
- package/example/lib/hooks/use-copy-to-clipboard.tsx +0 -33
- package/example/lib/hooks/use-enter-submit.tsx +0 -23
- package/example/lib/hooks/use-local-storage.ts +0 -24
- package/example/lib/hooks/use-scroll-anchor.tsx +0 -86
- package/example/lib/hooks/use-sidebar.tsx +0 -60
- package/example/lib/hooks/use-streamable-text.ts +0 -25
- package/example/lib/types.ts +0 -41
- package/example/lib/utils.ts +0 -89
- package/example/middleware.ts +0 -8
- package/example/next-env.d.ts +0 -5
- package/example/next.config.js +0 -16
- package/example/package-lock.json +0 -10917
- package/example/package.json +0 -84
- package/example/pnpm-lock.yaml +0 -5712
- package/example/postcss.config.js +0 -6
- package/example/prettier.config.cjs +0 -34
- package/example/public/apple-touch-icon.png +0 -0
- package/example/public/favicon-16x16.png +0 -0
- package/example/public/favicon.ico +0 -0
- package/example/public/next.svg +0 -1
- package/example/public/thirteen.svg +0 -1
- package/example/public/vercel.svg +0 -1
- package/example/tailwind.config.ts +0 -81
- package/example/tsconfig.json +0 -35
- package/src/LangWatchExporter.ts +0 -96
- package/src/evaluations.ts +0 -219
- package/src/index.test.ts +0 -402
- package/src/langchain.ts +0 -557
- package/src/typeUtils.ts +0 -89
- package/src/types.ts +0 -82
- package/src/utils.ts +0 -205
- /package/src/{server/types → internal/generated/openapi}/.gitkeep +0 -0
package/dist/utils.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../node_modules/secure-json-parse/index.js","../src/utils.ts","../node_modules/@ai-sdk/provider-utils/src/convert-async-generator-to-readable-stream.ts","../node_modules/@ai-sdk/provider-utils/src/extract-response-headers.ts","../node_modules/@ai-sdk/provider-utils/src/generate-id.ts","../node_modules/@ai-sdk/provider-utils/src/get-error-message.ts","../node_modules/@ai-sdk/provider-utils/src/is-abort-error.ts","../node_modules/@ai-sdk/provider-utils/src/load-api-key.ts","../node_modules/@ai-sdk/provider-utils/src/load-setting.ts","../node_modules/@ai-sdk/provider-utils/src/parse-json.ts","../node_modules/@ai-sdk/provider-utils/src/validate-types.ts","../node_modules/@ai-sdk/provider-utils/src/post-to-api.ts","../node_modules/@ai-sdk/provider-utils/src/response-handler.ts","../node_modules/@ai-sdk/provider-utils/src/uint8-utils.ts","../node_modules/@ai-sdk/provider-utils/src/without-trailing-slash.ts","../src/server/types/tracer.generated.ts"],"sourcesContent":["'use strict'\n\nconst hasBuffer = typeof Buffer !== 'undefined'\nconst suspectProtoRx = /\"(?:_|\\\\u005[Ff])(?:_|\\\\u005[Ff])(?:p|\\\\u0070)(?:r|\\\\u0072)(?:o|\\\\u006[Ff])(?:t|\\\\u0074)(?:o|\\\\u006[Ff])(?:_|\\\\u005[Ff])(?:_|\\\\u005[Ff])\"\\s*:/\nconst suspectConstructorRx = /\"(?:c|\\\\u0063)(?:o|\\\\u006[Ff])(?:n|\\\\u006[Ee])(?:s|\\\\u0073)(?:t|\\\\u0074)(?:r|\\\\u0072)(?:u|\\\\u0075)(?:c|\\\\u0063)(?:t|\\\\u0074)(?:o|\\\\u006[Ff])(?:r|\\\\u0072)\"\\s*:/\n\nfunction _parse (text, reviver, options) {\n // Normalize arguments\n if (options == null) {\n if (reviver !== null && typeof reviver === 'object') {\n options = reviver\n reviver = undefined\n }\n }\n\n if (hasBuffer && Buffer.isBuffer(text)) {\n text = text.toString()\n }\n\n // BOM checker\n if (text && text.charCodeAt(0) === 0xFEFF) {\n text = text.slice(1)\n }\n\n // Parse normally, allowing exceptions\n const obj = JSON.parse(text, reviver)\n\n // Ignore null and non-objects\n if (obj === null || typeof obj !== 'object') {\n return obj\n }\n\n const protoAction = (options && options.protoAction) || 'error'\n const constructorAction = (options && options.constructorAction) || 'error'\n\n // options: 'error' (default) / 'remove' / 'ignore'\n if (protoAction === 'ignore' && constructorAction === 'ignore') {\n return obj\n }\n\n if (protoAction !== 'ignore' && constructorAction !== 'ignore') {\n if (suspectProtoRx.test(text) === false && suspectConstructorRx.test(text) === false) {\n return obj\n }\n } else if (protoAction !== 'ignore' && constructorAction === 'ignore') {\n if (suspectProtoRx.test(text) === false) {\n return obj\n }\n } else {\n if (suspectConstructorRx.test(text) === false) {\n return obj\n }\n }\n\n // Scan result for proto keys\n return filter(obj, { protoAction, constructorAction, safe: options && options.safe })\n}\n\nfunction filter (obj, { protoAction = 'error', constructorAction = 'error', safe } = {}) {\n let next = [obj]\n\n while (next.length) {\n const nodes = next\n next = []\n\n for (const node of nodes) {\n if (protoAction !== 'ignore' && Object.prototype.hasOwnProperty.call(node, '__proto__')) { // Avoid calling node.hasOwnProperty directly\n if (safe === true) {\n return null\n } else if (protoAction === 'error') {\n throw new SyntaxError('Object contains forbidden prototype property')\n }\n\n delete node.__proto__ // eslint-disable-line no-proto\n }\n\n if (constructorAction !== 'ignore' &&\n Object.prototype.hasOwnProperty.call(node, 'constructor') &&\n Object.prototype.hasOwnProperty.call(node.constructor, 'prototype')) { // Avoid calling node.hasOwnProperty directly\n if (safe === true) {\n return null\n } else if (constructorAction === 'error') {\n throw new SyntaxError('Object contains forbidden prototype property')\n }\n\n delete node.constructor\n }\n\n for (const key in node) {\n const value = node[key]\n if (value && typeof value === 'object') {\n next.push(value)\n }\n }\n }\n }\n return obj\n}\n\nfunction parse (text, reviver, options) {\n const stackTraceLimit = Error.stackTraceLimit\n Error.stackTraceLimit = 0\n try {\n return _parse(text, reviver, options)\n } finally {\n Error.stackTraceLimit = stackTraceLimit\n }\n}\n\nfunction safeParse (text, reviver) {\n const stackTraceLimit = Error.stackTraceLimit\n Error.stackTraceLimit = 0\n try {\n return _parse(text, reviver, { safe: true })\n } catch (_e) {\n return null\n } finally {\n Error.stackTraceLimit = stackTraceLimit\n }\n}\n\nmodule.exports = parse\nmodule.exports.default = parse\nmodule.exports.parse = parse\nmodule.exports.safeParse = safeParse\nmodule.exports.scan = filter\n","import { convertUint8ArrayToBase64 } from \"@ai-sdk/provider-utils\";\nimport { type CoreMessage, type ImagePart } from \"ai\";\nimport { z } from \"zod\";\nimport { type ErrorCapture } from \"./server/types/tracer\";\nimport { chatMessageSchema } from \"./server/types/tracer.generated\";\nimport { type ChatMessage, type SpanInputOutput } from \"./types\";\n\nconst convertImageToUrl = (\n image: ImagePart[\"image\"],\n mimeType: string | undefined\n) => {\n try {\n return image instanceof URL\n ? image.toString()\n : typeof image === \"string\"\n ? image\n : `data:${mimeType ?? \"image/jpeg\"};base64,${convertUint8ArrayToBase64(\n image as any\n )}`;\n } catch (e) {\n console.error(\"[LangWatch] error converting vercel ui image to url:\", e);\n return \"\";\n }\n};\n\n// Mostly copied from https://github.com/vercel/ai/blob/main/packages/openai/src/convert-to-openai-chat-messages.ts\nexport function convertFromVercelAIMessages(\n messages: CoreMessage[]\n): ChatMessage[] {\n const lwMessages: ChatMessage[] = [];\n\n for (const { role, content } of messages) {\n switch (role) {\n case \"system\": {\n lwMessages.push({ role: \"system\", content });\n break;\n }\n\n case \"user\": {\n if (\n Array.isArray(content) &&\n content.length === 1 &&\n content[0]?.type === \"text\"\n ) {\n lwMessages.push({ role: \"user\", content: content[0].text });\n break;\n }\n\n lwMessages.push({\n role: \"user\",\n content: Array.isArray(content)\n ? content.map((part) => {\n switch (part.type) {\n case \"text\": {\n return { type: \"text\", text: part.text };\n }\n case \"image\": {\n return {\n type: \"image_url\",\n image_url: {\n url: convertImageToUrl(part.image, part.mimeType),\n },\n };\n }\n default: {\n return part as any;\n }\n }\n })\n : content,\n });\n\n break;\n }\n\n case \"assistant\": {\n let text = \"\";\n const toolCalls: Array<{\n id: string;\n type: \"function\";\n function: { name: string; arguments: string };\n }> = [];\n\n if (Array.isArray(content)) {\n for (const part of content) {\n switch (part.type) {\n case \"text\": {\n text += part.text;\n break;\n }\n case \"tool-call\": {\n toolCalls.push({\n id: part.toolCallId,\n type: \"function\",\n function: {\n name: part.toolName,\n arguments: JSON.stringify(part.args),\n },\n });\n break;\n }\n default: {\n const _exhaustiveCheck = part;\n throw new Error(`Unsupported part: ${_exhaustiveCheck as any}`);\n }\n }\n }\n } else {\n text = content;\n }\n\n lwMessages.push({\n role: \"assistant\",\n content: text,\n tool_calls: toolCalls.length > 0 ? toolCalls : undefined,\n });\n\n break;\n }\n\n case \"tool\": {\n for (const toolResponse of content) {\n lwMessages.push({\n role: \"tool\",\n tool_call_id: toolResponse.toolCallId,\n content: JSON.stringify(toolResponse.result),\n });\n }\n break;\n }\n\n default: {\n const _exhaustiveCheck = role;\n throw new Error(`Unsupported role: ${_exhaustiveCheck as any}`);\n }\n }\n }\n\n return lwMessages;\n}\n\nexport const captureError = (error: unknown): ErrorCapture => {\n if (\n error &&\n typeof error === \"object\" &&\n \"has_error\" in error &&\n \"message\" in error &&\n \"stacktrace\" in error\n ) {\n return error as ErrorCapture;\n } else if (error instanceof Error) {\n return {\n has_error: true,\n message: error.message,\n stacktrace: error.stack ? error.stack.split(\"\\n\") : [],\n };\n } else if (typeof error === \"object\" && error !== null) {\n const err = error as { message: unknown; stack: unknown };\n const message =\n typeof err.message === \"string\"\n ? err.message\n : \"An unknown error occurred\";\n const stacktrace =\n typeof err.stack === \"string\"\n ? err.stack.split(\"\\n\")\n : Array.isArray(err.stack) &&\n err.stack.length > 0 &&\n typeof err.stack[0] === \"string\"\n ? err.stack\n : [\"No stack trace available\"];\n return {\n has_error: true,\n message,\n stacktrace,\n };\n } else {\n // Handle primitives and other types that are not an error object\n return {\n has_error: true,\n message: String(error),\n stacktrace: [],\n };\n }\n};\n\nexport const autoconvertTypedValues = (value: unknown): SpanInputOutput => {\n if (typeof value === \"string\") {\n return { type: \"text\", value };\n }\n\n const chatMessages = z.array(chatMessageSchema).safeParse(value);\n if (Array.isArray(value) && chatMessages.success) {\n return {\n type: \"chat_messages\",\n value: chatMessages.data,\n };\n }\n\n try {\n JSON.stringify(value);\n return { type: \"json\", value: value as object };\n } catch (e) {\n return { type: \"raw\", value: value as any };\n }\n};\n","/**\n * Converts an AsyncGenerator to a ReadableStream.\n *\n * @template T - The type of elements produced by the AsyncGenerator.\n * @param {AsyncGenerator<T>} stream - The AsyncGenerator to convert.\n * @returns {ReadableStream<T>} - A ReadableStream that provides the same data as the AsyncGenerator.\n */\nexport function convertAsyncGeneratorToReadableStream<T>(\n stream: AsyncGenerator<T>,\n): ReadableStream<T> {\n return new ReadableStream<T>({\n /**\n * Called when the consumer wants to pull more data from the stream.\n *\n * @param {ReadableStreamDefaultController<T>} controller - The controller to enqueue data into the stream.\n * @returns {Promise<void>}\n */\n async pull(controller) {\n try {\n const { value, done } = await stream.next();\n if (done) {\n controller.close();\n } else {\n controller.enqueue(value);\n }\n } catch (error) {\n controller.error(error);\n }\n },\n /**\n * Called when the consumer cancels the stream.\n */\n cancel() {},\n });\n}\n","/**\nExtracts the headers from a response object and returns them as a key-value object.\n\n@param response - The response object to extract headers from.\n@returns The headers as a key-value object.\n*/\nexport function extractResponseHeaders(\n response: Response,\n): Record<string, string> {\n const headers: Record<string, string> = {};\n response.headers.forEach((value, key) => {\n headers[key] = value;\n });\n return headers;\n}\n","import { customAlphabet } from 'nanoid/non-secure';\n\n/**\n * Generates a 7-character random string to use for IDs. Not secure.\n */\nexport const generateId = customAlphabet(\n '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz',\n 7,\n);\n","export function getErrorMessage(error: unknown | undefined) {\n if (error == null) {\n return 'unknown error';\n }\n\n if (typeof error === 'string') {\n return error;\n }\n\n if (error instanceof Error) {\n return error.message;\n }\n\n return JSON.stringify(error);\n}\n","export function isAbortError(error: unknown): error is DOMException {\n return (\n error instanceof DOMException &&\n (error.name === 'AbortError' || error.name === 'TimeoutError')\n );\n}\n","import { LoadAPIKeyError } from '@ai-sdk/provider';\n\nexport function loadApiKey({\n apiKey,\n environmentVariableName,\n apiKeyParameterName = 'apiKey',\n description,\n}: {\n apiKey: string | undefined;\n environmentVariableName: string;\n apiKeyParameterName?: string;\n description: string;\n}): string {\n if (typeof apiKey === 'string') {\n return apiKey;\n }\n\n if (apiKey != null) {\n throw new LoadAPIKeyError({\n message: `${description} API key must be a string.`,\n });\n }\n\n if (typeof process === 'undefined') {\n throw new LoadAPIKeyError({\n message: `${description} API key is missing. Pass it using the '${apiKeyParameterName}' parameter. Environment variables is not supported in this environment.`,\n });\n }\n\n apiKey = process.env[environmentVariableName];\n\n if (apiKey == null) {\n throw new LoadAPIKeyError({\n message: `${description} API key is missing. Pass it using the '${apiKeyParameterName}' parameter or the ${environmentVariableName} environment variable.`,\n });\n }\n\n if (typeof apiKey !== 'string') {\n throw new LoadAPIKeyError({\n message: `${description} API key must be a string. The value of the ${environmentVariableName} environment variable is not a string.`,\n });\n }\n\n return apiKey;\n}\n","import { LoadSettingError } from '@ai-sdk/provider';\n\nexport function loadSetting({\n settingValue,\n environmentVariableName,\n settingName,\n description,\n}: {\n settingValue: string | undefined;\n environmentVariableName: string;\n settingName: string;\n description: string;\n}): string {\n if (typeof settingValue === 'string') {\n return settingValue;\n }\n\n if (settingValue != null) {\n throw new LoadSettingError({\n message: `${description} setting must be a string.`,\n });\n }\n\n if (typeof process === 'undefined') {\n throw new LoadSettingError({\n message: `${description} setting is missing. Pass it using the '${settingName}' parameter. Environment variables is not supported in this environment.`,\n });\n }\n\n settingValue = process.env[environmentVariableName];\n\n if (settingValue == null) {\n throw new LoadSettingError({\n message: `${description} setting is missing. Pass it using the '${settingName}' parameter or the ${environmentVariableName} environment variable.`,\n });\n }\n\n if (typeof settingValue !== 'string') {\n throw new LoadSettingError({\n message: `${description} setting must be a string. The value of the ${environmentVariableName} environment variable is not a string.`,\n });\n }\n\n return settingValue;\n}\n","import { JSONParseError, TypeValidationError } from '@ai-sdk/provider';\nimport SecureJSON from 'secure-json-parse';\nimport { ZodSchema } from 'zod';\nimport { safeValidateTypes, validateTypes } from './validate-types';\n\n/**\n * Parses a JSON string into an unknown object.\n *\n * @param text - The JSON string to parse.\n * @returns {unknown} - The parsed JSON object.\n */\nexport function parseJSON({ text }: { text: string }): unknown;\n/**\n * Parses a JSON string into a strongly-typed object using the provided schema.\n *\n * @template T - The type of the object to parse the JSON into.\n * @param {string} text - The JSON string to parse.\n * @param {Schema<T>} schema - The schema to use for parsing the JSON.\n * @returns {T} - The parsed object.\n */\nexport function parseJSON<T>({\n text,\n schema,\n}: {\n text: string;\n schema: ZodSchema<T>;\n}): T;\nexport function parseJSON<T>({\n text,\n schema,\n}: {\n text: string;\n schema?: ZodSchema<T>;\n}): T {\n try {\n const value = SecureJSON.parse(text);\n\n if (schema == null) {\n return value;\n }\n\n return validateTypes({ value, schema });\n } catch (error) {\n if (\n JSONParseError.isJSONParseError(error) ||\n TypeValidationError.isTypeValidationError(error)\n ) {\n throw error;\n }\n\n throw new JSONParseError({ text, cause: error });\n }\n}\n\nexport type ParseResult<T> =\n | { success: true; value: T }\n | { success: false; error: JSONParseError | TypeValidationError };\n\n/**\n * Safely parses a JSON string and returns the result as an object of type `unknown`.\n *\n * @param text - The JSON string to parse.\n * @returns {object} Either an object with `success: true` and the parsed data, or an object with `success: false` and the error that occurred.\n */\nexport function safeParseJSON({ text }: { text: string }): ParseResult<unknown>;\n/**\n * Safely parses a JSON string into a strongly-typed object, using a provided schema to validate the object.\n *\n * @template T - The type of the object to parse the JSON into.\n * @param {string} text - The JSON string to parse.\n * @param {Schema<T>} schema - The schema to use for parsing the JSON.\n * @returns An object with either a `success` flag and the parsed and typed data, or a `success` flag and an error object.\n */\nexport function safeParseJSON<T>({\n text,\n schema,\n}: {\n text: string;\n schema: ZodSchema<T>;\n}): ParseResult<T>;\nexport function safeParseJSON<T>({\n text,\n schema,\n}: {\n text: string;\n schema?: ZodSchema<T>;\n}):\n | { success: true; value: T }\n | { success: false; error: JSONParseError | TypeValidationError } {\n try {\n const value = SecureJSON.parse(text);\n\n if (schema == null) {\n return {\n success: true,\n value: value as T,\n };\n }\n\n return safeValidateTypes({ value, schema });\n } catch (error) {\n return {\n success: false,\n error: JSONParseError.isJSONParseError(error)\n ? error\n : new JSONParseError({ text, cause: error }),\n };\n }\n}\n\nexport function isParseableJson(input: string): boolean {\n try {\n SecureJSON.parse(input);\n return true;\n } catch {\n return false;\n }\n}\n","import { TypeValidationError } from '@ai-sdk/provider';\nimport { ZodSchema } from 'zod';\n\n/**\n * Validates the types of an unknown object using a schema and\n * return a strongly-typed object.\n *\n * @template T - The type of the object to validate.\n * @param {string} options.value - The object to validate.\n * @param {Schema<T>} options.schema - The schema to use for validating the JSON.\n * @returns {T} - The typed object.\n */\nexport function validateTypes<T>({\n value,\n schema,\n}: {\n value: unknown;\n schema: ZodSchema<T>;\n}): T {\n try {\n return schema.parse(value);\n } catch (error) {\n throw new TypeValidationError({ value, cause: error });\n }\n}\n\n/**\n * Safely validates the types of an unknown object using a schema and\n * return a strongly-typed object.\n *\n * @template T - The type of the object to validate.\n * @param {string} options.value - The JSON object to validate.\n * @param {Schema<T>} options.schema - The schema to use for validating the JSON.\n * @returns An object with either a `success` flag and the parsed and typed data, or a `success` flag and an error object.\n */\nexport function safeValidateTypes<T>({\n value,\n schema,\n}: {\n value: unknown;\n schema: ZodSchema<T>;\n}):\n | { success: true; value: T }\n | { success: false; error: TypeValidationError } {\n try {\n const validationResult = schema.safeParse(value);\n\n if (validationResult.success) {\n return {\n success: true,\n value: validationResult.data,\n };\n }\n\n return {\n success: false,\n error: new TypeValidationError({\n value,\n cause: validationResult.error,\n }),\n };\n } catch (error) {\n return {\n success: false,\n error: TypeValidationError.isTypeValidationError(error)\n ? error\n : new TypeValidationError({ value, cause: error }),\n };\n }\n}\n","import { APICallError } from '@ai-sdk/provider';\nimport { extractResponseHeaders } from './extract-response-headers';\nimport { isAbortError } from './is-abort-error';\nimport { ResponseHandler } from './response-handler';\n\nexport const postJsonToApi = async <T>({\n url,\n headers,\n body,\n failedResponseHandler,\n successfulResponseHandler,\n abortSignal,\n}: {\n url: string;\n headers?: Record<string, string | undefined>;\n body: unknown;\n failedResponseHandler: ResponseHandler<APICallError>;\n successfulResponseHandler: ResponseHandler<T>;\n abortSignal?: AbortSignal;\n}) =>\n postToApi({\n url,\n headers: {\n ...headers,\n 'Content-Type': 'application/json',\n },\n body: {\n content: JSON.stringify(body),\n values: body,\n },\n failedResponseHandler,\n successfulResponseHandler,\n abortSignal,\n });\n\nexport const postToApi = async <T>({\n url,\n headers = {},\n body,\n successfulResponseHandler,\n failedResponseHandler,\n abortSignal,\n}: {\n url: string;\n headers?: Record<string, string | undefined>;\n body: {\n content: string | FormData | Uint8Array;\n values: unknown;\n };\n failedResponseHandler: ResponseHandler<Error>;\n successfulResponseHandler: ResponseHandler<T>;\n abortSignal?: AbortSignal;\n}) => {\n try {\n // remove undefined headers:\n const definedHeaders = Object.fromEntries(\n Object.entries(headers).filter(([_key, value]) => value != null),\n ) as Record<string, string>;\n\n const response = await fetch(url, {\n method: 'POST',\n headers: definedHeaders,\n body: body.content,\n signal: abortSignal,\n });\n\n const responseHeaders = extractResponseHeaders(response);\n\n if (!response.ok) {\n let errorInformation: {\n value: Error;\n responseHeaders?: Record<string, string> | undefined;\n };\n\n try {\n errorInformation = await failedResponseHandler({\n response,\n url,\n requestBodyValues: body.values,\n });\n } catch (error) {\n if (isAbortError(error) || APICallError.isAPICallError(error)) {\n throw error;\n }\n\n throw new APICallError({\n message: 'Failed to process error response',\n cause: error,\n statusCode: response.status,\n url,\n responseHeaders,\n requestBodyValues: body.values,\n });\n }\n\n throw errorInformation.value;\n }\n\n try {\n return await successfulResponseHandler({\n response,\n url,\n requestBodyValues: body.values,\n });\n } catch (error) {\n if (error instanceof Error) {\n if (isAbortError(error) || APICallError.isAPICallError(error)) {\n throw error;\n }\n }\n\n throw new APICallError({\n message: 'Failed to process successful response',\n cause: error,\n statusCode: response.status,\n url,\n responseHeaders,\n requestBodyValues: body.values,\n });\n }\n } catch (error) {\n if (isAbortError(error)) {\n throw error;\n }\n\n // unwrap original error when fetch failed (for easier debugging):\n if (error instanceof TypeError && error.message === 'fetch failed') {\n const cause = (error as any).cause;\n\n if (cause != null) {\n // Failed to connect to server:\n throw new APICallError({\n message: `Cannot connect to API: ${cause.message}`,\n cause,\n url,\n requestBodyValues: body.values,\n isRetryable: true, // retry when network error\n });\n }\n }\n\n throw error;\n }\n};\n","import { APICallError, EmptyResponseBodyError } from '@ai-sdk/provider';\nimport {\n EventSourceParserStream,\n ParsedEvent,\n} from 'eventsource-parser/stream';\nimport { ZodSchema } from 'zod';\nimport { extractResponseHeaders } from './extract-response-headers';\nimport { ParseResult, parseJSON, safeParseJSON } from './parse-json';\n\nexport type ResponseHandler<RETURN_TYPE> = (options: {\n url: string;\n requestBodyValues: unknown;\n response: Response;\n}) => PromiseLike<{\n value: RETURN_TYPE;\n responseHeaders?: Record<string, string>;\n}>;\n\nexport const createJsonErrorResponseHandler =\n <T>({\n errorSchema,\n errorToMessage,\n isRetryable,\n }: {\n errorSchema: ZodSchema<T>;\n errorToMessage: (error: T) => string;\n isRetryable?: (response: Response, error?: T) => boolean;\n }): ResponseHandler<APICallError> =>\n async ({ response, url, requestBodyValues }) => {\n const responseBody = await response.text();\n const responseHeaders = extractResponseHeaders(response);\n\n // Some providers return an empty response body for some errors:\n if (responseBody.trim() === '') {\n return {\n responseHeaders,\n value: new APICallError({\n message: response.statusText,\n url,\n requestBodyValues,\n statusCode: response.status,\n responseHeaders,\n responseBody,\n isRetryable: isRetryable?.(response),\n }),\n };\n }\n\n // resilient parsing in case the response is not JSON or does not match the schema:\n try {\n const parsedError = parseJSON({\n text: responseBody,\n schema: errorSchema,\n });\n\n return {\n responseHeaders,\n value: new APICallError({\n message: errorToMessage(parsedError),\n url,\n requestBodyValues,\n statusCode: response.status,\n responseHeaders,\n responseBody,\n data: parsedError,\n isRetryable: isRetryable?.(response, parsedError),\n }),\n };\n } catch (parseError) {\n return {\n responseHeaders,\n value: new APICallError({\n message: response.statusText,\n url,\n requestBodyValues,\n statusCode: response.status,\n responseHeaders,\n responseBody,\n isRetryable: isRetryable?.(response),\n }),\n };\n }\n };\n\nexport const createEventSourceResponseHandler =\n <T>(\n chunkSchema: ZodSchema<T>,\n ): ResponseHandler<ReadableStream<ParseResult<T>>> =>\n async ({ response }: { response: Response }) => {\n const responseHeaders = extractResponseHeaders(response);\n\n if (response.body == null) {\n throw new EmptyResponseBodyError({});\n }\n\n return {\n responseHeaders,\n value: response.body\n .pipeThrough(new TextDecoderStream())\n .pipeThrough(new EventSourceParserStream())\n .pipeThrough(\n new TransformStream<ParsedEvent, ParseResult<T>>({\n transform({ data }, controller) {\n // ignore the 'DONE' event that e.g. OpenAI sends:\n if (data === '[DONE]') {\n return;\n }\n\n controller.enqueue(\n safeParseJSON({\n text: data,\n schema: chunkSchema,\n }),\n );\n },\n }),\n ),\n };\n };\n\nexport const createJsonResponseHandler =\n <T>(responseSchema: ZodSchema<T>): ResponseHandler<T> =>\n async ({ response, url, requestBodyValues }) => {\n const responseBody = await response.text();\n\n const parsedResult = safeParseJSON({\n text: responseBody,\n schema: responseSchema,\n });\n\n const responseHeaders = extractResponseHeaders(response);\n\n if (!parsedResult.success) {\n throw new APICallError({\n message: 'Invalid JSON response',\n cause: parsedResult.error,\n statusCode: response.status,\n responseHeaders,\n responseBody,\n url,\n requestBodyValues,\n });\n }\n\n return {\n responseHeaders,\n value: parsedResult.value,\n };\n };\n","export function convertBase64ToUint8Array(base64String: string) {\n const base64Url = base64String.replace(/-/g, '+').replace(/_/g, '/');\n const latin1string = globalThis.atob(base64Url);\n return Uint8Array.from(latin1string, byte => byte.codePointAt(0)!);\n}\n\nexport function convertUint8ArrayToBase64(array: Uint8Array): string {\n let latin1string = '';\n\n // Note: regular for loop to support older JavaScript versions that\n // do not support for..of on Uint8Array\n for (let i = 0; i < array.length; i++) {\n latin1string += String.fromCodePoint(array[i]);\n }\n\n return globalThis.btoa(latin1string);\n}\n","export function withoutTrailingSlash(url: string | undefined) {\n return url?.replace(/\\/$/, '');\n}\n","// Generated by ts-to-zod\nimport { z } from \"zod\";\nimport { SpanInputOutput } from \"./tracer\";\n\nconst chatRoleSchema = z.union([\n z.literal(\"system\"),\n z.literal(\"user\"),\n z.literal(\"assistant\"),\n z.literal(\"function\"),\n z.literal(\"tool\"),\n z.literal(\"unknown\"),\n]);\n\nconst functionCallSchema = z.object({\n name: z.string().optional(),\n arguments: z.string().optional(),\n});\n\nconst toolCallSchema = z.object({\n id: z.string(),\n type: z.string(),\n function: functionCallSchema,\n});\n\nexport const rAGChunkSchema = z.object({\n document_id: z.string().optional().nullable(),\n chunk_id: z.string().optional().nullable(),\n content: z.union([z.string(), z.record(z.any()), z.array(z.any())]),\n});\n\nexport const chatRichContentSchema = z.union([\n z.object({\n type: z.literal(\"text\"),\n text: z.string().optional(),\n }),\n z.object({\n text: z.string(),\n }),\n z.object({\n type: z.literal(\"image_url\"),\n image_url: z\n .object({\n url: z.string(),\n detail: z\n .union([z.literal(\"auto\"), z.literal(\"low\"), z.literal(\"high\")])\n .optional(),\n })\n .optional(),\n }),\n z.object({\n type: z.literal(\"tool_call\"),\n toolName: z.string().optional(),\n toolCallId: z.string().optional(),\n args: z.string().optional(),\n }),\n z.object({\n type: z.literal(\"tool_result\"),\n toolName: z.string().optional(),\n toolCallId: z.string().optional(),\n result: z.any().optional(),\n }),\n]);\n\nconst typedValueTextSchema = z.object({\n type: z.literal(\"text\"),\n value: z.string(),\n});\n\nconst typedValueRawSchema = z.object({\n type: z.literal(\"raw\"),\n value: z.string(),\n});\n\nconst jSONSerializableSchema = z\n .union([\n z.string(),\n z.number(),\n z.boolean(),\n z.record(z.any()),\n z.array(z.any()),\n ])\n .nullable();\n\nexport const typedValueJsonSchema = z.object({\n type: z.literal(\"json\"),\n value: jSONSerializableSchema,\n});\n\nexport const moneySchema = z.object({\n currency: z.string(),\n amount: z.number(),\n});\n\nexport const evaluationResultSchema = z.object({\n status: z.union([\n z.literal(\"processed\"),\n z.literal(\"skipped\"),\n z.literal(\"error\"),\n ]),\n passed: z.boolean().optional().nullable(),\n score: z.number().optional().nullable(),\n label: z.string().optional().nullable(),\n details: z.string().optional().nullable(),\n cost: moneySchema.optional().nullable(),\n});\n\nexport const typedValueGuardrailResultSchema = z.object({\n type: z.literal(\"guardrail_result\"),\n value: evaluationResultSchema,\n});\n\nexport const typedValueEvaluationResultSchema = z.object({\n type: z.literal(\"evaluation_result\"),\n value: evaluationResultSchema,\n});\n\nexport const errorCaptureSchema = z.object({\n has_error: z.literal(true),\n message: z.string(),\n stacktrace: z.array(z.string()),\n});\n\nexport const spanMetricsSchema = z.object({\n prompt_tokens: z.number().optional().nullable(),\n completion_tokens: z.number().optional().nullable(),\n tokens_estimated: z.boolean().optional().nullable(),\n cost: z.number().optional().nullable(),\n});\n\nexport const reservedSpanParamsSchema = z.object({\n frequency_penalty: z.number().optional().nullable(),\n logit_bias: z.record(z.number()).optional().nullable(),\n logprobs: z.boolean().optional().nullable(),\n top_logprobs: z.number().optional().nullable(),\n max_tokens: z.number().optional().nullable(),\n n: z.number().optional().nullable(),\n presence_penalty: z.number().optional().nullable(),\n seed: z.number().optional().nullable(),\n stop: z\n .union([z.string(), z.array(z.string())])\n .optional()\n .nullable(),\n stream: z.boolean().optional().nullable(),\n temperature: z.number().optional().nullable(),\n top_p: z.number().optional().nullable(),\n tools: z.array(z.record(z.any())).optional().nullable(),\n tool_choice: z\n .union([z.record(z.any()), z.string()])\n .optional()\n .nullable(),\n parallel_tool_calls: z.boolean().optional().nullable(),\n functions: z.array(z.record(z.any())).optional().nullable(),\n user: z.string().optional().nullable(),\n});\n\nexport const spanParamsSchema = reservedSpanParamsSchema.and(z.record(z.any()));\n\nexport const spanTimestampsSchema = z.object({\n started_at: z.number(),\n first_token_at: z.number().optional().nullable(),\n finished_at: z.number(),\n});\n\nexport const spanTypesSchema = z.union([\n z.literal(\"span\"),\n z.literal(\"llm\"),\n z.literal(\"chain\"),\n z.literal(\"tool\"),\n z.literal(\"agent\"),\n z.literal(\"rag\"),\n z.literal(\"guardrail\"),\n z.literal(\"evaluation\"),\n z.literal(\"workflow\"),\n z.literal(\"component\"),\n z.literal(\"module\"),\n z.literal(\"server\"),\n z.literal(\"client\"),\n z.literal(\"producer\"),\n z.literal(\"consumer\"),\n z.literal(\"task\"),\n z.literal(\"unknown\"),\n]);\n\nexport const traceInputSchema = z.object({\n value: z.string(),\n satisfaction_score: z.number().optional(),\n});\n\nexport const traceOutputSchema = z.object({\n value: z.string(),\n});\n\nconst primitiveTypeSchema = z\n .union([z.string(), z.number(), z.boolean(), z.undefined()])\n .nullable();\n\nexport const reservedTraceMetadataSchema = z.object({\n thread_id: z.string().optional().nullable(),\n user_id: z.string().optional().nullable(),\n customer_id: z.string().optional().nullable(),\n labels: z.array(z.string()).optional().nullable(),\n topic_id: z.string().optional().nullable(),\n subtopic_id: z.string().optional().nullable(),\n sdk_name: z.string().optional().nullable(),\n sdk_version: z.string().optional().nullable(),\n sdk_language: z.string().optional().nullable(),\n telemetry_sdk_language: z.string().optional().nullable(),\n telemetry_sdk_name: z.string().optional().nullable(),\n telemetry_sdk_version: z.string().optional().nullable(),\n prompt_ids: z.array(z.string()).optional().nullable(),\n prompt_version_ids: z.array(z.string()).optional().nullable(),\n});\n\nexport const reservedTraceMetadataMappingSchema = z.record(z.any());\n\nexport const customMetadataSchema = z.record(\n z.union([\n primitiveTypeSchema,\n z.array(primitiveTypeSchema),\n z.record(primitiveTypeSchema),\n z.record(z.record(primitiveTypeSchema)),\n ]),\n);\n\nexport const traceMetadataSchema =\n reservedTraceMetadataSchema.and(customMetadataSchema);\n\nexport const eventSchema = z.object({\n event_id: z.string(),\n event_type: z.string(),\n project_id: z.string(),\n metrics: z.record(z.number()),\n event_details: z.record(z.string()),\n trace_id: z.string(),\n timestamps: z.object({\n started_at: z.number(),\n inserted_at: z.number(),\n updated_at: z.number(),\n }),\n});\n\nexport const elasticSearchEventSchema = eventSchema\n .omit({ metrics: true, event_details: true })\n .and(\n z.object({\n metrics: z.array(\n z.object({\n key: z.string(),\n value: z.number(),\n }),\n ),\n event_details: z.array(\n z.object({\n key: z.string(),\n value: z.string(),\n }),\n ),\n }),\n );\n\nconst evaluationStatusSchema = z.union([\n z.literal(\"scheduled\"),\n z.literal(\"in_progress\"),\n z.literal(\"error\"),\n z.literal(\"skipped\"),\n z.literal(\"processed\"),\n]);\n\nexport const trackEventRESTParamsValidatorSchema = eventSchema\n .omit({\n event_id: true,\n project_id: true,\n timestamps: true,\n event_details: true,\n })\n .and(\n z.object({\n event_id: z.string().optional(),\n event_details: z.record(z.string()).optional(),\n timestamp: z.number().optional(),\n }),\n );\n\nexport const contextsSchema = z.object({\n traceId: z.string(),\n contexts: z.array(rAGChunkSchema),\n});\n\nexport const chatMessageSchema = z.object({\n role: chatRoleSchema.optional(),\n content: z\n .union([z.string(), z.array(chatRichContentSchema)])\n .optional()\n .nullable(),\n function_call: functionCallSchema.optional().nullable(),\n tool_calls: z.array(toolCallSchema).optional().nullable(),\n tool_call_id: z.string().optional().nullable(),\n name: z.string().optional().nullable(),\n});\n\nexport const typedValueChatMessagesSchema = z.object({\n type: z.literal(\"chat_messages\"),\n value: z.array(chatMessageSchema),\n});\n\nexport const spanInputOutputSchema: z.ZodSchema<SpanInputOutput> = z.lazy(() =>\n z.union([\n typedValueTextSchema,\n typedValueChatMessagesSchema,\n typedValueGuardrailResultSchema,\n typedValueEvaluationResultSchema,\n typedValueJsonSchema,\n typedValueRawSchema,\n z.object({\n type: z.literal(\"list\"),\n value: z.array(spanInputOutputSchema),\n }),\n ]),\n);\n\nexport const baseSpanSchema = z.object({\n span_id: z.string(),\n parent_id: z.string().optional().nullable(),\n trace_id: z.string(),\n type: spanTypesSchema,\n name: z.string().optional().nullable(),\n input: spanInputOutputSchema.optional().nullable(),\n output: spanInputOutputSchema.optional().nullable(),\n error: errorCaptureSchema.optional().nullable(),\n timestamps: spanTimestampsSchema,\n metrics: spanMetricsSchema.optional().nullable(),\n params: spanParamsSchema.optional().nullable(),\n});\n\nexport const lLMSpanSchema = baseSpanSchema.extend({\n type: z.literal(\"llm\"),\n vendor: z.string().optional().nullable(),\n model: z.string().optional().nullable(),\n});\n\nexport const rAGSpanSchema = baseSpanSchema.extend({\n type: z.literal(\"rag\"),\n contexts: z.array(rAGChunkSchema),\n});\n\nexport const spanSchema = z.union([\n lLMSpanSchema,\n rAGSpanSchema,\n baseSpanSchema,\n]);\n\nconst spanInputOutputValidatorSchema = spanInputOutputSchema.and(\n z.object({\n value: z.any(),\n }),\n);\n\nexport const spanValidatorSchema = z\n .union([\n lLMSpanSchema.omit({ input: true, output: true, params: true }),\n rAGSpanSchema.omit({ input: true, output: true, params: true }),\n baseSpanSchema.omit({ input: true, output: true, params: true }),\n ])\n .and(\n z.object({\n input: spanInputOutputValidatorSchema.optional().nullable(),\n output: spanInputOutputValidatorSchema.optional().nullable(),\n params: z.record(z.any()).optional().nullable(),\n }),\n );\n\nexport const evaluationSchema = z.object({\n evaluation_id: z.string(),\n evaluator_id: z.string(),\n span_id: z.string().optional().nullable(),\n name: z.string(),\n type: z.string().optional().nullable(),\n is_guardrail: z.boolean().optional().nullable(),\n status: evaluationStatusSchema,\n passed: z.boolean().optional().nullable(),\n score: z.number().optional().nullable(),\n label: z.string().optional().nullable(),\n details: z.string().optional().nullable(),\n error: errorCaptureSchema.optional().nullable(),\n retries: z.number().optional().nullable(),\n timestamps: z.object({\n inserted_at: z.number().optional().nullable(),\n started_at: z.number().optional().nullable(),\n finished_at: z.number().optional().nullable(),\n updated_at: z.number().optional().nullable(),\n }),\n});\n\nexport const elasticSearchEvaluationSchema = evaluationSchema;\n\nexport const rESTEvaluationSchema = evaluationSchema\n .omit({\n evaluation_id: true,\n evaluator_id: true,\n status: true,\n timestamps: true,\n retries: true,\n })\n .and(\n z.object({\n evaluation_id: z.string().optional().nullable(),\n evaluator_id: z.string().optional().nullable(),\n status: z\n .union([\n z.literal(\"processed\"),\n z.literal(\"skipped\"),\n z.literal(\"error\"),\n ])\n .optional()\n .nullable(),\n timestamps: z\n .object({\n started_at: z.number().optional().nullable(),\n finished_at: z.number().optional().nullable(),\n })\n .optional()\n .nullable(),\n }),\n );\n\nexport const collectorRESTParamsSchema = z.object({\n trace_id: z.union([z.string(), z.undefined()]).optional().nullable(),\n spans: z.array(spanSchema),\n metadata: z\n .object({\n user_id: z.union([z.string(), z.undefined()]).optional().nullable(),\n thread_id: z.union([z.string(), z.undefined()]).optional().nullable(),\n customer_id: z.union([z.string(), z.undefined()]).optional().nullable(),\n labels: z\n .union([z.array(z.string()), z.undefined()])\n .optional()\n .nullable(),\n sdk_version: z.union([z.string(), z.undefined()]).optional().nullable(),\n sdk_language: z.union([z.string(), z.undefined()]).optional().nullable(),\n })\n .and(customMetadataSchema)\n .optional(),\n expected_output: z.string().optional().nullable(),\n evaluations: z.array(rESTEvaluationSchema).optional(),\n});\n\nexport const collectorRESTParamsValidatorSchema =\n collectorRESTParamsSchema.omit({ spans: true });\n\nexport const traceSchema = z.object({\n trace_id: z.string(),\n project_id: z.string(),\n metadata: traceMetadataSchema,\n timestamps: z.object({\n started_at: z.number(),\n inserted_at: z.number(),\n updated_at: z.number(),\n }),\n input: traceInputSchema.optional(),\n output: traceOutputSchema.optional(),\n contexts: z.array(rAGChunkSchema).optional(),\n expected_output: z\n .object({\n value: z.string(),\n })\n .optional(),\n metrics: z\n .object({\n first_token_ms: z.number().optional().nullable(),\n total_time_ms: z.number().optional().nullable(),\n prompt_tokens: z.number().optional().nullable(),\n completion_tokens: z.number().optional().nullable(),\n total_cost: z.number().optional().nullable(),\n tokens_estimated: z.boolean().optional().nullable(),\n })\n .optional(),\n error: errorCaptureSchema.optional().nullable(),\n indexing_md5s: z.array(z.string()).optional(),\n events: z.array(eventSchema).optional(),\n evaluations: z.array(evaluationSchema).optional(),\n spans: z.array(spanSchema),\n});\n"],"mappings":"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","names":["exports","module","import_zod"]}
|
package/dist/utils.mjs
DELETED
package/dist/utils.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
package/example/.env.example
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
# You must first activate a Billing Account here: https://platform.openai.com/account/billing/overview
|
|
2
|
-
# Then get your OpenAI API Key here: https://platform.openai.com/account/api-keys
|
|
3
|
-
OPENAI_API_KEY=XXXXXXXX
|
|
4
|
-
|
|
5
|
-
# Generate a random secret: https://generate-secret.vercel.app/32 or `openssl rand -base64 32`
|
|
6
|
-
AUTH_SECRET=XXXXXXXX
|
|
7
|
-
|
|
8
|
-
# Get your LangWatch API Key here: https://app.langwatch.ai/
|
|
9
|
-
LANGWATCH_API_KEY=XXXXXXXX
|
|
10
|
-
|
|
11
|
-
# Keep the default endpoint unless pointing to a self-hosted version
|
|
12
|
-
LANGWATCH_ENDPOINT=https://app.langwatch.ai
|
package/example/.eslintrc.json
DELETED
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "https://json.schemastore.org/eslintrc",
|
|
3
|
-
"root": true,
|
|
4
|
-
"extends": [
|
|
5
|
-
"next/core-web-vitals",
|
|
6
|
-
"prettier",
|
|
7
|
-
"plugin:tailwindcss/recommended"
|
|
8
|
-
],
|
|
9
|
-
"plugins": ["tailwindcss"],
|
|
10
|
-
"rules": {
|
|
11
|
-
"tailwindcss/no-custom-classname": "off",
|
|
12
|
-
"tailwindcss/classnames-order": "off"
|
|
13
|
-
},
|
|
14
|
-
"settings": {
|
|
15
|
-
"tailwindcss": {
|
|
16
|
-
"callees": ["cn", "cva"],
|
|
17
|
-
"config": "tailwind.config.js"
|
|
18
|
-
}
|
|
19
|
-
},
|
|
20
|
-
"overrides": [
|
|
21
|
-
{
|
|
22
|
-
"files": ["*.ts", "*.tsx"],
|
|
23
|
-
"parser": "@typescript-eslint/parser"
|
|
24
|
-
}
|
|
25
|
-
]
|
|
26
|
-
}
|
package/example/LICENSE
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
Copyright 2023 Vercel, Inc.
|
|
2
|
-
|
|
3
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
-
you may not use this file except in compliance with the License.
|
|
5
|
-
You may obtain a copy of the License at
|
|
6
|
-
|
|
7
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
-
|
|
9
|
-
Unless required by applicable law or agreed to in writing, software
|
|
10
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
-
See the License for the specific language governing permissions and
|
|
13
|
-
limitations under the License.
|
package/example/README.md
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
# LangWatch TypeScript SDK example project
|
|
2
|
-
|
|
3
|
-
This is an example typescript project using Next.js AI Chatbot using LangWatch SDK for observability.
|
|
4
|
-
|
|
5
|
-
Run it with:
|
|
6
|
-
|
|
7
|
-
```
|
|
8
|
-
npm install
|
|
9
|
-
npm run dev
|
|
10
|
-
```
|
|
11
|
-
|
|
12
|
-
Go to lib/chat folder to see the example integrations with different frameworks (vercel-ai, langchain.js, etc)
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
import { type Metadata } from 'next'
|
|
2
|
-
import { notFound, redirect } from 'next/navigation'
|
|
3
|
-
|
|
4
|
-
import { auth } from '@/auth'
|
|
5
|
-
import { getChat, getMissingKeys } from '@/app/actions'
|
|
6
|
-
import { Chat } from '@/components/chat'
|
|
7
|
-
import { AI } from '@/lib/chat/vercel-ai'
|
|
8
|
-
import { Session } from '@/lib/types'
|
|
9
|
-
|
|
10
|
-
export interface ChatPageProps {
|
|
11
|
-
params: {
|
|
12
|
-
id: string
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export async function generateMetadata({
|
|
17
|
-
params
|
|
18
|
-
}: ChatPageProps): Promise<Metadata> {
|
|
19
|
-
const session = await auth()
|
|
20
|
-
|
|
21
|
-
if (!session?.user) {
|
|
22
|
-
return {}
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
const chat = await getChat(params.id, session.user.id)
|
|
26
|
-
return {
|
|
27
|
-
title: chat?.title.toString().slice(0, 50) ?? 'Chat'
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
export default async function ChatPage({ params }: ChatPageProps) {
|
|
32
|
-
const session = (await auth()) as Session
|
|
33
|
-
const missingKeys = await getMissingKeys()
|
|
34
|
-
|
|
35
|
-
if (!session?.user) {
|
|
36
|
-
redirect(`/login?next=/chat/${params.id}`)
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
const userId = session.user.id as string
|
|
40
|
-
const chat = await getChat(params.id, userId)
|
|
41
|
-
|
|
42
|
-
if (!chat) {
|
|
43
|
-
redirect('/')
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
if (chat?.userId !== session?.user?.id) {
|
|
47
|
-
notFound()
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
return (
|
|
51
|
-
<AI initialAIState={{ chatId: chat.id, messages: chat.messages }}>
|
|
52
|
-
<Chat
|
|
53
|
-
id={chat.id}
|
|
54
|
-
session={session}
|
|
55
|
-
initialMessages={chat.messages}
|
|
56
|
-
missingKeys={missingKeys}
|
|
57
|
-
/>
|
|
58
|
-
</AI>
|
|
59
|
-
)
|
|
60
|
-
}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { SidebarDesktop } from '@/components/sidebar-desktop'
|
|
2
|
-
|
|
3
|
-
interface ChatLayoutProps {
|
|
4
|
-
children: React.ReactNode
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
export default async function ChatLayout({ children }: ChatLayoutProps) {
|
|
8
|
-
return (
|
|
9
|
-
<div className="relative flex h-[calc(100vh_-_theme(spacing.16))] overflow-hidden">
|
|
10
|
-
<SidebarDesktop />
|
|
11
|
-
{children}
|
|
12
|
-
</div>
|
|
13
|
-
)
|
|
14
|
-
}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { nanoid } from '@/lib/utils'
|
|
2
|
-
import { Chat } from '@/components/chat'
|
|
3
|
-
import { AI } from '@/lib/chat/vercel-ai'
|
|
4
|
-
import { auth } from '@/auth'
|
|
5
|
-
import { Session } from '@/lib/types'
|
|
6
|
-
import { getMissingKeys } from '@/app/actions'
|
|
7
|
-
|
|
8
|
-
export const metadata = {
|
|
9
|
-
title: 'Vercel AI SDK Example'
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export default async function IndexPage() {
|
|
13
|
-
const id = nanoid()
|
|
14
|
-
const session = (await auth()) as Session
|
|
15
|
-
const missingKeys = await getMissingKeys()
|
|
16
|
-
|
|
17
|
-
return (
|
|
18
|
-
<>
|
|
19
|
-
<div className="text-center w-full absolute pt-1">
|
|
20
|
-
Vercel AI SDK example
|
|
21
|
-
</div>
|
|
22
|
-
<AI initialAIState={{ chatId: id, messages: [] }}>
|
|
23
|
-
<Chat id={id} session={session} missingKeys={missingKeys} />
|
|
24
|
-
</AI>
|
|
25
|
-
</>
|
|
26
|
-
)
|
|
27
|
-
}
|
package/example/app/actions.ts
DELETED
|
@@ -1,156 +0,0 @@
|
|
|
1
|
-
'use server'
|
|
2
|
-
|
|
3
|
-
import { revalidatePath } from 'next/cache'
|
|
4
|
-
import { redirect } from 'next/navigation'
|
|
5
|
-
import { kv } from '@vercel/kv'
|
|
6
|
-
|
|
7
|
-
import { auth } from '@/auth'
|
|
8
|
-
import { type Chat } from '@/lib/types'
|
|
9
|
-
|
|
10
|
-
export async function getChats(userId?: string | null) {
|
|
11
|
-
if (!userId) {
|
|
12
|
-
return []
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
try {
|
|
16
|
-
const pipeline = kv.pipeline()
|
|
17
|
-
const chats: string[] = await kv.zrange(`user:chat:${userId}`, 0, -1, {
|
|
18
|
-
rev: true
|
|
19
|
-
})
|
|
20
|
-
|
|
21
|
-
for (const chat of chats) {
|
|
22
|
-
pipeline.hgetall(chat)
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
const results = await pipeline.exec()
|
|
26
|
-
|
|
27
|
-
return results as Chat[]
|
|
28
|
-
} catch (error) {
|
|
29
|
-
return []
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
export async function getChat(id: string, userId: string) {
|
|
34
|
-
const chat = await kv.hgetall<Chat>(`chat:${id}`)
|
|
35
|
-
|
|
36
|
-
if (!chat || (userId && chat.userId !== userId)) {
|
|
37
|
-
return null
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
return chat
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
export async function removeChat({ id, path }: { id: string; path: string }) {
|
|
44
|
-
const session = await auth()
|
|
45
|
-
|
|
46
|
-
if (!session) {
|
|
47
|
-
return {
|
|
48
|
-
error: 'Unauthorized'
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
//Convert uid to string for consistent comparison with session.user.id
|
|
53
|
-
const uid = String(await kv.hget(`chat:${id}`, 'userId'))
|
|
54
|
-
|
|
55
|
-
if (uid !== session?.user?.id) {
|
|
56
|
-
return {
|
|
57
|
-
error: 'Unauthorized'
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
await kv.del(`chat:${id}`)
|
|
62
|
-
await kv.zrem(`user:chat:${session.user.id}`, `chat:${id}`)
|
|
63
|
-
|
|
64
|
-
revalidatePath('/')
|
|
65
|
-
return revalidatePath(path)
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
export async function clearChats() {
|
|
69
|
-
const session = await auth()
|
|
70
|
-
|
|
71
|
-
if (!session?.user?.id) {
|
|
72
|
-
return {
|
|
73
|
-
error: 'Unauthorized'
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
const chats: string[] = await kv.zrange(`user:chat:${session.user.id}`, 0, -1)
|
|
78
|
-
if (!chats.length) {
|
|
79
|
-
return redirect('/')
|
|
80
|
-
}
|
|
81
|
-
const pipeline = kv.pipeline()
|
|
82
|
-
|
|
83
|
-
for (const chat of chats) {
|
|
84
|
-
pipeline.del(chat)
|
|
85
|
-
pipeline.zrem(`user:chat:${session.user.id}`, chat)
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
await pipeline.exec()
|
|
89
|
-
|
|
90
|
-
revalidatePath('/')
|
|
91
|
-
return redirect('/')
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
export async function getSharedChat(id: string) {
|
|
95
|
-
const chat = await kv.hgetall<Chat>(`chat:${id}`)
|
|
96
|
-
|
|
97
|
-
if (!chat || !chat.sharePath) {
|
|
98
|
-
return null
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
return chat
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
export async function shareChat(id: string) {
|
|
105
|
-
const session = await auth()
|
|
106
|
-
|
|
107
|
-
if (!session?.user?.id) {
|
|
108
|
-
return {
|
|
109
|
-
error: 'Unauthorized'
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
const chat = await kv.hgetall<Chat>(`chat:${id}`)
|
|
114
|
-
|
|
115
|
-
if (!chat || chat.userId !== session.user.id) {
|
|
116
|
-
return {
|
|
117
|
-
error: 'Something went wrong'
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
const payload = {
|
|
122
|
-
...chat,
|
|
123
|
-
sharePath: `/share/${chat.id}`
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
await kv.hmset(`chat:${chat.id}`, payload)
|
|
127
|
-
|
|
128
|
-
return payload
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
export async function saveChat(chat: Chat) {
|
|
132
|
-
const session = await auth()
|
|
133
|
-
|
|
134
|
-
if (session && session.user) {
|
|
135
|
-
const pipeline = kv.pipeline()
|
|
136
|
-
pipeline.hmset(`chat:${chat.id}`, chat)
|
|
137
|
-
pipeline.zadd(`user:chat:${chat.userId}`, {
|
|
138
|
-
score: Date.now(),
|
|
139
|
-
member: `chat:${chat.id}`
|
|
140
|
-
})
|
|
141
|
-
await pipeline.exec()
|
|
142
|
-
} else {
|
|
143
|
-
return
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
export async function refreshHistory(path: string) {
|
|
148
|
-
redirect(path)
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
export async function getMissingKeys() {
|
|
152
|
-
const keysRequired = ['OPENAI_API_KEY']
|
|
153
|
-
return keysRequired
|
|
154
|
-
.map(key => (process.env[key] ? '' : key))
|
|
155
|
-
.filter(key => key !== '')
|
|
156
|
-
}
|
package/example/app/globals.css
DELETED
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
@tailwind base;
|
|
2
|
-
@tailwind components;
|
|
3
|
-
@tailwind utilities;
|
|
4
|
-
|
|
5
|
-
@layer base {
|
|
6
|
-
:root {
|
|
7
|
-
--background: 0 0% 100%;
|
|
8
|
-
--foreground: 240 10% 3.9%;
|
|
9
|
-
|
|
10
|
-
--card: 0 0% 100%;
|
|
11
|
-
--card-foreground: 240 10% 3.9%;
|
|
12
|
-
|
|
13
|
-
--popover: 0 0% 100%;
|
|
14
|
-
--popover-foreground: 240 10% 3.9%;
|
|
15
|
-
|
|
16
|
-
--primary: 240 5.9% 10%;
|
|
17
|
-
--primary-foreground: 0 0% 98%;
|
|
18
|
-
|
|
19
|
-
--secondary: 240 4.8% 95.9%;
|
|
20
|
-
--secondary-foreground: 240 5.9% 10%;
|
|
21
|
-
|
|
22
|
-
--muted: 240 4.8% 95.9%;
|
|
23
|
-
--muted-foreground: 240 3.8% 46.1%;
|
|
24
|
-
|
|
25
|
-
--accent: 240 4.8% 95.9%;
|
|
26
|
-
--accent-foreground: 240 5.9% 10%;
|
|
27
|
-
|
|
28
|
-
--destructive: 0 84.2% 60.2%;
|
|
29
|
-
--destructive-foreground: 0 0% 98%;
|
|
30
|
-
|
|
31
|
-
--border: 240 5.9% 90%;
|
|
32
|
-
--input: 240 5.9% 90%;
|
|
33
|
-
--ring: 240 10% 3.9%;
|
|
34
|
-
|
|
35
|
-
--radius: 0.5rem;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
.dark {
|
|
39
|
-
--background: 240 10% 3.9%;
|
|
40
|
-
--foreground: 0 0% 98%;
|
|
41
|
-
|
|
42
|
-
--card: 240 10% 3.9%;
|
|
43
|
-
--card-foreground: 0 0% 98%;
|
|
44
|
-
|
|
45
|
-
--popover: 240 10% 3.9%;
|
|
46
|
-
--popover-foreground: 0 0% 98%;
|
|
47
|
-
|
|
48
|
-
--primary: 0 0% 98%;
|
|
49
|
-
--primary-foreground: 240 5.9% 10%;
|
|
50
|
-
|
|
51
|
-
--secondary: 240 3.7% 15.9%;
|
|
52
|
-
--secondary-foreground: 0 0% 98%;
|
|
53
|
-
|
|
54
|
-
--muted: 240 3.7% 15.9%;
|
|
55
|
-
--muted-foreground: 240 5% 64.9%;
|
|
56
|
-
|
|
57
|
-
--accent: 240 3.7% 15.9%;
|
|
58
|
-
--accent-foreground: 0 0% 98%;
|
|
59
|
-
|
|
60
|
-
--destructive: 0 62.8% 30.6%;
|
|
61
|
-
--destructive-foreground: 0 0% 98%;
|
|
62
|
-
|
|
63
|
-
--border: 240 3.7% 15.9%;
|
|
64
|
-
--input: 240 3.7% 15.9%;
|
|
65
|
-
--ring: 240 4.9% 83.9%;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
@layer base {
|
|
70
|
-
* {
|
|
71
|
-
@apply border-border;
|
|
72
|
-
}
|
|
73
|
-
body {
|
|
74
|
-
@apply bg-background text-foreground;
|
|
75
|
-
}
|
|
76
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { nanoid } from '@/lib/utils'
|
|
2
|
-
import { Chat } from '@/components/chat'
|
|
3
|
-
import { AI } from '@/lib/chat/vercel-ai'
|
|
4
|
-
import { auth } from '@/auth'
|
|
5
|
-
import { Session } from '@/lib/types'
|
|
6
|
-
import { getMissingKeys } from '@/app/actions'
|
|
7
|
-
import { Guardrails } from '../../lib/chat/guardrails'
|
|
8
|
-
|
|
9
|
-
export const metadata = {
|
|
10
|
-
title: 'Guardrails Example'
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export default async function IndexPage() {
|
|
14
|
-
const id = nanoid()
|
|
15
|
-
const session = (await auth()) as Session
|
|
16
|
-
const missingKeys = await getMissingKeys()
|
|
17
|
-
|
|
18
|
-
return (
|
|
19
|
-
<>
|
|
20
|
-
<div className="text-center w-full absolute pt-1">Guardrails Example</div>
|
|
21
|
-
<Guardrails initialAIState={{ chatId: id, messages: [] }}>
|
|
22
|
-
<Chat id={id} session={session} missingKeys={missingKeys} />
|
|
23
|
-
</Guardrails>
|
|
24
|
-
</>
|
|
25
|
-
)
|
|
26
|
-
}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { nanoid } from '@/lib/utils'
|
|
2
|
-
import { Chat } from '@/components/chat'
|
|
3
|
-
import { auth } from '@/auth'
|
|
4
|
-
import { Session } from '@/lib/types'
|
|
5
|
-
import { getMissingKeys } from '@/app/actions'
|
|
6
|
-
import { LangChainAI } from '../../lib/chat/langchain'
|
|
7
|
-
|
|
8
|
-
export const metadata = {
|
|
9
|
-
title: 'LangChain.js Example'
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export default async function IndexPage() {
|
|
13
|
-
const id = nanoid()
|
|
14
|
-
const session = (await auth()) as Session
|
|
15
|
-
const missingKeys = await getMissingKeys()
|
|
16
|
-
|
|
17
|
-
return (
|
|
18
|
-
<>
|
|
19
|
-
<div className="text-center w-full absolute pt-1">
|
|
20
|
-
LangChain.js Example
|
|
21
|
-
</div>
|
|
22
|
-
<LangChainAI initialAIState={{ chatId: id, messages: [] }}>
|
|
23
|
-
<Chat id={id} session={session} missingKeys={missingKeys} />
|
|
24
|
-
</LangChainAI>
|
|
25
|
-
</>
|
|
26
|
-
)
|
|
27
|
-
}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { nanoid } from '@/lib/utils'
|
|
2
|
-
import { Chat } from '@/components/chat'
|
|
3
|
-
import { AI } from '@/lib/chat/vercel-ai'
|
|
4
|
-
import { auth } from '@/auth'
|
|
5
|
-
import { Session } from '@/lib/types'
|
|
6
|
-
import { getMissingKeys } from '@/app/actions'
|
|
7
|
-
import { LangChainRAGAI } from '../../lib/chat/langchain-rag'
|
|
8
|
-
|
|
9
|
-
export const metadata = {
|
|
10
|
-
title: 'LangChain.js Example'
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export default async function IndexPage() {
|
|
14
|
-
const id = nanoid()
|
|
15
|
-
const session = (await auth()) as Session
|
|
16
|
-
const missingKeys = await getMissingKeys()
|
|
17
|
-
|
|
18
|
-
return (
|
|
19
|
-
<>
|
|
20
|
-
<div className="text-center w-full absolute pt-1">
|
|
21
|
-
LangChain.js RAG Example
|
|
22
|
-
</div>
|
|
23
|
-
<LangChainRAGAI initialAIState={{ chatId: id, messages: [] }}>
|
|
24
|
-
<Chat id={id} session={session} missingKeys={missingKeys} />
|
|
25
|
-
</LangChainRAGAI>
|
|
26
|
-
</>
|
|
27
|
-
)
|
|
28
|
-
}
|