@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/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
@@ -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":[]}