@ai-sdk/provider 3.0.2 → 3.0.4
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 +12 -0
- package/dist/index.d.mts +7 -7
- package/dist/index.d.ts +7 -7
- package/package.json +3 -1
- package/src/embedding-model/index.ts +2 -0
- package/src/embedding-model/v2/embedding-model-v2-embedding.ts +5 -0
- package/src/embedding-model/v2/embedding-model-v2.ts +113 -0
- package/src/embedding-model/v2/index.ts +2 -0
- package/src/embedding-model/v3/embedding-model-v3-call-options.ts +26 -0
- package/src/embedding-model/v3/embedding-model-v3-embedding.ts +5 -0
- package/src/embedding-model/v3/embedding-model-v3-result.ts +48 -0
- package/src/embedding-model/v3/embedding-model-v3.ts +54 -0
- package/src/embedding-model/v3/index.ts +4 -0
- package/src/embedding-model-middleware/index.ts +1 -0
- package/src/embedding-model-middleware/v3/embedding-model-v3-middleware.ts +69 -0
- package/src/embedding-model-middleware/v3/index.ts +1 -0
- package/src/errors/ai-sdk-error.ts +62 -0
- package/src/errors/api-call-error.ts +59 -0
- package/src/errors/empty-response-body-error.ts +17 -0
- package/src/errors/get-error-message.ts +15 -0
- package/src/errors/index.ts +15 -0
- package/src/errors/invalid-argument-error.ts +32 -0
- package/src/errors/invalid-prompt-error.ts +33 -0
- package/src/errors/invalid-response-data-error.ts +31 -0
- package/src/errors/json-parse-error.ts +29 -0
- package/src/errors/load-api-key-error.ts +17 -0
- package/src/errors/load-setting-error.ts +17 -0
- package/src/errors/no-content-generated-error.ts +22 -0
- package/src/errors/no-such-model-error.ts +45 -0
- package/src/errors/too-many-embedding-values-for-call-error.ts +40 -0
- package/src/errors/type-validation-error.ts +51 -0
- package/src/errors/unsupported-functionality-error.ts +26 -0
- package/src/image-model/index.ts +2 -0
- package/src/image-model/v2/image-model-v2-call-options.ts +60 -0
- package/src/image-model/v2/image-model-v2-call-warning.ts +16 -0
- package/src/image-model/v2/image-model-v2.ts +104 -0
- package/src/image-model/v2/index.ts +6 -0
- package/src/image-model/v3/image-model-v3-call-options.ts +74 -0
- package/src/image-model/v3/image-model-v3-file.ts +44 -0
- package/src/image-model/v3/image-model-v3-usage.ts +19 -0
- package/src/image-model/v3/image-model-v3.ts +110 -0
- package/src/image-model/v3/index.ts +7 -0
- package/src/image-model-middleware/index.ts +1 -0
- package/src/image-model-middleware/v3/image-model-v3-middleware.ts +61 -0
- package/src/image-model-middleware/v3/index.ts +1 -0
- package/src/index.ts +15 -0
- package/src/json-value/index.ts +2 -0
- package/src/json-value/is-json.ts +40 -0
- package/src/json-value/json-value.ts +17 -0
- package/src/language-model/index.ts +2 -0
- package/src/language-model/v2/index.ts +18 -0
- package/src/language-model/v2/language-model-v2-call-options.ts +127 -0
- package/src/language-model/v2/language-model-v2-call-warning.ts +23 -0
- package/src/language-model/v2/language-model-v2-content.ts +14 -0
- package/src/language-model/v2/language-model-v2-data-content.ts +4 -0
- package/src/language-model/v2/language-model-v2-file.ts +25 -0
- package/src/language-model/v2/language-model-v2-finish-reason.ts +20 -0
- package/src/language-model/v2/language-model-v2-function-tool.ts +37 -0
- package/src/language-model/v2/language-model-v2-prompt.ts +218 -0
- package/src/language-model/v2/language-model-v2-provider-defined-tool.ts +24 -0
- package/src/language-model/v2/language-model-v2-reasoning.ts +14 -0
- package/src/language-model/v2/language-model-v2-response-metadata.ts +16 -0
- package/src/language-model/v2/language-model-v2-source.ts +67 -0
- package/src/language-model/v2/language-model-v2-stream-part.ts +102 -0
- package/src/language-model/v2/language-model-v2-text.ts +15 -0
- package/src/language-model/v2/language-model-v2-tool-call.ts +35 -0
- package/src/language-model/v2/language-model-v2-tool-choice.ts +5 -0
- package/src/language-model/v2/language-model-v2-tool-result.ts +40 -0
- package/src/language-model/v2/language-model-v2-usage.ts +34 -0
- package/src/language-model/v2/language-model-v2.ts +137 -0
- package/src/language-model/v3/index.ts +21 -0
- package/src/language-model/v3/language-model-v3-call-options.ts +125 -0
- package/src/language-model/v3/language-model-v3-content.ts +16 -0
- package/src/language-model/v3/language-model-v3-data-content.ts +4 -0
- package/src/language-model/v3/language-model-v3-file.ts +32 -0
- package/src/language-model/v3/language-model-v3-finish-reason.ts +33 -0
- package/src/language-model/v3/language-model-v3-function-tool.ts +53 -0
- package/src/language-model/v3/language-model-v3-generate-result.ts +63 -0
- package/src/language-model/v3/language-model-v3-prompt.ts +422 -0
- package/src/language-model/v3/language-model-v3-provider-tool.ts +28 -0
- package/src/language-model/v3/language-model-v3-reasoning.ts +14 -0
- package/src/language-model/v3/language-model-v3-response-metadata.ts +16 -0
- package/src/language-model/v3/language-model-v3-source.ts +67 -0
- package/src/language-model/v3/language-model-v3-stream-part.ts +106 -0
- package/src/language-model/v3/language-model-v3-stream-result.ts +32 -0
- package/src/language-model/v3/language-model-v3-text.ts +15 -0
- package/src/language-model/v3/language-model-v3-tool-approval-request.ts +27 -0
- package/src/language-model/v3/language-model-v3-tool-call.ts +41 -0
- package/src/language-model/v3/language-model-v3-tool-choice.ts +5 -0
- package/src/language-model/v3/language-model-v3-tool-result.ts +51 -0
- package/src/language-model/v3/language-model-v3-usage.ts +59 -0
- package/src/language-model/v3/language-model-v3.ts +61 -0
- package/src/language-model-middleware/index.ts +2 -0
- package/src/language-model-middleware/v2/index.ts +1 -0
- package/src/language-model-middleware/v2/language-model-v2-middleware.ts +82 -0
- package/src/language-model-middleware/v3/index.ts +1 -0
- package/src/language-model-middleware/v3/language-model-v3-middleware.ts +84 -0
- package/src/provider/index.ts +2 -0
- package/src/provider/v2/index.ts +1 -0
- package/src/provider/v2/provider-v2.ts +64 -0
- package/src/provider/v3/index.ts +1 -0
- package/src/provider/v3/provider-v3.ts +93 -0
- package/src/reranking-model/index.ts +1 -0
- package/src/reranking-model/v3/index.ts +2 -0
- package/src/reranking-model/v3/reranking-model-v3-call-options.ts +40 -0
- package/src/reranking-model/v3/reranking-model-v3.ts +90 -0
- package/src/shared/index.ts +2 -0
- package/src/shared/v2/index.ts +3 -0
- package/src/shared/v2/shared-v2-headers.ts +1 -0
- package/src/shared/v2/shared-v2-provider-metadata.ts +27 -0
- package/src/shared/v2/shared-v2-provider-options.ts +24 -0
- package/src/shared/v3/index.ts +4 -0
- package/src/shared/v3/shared-v3-headers.ts +1 -0
- package/src/shared/v3/shared-v3-provider-metadata.ts +24 -0
- package/src/shared/v3/shared-v3-provider-options.ts +24 -0
- package/src/shared/v3/shared-v3-warning.ts +50 -0
- package/src/speech-model/index.ts +2 -0
- package/src/speech-model/v2/index.ts +3 -0
- package/src/speech-model/v2/speech-model-v2-call-options.ts +62 -0
- package/src/speech-model/v2/speech-model-v2-call-warning.ts +16 -0
- package/src/speech-model/v2/speech-model-v2.ts +89 -0
- package/src/speech-model/v3/index.ts +2 -0
- package/src/speech-model/v3/speech-model-v3-call-options.ts +62 -0
- package/src/speech-model/v3/speech-model-v3.ts +89 -0
- package/src/transcription-model/index.ts +2 -0
- package/src/transcription-model/v2/index.ts +3 -0
- package/src/transcription-model/v2/transcription-model-v2-call-options.ts +48 -0
- package/src/transcription-model/v2/transcription-model-v2-call-warning.ts +16 -0
- package/src/transcription-model/v2/transcription-model-v2.ts +117 -0
- package/src/transcription-model/v3/index.ts +2 -0
- package/src/transcription-model/v3/transcription-model-v3-call-options.ts +45 -0
- package/src/transcription-model/v3/transcription-model-v3.ts +117 -0
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
|
|
3
|
+
const name = 'AI_InvalidArgumentError';
|
|
4
|
+
const marker = `vercel.ai.error.${name}`;
|
|
5
|
+
const symbol = Symbol.for(marker);
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* A function argument is invalid.
|
|
9
|
+
*/
|
|
10
|
+
export class InvalidArgumentError extends AISDKError {
|
|
11
|
+
private readonly [symbol] = true; // used in isInstance
|
|
12
|
+
|
|
13
|
+
readonly argument: string;
|
|
14
|
+
|
|
15
|
+
constructor({
|
|
16
|
+
message,
|
|
17
|
+
cause,
|
|
18
|
+
argument,
|
|
19
|
+
}: {
|
|
20
|
+
argument: string;
|
|
21
|
+
message: string;
|
|
22
|
+
cause?: unknown;
|
|
23
|
+
}) {
|
|
24
|
+
super({ name, message, cause });
|
|
25
|
+
|
|
26
|
+
this.argument = argument;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
static isInstance(error: unknown): error is InvalidArgumentError {
|
|
30
|
+
return AISDKError.hasMarker(error, marker);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
|
|
3
|
+
const name = 'AI_InvalidPromptError';
|
|
4
|
+
const marker = `vercel.ai.error.${name}`;
|
|
5
|
+
const symbol = Symbol.for(marker);
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* A prompt is invalid. This error should be thrown by providers when they cannot
|
|
9
|
+
* process a prompt.
|
|
10
|
+
*/
|
|
11
|
+
export class InvalidPromptError extends AISDKError {
|
|
12
|
+
private readonly [symbol] = true; // used in isInstance
|
|
13
|
+
|
|
14
|
+
readonly prompt: unknown;
|
|
15
|
+
|
|
16
|
+
constructor({
|
|
17
|
+
prompt,
|
|
18
|
+
message,
|
|
19
|
+
cause,
|
|
20
|
+
}: {
|
|
21
|
+
prompt: unknown;
|
|
22
|
+
message: string;
|
|
23
|
+
cause?: unknown;
|
|
24
|
+
}) {
|
|
25
|
+
super({ name, message: `Invalid prompt: ${message}`, cause });
|
|
26
|
+
|
|
27
|
+
this.prompt = prompt;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
static isInstance(error: unknown): error is InvalidPromptError {
|
|
31
|
+
return AISDKError.hasMarker(error, marker);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
|
|
3
|
+
const name = 'AI_InvalidResponseDataError';
|
|
4
|
+
const marker = `vercel.ai.error.${name}`;
|
|
5
|
+
const symbol = Symbol.for(marker);
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Server returned a response with invalid data content.
|
|
9
|
+
* This should be thrown by providers when they cannot parse the response from the API.
|
|
10
|
+
*/
|
|
11
|
+
export class InvalidResponseDataError extends AISDKError {
|
|
12
|
+
private readonly [symbol] = true; // used in isInstance
|
|
13
|
+
|
|
14
|
+
readonly data: unknown;
|
|
15
|
+
|
|
16
|
+
constructor({
|
|
17
|
+
data,
|
|
18
|
+
message = `Invalid response data: ${JSON.stringify(data)}.`,
|
|
19
|
+
}: {
|
|
20
|
+
data: unknown;
|
|
21
|
+
message?: string;
|
|
22
|
+
}) {
|
|
23
|
+
super({ name, message });
|
|
24
|
+
|
|
25
|
+
this.data = data;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
static isInstance(error: unknown): error is InvalidResponseDataError {
|
|
29
|
+
return AISDKError.hasMarker(error, marker);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
import { getErrorMessage } from './get-error-message';
|
|
3
|
+
|
|
4
|
+
const name = 'AI_JSONParseError';
|
|
5
|
+
const marker = `vercel.ai.error.${name}`;
|
|
6
|
+
const symbol = Symbol.for(marker);
|
|
7
|
+
|
|
8
|
+
export class JSONParseError extends AISDKError {
|
|
9
|
+
private readonly [symbol] = true; // used in isInstance
|
|
10
|
+
|
|
11
|
+
readonly text: string;
|
|
12
|
+
|
|
13
|
+
constructor({ text, cause }: { text: string; cause: unknown }) {
|
|
14
|
+
super({
|
|
15
|
+
name,
|
|
16
|
+
message:
|
|
17
|
+
`JSON parsing failed: ` +
|
|
18
|
+
`Text: ${text}.\n` +
|
|
19
|
+
`Error message: ${getErrorMessage(cause)}`,
|
|
20
|
+
cause,
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
this.text = text;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
static isInstance(error: unknown): error is JSONParseError {
|
|
27
|
+
return AISDKError.hasMarker(error, marker);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
|
|
3
|
+
const name = 'AI_LoadAPIKeyError';
|
|
4
|
+
const marker = `vercel.ai.error.${name}`;
|
|
5
|
+
const symbol = Symbol.for(marker);
|
|
6
|
+
|
|
7
|
+
export class LoadAPIKeyError extends AISDKError {
|
|
8
|
+
private readonly [symbol] = true; // used in isInstance
|
|
9
|
+
|
|
10
|
+
constructor({ message }: { message: string }) {
|
|
11
|
+
super({ name, message });
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
static isInstance(error: unknown): error is LoadAPIKeyError {
|
|
15
|
+
return AISDKError.hasMarker(error, marker);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
|
|
3
|
+
const name = 'AI_LoadSettingError';
|
|
4
|
+
const marker = `vercel.ai.error.${name}`;
|
|
5
|
+
const symbol = Symbol.for(marker);
|
|
6
|
+
|
|
7
|
+
export class LoadSettingError extends AISDKError {
|
|
8
|
+
private readonly [symbol] = true; // used in isInstance
|
|
9
|
+
|
|
10
|
+
constructor({ message }: { message: string }) {
|
|
11
|
+
super({ name, message });
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
static isInstance(error: unknown): error is LoadSettingError {
|
|
15
|
+
return AISDKError.hasMarker(error, marker);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
|
|
3
|
+
const name = 'AI_NoContentGeneratedError';
|
|
4
|
+
const marker = `vercel.ai.error.${name}`;
|
|
5
|
+
const symbol = Symbol.for(marker);
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
Thrown when the AI provider fails to generate any content.
|
|
9
|
+
*/
|
|
10
|
+
export class NoContentGeneratedError extends AISDKError {
|
|
11
|
+
private readonly [symbol] = true; // used in isInstance
|
|
12
|
+
|
|
13
|
+
constructor({
|
|
14
|
+
message = 'No content generated.',
|
|
15
|
+
}: { message?: string } = {}) {
|
|
16
|
+
super({ name, message });
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
static isInstance(error: unknown): error is NoContentGeneratedError {
|
|
20
|
+
return AISDKError.hasMarker(error, marker);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
|
|
3
|
+
const name = 'AI_NoSuchModelError';
|
|
4
|
+
const marker = `vercel.ai.error.${name}`;
|
|
5
|
+
const symbol = Symbol.for(marker);
|
|
6
|
+
|
|
7
|
+
export class NoSuchModelError extends AISDKError {
|
|
8
|
+
private readonly [symbol] = true; // used in isInstance
|
|
9
|
+
|
|
10
|
+
readonly modelId: string;
|
|
11
|
+
readonly modelType:
|
|
12
|
+
| 'languageModel'
|
|
13
|
+
| 'embeddingModel'
|
|
14
|
+
| 'imageModel'
|
|
15
|
+
| 'transcriptionModel'
|
|
16
|
+
| 'speechModel'
|
|
17
|
+
| 'rerankingModel';
|
|
18
|
+
|
|
19
|
+
constructor({
|
|
20
|
+
errorName = name,
|
|
21
|
+
modelId,
|
|
22
|
+
modelType,
|
|
23
|
+
message = `No such ${modelType}: ${modelId}`,
|
|
24
|
+
}: {
|
|
25
|
+
errorName?: string;
|
|
26
|
+
modelId: string;
|
|
27
|
+
modelType:
|
|
28
|
+
| 'languageModel'
|
|
29
|
+
| 'embeddingModel'
|
|
30
|
+
| 'imageModel'
|
|
31
|
+
| 'transcriptionModel'
|
|
32
|
+
| 'speechModel'
|
|
33
|
+
| 'rerankingModel';
|
|
34
|
+
message?: string;
|
|
35
|
+
}) {
|
|
36
|
+
super({ name: errorName, message });
|
|
37
|
+
|
|
38
|
+
this.modelId = modelId;
|
|
39
|
+
this.modelType = modelType;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
static isInstance(error: unknown): error is NoSuchModelError {
|
|
43
|
+
return AISDKError.hasMarker(error, marker);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
|
|
3
|
+
const name = 'AI_TooManyEmbeddingValuesForCallError';
|
|
4
|
+
const marker = `vercel.ai.error.${name}`;
|
|
5
|
+
const symbol = Symbol.for(marker);
|
|
6
|
+
|
|
7
|
+
export class TooManyEmbeddingValuesForCallError extends AISDKError {
|
|
8
|
+
private readonly [symbol] = true; // used in isInstance
|
|
9
|
+
|
|
10
|
+
readonly provider: string;
|
|
11
|
+
readonly modelId: string;
|
|
12
|
+
readonly maxEmbeddingsPerCall: number;
|
|
13
|
+
readonly values: Array<unknown>;
|
|
14
|
+
|
|
15
|
+
constructor(options: {
|
|
16
|
+
provider: string;
|
|
17
|
+
modelId: string;
|
|
18
|
+
maxEmbeddingsPerCall: number;
|
|
19
|
+
values: Array<unknown>;
|
|
20
|
+
}) {
|
|
21
|
+
super({
|
|
22
|
+
name,
|
|
23
|
+
message:
|
|
24
|
+
`Too many values for a single embedding call. ` +
|
|
25
|
+
`The ${options.provider} model "${options.modelId}" can only embed up to ` +
|
|
26
|
+
`${options.maxEmbeddingsPerCall} values per call, but ${options.values.length} values were provided.`,
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
this.provider = options.provider;
|
|
30
|
+
this.modelId = options.modelId;
|
|
31
|
+
this.maxEmbeddingsPerCall = options.maxEmbeddingsPerCall;
|
|
32
|
+
this.values = options.values;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
static isInstance(
|
|
36
|
+
error: unknown,
|
|
37
|
+
): error is TooManyEmbeddingValuesForCallError {
|
|
38
|
+
return AISDKError.hasMarker(error, marker);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
import { getErrorMessage } from './get-error-message';
|
|
3
|
+
|
|
4
|
+
const name = 'AI_TypeValidationError';
|
|
5
|
+
const marker = `vercel.ai.error.${name}`;
|
|
6
|
+
const symbol = Symbol.for(marker);
|
|
7
|
+
|
|
8
|
+
export class TypeValidationError extends AISDKError {
|
|
9
|
+
private readonly [symbol] = true; // used in isInstance
|
|
10
|
+
|
|
11
|
+
readonly value: unknown;
|
|
12
|
+
|
|
13
|
+
constructor({ value, cause }: { value: unknown; cause: unknown }) {
|
|
14
|
+
super({
|
|
15
|
+
name,
|
|
16
|
+
message:
|
|
17
|
+
`Type validation failed: ` +
|
|
18
|
+
`Value: ${JSON.stringify(value)}.\n` +
|
|
19
|
+
`Error message: ${getErrorMessage(cause)}`,
|
|
20
|
+
cause,
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
this.value = value;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
static isInstance(error: unknown): error is TypeValidationError {
|
|
27
|
+
return AISDKError.hasMarker(error, marker);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Wraps an error into a TypeValidationError.
|
|
32
|
+
* If the cause is already a TypeValidationError with the same value, it returns the cause.
|
|
33
|
+
* Otherwise, it creates a new TypeValidationError.
|
|
34
|
+
*
|
|
35
|
+
* @param {Object} params - The parameters for wrapping the error.
|
|
36
|
+
* @param {unknown} params.value - The value that failed validation.
|
|
37
|
+
* @param {unknown} params.cause - The original error or cause of the validation failure.
|
|
38
|
+
* @returns {TypeValidationError} A TypeValidationError instance.
|
|
39
|
+
*/
|
|
40
|
+
static wrap({
|
|
41
|
+
value,
|
|
42
|
+
cause,
|
|
43
|
+
}: {
|
|
44
|
+
value: unknown;
|
|
45
|
+
cause: unknown;
|
|
46
|
+
}): TypeValidationError {
|
|
47
|
+
return TypeValidationError.isInstance(cause) && cause.value === value
|
|
48
|
+
? cause
|
|
49
|
+
: new TypeValidationError({ value, cause });
|
|
50
|
+
}
|
|
51
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { AISDKError } from './ai-sdk-error';
|
|
2
|
+
|
|
3
|
+
const name = 'AI_UnsupportedFunctionalityError';
|
|
4
|
+
const marker = `vercel.ai.error.${name}`;
|
|
5
|
+
const symbol = Symbol.for(marker);
|
|
6
|
+
|
|
7
|
+
export class UnsupportedFunctionalityError extends AISDKError {
|
|
8
|
+
private readonly [symbol] = true; // used in isInstance
|
|
9
|
+
|
|
10
|
+
readonly functionality: string;
|
|
11
|
+
|
|
12
|
+
constructor({
|
|
13
|
+
functionality,
|
|
14
|
+
message = `'${functionality}' functionality not supported.`,
|
|
15
|
+
}: {
|
|
16
|
+
functionality: string;
|
|
17
|
+
message?: string;
|
|
18
|
+
}) {
|
|
19
|
+
super({ name, message });
|
|
20
|
+
this.functionality = functionality;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
static isInstance(error: unknown): error is UnsupportedFunctionalityError {
|
|
24
|
+
return AISDKError.hasMarker(error, marker);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { SharedV2ProviderOptions } from '../../shared';
|
|
2
|
+
|
|
3
|
+
export type ImageModelV2CallOptions = {
|
|
4
|
+
/**
|
|
5
|
+
Prompt for the image generation.
|
|
6
|
+
*/
|
|
7
|
+
prompt: string;
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
Number of images to generate.
|
|
11
|
+
*/
|
|
12
|
+
n: number;
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
Size of the images to generate.
|
|
16
|
+
Must have the format `{width}x{height}`.
|
|
17
|
+
`undefined` will use the provider's default size.
|
|
18
|
+
*/
|
|
19
|
+
size: `${number}x${number}` | undefined;
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
Aspect ratio of the images to generate.
|
|
23
|
+
Must have the format `{width}:{height}`.
|
|
24
|
+
`undefined` will use the provider's default aspect ratio.
|
|
25
|
+
*/
|
|
26
|
+
aspectRatio: `${number}:${number}` | undefined;
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
Seed for the image generation.
|
|
30
|
+
`undefined` will use the provider's default seed.
|
|
31
|
+
*/
|
|
32
|
+
seed: number | undefined;
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
Additional provider-specific options that are passed through to the provider
|
|
36
|
+
as body parameters.
|
|
37
|
+
|
|
38
|
+
The outer record is keyed by the provider name, and the inner
|
|
39
|
+
record is keyed by the provider-specific metadata key.
|
|
40
|
+
```ts
|
|
41
|
+
{
|
|
42
|
+
"openai": {
|
|
43
|
+
"style": "vivid"
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
```
|
|
47
|
+
*/
|
|
48
|
+
providerOptions: SharedV2ProviderOptions;
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
Abort signal for cancelling the operation.
|
|
52
|
+
*/
|
|
53
|
+
abortSignal?: AbortSignal;
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
Additional HTTP headers to be sent with the request.
|
|
57
|
+
Only applicable for HTTP-based providers.
|
|
58
|
+
*/
|
|
59
|
+
headers?: Record<string, string | undefined>;
|
|
60
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ImageModelV2CallOptions } from './image-model-v2-call-options';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
Warning from the model provider for this call. The call will proceed, but e.g.
|
|
5
|
+
some settings might not be supported, which can lead to suboptimal results.
|
|
6
|
+
*/
|
|
7
|
+
export type ImageModelV2CallWarning =
|
|
8
|
+
| {
|
|
9
|
+
type: 'unsupported-setting';
|
|
10
|
+
setting: keyof ImageModelV2CallOptions;
|
|
11
|
+
details?: string;
|
|
12
|
+
}
|
|
13
|
+
| {
|
|
14
|
+
type: 'other';
|
|
15
|
+
message: string;
|
|
16
|
+
};
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { JSONArray, JSONValue } from '../../json-value';
|
|
2
|
+
import { ImageModelV2CallOptions } from './image-model-v2-call-options';
|
|
3
|
+
import { ImageModelV2CallWarning } from './image-model-v2-call-warning';
|
|
4
|
+
|
|
5
|
+
export type ImageModelV2ProviderMetadata = Record<
|
|
6
|
+
string,
|
|
7
|
+
{
|
|
8
|
+
images: JSONArray;
|
|
9
|
+
} & JSONValue
|
|
10
|
+
>;
|
|
11
|
+
|
|
12
|
+
type GetMaxImagesPerCallFunction = (options: {
|
|
13
|
+
modelId: string;
|
|
14
|
+
}) => PromiseLike<number | undefined> | number | undefined;
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
Image generation model specification version 2.
|
|
18
|
+
*/
|
|
19
|
+
export type ImageModelV2 = {
|
|
20
|
+
/**
|
|
21
|
+
The image model must specify which image model interface
|
|
22
|
+
version it implements. This will allow us to evolve the image
|
|
23
|
+
model interface and retain backwards compatibility. The different
|
|
24
|
+
implementation versions can be handled as a discriminated union
|
|
25
|
+
on our side.
|
|
26
|
+
*/
|
|
27
|
+
readonly specificationVersion: 'v2';
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
Name of the provider for logging purposes.
|
|
31
|
+
*/
|
|
32
|
+
readonly provider: string;
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
Provider-specific model ID for logging purposes.
|
|
36
|
+
*/
|
|
37
|
+
readonly modelId: string;
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
Limit of how many images can be generated in a single API call.
|
|
41
|
+
Can be set to a number for a fixed limit, to undefined to use
|
|
42
|
+
the global limit, or a function that returns a number or undefined,
|
|
43
|
+
optionally as a promise.
|
|
44
|
+
*/
|
|
45
|
+
readonly maxImagesPerCall: number | undefined | GetMaxImagesPerCallFunction;
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
Generates an array of images.
|
|
49
|
+
*/
|
|
50
|
+
doGenerate(options: ImageModelV2CallOptions): PromiseLike<{
|
|
51
|
+
/**
|
|
52
|
+
Generated images as base64 encoded strings or binary data.
|
|
53
|
+
The images should be returned without any unnecessary conversion.
|
|
54
|
+
If the API returns base64 encoded strings, the images should be returned
|
|
55
|
+
as base64 encoded strings. If the API returns binary data, the images should
|
|
56
|
+
be returned as binary data.
|
|
57
|
+
*/
|
|
58
|
+
images: Array<string> | Array<Uint8Array>;
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
Warnings for the call, e.g. unsupported settings.
|
|
62
|
+
*/
|
|
63
|
+
warnings: Array<ImageModelV2CallWarning>;
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
Additional provider-specific metadata. They are passed through
|
|
67
|
+
from the provider to the AI SDK and enable provider-specific
|
|
68
|
+
results that can be fully encapsulated in the provider.
|
|
69
|
+
|
|
70
|
+
The outer record is keyed by the provider name, and the inner
|
|
71
|
+
record is provider-specific metadata. It always includes an
|
|
72
|
+
`images` key with image-specific metadata
|
|
73
|
+
|
|
74
|
+
```ts
|
|
75
|
+
{
|
|
76
|
+
"openai": {
|
|
77
|
+
"images": ["revisedPrompt": "Revised prompt here."]
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
```
|
|
81
|
+
*/
|
|
82
|
+
providerMetadata?: ImageModelV2ProviderMetadata;
|
|
83
|
+
|
|
84
|
+
/**
|
|
85
|
+
Response information for telemetry and debugging purposes.
|
|
86
|
+
*/
|
|
87
|
+
response: {
|
|
88
|
+
/**
|
|
89
|
+
Timestamp for the start of the generated response.
|
|
90
|
+
*/
|
|
91
|
+
timestamp: Date;
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
The ID of the response model that was used to generate the response.
|
|
95
|
+
*/
|
|
96
|
+
modelId: string;
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
Response headers.
|
|
100
|
+
*/
|
|
101
|
+
headers: Record<string, string> | undefined;
|
|
102
|
+
};
|
|
103
|
+
}>;
|
|
104
|
+
};
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { SharedV3ProviderOptions } from '../../shared';
|
|
2
|
+
import { ImageModelV3File } from './image-model-v3-file';
|
|
3
|
+
|
|
4
|
+
export type ImageModelV3CallOptions = {
|
|
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: ImageModelV3File[] | 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: ImageModelV3File | 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: SharedV3ProviderOptions;
|
|
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 { SharedV3ProviderMetadata } from '../../shared';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* An image file that can be used for image editing or variation generation.
|
|
5
|
+
*/
|
|
6
|
+
export type ImageModelV3File =
|
|
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?: SharedV3ProviderMetadata;
|
|
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?: SharedV3ProviderMetadata;
|
|
44
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
Usage information for an image model call.
|
|
3
|
+
*/
|
|
4
|
+
export type ImageModelV3Usage = {
|
|
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
|
+
};
|