From e2662a0ec54cb238d1890dbd851e0dcadebdf922 Mon Sep 17 00:00:00 2001 From: Vyacheslav Scherbinin Date: Tue, 19 Aug 2025 10:22:44 +0700 Subject: [PATCH 1/8] fix(ai): ollama ai provider api url --- packages/server/src/utils/ai/select-ai-provider.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/server/src/utils/ai/select-ai-provider.ts b/packages/server/src/utils/ai/select-ai-provider.ts index 39d7ae13c..b9de33114 100644 --- a/packages/server/src/utils/ai/select-ai-provider.ts +++ b/packages/server/src/utils/ai/select-ai-provider.ts @@ -60,7 +60,7 @@ export function selectAIProvider(config: { apiUrl: string; apiKey: string }) { case "ollama": return createOllama({ // optional settings, e.g. - baseURL: config.apiUrl, + baseURL: `${config.apiUrl}/api`, }); case "deepinfra": return createDeepInfra({ From 1e7f614bb610f1613b5e9b28f9878b9201a06bc1 Mon Sep 17 00:00:00 2001 From: Vyacheslav Scherbinin Date: Tue, 19 Aug 2025 10:24:16 +0700 Subject: [PATCH 2/8] fix(ai): ollama provider url-based detection --- packages/server/src/utils/ai/select-ai-provider.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/packages/server/src/utils/ai/select-ai-provider.ts b/packages/server/src/utils/ai/select-ai-provider.ts index b9de33114..b1a741138 100644 --- a/packages/server/src/utils/ai/select-ai-provider.ts +++ b/packages/server/src/utils/ai/select-ai-provider.ts @@ -14,8 +14,7 @@ function getProviderName(apiUrl: string) { if (apiUrl.includes("api.cohere.ai")) return "cohere"; if (apiUrl.includes("api.perplexity.ai")) return "perplexity"; if (apiUrl.includes("api.mistral.ai")) return "mistral"; - if (apiUrl.includes("localhost:11434") || apiUrl.includes("ollama")) - return "ollama"; + if (apiUrl.includes(":11434") || apiUrl.includes("ollama")) return "ollama"; if (apiUrl.includes("api.deepinfra.com")) return "deepinfra"; return "custom"; } From 72fca80047482fe427d311c84edfb1be778a1bb2 Mon Sep 17 00:00:00 2001 From: Vyacheslav Scherbinin Date: Tue, 19 Aug 2025 10:28:47 +0700 Subject: [PATCH 3/8] fix(ai-ui): disable AI key autocomplete --- apps/dokploy/components/dashboard/settings/handle-ai.tsx | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/apps/dokploy/components/dashboard/settings/handle-ai.tsx b/apps/dokploy/components/dashboard/settings/handle-ai.tsx index e1b21b48c..2c4e7847f 100644 --- a/apps/dokploy/components/dashboard/settings/handle-ai.tsx +++ b/apps/dokploy/components/dashboard/settings/handle-ai.tsx @@ -198,7 +198,12 @@ export const HandleAi = ({ aiId }: Props) => { API Key - + Your API key for authentication From 07c23292da58375cac553f83e63ccee2beb570b6 Mon Sep 17 00:00:00 2001 From: Vyacheslav Scherbinin Date: Tue, 19 Aug 2025 10:28:56 +0700 Subject: [PATCH 4/8] fix(ai): ollama fetch models --- .../dashboard/settings/handle-ai.tsx | 14 ++++++++++---- apps/dokploy/server/api/routers/ai.ts | 18 ++++++++++++++++-- packages/server/src/db/schema/ai.ts | 2 +- .../server/src/utils/ai/select-ai-provider.ts | 2 +- 4 files changed, 28 insertions(+), 8 deletions(-) diff --git a/apps/dokploy/components/dashboard/settings/handle-ai.tsx b/apps/dokploy/components/dashboard/settings/handle-ai.tsx index 2c4e7847f..a8041d71e 100644 --- a/apps/dokploy/components/dashboard/settings/handle-ai.tsx +++ b/apps/dokploy/components/dashboard/settings/handle-ai.tsx @@ -38,7 +38,7 @@ import { api } from "@/utils/api"; const Schema = z.object({ name: z.string().min(1, { message: "Name is required" }), apiUrl: z.string().url({ message: "Please enter a valid URL" }), - apiKey: z.string().min(1, { message: "API Key is required" }), + apiKey: z.string(), model: z.string().min(1, { message: "Model is required" }), isEnabled: z.boolean(), }); @@ -53,6 +53,7 @@ export const HandleAi = ({ aiId }: Props) => { const utils = api.useUtils(); const [error, setError] = useState(null); const [open, setOpen] = useState(false); + const [fetchModels, setFetchModels] = useState(false); const { data, refetch } = api.ai.one.useQuery( { aiId: aiId || "", @@ -71,7 +72,7 @@ export const HandleAi = ({ aiId }: Props) => { name: "", apiUrl: "", apiKey: "", - model: "gpt-3.5-turbo", + model: "", isEnabled: true, }, }); @@ -81,7 +82,7 @@ export const HandleAi = ({ aiId }: Props) => { name: data?.name ?? "", apiUrl: data?.apiUrl ?? "https://api.openai.com/v1", apiKey: data?.apiKey ?? "", - model: data?.model ?? "gpt-3.5-turbo", + model: data?.model ?? "", isEnabled: data?.isEnabled ?? true, }); }, [aiId, form, data]); @@ -96,12 +97,17 @@ export const HandleAi = ({ aiId }: Props) => { apiKey: apiKey ?? "", }, { - enabled: !!apiUrl && !!apiKey, + enabled: fetchModels, onError: (error) => { setError(`Failed to fetch models: ${error.message}`); }, }, ); + + useEffect(() => { + const isOllama = apiUrl.includes(":11434") || apiUrl.includes("ollama"); + setFetchModels(!!apiUrl && isOllama || !!apiKey); + }, [apiUrl, apiKey]); useEffect(() => { const apiUrl = form.watch("apiUrl"); diff --git a/apps/dokploy/server/api/routers/ai.ts b/apps/dokploy/server/api/routers/ai.ts index ed4277c1d..51b9ba95c 100644 --- a/apps/dokploy/server/api/routers/ai.ts +++ b/apps/dokploy/server/api/routers/ai.ts @@ -20,6 +20,7 @@ import { } from "@dokploy/server/services/user"; import { getProviderHeaders, + getProviderName, type Model, } from "@dokploy/server/utils/ai/select-ai-provider"; import { TRPCError } from "@trpc/server"; @@ -47,11 +48,24 @@ export const aiRouter = createTRPCRouter({ }), getModels: protectedProcedure - .input(z.object({ apiUrl: z.string().min(1), apiKey: z.string().min(1) })) + .input(z.object({ apiUrl: z.string().min(1), apiKey: z.string() })) .query(async ({ input }) => { try { + const providerName = getProviderName(input.apiUrl); const headers = getProviderHeaders(input.apiUrl, input.apiKey); - const response = await fetch(`${input.apiUrl}/models`, { headers }); + let response = null; + switch (providerName) { + case "ollama": + response = await fetch(`${input.apiUrl}/api/tags`, { headers }); + break; + default: + if (!input.apiKey) + throw new TRPCError({ + code: "BAD_REQUEST", + message: "API key must contain at least 1 character(s)", + }); + response = await fetch(`${input.apiUrl}/models`, { headers }); + } if (!response.ok) { const errorText = await response.text(); diff --git a/packages/server/src/db/schema/ai.ts b/packages/server/src/db/schema/ai.ts index 3704c3dd9..0ee5af4bd 100644 --- a/packages/server/src/db/schema/ai.ts +++ b/packages/server/src/db/schema/ai.ts @@ -32,7 +32,7 @@ export const aiRelations = relations(ai, ({ one }) => ({ const createSchema = createInsertSchema(ai, { name: z.string().min(1, { message: "Name is required" }), apiUrl: z.string().url({ message: "Please enter a valid URL" }), - apiKey: z.string().min(1, { message: "API Key is required" }), + apiKey: z.string(), model: z.string().min(1, { message: "Model is required" }), isEnabled: z.boolean().optional(), }); diff --git a/packages/server/src/utils/ai/select-ai-provider.ts b/packages/server/src/utils/ai/select-ai-provider.ts index b1a741138..4f3f28eb3 100644 --- a/packages/server/src/utils/ai/select-ai-provider.ts +++ b/packages/server/src/utils/ai/select-ai-provider.ts @@ -7,7 +7,7 @@ import { createOpenAI } from "@ai-sdk/openai"; import { createOpenAICompatible } from "@ai-sdk/openai-compatible"; import { createOllama } from "ollama-ai-provider"; -function getProviderName(apiUrl: string) { +export function getProviderName(apiUrl: string) { if (apiUrl.includes("api.openai.com")) return "openai"; if (apiUrl.includes("azure.com")) return "azure"; if (apiUrl.includes("api.anthropic.com")) return "anthropic"; From 220576fd6310d5e3a3c1f86a839766713a0f2e05 Mon Sep 17 00:00:00 2001 From: Vyacheslav Scherbinin Date: Tue, 19 Aug 2025 11:06:10 +0700 Subject: [PATCH 5/8] fix(ai-ui): empty models list text --- apps/dokploy/components/dashboard/settings/handle-ai.tsx | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/apps/dokploy/components/dashboard/settings/handle-ai.tsx b/apps/dokploy/components/dashboard/settings/handle-ai.tsx index a8041d71e..0b66cfe57 100644 --- a/apps/dokploy/components/dashboard/settings/handle-ai.tsx +++ b/apps/dokploy/components/dashboard/settings/handle-ai.tsx @@ -225,6 +225,12 @@ export const HandleAi = ({ aiId }: Props) => { )} + {!isLoadingServerModels && !models?.length && ( + + No models available + + )} + {!isLoadingServerModels && models && models.length > 0 && ( Date: Tue, 19 Aug 2025 15:44:04 +0700 Subject: [PATCH 6/8] fix(ai-ui): hide api key field for ollama --- .../dashboard/settings/handle-ai.tsx | 53 +++++++++---------- 1 file changed, 25 insertions(+), 28 deletions(-) diff --git a/apps/dokploy/components/dashboard/settings/handle-ai.tsx b/apps/dokploy/components/dashboard/settings/handle-ai.tsx index 0b66cfe57..19716e0f3 100644 --- a/apps/dokploy/components/dashboard/settings/handle-ai.tsx +++ b/apps/dokploy/components/dashboard/settings/handle-ai.tsx @@ -53,7 +53,6 @@ export const HandleAi = ({ aiId }: Props) => { const utils = api.useUtils(); const [error, setError] = useState(null); const [open, setOpen] = useState(false); - const [fetchModels, setFetchModels] = useState(false); const { data, refetch } = api.ai.one.useQuery( { aiId: aiId || "", @@ -90,6 +89,7 @@ export const HandleAi = ({ aiId }: Props) => { const apiUrl = form.watch("apiUrl"); const apiKey = form.watch("apiKey"); + const isOllama = apiUrl.includes(":11434") || apiUrl.includes("ollama"); const { data: models, isLoading: isLoadingServerModels } = api.ai.getModels.useQuery( { @@ -97,17 +97,12 @@ export const HandleAi = ({ aiId }: Props) => { apiKey: apiKey ?? "", }, { - enabled: fetchModels, + enabled: !!apiUrl && (isOllama || !!apiKey), onError: (error) => { setError(`Failed to fetch models: ${error.message}`); }, }, ); - - useEffect(() => { - const isOllama = apiUrl.includes(":11434") || apiUrl.includes("ollama"); - setFetchModels(!!apiUrl && isOllama || !!apiKey); - }, [apiUrl, apiKey]); useEffect(() => { const apiUrl = form.watch("apiUrl"); @@ -197,27 +192,29 @@ export const HandleAi = ({ aiId }: Props) => { )} /> - ( - - API Key - - - - - Your API key for authentication - - - - )} - /> + {!isOllama && ( + ( + + API Key + + + + + Your API key for authentication + + + + )} + /> + )} {isLoadingServerModels && ( From 88c8fe46146e2fdaaf98da9a538456e91c4a4bf6 Mon Sep 17 00:00:00 2001 From: Vyacheslav Scherbinin Date: Wed, 20 Aug 2025 00:30:19 +0700 Subject: [PATCH 7/8] chore: update ollama ai provider --- apps/dokploy/package.json | 4 +- packages/server/package.json | 4 +- .../server/src/utils/ai/select-ai-provider.ts | 4 +- pnpm-lock.yaml | 193 ++++++++---------- 4 files changed, 87 insertions(+), 118 deletions(-) diff --git a/apps/dokploy/package.json b/apps/dokploy/package.json index 2308efce3..0c04ef403 100644 --- a/apps/dokploy/package.json +++ b/apps/dokploy/package.json @@ -91,7 +91,8 @@ "@xterm/addon-clipboard": "0.1.0", "@xterm/xterm": "^5.5.0", "adm-zip": "^0.5.16", - "ai": "^4.3.16", + "ai": "^5.0.17", + "ai-sdk-ollama": "^0.5.1", "bcrypt": "5.1.1", "better-auth": "v1.2.8-beta.7", "bl": "6.0.11", @@ -124,7 +125,6 @@ "node-schedule": "2.1.1", "nodemailer": "6.9.14", "octokit": "3.1.2", - "ollama-ai-provider": "^1.2.0", "otpauth": "^9.4.0", "pino": "9.4.0", "pino-pretty": "11.2.2", diff --git a/packages/server/package.json b/packages/server/package.json index eeee8f831..129652d9e 100644 --- a/packages/server/package.json +++ b/packages/server/package.json @@ -44,7 +44,8 @@ "@react-email/components": "^0.0.21", "@trpc/server": "^10.45.2", "adm-zip": "^0.5.16", - "ai": "^4.3.16", + "ai": "^5.0.17", + "ai-sdk-ollama": "^0.5.1", "bcrypt": "5.1.1", "better-auth": "v1.2.8-beta.7", "bl": "6.0.11", @@ -65,7 +66,6 @@ "node-schedule": "2.1.1", "nodemailer": "6.9.14", "octokit": "3.1.2", - "ollama-ai-provider": "^1.2.0", "otpauth": "^9.4.0", "pino": "9.4.0", "pino-pretty": "11.2.2", diff --git a/packages/server/src/utils/ai/select-ai-provider.ts b/packages/server/src/utils/ai/select-ai-provider.ts index 4f3f28eb3..c0715030b 100644 --- a/packages/server/src/utils/ai/select-ai-provider.ts +++ b/packages/server/src/utils/ai/select-ai-provider.ts @@ -5,7 +5,7 @@ import { createDeepInfra } from "@ai-sdk/deepinfra"; import { createMistral } from "@ai-sdk/mistral"; import { createOpenAI } from "@ai-sdk/openai"; import { createOpenAICompatible } from "@ai-sdk/openai-compatible"; -import { createOllama } from "ollama-ai-provider"; +import { createOllama } from "ai-sdk-ollama"; export function getProviderName(apiUrl: string) { if (apiUrl.includes("api.openai.com")) return "openai"; @@ -59,7 +59,7 @@ export function selectAIProvider(config: { apiUrl: string; apiKey: string }) { case "ollama": return createOllama({ // optional settings, e.g. - baseURL: `${config.apiUrl}/api`, + baseURL: config.apiUrl, }); case "deepinfra": return createDeepInfra({ diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index db93bb4da..5c803d02a 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -263,8 +263,11 @@ importers: specifier: ^0.5.16 version: 0.5.16 ai: - specifier: ^4.3.16 - version: 4.3.16(react@18.2.0)(zod@3.25.32) + specifier: ^5.0.17 + version: 5.0.17(zod@3.25.32) + ai-sdk-ollama: + specifier: ^0.5.1 + version: 0.5.1(zod@3.25.32) bcrypt: specifier: 5.1.1 version: 5.1.1 @@ -361,9 +364,6 @@ importers: octokit: specifier: 3.1.2 version: 3.1.2 - ollama-ai-provider: - specifier: ^1.2.0 - version: 1.2.0(zod@3.25.32) otpauth: specifier: ^9.4.0 version: 9.4.0 @@ -643,8 +643,11 @@ importers: specifier: ^0.5.16 version: 0.5.16 ai: - specifier: ^4.3.16 - version: 4.3.16(react@18.2.0)(zod@3.25.32) + specifier: ^5.0.17 + version: 5.0.17(zod@3.25.32) + ai-sdk-ollama: + specifier: ^0.5.1 + version: 0.5.1(zod@3.25.32) bcrypt: specifier: 5.1.1 version: 5.1.1 @@ -705,9 +708,6 @@ importers: octokit: specifier: 3.1.2 version: 3.1.2 - ollama-ai-provider: - specifier: ^1.2.0 - version: 1.2.0(zod@3.25.32) otpauth: specifier: ^9.4.0 version: 9.4.0 @@ -847,6 +847,12 @@ packages: peerDependencies: zod: ^3.0.0 + '@ai-sdk/gateway@1.0.8': + resolution: {integrity: sha512-yiHYz0bAHEvhL+fSUBI2dNmyj0LOI8zw5qrYpa4gp1ojPgZq/7T1WXoIWRmVdjQwvT4PzSmRKLtbMPfz+umgfw==} + engines: {node: '>=18'} + peerDependencies: + zod: ^3.25.76 || ^4 + '@ai-sdk/mistral@1.2.8': resolution: {integrity: sha512-lv857D9UJqCVxiq2Fcu7mSPTypEHBUqLl1K+lCaP6X/7QAkcaxI36QDONG+tOhGHJOXTsS114u8lrUTaEiGXbg==} engines: {node: '>=18'} @@ -880,6 +886,12 @@ packages: peerDependencies: zod: ^3.23.8 + '@ai-sdk/provider-utils@3.0.4': + resolution: {integrity: sha512-/3Z6lfUp8r+ewFd9yzHkCmPlMOJUXup2Sx3aoUyrdXLhOmAfHRl6Z4lDbIdV0uvw/QYoBcVLJnvXN7ncYeS3uQ==} + engines: {node: '>=18'} + peerDependencies: + zod: ^3.25.76 || ^4 + '@ai-sdk/provider@1.0.3': resolution: {integrity: sha512-WiuJEpHTrltOIzv3x2wx4gwksAHW0h6nK3SoDzjqCOJLu/2OJ1yASESTIX+f07ChFykHElVoP80Ol/fe9dw6tQ==} engines: {node: '>=18'} @@ -888,21 +900,9 @@ packages: resolution: {integrity: sha512-qZMxYJ0qqX/RfnuIaab+zp8UAeJn/ygXXAffR5I4N0n1IrvA6qBsjc8hXLmBiMV2zoXlifkacF7sEFnYnjBcqg==} engines: {node: '>=18'} - '@ai-sdk/react@1.2.12': - resolution: {integrity: sha512-jK1IZZ22evPZoQW3vlkZ7wvjYGYF+tRBKXtrcolduIkQ/m/sOAVcVeVDUDvh1T91xCnWCdUGCPZg2avZ90mv3g==} + '@ai-sdk/provider@2.0.0': + resolution: {integrity: sha512-6o7Y2SeO9vFKB8lArHXehNuusnpddKPk7xqL7T2/b+OvXMRIXUO1rR4wcv1hAFUAT9avGZshty3Wlua/XA7TvA==} engines: {node: '>=18'} - peerDependencies: - react: ^18 || ^19 || ^19.0.0-rc - zod: ^3.23.8 - peerDependenciesMeta: - zod: - optional: true - - '@ai-sdk/ui-utils@1.2.11': - resolution: {integrity: sha512-3zcwCc8ezzFlwp3ZD15wAPjf2Au4s3vAbKsXQVyhxODHcmu0iyPO2Eua6D/vicq/AUm/BAo60r97O6HU+EI0+w==} - engines: {node: '>=18'} - peerDependencies: - zod: ^3.23.8 '@alloc/quick-lru@5.2.0': resolution: {integrity: sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw==} @@ -3716,6 +3716,9 @@ packages: resolution: {integrity: sha512-TV7t8GKYaJWsn00tFDqBw8+Uqmr8A0fRU1tvTQhyZzGv0sJCGRQL3JGMI3ucuKo3XIZdUP+Lx7/gh2t3lewy7g==} engines: {node: '>=14.16'} + '@standard-schema/spec@1.0.0': + resolution: {integrity: sha512-m2bOd0f2RT9k8QJx1JN85cZYyH1RqFBdlwtkSlf4tBDYLCiiZnv1fIIwacK6cqwXavOydf0NPToMQgpKq+dVlA==} + '@stepperize/react@4.0.1': resolution: {integrity: sha512-LAOcfi3d2mM/Jn740Xy35qsuTwmoLIuitvWZTZRURYeGsc7a6sIKAkk3+L1joZGkLFvf5q4I6V7LxWWfB5hDvg==} peerDependencies: @@ -3958,9 +3961,6 @@ packages: '@types/debug@4.1.12': resolution: {integrity: sha512-vIChWdVG3LG1SMxEvI/AK+FWJthlrqlTu7fbrlywTkkaONwk/UAGaULXRlf8vkzFBLVm0zkMdCquhL5aOjhXPQ==} - '@types/diff-match-patch@1.0.36': - resolution: {integrity: sha512-xFdR6tkm0MWvBfO8xXCSsinYxHcqkQUlcHeSpMC2ukzOb6lwQAfDmW+Qt0AvlGd8HpsS28qKsB+oPeJn9I39jg==} - '@types/docker-modem@3.0.6': resolution: {integrity: sha512-yKpAGEuKRSS8wwx0joknWxsmLha78wNMe9R2S3UNsVOkZded8UqOrV8KoeDXoXsjndxwyF3eIhyClGbO1SEhEg==} @@ -4201,15 +4201,15 @@ packages: resolution: {integrity: sha512-0poP0T7el6Vq3rstR8Mn4V/IQrpBLO6POkUSrN7RhyY+GF/InCFShQzsQ39T25gkHhLgSLByyAz+Kjb+c2L98w==} engines: {node: '>=12'} - ai@4.3.16: - resolution: {integrity: sha512-KUDwlThJ5tr2Vw0A1ZkbDKNME3wzWhuVfAOwIvFUzl1TPVDFAXDFTXio3p+jaKneB+dKNCvFFlolYmmgHttG1g==} + ai-sdk-ollama@0.5.1: + resolution: {integrity: sha512-VPE2yagxtowepiPROaP/7YUpiZxqZO4SDHHM2Tdw0wyatPCggct142eQI34UO2/PPJ1iXKpraWI5+n0/pcz69Q==} + engines: {node: '>=22'} + + ai@5.0.17: + resolution: {integrity: sha512-DLZikqZZJdwSkRhFikw6Mt7pUmPZ7Ue38TjdOcw2U6iZtBbuiyWGIhHyJXlUpLcZrtBE5yqPTozyZri1lRjduw==} engines: {node: '>=18'} peerDependencies: - react: ^18 || ^19 || ^19.0.0-rc - zod: ^3.23.8 - peerDependenciesMeta: - react: - optional: true + zod: ^3.25.76 || ^4 ajv@8.17.1: resolution: {integrity: sha512-B/gBuNg5SiMTrPkC+A2+cW0RszwxYmn6VYxB/inlBStS5nx6xHIt/ehKRhIMhqusl7a8LjQoZnjCs5vhwxOQ1g==} @@ -4846,9 +4846,6 @@ packages: didyoumean@1.2.2: resolution: {integrity: sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw==} - diff-match-patch@1.0.5: - resolution: {integrity: sha512-IayShXAgj/QMXgB0IWmKx+rOPuGMhqm5w6jvFxmVenXKIzRqTAAsbBPT3kWQeGANj3jGgvcvv4yK6SxqYmikgw==} - diff-sequences@29.6.3: resolution: {integrity: sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==} engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} @@ -5139,6 +5136,10 @@ packages: resolution: {integrity: sha512-6RxOBZ/cYgd8usLwsEl+EC09Au/9BcmCKYF2/xbml6DNczf7nv0MQb+7BA2F+li6//I+28VNlQR37XfQtcAJuA==} engines: {node: '>=18.0.0'} + eventsource-parser@3.0.5: + resolution: {integrity: sha512-bSRG85ZrMdmWtm7qkF9He9TNRzc/Bm99gEJMaQoHJ9E6Kv9QBbsldh2oMj7iXmYNEAVvNgvv5vPorG6W+XtBhQ==} + engines: {node: '>=20.0.0'} + execa@8.0.1: resolution: {integrity: sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==} engines: {node: '>=16.17'} @@ -5730,11 +5731,6 @@ packages: json-stringify-safe@5.0.1: resolution: {integrity: sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA==} - jsondiffpatch@0.6.0: - resolution: {integrity: sha512-3QItJOXp2AP1uv7waBkao5nCvhEv+QmJAd38Ybq7wNI74Q+BBmnLn4EDKz6yI9xGAIQoUF87qHt+kc1IVxB4zQ==} - engines: {node: ^18.0.0 || >=20.0.0} - hasBin: true - jsonparse@1.3.1: resolution: {integrity: sha512-POQXvpdL69+CluYsillJ7SUhKvytYjW9vG/GKpnf+xP8UWgYEM/RaMzHHofbALDiKbbP1W8UEYmgGl39WkPZsg==} engines: {'0': node >= 0.2.0} @@ -6395,14 +6391,8 @@ packages: resolution: {integrity: sha512-MG5qmrTL5y8KYwFgE1A4JWmgfQBaIETE/lOlfwNYx1QOtCQHGVxkRJmdUJltFc1HVn73d61TlMhMyNTOtMl+ng==} engines: {node: '>= 18'} - ollama-ai-provider@1.2.0: - resolution: {integrity: sha512-jTNFruwe3O/ruJeppI/quoOUxG7NA6blG3ZyQj3lei4+NnJo7bi3eIRWqlVpRlu/mbzbFXeJSBuYQWF6pzGKww==} - engines: {node: '>=18'} - peerDependencies: - zod: ^3.0.0 - peerDependenciesMeta: - zod: - optional: true + ollama@0.5.17: + resolution: {integrity: sha512-q5LmPtk6GLFouS+3aURIVl+qcAOPC4+Msmx7uBb3pd+fxI55WnGjmLZ0yijI/CYy79x0QPGx3BwC3u5zv9fBvQ==} on-exit-leak-free@2.1.2: resolution: {integrity: sha512-0eJJY6hXLGf1udHwfNftBqH+g73EU4B504nZeKpz1sYRKafAghwxEJunB2O7rDZkL4PGfsMVnTXZ2EjibbqcsA==} @@ -6485,9 +6475,6 @@ packages: resolution: {integrity: sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==} engines: {node: '>= 0.8'} - partial-json@0.1.7: - resolution: {integrity: sha512-Njv/59hHaokb/hRUjce3Hdv12wd60MtM9Z5Olmn+nehe0QDAsRtRbJPvJ0Z91TusF0SuZRIvnM+S4l6EIP8leA==} - path-exists@4.0.0: resolution: {integrity: sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==} engines: {node: '>=8'} @@ -7349,11 +7336,6 @@ packages: react: '>=16.8.0 <19' react-dom: '>=16.8.0 <19' - swr@2.3.3: - resolution: {integrity: sha512-dshNvs3ExOqtZ6kJBaAsabhPdHyeY4P2cKwRCniDVifBMoG/SVI7tfLWqPXriVspf2Rg4tPzXJTnwaihIeFw2A==} - peerDependencies: - react: ^16.11.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 - symbol-observable@1.2.0: resolution: {integrity: sha512-e900nM8RRtGhlV36KGEU9k65K3mPb1WV70OdjfxlG2EAuM1noi/E/BaW/uMhL7bPEssK8QV57vN3esixjUvcXQ==} engines: {node: '>=0.10.0'} @@ -7414,10 +7396,6 @@ packages: thread-stream@3.1.0: resolution: {integrity: sha512-OqyPZ9u96VohAyMfJykzmivOrY2wfMSf3C5TtFJVgN+Hm6aj+voFhlK+kZEIv2FBh1X6Xp3DlnCOfEQ3B2J86A==} - throttleit@2.1.0: - resolution: {integrity: sha512-nt6AMGKW1p/70DF/hGBdJB57B8Tspmbp5gfJ8ilhLnt7kkr2ye7hzD6NVG8GGErk2HWF34igrL2CXmNIkzKqKw==} - engines: {node: '>=18'} - through@2.3.8: resolution: {integrity: sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==} @@ -7735,6 +7713,9 @@ packages: webidl-conversions@3.0.1: resolution: {integrity: sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==} + whatwg-fetch@3.6.20: + resolution: {integrity: sha512-EqhiFU6daOA8kpjOWTL0olhVOF3i7OrFzSYiGsEMB8GcXS+RrzauAERX65xMeNWVqxA6HXH2m69Z9LaKKdisfg==} + whatwg-url@5.0.0: resolution: {integrity: sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==} @@ -7899,6 +7880,12 @@ snapshots: '@ai-sdk/provider-utils': 2.0.5(zod@3.25.32) zod: 3.25.32 + '@ai-sdk/gateway@1.0.8(zod@3.25.32)': + dependencies: + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) + zod: 3.25.32 + '@ai-sdk/mistral@1.2.8(zod@3.25.32)': dependencies: '@ai-sdk/provider': 1.1.3 @@ -7933,6 +7920,14 @@ snapshots: secure-json-parse: 2.7.0 zod: 3.25.32 + '@ai-sdk/provider-utils@3.0.4(zod@3.25.32)': + dependencies: + '@ai-sdk/provider': 2.0.0 + '@standard-schema/spec': 1.0.0 + eventsource-parser: 3.0.5 + zod: 3.25.32 + zod-to-json-schema: 3.24.5(zod@3.25.32) + '@ai-sdk/provider@1.0.3': dependencies: json-schema: 0.4.0 @@ -7941,22 +7936,9 @@ snapshots: dependencies: json-schema: 0.4.0 - '@ai-sdk/react@1.2.12(react@18.2.0)(zod@3.25.32)': + '@ai-sdk/provider@2.0.0': dependencies: - '@ai-sdk/provider-utils': 2.2.8(zod@3.25.32) - '@ai-sdk/ui-utils': 1.2.11(zod@3.25.32) - react: 18.2.0 - swr: 2.3.3(react@18.2.0) - throttleit: 2.1.0 - optionalDependencies: - zod: 3.25.32 - - '@ai-sdk/ui-utils@1.2.11(zod@3.25.32)': - dependencies: - '@ai-sdk/provider': 1.1.3 - '@ai-sdk/provider-utils': 2.2.8(zod@3.25.32) - zod: 3.25.32 - zod-to-json-schema: 3.24.5(zod@3.25.32) + json-schema: 0.4.0 '@alloc/quick-lru@5.2.0': {} @@ -10767,6 +10749,8 @@ snapshots: '@sindresorhus/is@5.6.0': {} + '@standard-schema/spec@1.0.0': {} + '@stepperize/react@4.0.1(react-dom@18.2.0(react@18.2.0))(react@18.2.0)': dependencies: react: 18.2.0 @@ -11257,8 +11241,6 @@ snapshots: dependencies: '@types/ms': 2.1.0 - '@types/diff-match-patch@1.0.36': {} - '@types/docker-modem@3.0.6': dependencies: '@types/node': 20.17.51 @@ -11347,7 +11329,7 @@ snapshots: '@types/pg@8.6.1': dependencies: - '@types/node': 20.17.51 + '@types/node': 18.19.104 pg-protocol: 1.10.3 pg-types: 2.2.0 @@ -11534,17 +11516,22 @@ snapshots: clean-stack: 4.2.0 indent-string: 5.0.0 - ai@4.3.16(react@18.2.0)(zod@3.25.32): + ai-sdk-ollama@0.5.1(zod@3.25.32): dependencies: - '@ai-sdk/provider': 1.1.3 - '@ai-sdk/provider-utils': 2.2.8(zod@3.25.32) - '@ai-sdk/react': 1.2.12(react@18.2.0)(zod@3.25.32) - '@ai-sdk/ui-utils': 1.2.11(zod@3.25.32) + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) + ai: 5.0.17(zod@3.25.32) + ollama: 0.5.17 + transitivePeerDependencies: + - zod + + ai@5.0.17(zod@3.25.32): + dependencies: + '@ai-sdk/gateway': 1.0.8(zod@3.25.32) + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) '@opentelemetry/api': 1.9.0 - jsondiffpatch: 0.6.0 zod: 3.25.32 - optionalDependencies: - react: 18.2.0 ajv@8.17.1: dependencies: @@ -12181,8 +12168,6 @@ snapshots: didyoumean@1.2.2: {} - diff-match-patch@1.0.5: {} - diff-sequences@29.6.3: {} dijkstrajs@1.0.3: {} @@ -12471,6 +12456,8 @@ snapshots: eventsource-parser@3.0.2: {} + eventsource-parser@3.0.5: {} + execa@8.0.1: dependencies: cross-spawn: 7.0.6 @@ -13088,12 +13075,6 @@ snapshots: json-stringify-safe@5.0.1: {} - jsondiffpatch@0.6.0: - dependencies: - '@types/diff-match-patch': 1.0.36 - chalk: 5.4.1 - diff-match-patch: 1.0.5 - jsonparse@1.3.1: {} jsonwebtoken@9.0.2: @@ -13895,13 +13876,9 @@ snapshots: '@octokit/request-error': 5.1.1 '@octokit/types': 12.6.0 - ollama-ai-provider@1.2.0(zod@3.25.32): + ollama@0.5.17: dependencies: - '@ai-sdk/provider': 1.1.3 - '@ai-sdk/provider-utils': 2.2.8(zod@3.25.32) - partial-json: 0.1.7 - optionalDependencies: - zod: 3.25.32 + whatwg-fetch: 3.6.20 on-exit-leak-free@2.1.2: {} @@ -13994,8 +13971,6 @@ snapshots: parseurl@1.3.3: {} - partial-json@0.1.7: {} - path-exists@4.0.0: {} path-exists@5.0.0: {} @@ -14957,12 +14932,6 @@ snapshots: - '@types/react' - debug - swr@2.3.3(react@18.2.0): - dependencies: - dequal: 2.0.3 - react: 18.2.0 - use-sync-external-store: 1.5.0(react@18.2.0) - symbol-observable@1.2.0: {} tailwind-merge@2.6.0: {} @@ -15054,8 +15023,6 @@ snapshots: dependencies: real-require: 0.2.0 - throttleit@2.1.0: {} - through@2.3.8: {} tiny-invariant@1.3.3: {} @@ -15359,6 +15326,8 @@ snapshots: webidl-conversions@3.0.1: {} + whatwg-fetch@3.6.20: {} + whatwg-url@5.0.0: dependencies: tr46: 0.0.3 From 6612c92b4f2f097d4602cdf900fef7a390bf4b5a Mon Sep 17 00:00:00 2001 From: Vyacheslav Scherbinin Date: Wed, 20 Aug 2025 13:16:04 +0700 Subject: [PATCH 8/8] chore: update ai providers --- apps/dokploy/package.json | 14 +-- packages/server/package.json | 14 +-- pnpm-lock.yaml | 197 +++++++++++++---------------------- 3 files changed, 86 insertions(+), 139 deletions(-) diff --git a/apps/dokploy/package.json b/apps/dokploy/package.json index 0c04ef403..1b2ee613a 100644 --- a/apps/dokploy/package.json +++ b/apps/dokploy/package.json @@ -37,13 +37,13 @@ "test": "vitest --config __test__/vitest.config.ts" }, "dependencies": { - "@ai-sdk/anthropic": "^1.2.12", - "@ai-sdk/azure": "^1.3.23", - "@ai-sdk/cohere": "^1.2.10", - "@ai-sdk/deepinfra": "^0.0.4", - "@ai-sdk/mistral": "^1.2.8", - "@ai-sdk/openai": "^1.3.22", - "@ai-sdk/openai-compatible": "^0.0.13", + "@ai-sdk/anthropic": "^2.0.5", + "@ai-sdk/azure": "^2.0.16", + "@ai-sdk/cohere": "^2.0.4", + "@ai-sdk/deepinfra": "^1.0.10", + "@ai-sdk/mistral": "^2.0.7", + "@ai-sdk/openai": "^2.0.16", + "@ai-sdk/openai-compatible": "^1.0.10", "@codemirror/autocomplete": "^6.18.6", "@codemirror/lang-json": "^6.0.1", "@codemirror/lang-yaml": "^6.1.2", diff --git a/packages/server/package.json b/packages/server/package.json index 129652d9e..dbf7d3c65 100644 --- a/packages/server/package.json +++ b/packages/server/package.json @@ -28,13 +28,13 @@ "typecheck": "tsc --noEmit" }, "dependencies": { - "@ai-sdk/anthropic": "^1.2.12", - "@ai-sdk/azure": "^1.3.23", - "@ai-sdk/cohere": "^1.2.10", - "@ai-sdk/deepinfra": "^0.0.4", - "@ai-sdk/mistral": "^1.2.8", - "@ai-sdk/openai": "^1.3.22", - "@ai-sdk/openai-compatible": "^0.0.13", + "@ai-sdk/anthropic": "^2.0.5", + "@ai-sdk/azure": "^2.0.16", + "@ai-sdk/cohere": "^2.0.4", + "@ai-sdk/deepinfra": "^1.0.10", + "@ai-sdk/mistral": "^2.0.7", + "@ai-sdk/openai": "^2.0.16", + "@ai-sdk/openai-compatible": "^1.0.10", "@better-auth/utils": "0.2.4", "@faker-js/faker": "^8.4.1", "@octokit/auth-app": "^6.1.3", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 5c803d02a..94dedb322 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -101,26 +101,26 @@ importers: apps/dokploy: dependencies: '@ai-sdk/anthropic': - specifier: ^1.2.12 - version: 1.2.12(zod@3.25.32) + specifier: ^2.0.5 + version: 2.0.5(zod@3.25.32) '@ai-sdk/azure': - specifier: ^1.3.23 - version: 1.3.23(zod@3.25.32) + specifier: ^2.0.16 + version: 2.0.16(zod@3.25.32) '@ai-sdk/cohere': - specifier: ^1.2.10 - version: 1.2.10(zod@3.25.32) + specifier: ^2.0.4 + version: 2.0.4(zod@3.25.32) '@ai-sdk/deepinfra': - specifier: ^0.0.4 - version: 0.0.4(zod@3.25.32) + specifier: ^1.0.10 + version: 1.0.10(zod@3.25.32) '@ai-sdk/mistral': - specifier: ^1.2.8 - version: 1.2.8(zod@3.25.32) + specifier: ^2.0.7 + version: 2.0.7(zod@3.25.32) '@ai-sdk/openai': - specifier: ^1.3.22 - version: 1.3.22(zod@3.25.32) + specifier: ^2.0.16 + version: 2.0.16(zod@3.25.32) '@ai-sdk/openai-compatible': - specifier: ^0.0.13 - version: 0.0.13(zod@3.25.32) + specifier: ^1.0.10 + version: 1.0.10(zod@3.25.32) '@codemirror/autocomplete': specifier: ^6.18.6 version: 6.18.6 @@ -595,26 +595,26 @@ importers: packages/server: dependencies: '@ai-sdk/anthropic': - specifier: ^1.2.12 - version: 1.2.12(zod@3.25.32) + specifier: ^2.0.5 + version: 2.0.5(zod@3.25.32) '@ai-sdk/azure': - specifier: ^1.3.23 - version: 1.3.23(zod@3.25.32) + specifier: ^2.0.16 + version: 2.0.16(zod@3.25.32) '@ai-sdk/cohere': - specifier: ^1.2.10 - version: 1.2.10(zod@3.25.32) + specifier: ^2.0.4 + version: 2.0.4(zod@3.25.32) '@ai-sdk/deepinfra': - specifier: ^0.0.4 - version: 0.0.4(zod@3.25.32) + specifier: ^1.0.10 + version: 1.0.10(zod@3.25.32) '@ai-sdk/mistral': - specifier: ^1.2.8 - version: 1.2.8(zod@3.25.32) + specifier: ^2.0.7 + version: 2.0.7(zod@3.25.32) '@ai-sdk/openai': - specifier: ^1.3.22 - version: 1.3.22(zod@3.25.32) + specifier: ^2.0.16 + version: 2.0.16(zod@3.25.32) '@ai-sdk/openai-compatible': - specifier: ^0.0.13 - version: 0.0.13(zod@3.25.32) + specifier: ^1.0.10 + version: 1.0.10(zod@3.25.32) '@better-auth/utils': specifier: 0.2.4 version: 0.2.4 @@ -823,29 +823,29 @@ importers: packages: - '@ai-sdk/anthropic@1.2.12': - resolution: {integrity: sha512-YSzjlko7JvuiyQFmI9RN1tNZdEiZxc+6xld/0tq/VkJaHpEzGAb1yiNxxvmYVcjvfu/PcvCxAAYXmTYQQ63IHQ==} + '@ai-sdk/anthropic@2.0.5': + resolution: {integrity: sha512-f0+mD3c5D+ImCWqxFxkT3buGeBg9vFOd2aTaLd1jjIJmWO8O4INLxBC2ETif7z0BfegTIw528B6acBRIeg3jIw==} engines: {node: '>=18'} peerDependencies: - zod: ^3.0.0 + zod: ^3.25.76 || ^4 - '@ai-sdk/azure@1.3.23': - resolution: {integrity: sha512-vpsaPtU24RBVk/IMM5UylR/N4RtAuL2NZLWc7LJ3tvMTHu6pI46a7w+1qIwR3F6yO9ehWR8qvfLaBefJNFxaVw==} + '@ai-sdk/azure@2.0.16': + resolution: {integrity: sha512-Q8Fq7aJP9tJOCNicfEUDxU763NkX646zCePayy2Nse+5Gz6ElQEJ9MApIdC4LAyR/IsEuY8G5iY477GAF+iBjg==} engines: {node: '>=18'} peerDependencies: - zod: ^3.0.0 + zod: ^3.25.76 || ^4 - '@ai-sdk/cohere@1.2.10': - resolution: {integrity: sha512-OaUwd5xj4bxSO8hdCbX1a5uUlTouU8FcodSuRON6xDSsmjZIvQL4O2G1XzcidxiQVL8JQuA+M0tHZOwGxSL96A==} + '@ai-sdk/cohere@2.0.4': + resolution: {integrity: sha512-GkQsTmhDNVDv8OiwWEGBhkjWYXFzBSbRtmyaM5y4yr9h6rqNwRiwueJG89/aX4mqpGf431mnJCPYxD+eSV6vgQ==} engines: {node: '>=18'} peerDependencies: - zod: ^3.0.0 + zod: ^3.25.76 || ^4 - '@ai-sdk/deepinfra@0.0.4': - resolution: {integrity: sha512-0YZpe7bFWpSZpk2swBhYsKyd2DjxyMa0bJTajJjwec4UGUpuiDyhjXkBgEHY85JjlTubEPby8Ix+FgU0E3ofnw==} + '@ai-sdk/deepinfra@1.0.10': + resolution: {integrity: sha512-bAvg29LkPI04o9ehRyqwjkKAUlX6W8AXlBTzX/k/gMez9qBbiW6uDpRRXTNYbaEuMONrEHgOQLh2OQ5WYJLDPg==} engines: {node: '>=18'} peerDependencies: - zod: ^3.0.0 + zod: ^3.25.76 || ^4 '@ai-sdk/gateway@1.0.8': resolution: {integrity: sha512-yiHYz0bAHEvhL+fSUBI2dNmyj0LOI8zw5qrYpa4gp1ojPgZq/7T1WXoIWRmVdjQwvT4PzSmRKLtbMPfz+umgfw==} @@ -853,38 +853,23 @@ packages: peerDependencies: zod: ^3.25.76 || ^4 - '@ai-sdk/mistral@1.2.8': - resolution: {integrity: sha512-lv857D9UJqCVxiq2Fcu7mSPTypEHBUqLl1K+lCaP6X/7QAkcaxI36QDONG+tOhGHJOXTsS114u8lrUTaEiGXbg==} + '@ai-sdk/mistral@2.0.7': + resolution: {integrity: sha512-wWBacWHZHx+WxwjSqb5iIdtK76tmBiEb35ZBLmjODFEdh/dMIaj+g/qMVFT9PY7hHxZ1sT9C58KS671l8nAISw==} engines: {node: '>=18'} peerDependencies: - zod: ^3.0.0 + zod: ^3.25.76 || ^4 - '@ai-sdk/openai-compatible@0.0.13': - resolution: {integrity: sha512-fuauXYKac6PBuf8m52tWcWQW0UCScEkwTaOyr00TcPeK3dd8nPP+ZJzSYE5QhFg7rwi9EH3ahIFqSX1biXhdkQ==} + '@ai-sdk/openai-compatible@1.0.10': + resolution: {integrity: sha512-NInkII/DOvrMvO/mS0BxGUGi3r+wuXxbdzAh9k2gFGT+xVoP6OePikhogQu8qZuti8loUZJGYq3GJ/DCftOzhQ==} engines: {node: '>=18'} peerDependencies: - zod: ^3.0.0 + zod: ^3.25.76 || ^4 - '@ai-sdk/openai@1.3.22': - resolution: {integrity: sha512-QwA+2EkG0QyjVR+7h6FE7iOu2ivNqAVMm9UJZkVxxTk5OIq5fFJDTEI/zICEMuHImTTXR2JjsL6EirJ28Jc4cw==} + '@ai-sdk/openai@2.0.16': + resolution: {integrity: sha512-Boe715q4SkSJedFfAtbP0yuo8DmF9iYElAaDH2g4YgqJqqkskIJJx4hlCYGMMk1eMesRrB2NqZvtOeyTZ/u4fA==} engines: {node: '>=18'} peerDependencies: - zod: ^3.0.0 - - '@ai-sdk/provider-utils@2.0.5': - resolution: {integrity: sha512-2M7vLhYN0ThGjNlzow7oO/lsL+DyMxvGMIYmVQvEYaCWhDzxH5dOp78VNjJIVwHzVLMbBDigX3rJuzAs853idw==} - engines: {node: '>=18'} - peerDependencies: - zod: ^3.0.0 - peerDependenciesMeta: - zod: - optional: true - - '@ai-sdk/provider-utils@2.2.8': - resolution: {integrity: sha512-fqhG+4sCVv8x7nFzYnFo19ryhAa3w096Kmc3hWxMQfW/TubPOmt3A6tYZhl4mUfQWWQMsuSkLrtjlWuXBVSGQA==} - engines: {node: '>=18'} - peerDependencies: - zod: ^3.23.8 + zod: ^3.25.76 || ^4 '@ai-sdk/provider-utils@3.0.4': resolution: {integrity: sha512-/3Z6lfUp8r+ewFd9yzHkCmPlMOJUXup2Sx3aoUyrdXLhOmAfHRl6Z4lDbIdV0uvw/QYoBcVLJnvXN7ncYeS3uQ==} @@ -892,14 +877,6 @@ packages: peerDependencies: zod: ^3.25.76 || ^4 - '@ai-sdk/provider@1.0.3': - resolution: {integrity: sha512-WiuJEpHTrltOIzv3x2wx4gwksAHW0h6nK3SoDzjqCOJLu/2OJ1yASESTIX+f07ChFykHElVoP80Ol/fe9dw6tQ==} - engines: {node: '>=18'} - - '@ai-sdk/provider@1.1.3': - resolution: {integrity: sha512-qZMxYJ0qqX/RfnuIaab+zp8UAeJn/ygXXAffR5I4N0n1IrvA6qBsjc8hXLmBiMV2zoXlifkacF7sEFnYnjBcqg==} - engines: {node: '>=18'} - '@ai-sdk/provider@2.0.0': resolution: {integrity: sha512-6o7Y2SeO9vFKB8lArHXehNuusnpddKPk7xqL7T2/b+OvXMRIXUO1rR4wcv1hAFUAT9avGZshty3Wlua/XA7TvA==} engines: {node: '>=18'} @@ -5132,10 +5109,6 @@ packages: resolution: {integrity: sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==} engines: {node: '>=0.8.x'} - eventsource-parser@3.0.2: - resolution: {integrity: sha512-6RxOBZ/cYgd8usLwsEl+EC09Au/9BcmCKYF2/xbml6DNczf7nv0MQb+7BA2F+li6//I+28VNlQR37XfQtcAJuA==} - engines: {node: '>=18.0.0'} - eventsource-parser@3.0.5: resolution: {integrity: sha512-bSRG85ZrMdmWtm7qkF9He9TNRzc/Bm99gEJMaQoHJ9E6Kv9QBbsldh2oMj7iXmYNEAVvNgvv5vPorG6W+XtBhQ==} engines: {node: '>=20.0.0'} @@ -7854,30 +7827,30 @@ packages: snapshots: - '@ai-sdk/anthropic@1.2.12(zod@3.25.32)': + '@ai-sdk/anthropic@2.0.5(zod@3.25.32)': dependencies: - '@ai-sdk/provider': 1.1.3 - '@ai-sdk/provider-utils': 2.2.8(zod@3.25.32) + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) zod: 3.25.32 - '@ai-sdk/azure@1.3.23(zod@3.25.32)': + '@ai-sdk/azure@2.0.16(zod@3.25.32)': dependencies: - '@ai-sdk/openai': 1.3.22(zod@3.25.32) - '@ai-sdk/provider': 1.1.3 - '@ai-sdk/provider-utils': 2.2.8(zod@3.25.32) + '@ai-sdk/openai': 2.0.16(zod@3.25.32) + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) zod: 3.25.32 - '@ai-sdk/cohere@1.2.10(zod@3.25.32)': + '@ai-sdk/cohere@2.0.4(zod@3.25.32)': dependencies: - '@ai-sdk/provider': 1.1.3 - '@ai-sdk/provider-utils': 2.2.8(zod@3.25.32) + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) zod: 3.25.32 - '@ai-sdk/deepinfra@0.0.4(zod@3.25.32)': + '@ai-sdk/deepinfra@1.0.10(zod@3.25.32)': dependencies: - '@ai-sdk/openai-compatible': 0.0.13(zod@3.25.32) - '@ai-sdk/provider': 1.0.3 - '@ai-sdk/provider-utils': 2.0.5(zod@3.25.32) + '@ai-sdk/openai-compatible': 1.0.10(zod@3.25.32) + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) zod: 3.25.32 '@ai-sdk/gateway@1.0.8(zod@3.25.32)': @@ -7886,38 +7859,22 @@ snapshots: '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) zod: 3.25.32 - '@ai-sdk/mistral@1.2.8(zod@3.25.32)': + '@ai-sdk/mistral@2.0.7(zod@3.25.32)': dependencies: - '@ai-sdk/provider': 1.1.3 - '@ai-sdk/provider-utils': 2.2.8(zod@3.25.32) + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) zod: 3.25.32 - '@ai-sdk/openai-compatible@0.0.13(zod@3.25.32)': + '@ai-sdk/openai-compatible@1.0.10(zod@3.25.32)': dependencies: - '@ai-sdk/provider': 1.0.3 - '@ai-sdk/provider-utils': 2.0.5(zod@3.25.32) + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) zod: 3.25.32 - '@ai-sdk/openai@1.3.22(zod@3.25.32)': + '@ai-sdk/openai@2.0.16(zod@3.25.32)': dependencies: - '@ai-sdk/provider': 1.1.3 - '@ai-sdk/provider-utils': 2.2.8(zod@3.25.32) - zod: 3.25.32 - - '@ai-sdk/provider-utils@2.0.5(zod@3.25.32)': - dependencies: - '@ai-sdk/provider': 1.0.3 - eventsource-parser: 3.0.2 - nanoid: 3.3.11 - secure-json-parse: 2.7.0 - optionalDependencies: - zod: 3.25.32 - - '@ai-sdk/provider-utils@2.2.8(zod@3.25.32)': - dependencies: - '@ai-sdk/provider': 1.1.3 - nanoid: 3.3.11 - secure-json-parse: 2.7.0 + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.4(zod@3.25.32) zod: 3.25.32 '@ai-sdk/provider-utils@3.0.4(zod@3.25.32)': @@ -7928,14 +7885,6 @@ snapshots: zod: 3.25.32 zod-to-json-schema: 3.24.5(zod@3.25.32) - '@ai-sdk/provider@1.0.3': - dependencies: - json-schema: 0.4.0 - - '@ai-sdk/provider@1.1.3': - dependencies: - json-schema: 0.4.0 - '@ai-sdk/provider@2.0.0': dependencies: json-schema: 0.4.0 @@ -12454,8 +12403,6 @@ snapshots: events@3.3.0: {} - eventsource-parser@3.0.2: {} - eventsource-parser@3.0.5: {} execa@8.0.1: