@ai-sdk/prodia 2.0.0-beta.3 → 2.0.0-beta.30
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/CHANGELOG.md +218 -0
- package/README.md +2 -0
- package/dist/index.d.ts +34 -2
- package/dist/index.js +754 -183
- package/dist/index.js.map +1 -1
- package/package.json +7 -9
- package/src/index.ts +4 -0
- package/src/prodia-api.ts +198 -0
- package/src/prodia-image-model.ts +34 -197
- package/src/prodia-language-model-settings.ts +6 -0
- package/src/prodia-language-model.ts +429 -0
- package/src/prodia-provider.ts +40 -8
- package/src/prodia-video-model-settings.ts +7 -0
- package/src/prodia-video-model.ts +282 -0
- package/dist/index.d.mts +0 -58
- package/dist/index.mjs +0 -423
- package/dist/index.mjs.map +0 -1
package/dist/index.mjs
DELETED
|
@@ -1,423 +0,0 @@
|
|
|
1
|
-
// src/prodia-provider.ts
|
|
2
|
-
import {
|
|
3
|
-
NoSuchModelError
|
|
4
|
-
} from "@ai-sdk/provider";
|
|
5
|
-
import {
|
|
6
|
-
loadApiKey,
|
|
7
|
-
withoutTrailingSlash,
|
|
8
|
-
withUserAgentSuffix
|
|
9
|
-
} from "@ai-sdk/provider-utils";
|
|
10
|
-
|
|
11
|
-
// src/prodia-image-model.ts
|
|
12
|
-
import {
|
|
13
|
-
combineHeaders,
|
|
14
|
-
createJsonErrorResponseHandler,
|
|
15
|
-
lazySchema,
|
|
16
|
-
parseProviderOptions,
|
|
17
|
-
postToApi,
|
|
18
|
-
resolve,
|
|
19
|
-
zodSchema
|
|
20
|
-
} from "@ai-sdk/provider-utils";
|
|
21
|
-
import { z } from "zod/v4";
|
|
22
|
-
var ProdiaImageModel = class {
|
|
23
|
-
constructor(modelId, config) {
|
|
24
|
-
this.modelId = modelId;
|
|
25
|
-
this.config = config;
|
|
26
|
-
this.specificationVersion = "v4";
|
|
27
|
-
this.maxImagesPerCall = 1;
|
|
28
|
-
}
|
|
29
|
-
get provider() {
|
|
30
|
-
return this.config.provider;
|
|
31
|
-
}
|
|
32
|
-
async getArgs({
|
|
33
|
-
prompt,
|
|
34
|
-
size,
|
|
35
|
-
seed,
|
|
36
|
-
providerOptions
|
|
37
|
-
}) {
|
|
38
|
-
const warnings = [];
|
|
39
|
-
const prodiaOptions = await parseProviderOptions({
|
|
40
|
-
provider: "prodia",
|
|
41
|
-
providerOptions,
|
|
42
|
-
schema: prodiaImageModelOptionsSchema
|
|
43
|
-
});
|
|
44
|
-
let width;
|
|
45
|
-
let height;
|
|
46
|
-
if (size) {
|
|
47
|
-
const [widthStr, heightStr] = size.split("x");
|
|
48
|
-
width = Number(widthStr);
|
|
49
|
-
height = Number(heightStr);
|
|
50
|
-
if (!widthStr || !heightStr || !Number.isFinite(width) || !Number.isFinite(height)) {
|
|
51
|
-
warnings.push({
|
|
52
|
-
type: "unsupported",
|
|
53
|
-
feature: "size",
|
|
54
|
-
details: `Invalid size format: ${size}. Expected format: WIDTHxHEIGHT (e.g., 1024x1024)`
|
|
55
|
-
});
|
|
56
|
-
width = void 0;
|
|
57
|
-
height = void 0;
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
const jobConfig = {
|
|
61
|
-
prompt
|
|
62
|
-
};
|
|
63
|
-
if ((prodiaOptions == null ? void 0 : prodiaOptions.width) !== void 0) {
|
|
64
|
-
jobConfig.width = prodiaOptions.width;
|
|
65
|
-
} else if (width !== void 0) {
|
|
66
|
-
jobConfig.width = width;
|
|
67
|
-
}
|
|
68
|
-
if ((prodiaOptions == null ? void 0 : prodiaOptions.height) !== void 0) {
|
|
69
|
-
jobConfig.height = prodiaOptions.height;
|
|
70
|
-
} else if (height !== void 0) {
|
|
71
|
-
jobConfig.height = height;
|
|
72
|
-
}
|
|
73
|
-
if (seed !== void 0) {
|
|
74
|
-
jobConfig.seed = seed;
|
|
75
|
-
}
|
|
76
|
-
if ((prodiaOptions == null ? void 0 : prodiaOptions.steps) !== void 0) {
|
|
77
|
-
jobConfig.steps = prodiaOptions.steps;
|
|
78
|
-
}
|
|
79
|
-
if ((prodiaOptions == null ? void 0 : prodiaOptions.stylePreset) !== void 0) {
|
|
80
|
-
jobConfig.style_preset = prodiaOptions.stylePreset;
|
|
81
|
-
}
|
|
82
|
-
if ((prodiaOptions == null ? void 0 : prodiaOptions.loras) !== void 0 && prodiaOptions.loras.length > 0) {
|
|
83
|
-
jobConfig.loras = prodiaOptions.loras;
|
|
84
|
-
}
|
|
85
|
-
if ((prodiaOptions == null ? void 0 : prodiaOptions.progressive) !== void 0) {
|
|
86
|
-
jobConfig.progressive = prodiaOptions.progressive;
|
|
87
|
-
}
|
|
88
|
-
const body = {
|
|
89
|
-
type: this.modelId,
|
|
90
|
-
config: jobConfig
|
|
91
|
-
};
|
|
92
|
-
return { body, warnings };
|
|
93
|
-
}
|
|
94
|
-
async doGenerate(options) {
|
|
95
|
-
var _a, _b, _c, _d, _e, _f, _g;
|
|
96
|
-
const { body, warnings } = await this.getArgs(options);
|
|
97
|
-
const currentDate = (_c = (_b = (_a = this.config._internal) == null ? void 0 : _a.currentDate) == null ? void 0 : _b.call(_a)) != null ? _c : /* @__PURE__ */ new Date();
|
|
98
|
-
const combinedHeaders = combineHeaders(
|
|
99
|
-
await resolve(this.config.headers),
|
|
100
|
-
options.headers
|
|
101
|
-
);
|
|
102
|
-
const { value: multipartResult, responseHeaders } = await postToApi({
|
|
103
|
-
url: `${this.config.baseURL}/job?price=true`,
|
|
104
|
-
headers: {
|
|
105
|
-
...combinedHeaders,
|
|
106
|
-
Accept: "multipart/form-data; image/png",
|
|
107
|
-
"Content-Type": "application/json"
|
|
108
|
-
},
|
|
109
|
-
body: {
|
|
110
|
-
content: JSON.stringify(body),
|
|
111
|
-
values: body
|
|
112
|
-
},
|
|
113
|
-
failedResponseHandler: prodiaFailedResponseHandler,
|
|
114
|
-
successfulResponseHandler: createMultipartResponseHandler(),
|
|
115
|
-
abortSignal: options.abortSignal,
|
|
116
|
-
fetch: this.config.fetch
|
|
117
|
-
});
|
|
118
|
-
const { jobResult, imageBytes } = multipartResult;
|
|
119
|
-
return {
|
|
120
|
-
images: [imageBytes],
|
|
121
|
-
warnings,
|
|
122
|
-
providerMetadata: {
|
|
123
|
-
prodia: {
|
|
124
|
-
images: [
|
|
125
|
-
{
|
|
126
|
-
jobId: jobResult.id,
|
|
127
|
-
...((_d = jobResult.config) == null ? void 0 : _d.seed) != null && {
|
|
128
|
-
seed: jobResult.config.seed
|
|
129
|
-
},
|
|
130
|
-
...((_e = jobResult.metrics) == null ? void 0 : _e.elapsed) != null && {
|
|
131
|
-
elapsed: jobResult.metrics.elapsed
|
|
132
|
-
},
|
|
133
|
-
...((_f = jobResult.metrics) == null ? void 0 : _f.ips) != null && {
|
|
134
|
-
iterationsPerSecond: jobResult.metrics.ips
|
|
135
|
-
},
|
|
136
|
-
...jobResult.created_at != null && {
|
|
137
|
-
createdAt: jobResult.created_at
|
|
138
|
-
},
|
|
139
|
-
...jobResult.updated_at != null && {
|
|
140
|
-
updatedAt: jobResult.updated_at
|
|
141
|
-
},
|
|
142
|
-
...((_g = jobResult.price) == null ? void 0 : _g.dollars) != null && {
|
|
143
|
-
dollars: jobResult.price.dollars
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
]
|
|
147
|
-
}
|
|
148
|
-
},
|
|
149
|
-
response: {
|
|
150
|
-
modelId: this.modelId,
|
|
151
|
-
timestamp: currentDate,
|
|
152
|
-
headers: responseHeaders
|
|
153
|
-
}
|
|
154
|
-
};
|
|
155
|
-
}
|
|
156
|
-
};
|
|
157
|
-
var stylePresets = [
|
|
158
|
-
"3d-model",
|
|
159
|
-
"analog-film",
|
|
160
|
-
"anime",
|
|
161
|
-
"cinematic",
|
|
162
|
-
"comic-book",
|
|
163
|
-
"digital-art",
|
|
164
|
-
"enhance",
|
|
165
|
-
"fantasy-art",
|
|
166
|
-
"isometric",
|
|
167
|
-
"line-art",
|
|
168
|
-
"low-poly",
|
|
169
|
-
"neon-punk",
|
|
170
|
-
"origami",
|
|
171
|
-
"photographic",
|
|
172
|
-
"pixel-art",
|
|
173
|
-
"texture",
|
|
174
|
-
"craft-clay"
|
|
175
|
-
];
|
|
176
|
-
var prodiaImageModelOptionsSchema = lazySchema(
|
|
177
|
-
() => zodSchema(
|
|
178
|
-
z.object({
|
|
179
|
-
/**
|
|
180
|
-
* Amount of computational iterations to run. More is typically higher quality.
|
|
181
|
-
*/
|
|
182
|
-
steps: z.number().int().min(1).max(4).optional(),
|
|
183
|
-
/**
|
|
184
|
-
* Width of the output image in pixels.
|
|
185
|
-
*/
|
|
186
|
-
width: z.number().int().min(256).max(1920).optional(),
|
|
187
|
-
/**
|
|
188
|
-
* Height of the output image in pixels.
|
|
189
|
-
*/
|
|
190
|
-
height: z.number().int().min(256).max(1920).optional(),
|
|
191
|
-
/**
|
|
192
|
-
* Apply a visual theme to your output image.
|
|
193
|
-
*/
|
|
194
|
-
stylePreset: z.enum(stylePresets).optional(),
|
|
195
|
-
/**
|
|
196
|
-
* Augment the output with a LoRa model.
|
|
197
|
-
*/
|
|
198
|
-
loras: z.array(z.string()).max(3).optional(),
|
|
199
|
-
/**
|
|
200
|
-
* When using JPEG output, return a progressive JPEG.
|
|
201
|
-
*/
|
|
202
|
-
progressive: z.boolean().optional()
|
|
203
|
-
})
|
|
204
|
-
)
|
|
205
|
-
);
|
|
206
|
-
var prodiaJobResultSchema = z.object({
|
|
207
|
-
id: z.string(),
|
|
208
|
-
created_at: z.string().optional(),
|
|
209
|
-
updated_at: z.string().optional(),
|
|
210
|
-
expires_at: z.string().optional(),
|
|
211
|
-
state: z.object({
|
|
212
|
-
current: z.string()
|
|
213
|
-
}).optional(),
|
|
214
|
-
config: z.object({
|
|
215
|
-
seed: z.number().optional()
|
|
216
|
-
}).passthrough().optional(),
|
|
217
|
-
metrics: z.object({
|
|
218
|
-
elapsed: z.number().optional(),
|
|
219
|
-
ips: z.number().optional()
|
|
220
|
-
}).optional(),
|
|
221
|
-
price: z.object({
|
|
222
|
-
product: z.string(),
|
|
223
|
-
dollars: z.number()
|
|
224
|
-
}).nullish()
|
|
225
|
-
});
|
|
226
|
-
function createMultipartResponseHandler() {
|
|
227
|
-
return async ({
|
|
228
|
-
response
|
|
229
|
-
}) => {
|
|
230
|
-
var _a, _b, _c;
|
|
231
|
-
const contentType = (_a = response.headers.get("content-type")) != null ? _a : "";
|
|
232
|
-
const responseHeaders = {};
|
|
233
|
-
response.headers.forEach((value, key) => {
|
|
234
|
-
responseHeaders[key] = value;
|
|
235
|
-
});
|
|
236
|
-
const boundaryMatch = contentType.match(/boundary=([^\s;]+)/);
|
|
237
|
-
if (!boundaryMatch) {
|
|
238
|
-
throw new Error(
|
|
239
|
-
`Prodia response missing multipart boundary in content-type: ${contentType}`
|
|
240
|
-
);
|
|
241
|
-
}
|
|
242
|
-
const boundary = boundaryMatch[1];
|
|
243
|
-
const arrayBuffer = await response.arrayBuffer();
|
|
244
|
-
const bytes = new Uint8Array(arrayBuffer);
|
|
245
|
-
const parts = parseMultipart(bytes, boundary);
|
|
246
|
-
let jobResult;
|
|
247
|
-
let imageBytes;
|
|
248
|
-
for (const part of parts) {
|
|
249
|
-
const contentDisposition = (_b = part.headers["content-disposition"]) != null ? _b : "";
|
|
250
|
-
const partContentType = (_c = part.headers["content-type"]) != null ? _c : "";
|
|
251
|
-
if (contentDisposition.includes('name="job"')) {
|
|
252
|
-
const jsonStr = new TextDecoder().decode(part.body);
|
|
253
|
-
jobResult = prodiaJobResultSchema.parse(JSON.parse(jsonStr));
|
|
254
|
-
} else if (contentDisposition.includes('name="output"')) {
|
|
255
|
-
imageBytes = part.body;
|
|
256
|
-
} else if (partContentType.startsWith("image/")) {
|
|
257
|
-
imageBytes = part.body;
|
|
258
|
-
}
|
|
259
|
-
}
|
|
260
|
-
if (!jobResult) {
|
|
261
|
-
throw new Error("Prodia multipart response missing job part");
|
|
262
|
-
}
|
|
263
|
-
if (!imageBytes) {
|
|
264
|
-
throw new Error("Prodia multipart response missing output image");
|
|
265
|
-
}
|
|
266
|
-
return {
|
|
267
|
-
value: { jobResult, imageBytes },
|
|
268
|
-
responseHeaders
|
|
269
|
-
};
|
|
270
|
-
};
|
|
271
|
-
}
|
|
272
|
-
function parseMultipart(data, boundary) {
|
|
273
|
-
const parts = [];
|
|
274
|
-
const boundaryBytes = new TextEncoder().encode(`--${boundary}`);
|
|
275
|
-
const endBoundaryBytes = new TextEncoder().encode(`--${boundary}--`);
|
|
276
|
-
const positions = [];
|
|
277
|
-
for (let i = 0; i <= data.length - boundaryBytes.length; i++) {
|
|
278
|
-
let match = true;
|
|
279
|
-
for (let j = 0; j < boundaryBytes.length; j++) {
|
|
280
|
-
if (data[i + j] !== boundaryBytes[j]) {
|
|
281
|
-
match = false;
|
|
282
|
-
break;
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
if (match) {
|
|
286
|
-
positions.push(i);
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
for (let i = 0; i < positions.length - 1; i++) {
|
|
290
|
-
const start = positions[i] + boundaryBytes.length;
|
|
291
|
-
const end = positions[i + 1];
|
|
292
|
-
let isEndBoundary = true;
|
|
293
|
-
for (let j = 0; j < endBoundaryBytes.length && isEndBoundary; j++) {
|
|
294
|
-
if (data[positions[i] + j] !== endBoundaryBytes[j]) {
|
|
295
|
-
isEndBoundary = false;
|
|
296
|
-
}
|
|
297
|
-
}
|
|
298
|
-
if (isEndBoundary && positions[i] + endBoundaryBytes.length <= data.length) {
|
|
299
|
-
continue;
|
|
300
|
-
}
|
|
301
|
-
let partStart = start;
|
|
302
|
-
if (data[partStart] === 13 && data[partStart + 1] === 10) {
|
|
303
|
-
partStart += 2;
|
|
304
|
-
} else if (data[partStart] === 10) {
|
|
305
|
-
partStart += 1;
|
|
306
|
-
}
|
|
307
|
-
let partEnd = end;
|
|
308
|
-
if (data[partEnd - 2] === 13 && data[partEnd - 1] === 10) {
|
|
309
|
-
partEnd -= 2;
|
|
310
|
-
} else if (data[partEnd - 1] === 10) {
|
|
311
|
-
partEnd -= 1;
|
|
312
|
-
}
|
|
313
|
-
const partData = data.slice(partStart, partEnd);
|
|
314
|
-
let headerEnd = -1;
|
|
315
|
-
for (let j = 0; j < partData.length - 3; j++) {
|
|
316
|
-
if (partData[j] === 13 && partData[j + 1] === 10 && partData[j + 2] === 13 && partData[j + 3] === 10) {
|
|
317
|
-
headerEnd = j;
|
|
318
|
-
break;
|
|
319
|
-
}
|
|
320
|
-
if (partData[j] === 10 && partData[j + 1] === 10) {
|
|
321
|
-
headerEnd = j;
|
|
322
|
-
break;
|
|
323
|
-
}
|
|
324
|
-
}
|
|
325
|
-
if (headerEnd === -1) {
|
|
326
|
-
continue;
|
|
327
|
-
}
|
|
328
|
-
const headerBytes = partData.slice(0, headerEnd);
|
|
329
|
-
const headerStr = new TextDecoder().decode(headerBytes);
|
|
330
|
-
const headers = {};
|
|
331
|
-
for (const line of headerStr.split(/\r?\n/)) {
|
|
332
|
-
const colonIdx = line.indexOf(":");
|
|
333
|
-
if (colonIdx > 0) {
|
|
334
|
-
const key = line.slice(0, colonIdx).trim().toLowerCase();
|
|
335
|
-
const value = line.slice(colonIdx + 1).trim();
|
|
336
|
-
headers[key] = value;
|
|
337
|
-
}
|
|
338
|
-
}
|
|
339
|
-
let bodyStart = headerEnd + 2;
|
|
340
|
-
if (partData[headerEnd] === 13) {
|
|
341
|
-
bodyStart = headerEnd + 4;
|
|
342
|
-
}
|
|
343
|
-
const body = partData.slice(bodyStart);
|
|
344
|
-
parts.push({ headers, body });
|
|
345
|
-
}
|
|
346
|
-
return parts;
|
|
347
|
-
}
|
|
348
|
-
var prodiaErrorSchema = z.object({
|
|
349
|
-
message: z.string().optional(),
|
|
350
|
-
detail: z.unknown().optional(),
|
|
351
|
-
error: z.string().optional()
|
|
352
|
-
});
|
|
353
|
-
var prodiaFailedResponseHandler = createJsonErrorResponseHandler({
|
|
354
|
-
errorSchema: prodiaErrorSchema,
|
|
355
|
-
errorToMessage: (error) => {
|
|
356
|
-
var _a;
|
|
357
|
-
const parsed = prodiaErrorSchema.safeParse(error);
|
|
358
|
-
if (!parsed.success) return "Unknown Prodia error";
|
|
359
|
-
const { message, detail, error: errorField } = parsed.data;
|
|
360
|
-
if (typeof detail === "string") return detail;
|
|
361
|
-
if (detail != null) {
|
|
362
|
-
try {
|
|
363
|
-
return JSON.stringify(detail);
|
|
364
|
-
} catch (e) {
|
|
365
|
-
}
|
|
366
|
-
}
|
|
367
|
-
return (_a = errorField != null ? errorField : message) != null ? _a : "Unknown Prodia error";
|
|
368
|
-
}
|
|
369
|
-
});
|
|
370
|
-
|
|
371
|
-
// src/version.ts
|
|
372
|
-
var VERSION = true ? "2.0.0-beta.3" : "0.0.0-test";
|
|
373
|
-
|
|
374
|
-
// src/prodia-provider.ts
|
|
375
|
-
var defaultBaseURL = "https://inference.prodia.com/v2";
|
|
376
|
-
function createProdia(options = {}) {
|
|
377
|
-
var _a;
|
|
378
|
-
const baseURL = withoutTrailingSlash((_a = options.baseURL) != null ? _a : defaultBaseURL);
|
|
379
|
-
const getHeaders = () => withUserAgentSuffix(
|
|
380
|
-
{
|
|
381
|
-
Authorization: `Bearer ${loadApiKey({
|
|
382
|
-
apiKey: options.apiKey,
|
|
383
|
-
environmentVariableName: "PRODIA_TOKEN",
|
|
384
|
-
description: "Prodia"
|
|
385
|
-
})}`,
|
|
386
|
-
...options.headers
|
|
387
|
-
},
|
|
388
|
-
`ai-sdk/prodia/${VERSION}`
|
|
389
|
-
);
|
|
390
|
-
const createImageModel = (modelId) => new ProdiaImageModel(modelId, {
|
|
391
|
-
provider: "prodia.image",
|
|
392
|
-
baseURL: baseURL != null ? baseURL : defaultBaseURL,
|
|
393
|
-
headers: getHeaders,
|
|
394
|
-
fetch: options.fetch
|
|
395
|
-
});
|
|
396
|
-
const embeddingModel = (modelId) => {
|
|
397
|
-
throw new NoSuchModelError({
|
|
398
|
-
modelId,
|
|
399
|
-
modelType: "embeddingModel"
|
|
400
|
-
});
|
|
401
|
-
};
|
|
402
|
-
const languageModel = (modelId) => {
|
|
403
|
-
throw new NoSuchModelError({
|
|
404
|
-
modelId,
|
|
405
|
-
modelType: "languageModel"
|
|
406
|
-
});
|
|
407
|
-
};
|
|
408
|
-
return {
|
|
409
|
-
specificationVersion: "v4",
|
|
410
|
-
imageModel: createImageModel,
|
|
411
|
-
image: createImageModel,
|
|
412
|
-
languageModel,
|
|
413
|
-
embeddingModel,
|
|
414
|
-
textEmbeddingModel: embeddingModel
|
|
415
|
-
};
|
|
416
|
-
}
|
|
417
|
-
var prodia = createProdia();
|
|
418
|
-
export {
|
|
419
|
-
VERSION,
|
|
420
|
-
createProdia,
|
|
421
|
-
prodia
|
|
422
|
-
};
|
|
423
|
-
//# sourceMappingURL=index.mjs.map
|
package/dist/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/prodia-provider.ts","../src/prodia-image-model.ts","../src/version.ts"],"sourcesContent":["import {\n type ImageModelV4,\n NoSuchModelError,\n type ProviderV4,\n} from '@ai-sdk/provider';\nimport type { FetchFunction } from '@ai-sdk/provider-utils';\nimport {\n loadApiKey,\n withoutTrailingSlash,\n withUserAgentSuffix,\n} from '@ai-sdk/provider-utils';\nimport { ProdiaImageModel } from './prodia-image-model';\nimport type { ProdiaImageModelId } from './prodia-image-settings';\nimport { VERSION } from './version';\n\nexport interface ProdiaProviderSettings {\n /**\n * Prodia API key. Default value is taken from the `PRODIA_TOKEN` environment variable.\n */\n apiKey?: string;\n\n /**\n * Base URL for the API calls. Defaults to `https://inference.prodia.com/v2`.\n */\n baseURL?: string;\n\n /**\n * Custom headers to include in the requests.\n */\n headers?: Record<string, string>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept\n * requests, or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n}\n\nexport interface ProdiaProvider extends ProviderV4 {\n /**\n * Creates a model for image generation.\n */\n image(modelId: ProdiaImageModelId): ImageModelV4;\n\n /**\n * Creates a model for image generation.\n */\n imageModel(modelId: ProdiaImageModelId): ImageModelV4;\n\n /**\n * @deprecated Use `embeddingModel` instead.\n */\n textEmbeddingModel(modelId: string): never;\n}\n\nconst defaultBaseURL = 'https://inference.prodia.com/v2';\n\nexport function createProdia(\n options: ProdiaProviderSettings = {},\n): ProdiaProvider {\n const baseURL = withoutTrailingSlash(options.baseURL ?? defaultBaseURL);\n const getHeaders = () =>\n withUserAgentSuffix(\n {\n Authorization: `Bearer ${loadApiKey({\n apiKey: options.apiKey,\n environmentVariableName: 'PRODIA_TOKEN',\n description: 'Prodia',\n })}`,\n ...options.headers,\n },\n `ai-sdk/prodia/${VERSION}`,\n );\n\n const createImageModel = (modelId: ProdiaImageModelId) =>\n new ProdiaImageModel(modelId, {\n provider: 'prodia.image',\n baseURL: baseURL ?? defaultBaseURL,\n headers: getHeaders,\n fetch: options.fetch,\n });\n\n const embeddingModel = (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'embeddingModel',\n });\n };\n\n const languageModel = (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'languageModel',\n });\n };\n\n return {\n specificationVersion: 'v4',\n imageModel: createImageModel,\n image: createImageModel,\n languageModel,\n embeddingModel,\n textEmbeddingModel: embeddingModel,\n };\n}\n\nexport const prodia = createProdia();\n","import type { ImageModelV4, SharedV4Warning } from '@ai-sdk/provider';\nimport type { InferSchema, Resolvable } from '@ai-sdk/provider-utils';\nimport {\n combineHeaders,\n createJsonErrorResponseHandler,\n type FetchFunction,\n lazySchema,\n parseProviderOptions,\n postToApi,\n resolve,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport type { ProdiaImageModelId } from './prodia-image-settings';\n\nexport class ProdiaImageModel implements ImageModelV4 {\n readonly specificationVersion = 'v4';\n readonly maxImagesPerCall = 1;\n\n get provider(): string {\n return this.config.provider;\n }\n\n constructor(\n readonly modelId: ProdiaImageModelId,\n private readonly config: ProdiaImageModelConfig,\n ) {}\n\n private async getArgs({\n prompt,\n size,\n seed,\n providerOptions,\n }: Parameters<ImageModelV4['doGenerate']>[0]) {\n const warnings: Array<SharedV4Warning> = [];\n\n const prodiaOptions = await parseProviderOptions({\n provider: 'prodia',\n providerOptions,\n schema: prodiaImageModelOptionsSchema,\n });\n\n let width: number | undefined;\n let height: number | undefined;\n if (size) {\n const [widthStr, heightStr] = size.split('x');\n width = Number(widthStr);\n height = Number(heightStr);\n if (\n !widthStr ||\n !heightStr ||\n !Number.isFinite(width) ||\n !Number.isFinite(height)\n ) {\n warnings.push({\n type: 'unsupported',\n feature: 'size',\n details: `Invalid size format: ${size}. Expected format: WIDTHxHEIGHT (e.g., 1024x1024)`,\n });\n width = undefined;\n height = undefined;\n }\n }\n\n const jobConfig: Record<string, unknown> = {\n prompt,\n };\n\n if (prodiaOptions?.width !== undefined) {\n jobConfig.width = prodiaOptions.width;\n } else if (width !== undefined) {\n jobConfig.width = width;\n }\n\n if (prodiaOptions?.height !== undefined) {\n jobConfig.height = prodiaOptions.height;\n } else if (height !== undefined) {\n jobConfig.height = height;\n }\n\n if (seed !== undefined) {\n jobConfig.seed = seed;\n }\n if (prodiaOptions?.steps !== undefined) {\n jobConfig.steps = prodiaOptions.steps;\n }\n if (prodiaOptions?.stylePreset !== undefined) {\n jobConfig.style_preset = prodiaOptions.stylePreset;\n }\n if (prodiaOptions?.loras !== undefined && prodiaOptions.loras.length > 0) {\n jobConfig.loras = prodiaOptions.loras;\n }\n if (prodiaOptions?.progressive !== undefined) {\n jobConfig.progressive = prodiaOptions.progressive;\n }\n\n const body = {\n type: this.modelId,\n config: jobConfig,\n };\n\n return { body, warnings };\n }\n\n async doGenerate(\n options: Parameters<ImageModelV4['doGenerate']>[0],\n ): Promise<Awaited<ReturnType<ImageModelV4['doGenerate']>>> {\n const { body, warnings } = await this.getArgs(options);\n\n const currentDate = this.config._internal?.currentDate?.() ?? new Date();\n const combinedHeaders = combineHeaders(\n await resolve(this.config.headers),\n options.headers,\n );\n\n const { value: multipartResult, responseHeaders } = await postToApi({\n url: `${this.config.baseURL}/job?price=true`,\n headers: {\n ...combinedHeaders,\n Accept: 'multipart/form-data; image/png',\n 'Content-Type': 'application/json',\n },\n body: {\n content: JSON.stringify(body),\n values: body,\n },\n failedResponseHandler: prodiaFailedResponseHandler,\n successfulResponseHandler: createMultipartResponseHandler(),\n abortSignal: options.abortSignal,\n fetch: this.config.fetch,\n });\n\n const { jobResult, imageBytes } = multipartResult;\n\n return {\n images: [imageBytes],\n warnings,\n providerMetadata: {\n prodia: {\n images: [\n {\n jobId: jobResult.id,\n ...(jobResult.config?.seed != null && {\n seed: jobResult.config.seed,\n }),\n ...(jobResult.metrics?.elapsed != null && {\n elapsed: jobResult.metrics.elapsed,\n }),\n ...(jobResult.metrics?.ips != null && {\n iterationsPerSecond: jobResult.metrics.ips,\n }),\n ...(jobResult.created_at != null && {\n createdAt: jobResult.created_at,\n }),\n ...(jobResult.updated_at != null && {\n updatedAt: jobResult.updated_at,\n }),\n ...(jobResult.price?.dollars != null && {\n dollars: jobResult.price.dollars,\n }),\n },\n ],\n },\n },\n response: {\n modelId: this.modelId,\n timestamp: currentDate,\n headers: responseHeaders,\n },\n };\n }\n}\n\nconst stylePresets = [\n '3d-model',\n 'analog-film',\n 'anime',\n 'cinematic',\n 'comic-book',\n 'digital-art',\n 'enhance',\n 'fantasy-art',\n 'isometric',\n 'line-art',\n 'low-poly',\n 'neon-punk',\n 'origami',\n 'photographic',\n 'pixel-art',\n 'texture',\n 'craft-clay',\n] as const;\n\nexport const prodiaImageModelOptionsSchema = lazySchema(() =>\n zodSchema(\n z.object({\n /**\n * Amount of computational iterations to run. More is typically higher quality.\n */\n steps: z.number().int().min(1).max(4).optional(),\n /**\n * Width of the output image in pixels.\n */\n width: z.number().int().min(256).max(1920).optional(),\n /**\n * Height of the output image in pixels.\n */\n height: z.number().int().min(256).max(1920).optional(),\n /**\n * Apply a visual theme to your output image.\n */\n stylePreset: z.enum(stylePresets).optional(),\n /**\n * Augment the output with a LoRa model.\n */\n loras: z.array(z.string()).max(3).optional(),\n /**\n * When using JPEG output, return a progressive JPEG.\n */\n progressive: z.boolean().optional(),\n }),\n ),\n);\n\nexport type ProdiaImageModelOptions = InferSchema<\n typeof prodiaImageModelOptionsSchema\n>;\n\ninterface ProdiaImageModelConfig {\n provider: string;\n baseURL: string;\n headers?: Resolvable<Record<string, string | undefined>>;\n fetch?: FetchFunction;\n _internal?: {\n currentDate?: () => Date;\n };\n}\n\nconst prodiaJobResultSchema = z.object({\n id: z.string(),\n created_at: z.string().optional(),\n updated_at: z.string().optional(),\n expires_at: z.string().optional(),\n state: z\n .object({\n current: z.string(),\n })\n .optional(),\n config: z\n .object({\n seed: z.number().optional(),\n })\n .passthrough()\n .optional(),\n metrics: z\n .object({\n elapsed: z.number().optional(),\n ips: z.number().optional(),\n })\n .optional(),\n price: z\n .object({\n product: z.string(),\n dollars: z.number(),\n })\n .nullish(),\n});\n\ntype ProdiaJobResult = z.infer<typeof prodiaJobResultSchema>;\n\ninterface MultipartResult {\n jobResult: ProdiaJobResult;\n imageBytes: Uint8Array;\n}\n\nfunction createMultipartResponseHandler() {\n return async ({\n response,\n }: {\n response: Response;\n }): Promise<{\n value: MultipartResult;\n responseHeaders: Record<string, string>;\n }> => {\n const contentType = response.headers.get('content-type') ?? '';\n const responseHeaders: Record<string, string> = {};\n response.headers.forEach((value, key) => {\n responseHeaders[key] = value;\n });\n\n const boundaryMatch = contentType.match(/boundary=([^\\s;]+)/);\n if (!boundaryMatch) {\n throw new Error(\n `Prodia response missing multipart boundary in content-type: ${contentType}`,\n );\n }\n const boundary = boundaryMatch[1];\n\n const arrayBuffer = await response.arrayBuffer();\n const bytes = new Uint8Array(arrayBuffer);\n\n const parts = parseMultipart(bytes, boundary);\n\n let jobResult: ProdiaJobResult | undefined;\n let imageBytes: Uint8Array | undefined;\n\n for (const part of parts) {\n const contentDisposition = part.headers['content-disposition'] ?? '';\n const partContentType = part.headers['content-type'] ?? '';\n\n if (contentDisposition.includes('name=\"job\"')) {\n const jsonStr = new TextDecoder().decode(part.body);\n jobResult = prodiaJobResultSchema.parse(JSON.parse(jsonStr));\n } else if (contentDisposition.includes('name=\"output\"')) {\n imageBytes = part.body;\n } else if (partContentType.startsWith('image/')) {\n imageBytes = part.body;\n }\n }\n\n if (!jobResult) {\n throw new Error('Prodia multipart response missing job part');\n }\n if (!imageBytes) {\n throw new Error('Prodia multipart response missing output image');\n }\n\n return {\n value: { jobResult, imageBytes },\n responseHeaders,\n };\n };\n}\n\ninterface MultipartPart {\n headers: Record<string, string>;\n body: Uint8Array;\n}\n\nfunction parseMultipart(data: Uint8Array, boundary: string): MultipartPart[] {\n const parts: MultipartPart[] = [];\n const boundaryBytes = new TextEncoder().encode(`--${boundary}`);\n const endBoundaryBytes = new TextEncoder().encode(`--${boundary}--`);\n\n const positions: number[] = [];\n for (let i = 0; i <= data.length - boundaryBytes.length; i++) {\n let match = true;\n for (let j = 0; j < boundaryBytes.length; j++) {\n if (data[i + j] !== boundaryBytes[j]) {\n match = false;\n break;\n }\n }\n if (match) {\n positions.push(i);\n }\n }\n\n for (let i = 0; i < positions.length - 1; i++) {\n const start = positions[i] + boundaryBytes.length;\n const end = positions[i + 1];\n\n let isEndBoundary = true;\n for (let j = 0; j < endBoundaryBytes.length && isEndBoundary; j++) {\n if (data[positions[i] + j] !== endBoundaryBytes[j]) {\n isEndBoundary = false;\n }\n }\n if (\n isEndBoundary &&\n positions[i] + endBoundaryBytes.length <= data.length\n ) {\n continue;\n }\n\n let partStart = start;\n if (data[partStart] === 0x0d && data[partStart + 1] === 0x0a) {\n partStart += 2;\n } else if (data[partStart] === 0x0a) {\n partStart += 1;\n }\n\n let partEnd = end;\n if (data[partEnd - 2] === 0x0d && data[partEnd - 1] === 0x0a) {\n partEnd -= 2;\n } else if (data[partEnd - 1] === 0x0a) {\n partEnd -= 1;\n }\n\n const partData = data.slice(partStart, partEnd);\n\n let headerEnd = -1;\n for (let j = 0; j < partData.length - 3; j++) {\n if (\n partData[j] === 0x0d &&\n partData[j + 1] === 0x0a &&\n partData[j + 2] === 0x0d &&\n partData[j + 3] === 0x0a\n ) {\n headerEnd = j;\n break;\n }\n if (partData[j] === 0x0a && partData[j + 1] === 0x0a) {\n headerEnd = j;\n break;\n }\n }\n\n if (headerEnd === -1) {\n continue;\n }\n\n const headerBytes = partData.slice(0, headerEnd);\n const headerStr = new TextDecoder().decode(headerBytes);\n const headers: Record<string, string> = {};\n for (const line of headerStr.split(/\\r?\\n/)) {\n const colonIdx = line.indexOf(':');\n if (colonIdx > 0) {\n const key = line.slice(0, colonIdx).trim().toLowerCase();\n const value = line.slice(colonIdx + 1).trim();\n headers[key] = value;\n }\n }\n\n let bodyStart = headerEnd + 2;\n if (partData[headerEnd] === 0x0d) {\n bodyStart = headerEnd + 4;\n }\n const body = partData.slice(bodyStart);\n\n parts.push({ headers, body });\n }\n\n return parts;\n}\n\nconst prodiaErrorSchema = z.object({\n message: z.string().optional(),\n detail: z.unknown().optional(),\n error: z.string().optional(),\n});\n\nconst prodiaFailedResponseHandler = createJsonErrorResponseHandler({\n errorSchema: prodiaErrorSchema,\n errorToMessage: error => {\n const parsed = prodiaErrorSchema.safeParse(error);\n if (!parsed.success) return 'Unknown Prodia error';\n const { message, detail, error: errorField } = parsed.data;\n if (typeof detail === 'string') return detail;\n if (detail != null) {\n try {\n return JSON.stringify(detail);\n } catch {\n // ignore\n }\n }\n return errorField ?? message ?? 'Unknown Prodia error';\n },\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":[]}
|