@ai-sdk/provider 3.0.8 → 4.0.0-beta.0
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 +6 -0
- package/dist/index.d.mts +2710 -436
- package/dist/index.d.ts +2710 -436
- package/package.json +1 -1
- package/src/embedding-model/index.ts +1 -0
- package/src/embedding-model/v4/embedding-model-v4-call-options.ts +26 -0
- package/src/embedding-model/v4/embedding-model-v4-embedding.ts +5 -0
- package/src/embedding-model/v4/embedding-model-v4-result.ts +48 -0
- package/src/embedding-model/v4/embedding-model-v4.ts +54 -0
- package/src/embedding-model/v4/index.ts +4 -0
- package/src/embedding-model-middleware/index.ts +1 -0
- package/src/embedding-model-middleware/v4/embedding-model-v4-middleware.ts +69 -0
- package/src/embedding-model-middleware/v4/index.ts +1 -0
- package/src/image-model/index.ts +1 -0
- package/src/image-model/v4/image-model-v4-call-options.ts +74 -0
- package/src/image-model/v4/image-model-v4-file.ts +44 -0
- package/src/image-model/v4/image-model-v4-usage.ts +19 -0
- package/src/image-model/v4/image-model-v4.ts +110 -0
- package/src/image-model/v4/index.ts +7 -0
- package/src/image-model-middleware/index.ts +1 -0
- package/src/image-model-middleware/v4/image-model-v4-middleware.ts +61 -0
- package/src/image-model-middleware/v4/index.ts +1 -0
- package/src/language-model/index.ts +1 -0
- package/src/language-model/v4/index.ts +21 -0
- package/src/language-model/v4/language-model-v4-call-options.ts +125 -0
- package/src/language-model/v4/language-model-v4-content.ts +16 -0
- package/src/language-model/v4/language-model-v4-data-content.ts +4 -0
- package/src/language-model/v4/language-model-v4-file.ts +32 -0
- package/src/language-model/v4/language-model-v4-finish-reason.ts +33 -0
- package/src/language-model/v4/language-model-v4-function-tool.ts +53 -0
- package/src/language-model/v4/language-model-v4-generate-result.ts +63 -0
- package/src/language-model/v4/language-model-v4-prompt.ts +422 -0
- package/src/language-model/v4/language-model-v4-provider-tool.ts +28 -0
- package/src/language-model/v4/language-model-v4-reasoning.ts +14 -0
- package/src/language-model/v4/language-model-v4-response-metadata.ts +16 -0
- package/src/language-model/v4/language-model-v4-source.ts +67 -0
- package/src/language-model/v4/language-model-v4-stream-part.ts +106 -0
- package/src/language-model/v4/language-model-v4-stream-result.ts +32 -0
- package/src/language-model/v4/language-model-v4-text.ts +15 -0
- package/src/language-model/v4/language-model-v4-tool-approval-request.ts +27 -0
- package/src/language-model/v4/language-model-v4-tool-call.ts +41 -0
- package/src/language-model/v4/language-model-v4-tool-choice.ts +5 -0
- package/src/language-model/v4/language-model-v4-tool-result.ts +51 -0
- package/src/language-model/v4/language-model-v4-usage.ts +59 -0
- package/src/language-model/v4/language-model-v4.ts +61 -0
- package/src/language-model-middleware/index.ts +1 -0
- package/src/language-model-middleware/v4/index.ts +1 -0
- package/src/language-model-middleware/v4/language-model-v4-middleware.ts +84 -0
- package/src/provider/index.ts +1 -0
- package/src/provider/v4/index.ts +1 -0
- package/src/provider/v4/provider-v4.ts +79 -0
- package/src/reranking-model/index.ts +1 -0
- package/src/reranking-model/v4/index.ts +2 -0
- package/src/reranking-model/v4/reranking-model-v4-call-options.ts +40 -0
- package/src/reranking-model/v4/reranking-model-v4.ts +90 -0
- package/src/shared/index.ts +1 -0
- package/src/shared/v4/index.ts +4 -0
- package/src/shared/v4/shared-v4-headers.ts +1 -0
- package/src/shared/v4/shared-v4-provider-metadata.ts +24 -0
- package/src/shared/v4/shared-v4-provider-options.ts +24 -0
- package/src/shared/v4/shared-v4-warning.ts +50 -0
- package/src/speech-model/index.ts +2 -1
- package/src/speech-model/v4/index.ts +2 -0
- package/src/speech-model/v4/speech-model-v4-call-options.ts +62 -0
- package/src/speech-model/v4/speech-model-v4.ts +89 -0
- package/src/transcription-model/index.ts +2 -1
- package/src/transcription-model/v4/index.ts +2 -0
- package/src/transcription-model/v4/transcription-model-v4-call-options.ts +45 -0
- package/src/transcription-model/v4/transcription-model-v4.ts +117 -0
- package/src/video-model/index.ts +1 -0
- package/src/video-model/v4/index.ts +6 -0
- package/src/video-model/v4/video-model-v4-call-options.ts +81 -0
- package/src/video-model/v4/video-model-v4-file.ts +40 -0
- package/src/video-model/v4/video-model-v4.ts +132 -0
package/package.json
CHANGED
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { SharedV4Headers, SharedV4ProviderOptions } from '../../shared';
|
|
2
|
+
|
|
3
|
+
export type EmbeddingModelV4CallOptions = {
|
|
4
|
+
/**
|
|
5
|
+
* List of text values to generate embeddings for.
|
|
6
|
+
*/
|
|
7
|
+
values: Array<string>;
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Abort signal for cancelling the operation.
|
|
11
|
+
*/
|
|
12
|
+
abortSignal?: AbortSignal;
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Additional provider-specific options. They are passed through
|
|
16
|
+
* to the provider from the AI SDK and enable provider-specific
|
|
17
|
+
* functionality that can be fully encapsulated in the provider.
|
|
18
|
+
*/
|
|
19
|
+
providerOptions?: SharedV4ProviderOptions;
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Additional HTTP headers to be sent with the request.
|
|
23
|
+
* Only applicable for HTTP-based providers.
|
|
24
|
+
*/
|
|
25
|
+
headers?: SharedV4Headers;
|
|
26
|
+
};
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import {
|
|
2
|
+
SharedV4Headers,
|
|
3
|
+
SharedV4ProviderMetadata,
|
|
4
|
+
SharedV4Warning,
|
|
5
|
+
} from '../../shared';
|
|
6
|
+
import { EmbeddingModelV4Embedding } from './embedding-model-v4-embedding';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* The result of a embedding model doEmbed call.
|
|
10
|
+
*/
|
|
11
|
+
export type EmbeddingModelV4Result = {
|
|
12
|
+
/**
|
|
13
|
+
* Generated embeddings. They are in the same order as the input values.
|
|
14
|
+
*/
|
|
15
|
+
embeddings: Array<EmbeddingModelV4Embedding>;
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Token usage. We only have input tokens for embeddings.
|
|
19
|
+
*/
|
|
20
|
+
usage?: { tokens: number };
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Additional provider-specific metadata. They are passed through
|
|
24
|
+
* from the provider to the AI SDK and enable provider-specific
|
|
25
|
+
* results that can be fully encapsulated in the provider.
|
|
26
|
+
*/
|
|
27
|
+
providerMetadata?: SharedV4ProviderMetadata;
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Optional response information for debugging purposes.
|
|
31
|
+
*/
|
|
32
|
+
response?: {
|
|
33
|
+
/**
|
|
34
|
+
* Response headers.
|
|
35
|
+
*/
|
|
36
|
+
headers?: SharedV4Headers;
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* The response body.
|
|
40
|
+
*/
|
|
41
|
+
body?: unknown;
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Warnings for the call, e.g. unsupported settings.
|
|
46
|
+
*/
|
|
47
|
+
warnings: Array<SharedV4Warning>;
|
|
48
|
+
};
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { EmbeddingModelV4CallOptions } from './embedding-model-v4-call-options';
|
|
2
|
+
import { EmbeddingModelV4Result } from './embedding-model-v4-result';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Specification for an embedding model that implements the embedding model
|
|
6
|
+
* interface version 3.
|
|
7
|
+
*
|
|
8
|
+
* It is specific to text embeddings.
|
|
9
|
+
*/
|
|
10
|
+
export type EmbeddingModelV4 = {
|
|
11
|
+
/**
|
|
12
|
+
* The embedding model must specify which embedding model interface
|
|
13
|
+
* version it implements. This will allow us to evolve the embedding
|
|
14
|
+
* model interface and retain backwards compatibility. The different
|
|
15
|
+
* implementation versions can be handled as a discriminated union
|
|
16
|
+
* on our side.
|
|
17
|
+
*/
|
|
18
|
+
readonly specificationVersion: 'v4';
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Name of the provider for logging purposes.
|
|
22
|
+
*/
|
|
23
|
+
readonly provider: string;
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Provider-specific model ID for logging purposes.
|
|
27
|
+
*/
|
|
28
|
+
readonly modelId: string;
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Limit of how many embeddings can be generated in a single API call.
|
|
32
|
+
*
|
|
33
|
+
* Use Infinity for models that do not have a limit.
|
|
34
|
+
*/
|
|
35
|
+
readonly maxEmbeddingsPerCall:
|
|
36
|
+
| PromiseLike<number | undefined>
|
|
37
|
+
| number
|
|
38
|
+
| undefined;
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* True if the model can handle multiple embedding calls in parallel.
|
|
42
|
+
*/
|
|
43
|
+
readonly supportsParallelCalls: PromiseLike<boolean> | boolean;
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Generates a list of embeddings for the given input text.
|
|
47
|
+
*
|
|
48
|
+
* Naming: "do" prefix to prevent accidental direct usage of the method
|
|
49
|
+
* by the user.
|
|
50
|
+
*/
|
|
51
|
+
doEmbed(
|
|
52
|
+
options: EmbeddingModelV4CallOptions,
|
|
53
|
+
): PromiseLike<EmbeddingModelV4Result>;
|
|
54
|
+
};
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { EmbeddingModelV4 } from '../../embedding-model/v4/embedding-model-v4';
|
|
2
|
+
import { EmbeddingModelV4CallOptions } from '../../embedding-model/v4/embedding-model-v4-call-options';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Middleware for EmbeddingModelV4.
|
|
6
|
+
* This type defines the structure for middleware that can be used to modify
|
|
7
|
+
* the behavior of EmbeddingModelV4 operations.
|
|
8
|
+
*/
|
|
9
|
+
export type EmbeddingModelV4Middleware = {
|
|
10
|
+
/**
|
|
11
|
+
* Middleware specification version. Use `v4` for the current version.
|
|
12
|
+
*/
|
|
13
|
+
readonly specificationVersion: 'v4';
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Override the provider name if desired.
|
|
17
|
+
* @param options.model - The embedding model instance.
|
|
18
|
+
*/
|
|
19
|
+
overrideProvider?: (options: { model: EmbeddingModelV4 }) => string;
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Override the model ID if desired.
|
|
23
|
+
* @param options.model - The embedding model instance.
|
|
24
|
+
*/
|
|
25
|
+
overrideModelId?: (options: { model: EmbeddingModelV4 }) => string;
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Override the limit of how many embeddings can be generated in a single API call if desired.
|
|
29
|
+
* @param options.model - The embedding model instance.
|
|
30
|
+
*/
|
|
31
|
+
overrideMaxEmbeddingsPerCall?: (options: {
|
|
32
|
+
model: EmbeddingModelV4;
|
|
33
|
+
}) => PromiseLike<number | undefined> | number | undefined;
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Override support for handling multiple embedding calls in parallel, if desired..
|
|
37
|
+
* @param options.model - The embedding model instance.
|
|
38
|
+
*/
|
|
39
|
+
overrideSupportsParallelCalls?: (options: {
|
|
40
|
+
model: EmbeddingModelV4;
|
|
41
|
+
}) => PromiseLike<boolean> | boolean;
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Transforms the parameters before they are passed to the embed model.
|
|
45
|
+
* @param options - Object containing the type of operation and the parameters.
|
|
46
|
+
* @param options.params - The original parameters for the embedding model call.
|
|
47
|
+
* @returns A promise that resolves to the transformed parameters.
|
|
48
|
+
*/
|
|
49
|
+
transformParams?: (options: {
|
|
50
|
+
params: EmbeddingModelV4CallOptions;
|
|
51
|
+
model: EmbeddingModelV4;
|
|
52
|
+
}) => PromiseLike<EmbeddingModelV4CallOptions>;
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Wraps the embed operation of the embedding model.
|
|
56
|
+
*
|
|
57
|
+
* @param options - Object containing the embed function, parameters, and model.
|
|
58
|
+
* @param options.doEmbed - The original embed function.
|
|
59
|
+
* @param options.params - The parameters for the embed call. If the
|
|
60
|
+
* `transformParams` middleware is used, this will be the transformed parameters.
|
|
61
|
+
* @param options.model - The embedding model instance.
|
|
62
|
+
* @returns A promise that resolves to the result of the generate operation.
|
|
63
|
+
*/
|
|
64
|
+
wrapEmbed?: (options: {
|
|
65
|
+
doEmbed: () => ReturnType<EmbeddingModelV4['doEmbed']>;
|
|
66
|
+
params: EmbeddingModelV4CallOptions;
|
|
67
|
+
model: EmbeddingModelV4;
|
|
68
|
+
}) => Promise<Awaited<ReturnType<EmbeddingModelV4['doEmbed']>>>;
|
|
69
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './embedding-model-v4-middleware';
|
package/src/image-model/index.ts
CHANGED
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { SharedV4ProviderOptions } from '../../shared';
|
|
2
|
+
import { ImageModelV4File } from './image-model-v4-file';
|
|
3
|
+
|
|
4
|
+
export type ImageModelV4CallOptions = {
|
|
5
|
+
/**
|
|
6
|
+
* Prompt for the image generation. Some operations, like upscaling, may not require a prompt.
|
|
7
|
+
*/
|
|
8
|
+
prompt: string | undefined;
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Number of images to generate.
|
|
12
|
+
*/
|
|
13
|
+
n: number;
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Size of the images to generate.
|
|
17
|
+
* Must have the format `{width}x{height}`.
|
|
18
|
+
* `undefined` will use the provider's default size.
|
|
19
|
+
*/
|
|
20
|
+
size: `${number}x${number}` | undefined;
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Aspect ratio of the images to generate.
|
|
24
|
+
* Must have the format `{width}:{height}`.
|
|
25
|
+
* `undefined` will use the provider's default aspect ratio.
|
|
26
|
+
*/
|
|
27
|
+
aspectRatio: `${number}:${number}` | undefined;
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Seed for the image generation.
|
|
31
|
+
* `undefined` will use the provider's default seed.
|
|
32
|
+
*/
|
|
33
|
+
seed: number | undefined;
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Array of images for image editing or variation generation.
|
|
37
|
+
* The images should be provided as base64 encoded strings or binary data.
|
|
38
|
+
*/
|
|
39
|
+
files: ImageModelV4File[] | undefined;
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Mask image for inpainting operations.
|
|
43
|
+
* The mask should be provided as base64 encoded strings or binary data.
|
|
44
|
+
*/
|
|
45
|
+
mask: ImageModelV4File | undefined;
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* Additional provider-specific options that are passed through to the provider
|
|
49
|
+
* as body parameters.
|
|
50
|
+
*
|
|
51
|
+
* The outer record is keyed by the provider name, and the inner
|
|
52
|
+
* record is keyed by the provider-specific metadata key.
|
|
53
|
+
*
|
|
54
|
+
* ```ts
|
|
55
|
+
* {
|
|
56
|
+
* "openai": {
|
|
57
|
+
* "style": "vivid"
|
|
58
|
+
* }
|
|
59
|
+
* }
|
|
60
|
+
* ```
|
|
61
|
+
*/
|
|
62
|
+
providerOptions: SharedV4ProviderOptions;
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Abort signal for cancelling the operation.
|
|
66
|
+
*/
|
|
67
|
+
abortSignal?: AbortSignal;
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* Additional HTTP headers to be sent with the request.
|
|
71
|
+
* Only applicable for HTTP-based providers.
|
|
72
|
+
*/
|
|
73
|
+
headers?: Record<string, string | undefined>;
|
|
74
|
+
};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { SharedV4ProviderMetadata } from '../../shared';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* An image file that can be used for image editing or variation generation.
|
|
5
|
+
*/
|
|
6
|
+
export type ImageModelV4File =
|
|
7
|
+
| {
|
|
8
|
+
type: 'file';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* The IANA media type of the file, e.g. `image/png`. Any string is supported.
|
|
12
|
+
*
|
|
13
|
+
* @see https://www.iana.org/assignments/media-types/media-types.xhtml
|
|
14
|
+
*/
|
|
15
|
+
mediaType: string;
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Generated file data as base64 encoded strings or binary data.
|
|
19
|
+
*
|
|
20
|
+
* The file data should be returned without any unnecessary conversion.
|
|
21
|
+
* If the API returns base64 encoded strings, the file data should be returned
|
|
22
|
+
* as base64 encoded strings. If the API returns binary data, the file data should
|
|
23
|
+
* be returned as binary data.
|
|
24
|
+
*/
|
|
25
|
+
data: string | Uint8Array;
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Optional provider-specific metadata for the file part.
|
|
29
|
+
*/
|
|
30
|
+
providerOptions?: SharedV4ProviderMetadata;
|
|
31
|
+
}
|
|
32
|
+
| {
|
|
33
|
+
type: 'url';
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* The URL of the image file.
|
|
37
|
+
*/
|
|
38
|
+
url: string;
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Optional provider-specific metadata for the file part.
|
|
42
|
+
*/
|
|
43
|
+
providerOptions?: SharedV4ProviderMetadata;
|
|
44
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Usage information for an image model call.
|
|
3
|
+
*/
|
|
4
|
+
export type ImageModelV4Usage = {
|
|
5
|
+
/**
|
|
6
|
+
* The number of input (prompt) tokens used.
|
|
7
|
+
*/
|
|
8
|
+
inputTokens: number | undefined;
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* The number of output tokens used, if reported by the provider.
|
|
12
|
+
*/
|
|
13
|
+
outputTokens: number | undefined;
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* The total number of tokens as reported by the provider.
|
|
17
|
+
*/
|
|
18
|
+
totalTokens: number | undefined;
|
|
19
|
+
};
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { JSONArray, JSONValue } from '../../json-value';
|
|
2
|
+
import { ImageModelV4Usage } from './image-model-v4-usage';
|
|
3
|
+
import { ImageModelV4CallOptions } from './image-model-v4-call-options';
|
|
4
|
+
import { SharedV4Warning } from '../../shared/v4/shared-v4-warning';
|
|
5
|
+
|
|
6
|
+
export type ImageModelV4ProviderMetadata = Record<
|
|
7
|
+
string,
|
|
8
|
+
{
|
|
9
|
+
images: JSONArray;
|
|
10
|
+
} & JSONValue
|
|
11
|
+
>;
|
|
12
|
+
|
|
13
|
+
type GetMaxImagesPerCallFunction = (options: {
|
|
14
|
+
modelId: string;
|
|
15
|
+
}) => PromiseLike<number | undefined> | number | undefined;
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Image generation model specification version 3.
|
|
19
|
+
*/
|
|
20
|
+
export type ImageModelV4 = {
|
|
21
|
+
/**
|
|
22
|
+
* The image model must specify which image model interface
|
|
23
|
+
* version it implements. This will allow us to evolve the image
|
|
24
|
+
* model interface and retain backwards compatibility. The different
|
|
25
|
+
* implementation versions can be handled as a discriminated union
|
|
26
|
+
* on our side.
|
|
27
|
+
*/
|
|
28
|
+
readonly specificationVersion: 'v4';
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Name of the provider for logging purposes.
|
|
32
|
+
*/
|
|
33
|
+
readonly provider: string;
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Provider-specific model ID for logging purposes.
|
|
37
|
+
*/
|
|
38
|
+
readonly modelId: string;
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Limit of how many images can be generated in a single API call.
|
|
42
|
+
* Can be set to a number for a fixed limit, to undefined to use
|
|
43
|
+
* the global limit, or a function that returns a number or undefined,
|
|
44
|
+
* optionally as a promise.
|
|
45
|
+
*/
|
|
46
|
+
readonly maxImagesPerCall: number | undefined | GetMaxImagesPerCallFunction;
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* Generates an array of images.
|
|
50
|
+
*/
|
|
51
|
+
doGenerate(options: ImageModelV4CallOptions): PromiseLike<{
|
|
52
|
+
/**
|
|
53
|
+
* Generated images as base64 encoded strings or binary data.
|
|
54
|
+
* The images should be returned without any unnecessary conversion.
|
|
55
|
+
* If the API returns base64 encoded strings, the images should be returned
|
|
56
|
+
* as base64 encoded strings. If the API returns binary data, the images should
|
|
57
|
+
* be returned as binary data.
|
|
58
|
+
*/
|
|
59
|
+
images: Array<string> | Array<Uint8Array>;
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* Warnings for the call, e.g. unsupported features.
|
|
63
|
+
*/
|
|
64
|
+
warnings: Array<SharedV4Warning>;
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* Additional provider-specific metadata. They are passed through
|
|
68
|
+
* from the provider to the AI SDK and enable provider-specific
|
|
69
|
+
* results that can be fully encapsulated in the provider.
|
|
70
|
+
*
|
|
71
|
+
* The outer record is keyed by the provider name, and the inner
|
|
72
|
+
* record is provider-specific metadata. It always includes an
|
|
73
|
+
* `images` key with image-specific metadata
|
|
74
|
+
*
|
|
75
|
+
* ```ts
|
|
76
|
+
* {
|
|
77
|
+
* "openai": {
|
|
78
|
+
* "images": ["revisedPrompt": "Revised prompt here."]
|
|
79
|
+
* }
|
|
80
|
+
* }
|
|
81
|
+
* ```
|
|
82
|
+
*/
|
|
83
|
+
providerMetadata?: ImageModelV4ProviderMetadata;
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* Response information for telemetry and debugging purposes.
|
|
87
|
+
*/
|
|
88
|
+
response: {
|
|
89
|
+
/**
|
|
90
|
+
* Timestamp for the start of the generated response.
|
|
91
|
+
*/
|
|
92
|
+
timestamp: Date;
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* The ID of the response model that was used to generate the response.
|
|
96
|
+
*/
|
|
97
|
+
modelId: string;
|
|
98
|
+
|
|
99
|
+
/**
|
|
100
|
+
* Response headers.
|
|
101
|
+
*/
|
|
102
|
+
headers: Record<string, string> | undefined;
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Optional token usage for the image generation call (if the provider reports it).
|
|
107
|
+
*/
|
|
108
|
+
usage?: ImageModelV4Usage;
|
|
109
|
+
}>;
|
|
110
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export type {
|
|
2
|
+
ImageModelV4,
|
|
3
|
+
ImageModelV4ProviderMetadata,
|
|
4
|
+
} from './image-model-v4';
|
|
5
|
+
export type { ImageModelV4CallOptions } from './image-model-v4-call-options';
|
|
6
|
+
export type { ImageModelV4Usage } from './image-model-v4-usage';
|
|
7
|
+
export type { ImageModelV4File } from './image-model-v4-file';
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { ImageModelV4 } from '../../image-model/v4/image-model-v4';
|
|
2
|
+
import { ImageModelV4CallOptions } from '../../image-model/v4/image-model-v4-call-options';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Middleware for ImageModelV4.
|
|
6
|
+
* This type defines the structure for middleware that can be used to modify
|
|
7
|
+
* the behavior of ImageModelV4 operations.
|
|
8
|
+
*/
|
|
9
|
+
export type ImageModelV4Middleware = {
|
|
10
|
+
/**
|
|
11
|
+
* Middleware specification version. Use `v4` for the current version.
|
|
12
|
+
*/
|
|
13
|
+
readonly specificationVersion: 'v4';
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Override the provider name if desired.
|
|
17
|
+
* @param options.model - The image model instance.
|
|
18
|
+
*/
|
|
19
|
+
overrideProvider?: (options: { model: ImageModelV4 }) => string;
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Override the model ID if desired.
|
|
23
|
+
* @param options.model - The image model instance.
|
|
24
|
+
*/
|
|
25
|
+
overrideModelId?: (options: { model: ImageModelV4 }) => string;
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Override the limit of how many images can be generated in a single API call if desired.
|
|
29
|
+
* @param options.model - The image model instance.
|
|
30
|
+
*/
|
|
31
|
+
overrideMaxImagesPerCall?: (options: {
|
|
32
|
+
model: ImageModelV4;
|
|
33
|
+
}) => ImageModelV4['maxImagesPerCall'];
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Transforms the parameters before they are passed to the image model.
|
|
37
|
+
* @param options - Object containing the parameters.
|
|
38
|
+
* @param options.params - The original parameters for the image model call.
|
|
39
|
+
* @returns A promise that resolves to the transformed parameters.
|
|
40
|
+
*/
|
|
41
|
+
transformParams?: (options: {
|
|
42
|
+
params: ImageModelV4CallOptions;
|
|
43
|
+
model: ImageModelV4;
|
|
44
|
+
}) => PromiseLike<ImageModelV4CallOptions>;
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Wraps the generate operation of the image model.
|
|
48
|
+
*
|
|
49
|
+
* @param options - Object containing the generate function, parameters, and model.
|
|
50
|
+
* @param options.doGenerate - The original generate function.
|
|
51
|
+
* @param options.params - The parameters for the generate call. If the
|
|
52
|
+
* `transformParams` middleware is used, this will be the transformed parameters.
|
|
53
|
+
* @param options.model - The image model instance.
|
|
54
|
+
* @returns A promise that resolves to the result of the generate operation.
|
|
55
|
+
*/
|
|
56
|
+
wrapGenerate?: (options: {
|
|
57
|
+
doGenerate: () => ReturnType<ImageModelV4['doGenerate']>;
|
|
58
|
+
params: ImageModelV4CallOptions;
|
|
59
|
+
model: ImageModelV4;
|
|
60
|
+
}) => Promise<Awaited<ReturnType<ImageModelV4['doGenerate']>>>;
|
|
61
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './image-model-v4-middleware';
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export * from './language-model-v4';
|
|
2
|
+
export * from './language-model-v4-call-options';
|
|
3
|
+
export * from './language-model-v4-content';
|
|
4
|
+
export * from './language-model-v4-data-content';
|
|
5
|
+
export * from './language-model-v4-file';
|
|
6
|
+
export * from './language-model-v4-finish-reason';
|
|
7
|
+
export * from './language-model-v4-function-tool';
|
|
8
|
+
export * from './language-model-v4-generate-result';
|
|
9
|
+
export * from './language-model-v4-prompt';
|
|
10
|
+
export * from './language-model-v4-provider-tool';
|
|
11
|
+
export * from './language-model-v4-reasoning';
|
|
12
|
+
export * from './language-model-v4-response-metadata';
|
|
13
|
+
export * from './language-model-v4-source';
|
|
14
|
+
export * from './language-model-v4-stream-part';
|
|
15
|
+
export * from './language-model-v4-stream-result';
|
|
16
|
+
export * from './language-model-v4-text';
|
|
17
|
+
export * from './language-model-v4-tool-approval-request';
|
|
18
|
+
export * from './language-model-v4-tool-call';
|
|
19
|
+
export * from './language-model-v4-tool-choice';
|
|
20
|
+
export * from './language-model-v4-tool-result';
|
|
21
|
+
export * from './language-model-v4-usage';
|