@ai-sdk/replicate 0.0.0-fd764a60-20260114143805

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs ADDED
@@ -0,0 +1,262 @@
1
+ // src/replicate-provider.ts
2
+ import { NoSuchModelError } from "@ai-sdk/provider";
3
+ import { loadApiKey, withUserAgentSuffix } from "@ai-sdk/provider-utils";
4
+
5
+ // src/replicate-image-model.ts
6
+ import {
7
+ combineHeaders,
8
+ convertImageModelFileToDataUri,
9
+ createBinaryResponseHandler,
10
+ createJsonResponseHandler,
11
+ getFromApi,
12
+ lazySchema,
13
+ parseProviderOptions,
14
+ postJsonToApi,
15
+ resolve,
16
+ zodSchema
17
+ } from "@ai-sdk/provider-utils";
18
+ import { z as z2 } from "zod/v4";
19
+
20
+ // src/replicate-error.ts
21
+ import { createJsonErrorResponseHandler } from "@ai-sdk/provider-utils";
22
+ import { z } from "zod/v4";
23
+ var replicateErrorSchema = z.object({
24
+ detail: z.string().optional(),
25
+ error: z.string().optional()
26
+ });
27
+ var replicateFailedResponseHandler = createJsonErrorResponseHandler({
28
+ errorSchema: replicateErrorSchema,
29
+ errorToMessage: (error) => {
30
+ var _a, _b;
31
+ return (_b = (_a = error.detail) != null ? _a : error.error) != null ? _b : "Unknown Replicate error";
32
+ }
33
+ });
34
+
35
+ // src/replicate-image-model.ts
36
+ var FLUX_2_MODEL_PATTERN = /^black-forest-labs\/flux-2-/;
37
+ var MAX_FLUX_2_INPUT_IMAGES = 8;
38
+ var ReplicateImageModel = class {
39
+ constructor(modelId, config) {
40
+ this.modelId = modelId;
41
+ this.config = config;
42
+ this.specificationVersion = "v3";
43
+ }
44
+ get maxImagesPerCall() {
45
+ return this.isFlux2Model ? MAX_FLUX_2_INPUT_IMAGES : 1;
46
+ }
47
+ get provider() {
48
+ return this.config.provider;
49
+ }
50
+ get isFlux2Model() {
51
+ return FLUX_2_MODEL_PATTERN.test(this.modelId);
52
+ }
53
+ async doGenerate({
54
+ prompt,
55
+ n,
56
+ aspectRatio,
57
+ size,
58
+ seed,
59
+ providerOptions,
60
+ headers,
61
+ abortSignal,
62
+ files,
63
+ mask
64
+ }) {
65
+ var _a, _b, _c;
66
+ const warnings = [];
67
+ const [modelId, version] = this.modelId.split(":");
68
+ const currentDate = (_c = (_b = (_a = this.config._internal) == null ? void 0 : _a.currentDate) == null ? void 0 : _b.call(_a)) != null ? _c : /* @__PURE__ */ new Date();
69
+ const replicateOptions = await parseProviderOptions({
70
+ provider: "replicate",
71
+ providerOptions,
72
+ schema: replicateImageProviderOptionsSchema
73
+ });
74
+ let imageInputs = {};
75
+ if (files != null && files.length > 0) {
76
+ if (this.isFlux2Model) {
77
+ for (let i = 0; i < Math.min(files.length, MAX_FLUX_2_INPUT_IMAGES); i++) {
78
+ const key = i === 0 ? "input_image" : `input_image_${i + 1}`;
79
+ imageInputs[key] = convertImageModelFileToDataUri(files[i]);
80
+ }
81
+ if (files.length > MAX_FLUX_2_INPUT_IMAGES) {
82
+ warnings.push({
83
+ type: "other",
84
+ message: `Flux-2 models support up to ${MAX_FLUX_2_INPUT_IMAGES} input images. Additional images are ignored.`
85
+ });
86
+ }
87
+ } else {
88
+ imageInputs = { image: convertImageModelFileToDataUri(files[0]) };
89
+ if (files.length > 1) {
90
+ warnings.push({
91
+ type: "other",
92
+ message: "This Replicate model only supports a single input image. Additional images are ignored."
93
+ });
94
+ }
95
+ }
96
+ }
97
+ let maskInput;
98
+ if (mask != null) {
99
+ if (this.isFlux2Model) {
100
+ warnings.push({
101
+ type: "other",
102
+ message: "Flux-2 models do not support mask input. The mask will be ignored."
103
+ });
104
+ } else {
105
+ maskInput = convertImageModelFileToDataUri(mask);
106
+ }
107
+ }
108
+ const { maxWaitTimeInSeconds, ...inputOptions } = replicateOptions != null ? replicateOptions : {};
109
+ const preferHeader = maxWaitTimeInSeconds != null ? { prefer: `wait=${maxWaitTimeInSeconds}` } : { prefer: "wait" };
110
+ const {
111
+ value: { output },
112
+ responseHeaders
113
+ } = await postJsonToApi({
114
+ url: (
115
+ // different endpoints for versioned vs unversioned models:
116
+ version != null ? `${this.config.baseURL}/predictions` : `${this.config.baseURL}/models/${modelId}/predictions`
117
+ ),
118
+ headers: combineHeaders(
119
+ await resolve(this.config.headers),
120
+ headers,
121
+ preferHeader
122
+ ),
123
+ body: {
124
+ input: {
125
+ prompt,
126
+ aspect_ratio: aspectRatio,
127
+ size,
128
+ seed,
129
+ num_outputs: n,
130
+ ...imageInputs,
131
+ ...maskInput != null ? { mask: maskInput } : {},
132
+ ...inputOptions
133
+ },
134
+ // for versioned models, include the version in the body:
135
+ ...version != null ? { version } : {}
136
+ },
137
+ successfulResponseHandler: createJsonResponseHandler(
138
+ replicateImageResponseSchema
139
+ ),
140
+ failedResponseHandler: replicateFailedResponseHandler,
141
+ abortSignal,
142
+ fetch: this.config.fetch
143
+ });
144
+ const outputArray = Array.isArray(output) ? output : [output];
145
+ const images = await Promise.all(
146
+ outputArray.map(async (url) => {
147
+ const { value: image } = await getFromApi({
148
+ url,
149
+ successfulResponseHandler: createBinaryResponseHandler(),
150
+ failedResponseHandler: replicateFailedResponseHandler,
151
+ abortSignal,
152
+ fetch: this.config.fetch
153
+ });
154
+ return image;
155
+ })
156
+ );
157
+ return {
158
+ images,
159
+ warnings,
160
+ response: {
161
+ timestamp: currentDate,
162
+ modelId: this.modelId,
163
+ headers: responseHeaders
164
+ }
165
+ };
166
+ }
167
+ };
168
+ var replicateImageResponseSchema = z2.object({
169
+ output: z2.union([z2.array(z2.string()), z2.string()])
170
+ });
171
+ var replicateImageProviderOptionsSchema = lazySchema(
172
+ () => zodSchema(
173
+ z2.object({
174
+ /**
175
+ * Maximum time in seconds to wait for the prediction to complete in sync mode.
176
+ * By default, Replicate uses sync mode with a 60-second timeout.
177
+ *
178
+ * - When not specified: Uses default 60-second sync wait (`prefer: wait`)
179
+ * - When set to a positive number: Uses that duration (`prefer: wait=N`)
180
+ */
181
+ maxWaitTimeInSeconds: z2.number().positive().nullish(),
182
+ /**
183
+ * Guidance scale for classifier-free guidance.
184
+ * Higher values make the output more closely match the prompt.
185
+ */
186
+ guidance_scale: z2.number().nullish(),
187
+ /**
188
+ * Number of denoising steps. More steps = higher quality but slower.
189
+ */
190
+ num_inference_steps: z2.number().nullish(),
191
+ /**
192
+ * Negative prompt to guide what to avoid in the generation.
193
+ */
194
+ negative_prompt: z2.string().nullish(),
195
+ /**
196
+ * Output image format.
197
+ */
198
+ output_format: z2.enum(["png", "jpg", "webp"]).nullish(),
199
+ /**
200
+ * Output image quality (1-100). Only applies to jpg and webp.
201
+ */
202
+ output_quality: z2.number().min(1).max(100).nullish(),
203
+ /**
204
+ * Strength of the transformation for img2img (0-1).
205
+ * Lower values keep more of the original image.
206
+ */
207
+ strength: z2.number().min(0).max(1).nullish()
208
+ }).passthrough()
209
+ )
210
+ );
211
+
212
+ // src/version.ts
213
+ var VERSION = true ? "0.0.0-fd764a60-20260114143805" : "0.0.0-test";
214
+
215
+ // src/replicate-provider.ts
216
+ function createReplicate(options = {}) {
217
+ const createImageModel = (modelId) => {
218
+ var _a;
219
+ return new ReplicateImageModel(modelId, {
220
+ provider: "replicate",
221
+ baseURL: (_a = options.baseURL) != null ? _a : "https://api.replicate.com/v1",
222
+ headers: withUserAgentSuffix(
223
+ {
224
+ Authorization: `Bearer ${loadApiKey({
225
+ apiKey: options.apiToken,
226
+ environmentVariableName: "REPLICATE_API_TOKEN",
227
+ description: "Replicate"
228
+ })}`,
229
+ ...options.headers
230
+ },
231
+ `ai-sdk/replicate/${VERSION}`
232
+ ),
233
+ fetch: options.fetch
234
+ });
235
+ };
236
+ const embeddingModel = (modelId) => {
237
+ throw new NoSuchModelError({
238
+ modelId,
239
+ modelType: "embeddingModel"
240
+ });
241
+ };
242
+ return {
243
+ specificationVersion: "v3",
244
+ image: createImageModel,
245
+ imageModel: createImageModel,
246
+ languageModel: (modelId) => {
247
+ throw new NoSuchModelError({
248
+ modelId,
249
+ modelType: "languageModel"
250
+ });
251
+ },
252
+ embeddingModel,
253
+ textEmbeddingModel: embeddingModel
254
+ };
255
+ }
256
+ var replicate = createReplicate();
257
+ export {
258
+ VERSION,
259
+ createReplicate,
260
+ replicate
261
+ };
262
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/replicate-provider.ts","../src/replicate-image-model.ts","../src/replicate-error.ts","../src/version.ts"],"sourcesContent":["import { NoSuchModelError, ProviderV3 } from '@ai-sdk/provider';\nimport type { FetchFunction } from '@ai-sdk/provider-utils';\nimport { loadApiKey, withUserAgentSuffix } from '@ai-sdk/provider-utils';\nimport { ReplicateImageModel } from './replicate-image-model';\nimport { ReplicateImageModelId } from './replicate-image-settings';\nimport { VERSION } from './version';\n\nexport interface ReplicateProviderSettings {\n /**\nAPI token that is being send using the `Authorization` header.\nIt defaults to the `REPLICATE_API_TOKEN` environment variable.\n */\n apiToken?: string;\n\n /**\nUse a different URL prefix for API calls, e.g. to use proxy servers.\nThe default prefix is `https://api.replicate.com/v1`.\n */\n baseURL?: string;\n\n /**\nCustom headers to include in the requests.\n */\n headers?: Record<string, string>;\n\n /**\nCustom fetch implementation. You can use it as a middleware to intercept requests,\nor to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n}\n\nexport interface ReplicateProvider extends ProviderV3 {\n /**\n * Creates a Replicate image generation model.\n */\n image(modelId: ReplicateImageModelId): ReplicateImageModel;\n\n /**\n * Creates a Replicate image generation model.\n */\n imageModel(modelId: ReplicateImageModelId): ReplicateImageModel;\n\n /**\n * @deprecated Use `embeddingModel` instead.\n */\n textEmbeddingModel(modelId: string): never;\n}\n\n/**\n * Create a Replicate provider instance.\n */\nexport function createReplicate(\n options: ReplicateProviderSettings = {},\n): ReplicateProvider {\n const createImageModel = (modelId: ReplicateImageModelId) =>\n new ReplicateImageModel(modelId, {\n provider: 'replicate',\n baseURL: options.baseURL ?? 'https://api.replicate.com/v1',\n headers: withUserAgentSuffix(\n {\n Authorization: `Bearer ${loadApiKey({\n apiKey: options.apiToken,\n environmentVariableName: 'REPLICATE_API_TOKEN',\n description: 'Replicate',\n })}`,\n ...options.headers,\n },\n `ai-sdk/replicate/${VERSION}`,\n ),\n fetch: options.fetch,\n });\n\n const embeddingModel = (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'embeddingModel',\n });\n };\n\n return {\n specificationVersion: 'v3' as const,\n image: createImageModel,\n imageModel: createImageModel,\n languageModel: (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'languageModel',\n });\n },\n embeddingModel,\n textEmbeddingModel: embeddingModel,\n };\n}\n\n/**\n * Default Replicate provider instance.\n */\nexport const replicate = createReplicate();\n","import type { ImageModelV3, SharedV3Warning } from '@ai-sdk/provider';\nimport type { Resolvable } from '@ai-sdk/provider-utils';\nimport {\n combineHeaders,\n convertImageModelFileToDataUri,\n createBinaryResponseHandler,\n createJsonResponseHandler,\n FetchFunction,\n getFromApi,\n InferSchema,\n lazySchema,\n parseProviderOptions,\n postJsonToApi,\n resolve,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { replicateFailedResponseHandler } from './replicate-error';\nimport { ReplicateImageModelId } from './replicate-image-settings';\n\ninterface ReplicateImageModelConfig {\n provider: string;\n baseURL: string;\n headers?: Resolvable<Record<string, string | undefined>>;\n fetch?: FetchFunction;\n _internal?: {\n currentDate?: () => Date;\n };\n}\n\n// Flux-2 models support up to 8 input images with input_image, input_image_2, etc.\nconst FLUX_2_MODEL_PATTERN = /^black-forest-labs\\/flux-2-/;\nconst MAX_FLUX_2_INPUT_IMAGES = 8;\n\nexport class ReplicateImageModel implements ImageModelV3 {\n readonly specificationVersion = 'v3';\n\n get maxImagesPerCall(): number {\n // Flux-2 models support up to 8 input images\n return this.isFlux2Model ? MAX_FLUX_2_INPUT_IMAGES : 1;\n }\n\n get provider(): string {\n return this.config.provider;\n }\n\n private get isFlux2Model(): boolean {\n return FLUX_2_MODEL_PATTERN.test(this.modelId);\n }\n\n constructor(\n readonly modelId: ReplicateImageModelId,\n private readonly config: ReplicateImageModelConfig,\n ) {}\n\n async doGenerate({\n prompt,\n n,\n aspectRatio,\n size,\n seed,\n providerOptions,\n headers,\n abortSignal,\n files,\n mask,\n }: Parameters<ImageModelV3['doGenerate']>[0]): Promise<\n Awaited<ReturnType<ImageModelV3['doGenerate']>>\n > {\n const warnings: Array<SharedV3Warning> = [];\n\n const [modelId, version] = this.modelId.split(':');\n\n const currentDate = this.config._internal?.currentDate?.() ?? new Date();\n\n // Parse provider options\n const replicateOptions = await parseProviderOptions({\n provider: 'replicate',\n providerOptions,\n schema: replicateImageProviderOptionsSchema,\n });\n\n // Handle image input from files\n let imageInputs: Record<string, string> = {};\n if (files != null && files.length > 0) {\n if (this.isFlux2Model) {\n // Flux-2 models use input_image, input_image_2, input_image_3, etc.\n for (\n let i = 0;\n i < Math.min(files.length, MAX_FLUX_2_INPUT_IMAGES);\n i++\n ) {\n const key = i === 0 ? 'input_image' : `input_image_${i + 1}`;\n imageInputs[key] = convertImageModelFileToDataUri(files[i]);\n }\n if (files.length > MAX_FLUX_2_INPUT_IMAGES) {\n warnings.push({\n type: 'other',\n message: `Flux-2 models support up to ${MAX_FLUX_2_INPUT_IMAGES} input images. Additional images are ignored.`,\n });\n }\n } else {\n // Other models use single 'image' parameter\n imageInputs = { image: convertImageModelFileToDataUri(files[0]) };\n if (files.length > 1) {\n warnings.push({\n type: 'other',\n message:\n 'This Replicate model only supports a single input image. Additional images are ignored.',\n });\n }\n }\n }\n\n // Handle mask input (not supported by Flux-2 models)\n let maskInput: string | undefined;\n if (mask != null) {\n if (this.isFlux2Model) {\n warnings.push({\n type: 'other',\n message:\n 'Flux-2 models do not support mask input. The mask will be ignored.',\n });\n } else {\n maskInput = convertImageModelFileToDataUri(mask);\n }\n }\n\n // Extract maxWaitTimeInSeconds from provider options and prepare the rest for the request body\n const { maxWaitTimeInSeconds, ...inputOptions } = replicateOptions ?? {};\n\n // Build the prefer header based on maxWaitTimeInSeconds:\n // - undefined/null: use default sync wait (prefer: wait)\n // - positive number: use custom wait duration (prefer: wait=N)\n const preferHeader: Record<string, string> =\n maxWaitTimeInSeconds != null\n ? { prefer: `wait=${maxWaitTimeInSeconds}` }\n : { prefer: 'wait' };\n\n const {\n value: { output },\n responseHeaders,\n } = await postJsonToApi({\n url:\n // different endpoints for versioned vs unversioned models:\n version != null\n ? `${this.config.baseURL}/predictions`\n : `${this.config.baseURL}/models/${modelId}/predictions`,\n\n headers: combineHeaders(\n await resolve(this.config.headers),\n headers,\n preferHeader,\n ),\n\n body: {\n input: {\n prompt,\n aspect_ratio: aspectRatio,\n size,\n seed,\n num_outputs: n,\n ...imageInputs,\n ...(maskInput != null ? { mask: maskInput } : {}),\n ...inputOptions,\n },\n // for versioned models, include the version in the body:\n ...(version != null ? { version } : {}),\n },\n\n successfulResponseHandler: createJsonResponseHandler(\n replicateImageResponseSchema,\n ),\n failedResponseHandler: replicateFailedResponseHandler,\n abortSignal,\n fetch: this.config.fetch,\n });\n\n // download the images:\n const outputArray = Array.isArray(output) ? output : [output];\n const images = await Promise.all(\n outputArray.map(async url => {\n const { value: image } = await getFromApi({\n url,\n successfulResponseHandler: createBinaryResponseHandler(),\n failedResponseHandler: replicateFailedResponseHandler,\n abortSignal,\n fetch: this.config.fetch,\n });\n return image;\n }),\n );\n\n return {\n images,\n warnings,\n response: {\n timestamp: currentDate,\n modelId: this.modelId,\n headers: responseHeaders,\n },\n };\n }\n}\n\nconst replicateImageResponseSchema = z.object({\n output: z.union([z.array(z.string()), z.string()]),\n});\n\n/**\n * Provider options schema for Replicate image generation.\n *\n * Note: Different Replicate models support different parameters.\n * This schema includes common parameters, but you can pass any\n * model-specific parameters through the passthrough.\n */\nexport const replicateImageProviderOptionsSchema = lazySchema(() =>\n zodSchema(\n z\n .object({\n /**\n * Maximum time in seconds to wait for the prediction to complete in sync mode.\n * By default, Replicate uses sync mode with a 60-second timeout.\n *\n * - When not specified: Uses default 60-second sync wait (`prefer: wait`)\n * - When set to a positive number: Uses that duration (`prefer: wait=N`)\n */\n maxWaitTimeInSeconds: z.number().positive().nullish(),\n\n /**\n * Guidance scale for classifier-free guidance.\n * Higher values make the output more closely match the prompt.\n */\n guidance_scale: z.number().nullish(),\n\n /**\n * Number of denoising steps. More steps = higher quality but slower.\n */\n num_inference_steps: z.number().nullish(),\n\n /**\n * Negative prompt to guide what to avoid in the generation.\n */\n negative_prompt: z.string().nullish(),\n\n /**\n * Output image format.\n */\n output_format: z.enum(['png', 'jpg', 'webp']).nullish(),\n\n /**\n * Output image quality (1-100). Only applies to jpg and webp.\n */\n output_quality: z.number().min(1).max(100).nullish(),\n\n /**\n * Strength of the transformation for img2img (0-1).\n * Lower values keep more of the original image.\n */\n strength: z.number().min(0).max(1).nullish(),\n })\n .passthrough(),\n ),\n);\n\nexport type ReplicateImageProviderOptions = InferSchema<\n typeof replicateImageProviderOptionsSchema\n>;\n","import { createJsonErrorResponseHandler } from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\n\nconst replicateErrorSchema = z.object({\n detail: z.string().optional(),\n error: z.string().optional(),\n});\n\nexport const replicateFailedResponseHandler = createJsonErrorResponseHandler({\n errorSchema: replicateErrorSchema,\n errorToMessage: error =>\n error.detail ?? error.error ?? 'Unknown Replicate error',\n});\n","// Version string of this package injected at build time.\ndeclare const __PACKAGE_VERSION__: string | undefined;\nexport const VERSION: string =\n typeof __PACKAGE_VERSION__ !== 'undefined'\n ? __PACKAGE_VERSION__\n : '0.0.0-test';\n"],"mappings":"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","names":["z","z"]}
package/package.json ADDED
@@ -0,0 +1,67 @@
1
+ {
2
+ "name": "@ai-sdk/replicate",
3
+ "version": "0.0.0-fd764a60-20260114143805",
4
+ "license": "Apache-2.0",
5
+ "sideEffects": false,
6
+ "main": "./dist/index.js",
7
+ "module": "./dist/index.mjs",
8
+ "types": "./dist/index.d.ts",
9
+ "files": [
10
+ "dist/**/*",
11
+ "CHANGELOG.md",
12
+ "README.md"
13
+ ],
14
+ "exports": {
15
+ "./package.json": "./package.json",
16
+ ".": {
17
+ "types": "./dist/index.d.ts",
18
+ "import": "./dist/index.mjs",
19
+ "require": "./dist/index.js"
20
+ }
21
+ },
22
+ "dependencies": {
23
+ "@ai-sdk/provider": "0.0.0-fd764a60-20260114143805",
24
+ "@ai-sdk/provider-utils": "0.0.0-fd764a60-20260114143805"
25
+ },
26
+ "devDependencies": {
27
+ "@types/node": "20.17.24",
28
+ "tsup": "^8",
29
+ "typescript": "5.8.3",
30
+ "zod": "3.25.76",
31
+ "@ai-sdk/test-server": "1.0.1",
32
+ "@vercel/ai-tsconfig": "0.0.0"
33
+ },
34
+ "peerDependencies": {
35
+ "zod": "^3.25.76 || ^4.1.8"
36
+ },
37
+ "engines": {
38
+ "node": ">=18"
39
+ },
40
+ "publishConfig": {
41
+ "access": "public"
42
+ },
43
+ "homepage": "https://ai-sdk.dev/docs",
44
+ "repository": {
45
+ "type": "git",
46
+ "url": "git+https://github.com/vercel/ai.git"
47
+ },
48
+ "bugs": {
49
+ "url": "https://github.com/vercel/ai/issues"
50
+ },
51
+ "keywords": [
52
+ "ai"
53
+ ],
54
+ "scripts": {
55
+ "build": "pnpm clean && tsup --tsconfig tsconfig.build.json",
56
+ "build:watch": "pnpm clean && tsup --watch",
57
+ "clean": "del-cli dist *.tsbuildinfo",
58
+ "lint": "eslint \"./**/*.ts*\"",
59
+ "type-check": "tsc --build",
60
+ "prettier-check": "prettier --check \"./**/*.ts*\"",
61
+ "test": "pnpm test:node && pnpm test:edge",
62
+ "test:update": "pnpm test:node -u",
63
+ "test:watch": "vitest --config vitest.node.config.js",
64
+ "test:edge": "vitest --config vitest.edge.config.js --run",
65
+ "test:node": "vitest --config vitest.node.config.js --run"
66
+ }
67
+ }