@ai-sdk/provider 0.0.0-01d6317c-20260129172110
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 +967 -0
- package/LICENSE +13 -0
- package/README.md +1 -0
- package/dist/index.d.mts +3814 -0
- package/dist/index.d.ts +3814 -0
- package/dist/index.js +448 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +404 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +63 -0
- 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 +16 -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 +108 -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,40 @@
|
|
|
1
|
+
import { JSONArray, JSONObject, JSONValue } from './json-value';
|
|
2
|
+
|
|
3
|
+
export function isJSONValue(value: unknown): value is JSONValue {
|
|
4
|
+
if (
|
|
5
|
+
value === null ||
|
|
6
|
+
typeof value === 'string' ||
|
|
7
|
+
typeof value === 'number' ||
|
|
8
|
+
typeof value === 'boolean'
|
|
9
|
+
) {
|
|
10
|
+
return true;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
if (Array.isArray(value)) {
|
|
14
|
+
return value.every(isJSONValue);
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
if (typeof value === 'object') {
|
|
18
|
+
return Object.entries(value).every(
|
|
19
|
+
([key, val]) =>
|
|
20
|
+
typeof key === 'string' && (val === undefined || isJSONValue(val)),
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export function isJSONArray(value: unknown): value is JSONArray {
|
|
28
|
+
return Array.isArray(value) && value.every(isJSONValue);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export function isJSONObject(value: unknown): value is JSONObject {
|
|
32
|
+
return (
|
|
33
|
+
value != null &&
|
|
34
|
+
typeof value === 'object' &&
|
|
35
|
+
Object.entries(value).every(
|
|
36
|
+
([key, val]) =>
|
|
37
|
+
typeof key === 'string' && (val === undefined || isJSONValue(val)),
|
|
38
|
+
)
|
|
39
|
+
);
|
|
40
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A JSON value can be a string, number, boolean, object, array, or null.
|
|
3
|
+
* JSON values can be serialized and deserialized by the JSON.stringify and JSON.parse methods.
|
|
4
|
+
*/
|
|
5
|
+
export type JSONValue =
|
|
6
|
+
| null
|
|
7
|
+
| string
|
|
8
|
+
| number
|
|
9
|
+
| boolean
|
|
10
|
+
| JSONObject
|
|
11
|
+
| JSONArray;
|
|
12
|
+
|
|
13
|
+
export type JSONObject = {
|
|
14
|
+
[key: string]: JSONValue | undefined;
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
export type JSONArray = JSONValue[];
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export * from './language-model-v2';
|
|
2
|
+
export * from './language-model-v2-call-options';
|
|
3
|
+
export * from './language-model-v2-call-warning';
|
|
4
|
+
export * from './language-model-v2-content';
|
|
5
|
+
export * from './language-model-v2-data-content';
|
|
6
|
+
export * from './language-model-v2-file';
|
|
7
|
+
export * from './language-model-v2-finish-reason';
|
|
8
|
+
export * from './language-model-v2-function-tool';
|
|
9
|
+
export * from './language-model-v2-prompt';
|
|
10
|
+
export * from './language-model-v2-provider-defined-tool';
|
|
11
|
+
export * from './language-model-v2-reasoning';
|
|
12
|
+
export * from './language-model-v2-response-metadata';
|
|
13
|
+
export * from './language-model-v2-source';
|
|
14
|
+
export * from './language-model-v2-stream-part';
|
|
15
|
+
export * from './language-model-v2-text';
|
|
16
|
+
export * from './language-model-v2-tool-call';
|
|
17
|
+
export * from './language-model-v2-tool-choice';
|
|
18
|
+
export * from './language-model-v2-usage';
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { JSONSchema7 } from 'json-schema';
|
|
2
|
+
import { SharedV2ProviderOptions } from '../../shared/v2/shared-v2-provider-options';
|
|
3
|
+
import { LanguageModelV2FunctionTool } from './language-model-v2-function-tool';
|
|
4
|
+
import { LanguageModelV2Prompt } from './language-model-v2-prompt';
|
|
5
|
+
import { LanguageModelV2ProviderDefinedTool } from './language-model-v2-provider-defined-tool';
|
|
6
|
+
import { LanguageModelV2ToolChoice } from './language-model-v2-tool-choice';
|
|
7
|
+
|
|
8
|
+
export type LanguageModelV2CallOptions = {
|
|
9
|
+
/**
|
|
10
|
+
* A language mode prompt is a standardized prompt type.
|
|
11
|
+
*
|
|
12
|
+
* Note: This is **not** the user-facing prompt. The AI SDK methods will map the
|
|
13
|
+
* user-facing prompt types such as chat or instruction prompts to this format.
|
|
14
|
+
* That approach allows us to evolve the user facing prompts without breaking
|
|
15
|
+
* the language model interface.
|
|
16
|
+
*/
|
|
17
|
+
prompt: LanguageModelV2Prompt;
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* Maximum number of tokens to generate.
|
|
21
|
+
*/
|
|
22
|
+
maxOutputTokens?: number;
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Temperature setting. The range depends on the provider and model.
|
|
26
|
+
*/
|
|
27
|
+
temperature?: number;
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Stop sequences.
|
|
31
|
+
* If set, the model will stop generating text when one of the stop sequences is generated.
|
|
32
|
+
* Providers may have limits on the number of stop sequences.
|
|
33
|
+
*/
|
|
34
|
+
stopSequences?: string[];
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Nucleus sampling.
|
|
38
|
+
*/
|
|
39
|
+
topP?: number;
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Only sample from the top K options for each subsequent token.
|
|
43
|
+
*
|
|
44
|
+
* Used to remove "long tail" low probability responses.
|
|
45
|
+
* Recommended for advanced use cases only. You usually only need to use temperature.
|
|
46
|
+
*/
|
|
47
|
+
topK?: number;
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* Presence penalty setting. It affects the likelihood of the model to
|
|
51
|
+
* repeat information that is already in the prompt.
|
|
52
|
+
*/
|
|
53
|
+
presencePenalty?: number;
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Frequency penalty setting. It affects the likelihood of the model
|
|
57
|
+
* to repeatedly use the same words or phrases.
|
|
58
|
+
*/
|
|
59
|
+
frequencyPenalty?: number;
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* Response format. The output can either be text or JSON. Default is text.
|
|
63
|
+
*
|
|
64
|
+
* If JSON is selected, a schema can optionally be provided to guide the LLM.
|
|
65
|
+
*/
|
|
66
|
+
responseFormat?:
|
|
67
|
+
| { type: 'text' }
|
|
68
|
+
| {
|
|
69
|
+
type: 'json';
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* JSON schema that the generated output should conform to.
|
|
73
|
+
*/
|
|
74
|
+
schema?: JSONSchema7;
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* Name of output that should be generated. Used by some providers for additional LLM guidance.
|
|
78
|
+
*/
|
|
79
|
+
name?: string;
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* Description of the output that should be generated. Used by some providers for additional LLM guidance.
|
|
83
|
+
*/
|
|
84
|
+
description?: string;
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
/**
|
|
88
|
+
* The seed (integer) to use for random sampling. If set and supported
|
|
89
|
+
* by the model, calls will generate deterministic results.
|
|
90
|
+
*/
|
|
91
|
+
seed?: number;
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
* The tools that are available for the model.
|
|
95
|
+
*/
|
|
96
|
+
tools?: Array<
|
|
97
|
+
LanguageModelV2FunctionTool | LanguageModelV2ProviderDefinedTool
|
|
98
|
+
>;
|
|
99
|
+
|
|
100
|
+
/**
|
|
101
|
+
* Specifies how the tool should be selected. Defaults to 'auto'.
|
|
102
|
+
*/
|
|
103
|
+
toolChoice?: LanguageModelV2ToolChoice;
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Include raw chunks in the stream. Only applicable for streaming calls.
|
|
107
|
+
*/
|
|
108
|
+
includeRawChunks?: boolean;
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* Abort signal for cancelling the operation.
|
|
112
|
+
*/
|
|
113
|
+
abortSignal?: AbortSignal;
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
* Additional HTTP headers to be sent with the request.
|
|
117
|
+
* Only applicable for HTTP-based providers.
|
|
118
|
+
*/
|
|
119
|
+
headers?: Record<string, string | undefined>;
|
|
120
|
+
|
|
121
|
+
/**
|
|
122
|
+
* Additional provider-specific options. They are passed through
|
|
123
|
+
* to the provider from the AI SDK and enable provider-specific
|
|
124
|
+
* functionality that can be fully encapsulated in the provider.
|
|
125
|
+
*/
|
|
126
|
+
providerOptions?: SharedV2ProviderOptions;
|
|
127
|
+
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { LanguageModelV2CallOptions } from './language-model-v2-call-options';
|
|
2
|
+
import { LanguageModelV2FunctionTool } from './language-model-v2-function-tool';
|
|
3
|
+
import { LanguageModelV2ProviderDefinedTool } from './language-model-v2-provider-defined-tool';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Warning from the model provider for this call. The call will proceed, but e.g.
|
|
7
|
+
* some settings might not be supported, which can lead to suboptimal results.
|
|
8
|
+
*/
|
|
9
|
+
export type LanguageModelV2CallWarning =
|
|
10
|
+
| {
|
|
11
|
+
type: 'unsupported-setting';
|
|
12
|
+
setting: Omit<keyof LanguageModelV2CallOptions, 'prompt'>;
|
|
13
|
+
details?: string;
|
|
14
|
+
}
|
|
15
|
+
| {
|
|
16
|
+
type: 'unsupported-tool';
|
|
17
|
+
tool: LanguageModelV2FunctionTool | LanguageModelV2ProviderDefinedTool;
|
|
18
|
+
details?: string;
|
|
19
|
+
}
|
|
20
|
+
| {
|
|
21
|
+
type: 'other';
|
|
22
|
+
message: string;
|
|
23
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { LanguageModelV2File } from './language-model-v2-file';
|
|
2
|
+
import { LanguageModelV2Reasoning } from './language-model-v2-reasoning';
|
|
3
|
+
import { LanguageModelV2Source } from './language-model-v2-source';
|
|
4
|
+
import { LanguageModelV2Text } from './language-model-v2-text';
|
|
5
|
+
import { LanguageModelV2ToolCall } from './language-model-v2-tool-call';
|
|
6
|
+
import { LanguageModelV2ToolResult } from './language-model-v2-tool-result';
|
|
7
|
+
|
|
8
|
+
export type LanguageModelV2Content =
|
|
9
|
+
| LanguageModelV2Text
|
|
10
|
+
| LanguageModelV2Reasoning
|
|
11
|
+
| LanguageModelV2File
|
|
12
|
+
| LanguageModelV2Source
|
|
13
|
+
| LanguageModelV2ToolCall
|
|
14
|
+
| LanguageModelV2ToolResult;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A file that has been generated by the model.
|
|
3
|
+
* Generated files as base64 encoded strings or binary data.
|
|
4
|
+
* The files should be returned without any unnecessary conversion.
|
|
5
|
+
*/
|
|
6
|
+
export type LanguageModelV2File = {
|
|
7
|
+
type: 'file';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* The IANA media type of the file, e.g. `image/png` or `audio/mp3`.
|
|
11
|
+
*
|
|
12
|
+
* @see https://www.iana.org/assignments/media-types/media-types.xhtml
|
|
13
|
+
*/
|
|
14
|
+
mediaType: string;
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Generated file data as base64 encoded strings or binary data.
|
|
18
|
+
*
|
|
19
|
+
* The file data should be returned without any unnecessary conversion.
|
|
20
|
+
* If the API returns base64 encoded strings, the file data should be returned
|
|
21
|
+
* as base64 encoded strings. If the API returns binary data, the file data should
|
|
22
|
+
* be returned as binary data.
|
|
23
|
+
*/
|
|
24
|
+
data: string | Uint8Array;
|
|
25
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Reason why a language model finished generating a response.
|
|
3
|
+
*
|
|
4
|
+
* Can be one of the following:
|
|
5
|
+
* - `stop`: model generated stop sequence
|
|
6
|
+
* - `length`: model generated maximum number of tokens
|
|
7
|
+
* - `content-filter`: content filter violation stopped the model
|
|
8
|
+
* - `tool-calls`: model triggered tool calls
|
|
9
|
+
* - `error`: model stopped because of an error
|
|
10
|
+
* - `other`: model stopped for other reasons
|
|
11
|
+
* - `unknown`: the model has not transmitted a finish reason
|
|
12
|
+
*/
|
|
13
|
+
export type LanguageModelV2FinishReason =
|
|
14
|
+
| 'stop' // model generated stop sequence
|
|
15
|
+
| 'length' // model generated maximum number of tokens
|
|
16
|
+
| 'content-filter' // content filter violation stopped the model
|
|
17
|
+
| 'tool-calls' // model triggered tool calls
|
|
18
|
+
| 'error' // model stopped because of an error
|
|
19
|
+
| 'other' // model stopped for other reasons
|
|
20
|
+
| 'unknown'; // the model has not transmitted a finish reason
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { JSONSchema7 } from 'json-schema';
|
|
2
|
+
import { SharedV2ProviderOptions } from '../../shared';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* A tool has a name, a description, and a set of parameters.
|
|
6
|
+
*
|
|
7
|
+
* Note: this is **not** the user-facing tool definition. The AI SDK methods will
|
|
8
|
+
* map the user-facing tool definitions to this format.
|
|
9
|
+
*/
|
|
10
|
+
export type LanguageModelV2FunctionTool = {
|
|
11
|
+
/**
|
|
12
|
+
* The type of the tool (always 'function').
|
|
13
|
+
*/
|
|
14
|
+
type: 'function';
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* The name of the tool. Unique within this model call.
|
|
18
|
+
*/
|
|
19
|
+
name: string;
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* A description of the tool. The language model uses this to understand the
|
|
23
|
+
* tool's purpose and to provide better completion suggestions.
|
|
24
|
+
*/
|
|
25
|
+
description?: string;
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* The parameters that the tool expects. The language model uses this to
|
|
29
|
+
* understand the tool's input requirements and to provide matching suggestions.
|
|
30
|
+
*/
|
|
31
|
+
inputSchema: JSONSchema7;
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* The provider-specific options for the tool.
|
|
35
|
+
*/
|
|
36
|
+
providerOptions?: SharedV2ProviderOptions;
|
|
37
|
+
};
|
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
import { JSONValue } from '../../json-value/json-value';
|
|
2
|
+
import { SharedV2ProviderOptions } from '../../shared/v2/shared-v2-provider-options';
|
|
3
|
+
import { LanguageModelV2DataContent } from './language-model-v2-data-content';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* A prompt is a list of messages.
|
|
7
|
+
*
|
|
8
|
+
* Note: Not all models and prompt formats support multi-modal inputs and
|
|
9
|
+
* tool calls. The validation happens at runtime.
|
|
10
|
+
*
|
|
11
|
+
* Note: This is not a user-facing prompt. The AI SDK methods will map the
|
|
12
|
+
* user-facing prompt types such as chat or instruction prompts to this format.
|
|
13
|
+
*/
|
|
14
|
+
export type LanguageModelV2Prompt = Array<LanguageModelV2Message>;
|
|
15
|
+
|
|
16
|
+
export type LanguageModelV2Message =
|
|
17
|
+
// Note: there could be additional parts for each role in the future,
|
|
18
|
+
// e.g. when the assistant can return images or the user can share files
|
|
19
|
+
// such as PDFs.
|
|
20
|
+
(
|
|
21
|
+
| {
|
|
22
|
+
role: 'system';
|
|
23
|
+
content: string;
|
|
24
|
+
}
|
|
25
|
+
| {
|
|
26
|
+
role: 'user';
|
|
27
|
+
content: Array<LanguageModelV2TextPart | LanguageModelV2FilePart>;
|
|
28
|
+
}
|
|
29
|
+
| {
|
|
30
|
+
role: 'assistant';
|
|
31
|
+
content: Array<
|
|
32
|
+
| LanguageModelV2TextPart
|
|
33
|
+
| LanguageModelV2FilePart
|
|
34
|
+
| LanguageModelV2ReasoningPart
|
|
35
|
+
| LanguageModelV2ToolCallPart
|
|
36
|
+
| LanguageModelV2ToolResultPart
|
|
37
|
+
>;
|
|
38
|
+
}
|
|
39
|
+
| {
|
|
40
|
+
role: 'tool';
|
|
41
|
+
content: Array<LanguageModelV2ToolResultPart>;
|
|
42
|
+
}
|
|
43
|
+
) & {
|
|
44
|
+
/**
|
|
45
|
+
* Additional provider-specific options. They are passed through
|
|
46
|
+
* to the provider from the AI SDK and enable provider-specific
|
|
47
|
+
* functionality that can be fully encapsulated in the provider.
|
|
48
|
+
*/
|
|
49
|
+
providerOptions?: SharedV2ProviderOptions;
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* Text content part of a prompt. It contains a string of text.
|
|
54
|
+
*/
|
|
55
|
+
export interface LanguageModelV2TextPart {
|
|
56
|
+
type: 'text';
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* The text content.
|
|
60
|
+
*/
|
|
61
|
+
text: string;
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Additional provider-specific options. They are passed through
|
|
65
|
+
* to the provider from the AI SDK and enable provider-specific
|
|
66
|
+
* functionality that can be fully encapsulated in the provider.
|
|
67
|
+
*/
|
|
68
|
+
providerOptions?: SharedV2ProviderOptions;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* Reasoning content part of a prompt. It contains a string of reasoning text.
|
|
73
|
+
*/
|
|
74
|
+
export interface LanguageModelV2ReasoningPart {
|
|
75
|
+
type: 'reasoning';
|
|
76
|
+
|
|
77
|
+
/**
|
|
78
|
+
* The reasoning text.
|
|
79
|
+
*/
|
|
80
|
+
text: string;
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Additional provider-specific options. They are passed through
|
|
84
|
+
* to the provider from the AI SDK and enable provider-specific
|
|
85
|
+
* functionality that can be fully encapsulated in the provider.
|
|
86
|
+
*/
|
|
87
|
+
providerOptions?: SharedV2ProviderOptions;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* File content part of a prompt. It contains a file.
|
|
92
|
+
*/
|
|
93
|
+
export interface LanguageModelV2FilePart {
|
|
94
|
+
type: 'file';
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* Optional filename of the file.
|
|
98
|
+
*/
|
|
99
|
+
filename?: string;
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* File data. Can be a Uint8Array, base64 encoded data as a string or a URL.
|
|
103
|
+
*/
|
|
104
|
+
data: LanguageModelV2DataContent;
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* IANA media type of the file.
|
|
108
|
+
*
|
|
109
|
+
* Can support wildcards, e.g. `image/*` (in which case the provider needs to take appropriate action).
|
|
110
|
+
*
|
|
111
|
+
* @see https://www.iana.org/assignments/media-types/media-types.xhtml
|
|
112
|
+
*/
|
|
113
|
+
mediaType: string;
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
* Additional provider-specific options. They are passed through
|
|
117
|
+
* to the provider from the AI SDK and enable provider-specific
|
|
118
|
+
* functionality that can be fully encapsulated in the provider.
|
|
119
|
+
*/
|
|
120
|
+
providerOptions?: SharedV2ProviderOptions;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* Tool call content part of a prompt. It contains a tool call (usually generated by the AI model).
|
|
125
|
+
*/
|
|
126
|
+
export interface LanguageModelV2ToolCallPart {
|
|
127
|
+
type: 'tool-call';
|
|
128
|
+
|
|
129
|
+
/**
|
|
130
|
+
* ID of the tool call. This ID is used to match the tool call with the tool result.
|
|
131
|
+
*/
|
|
132
|
+
toolCallId: string;
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* Name of the tool that is being called.
|
|
136
|
+
*/
|
|
137
|
+
toolName: string;
|
|
138
|
+
|
|
139
|
+
/**
|
|
140
|
+
* Arguments of the tool call. This is a JSON-serializable object that matches the tool's input schema.
|
|
141
|
+
*/
|
|
142
|
+
input: unknown;
|
|
143
|
+
|
|
144
|
+
/**
|
|
145
|
+
* Whether the tool call will be executed by the provider.
|
|
146
|
+
* If this flag is not set or is false, the tool call will be executed by the client.
|
|
147
|
+
*/
|
|
148
|
+
providerExecuted?: boolean;
|
|
149
|
+
|
|
150
|
+
/**
|
|
151
|
+
* Additional provider-specific options. They are passed through
|
|
152
|
+
* to the provider from the AI SDK and enable provider-specific
|
|
153
|
+
* functionality that can be fully encapsulated in the provider.
|
|
154
|
+
*/
|
|
155
|
+
providerOptions?: SharedV2ProviderOptions;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
/**
|
|
159
|
+
* Tool result content part of a prompt. It contains the result of the tool call with the matching ID.
|
|
160
|
+
*/
|
|
161
|
+
export interface LanguageModelV2ToolResultPart {
|
|
162
|
+
type: 'tool-result';
|
|
163
|
+
|
|
164
|
+
/**
|
|
165
|
+
* ID of the tool call that this result is associated with.
|
|
166
|
+
*/
|
|
167
|
+
toolCallId: string;
|
|
168
|
+
|
|
169
|
+
/**
|
|
170
|
+
* Name of the tool that generated this result.
|
|
171
|
+
*/
|
|
172
|
+
toolName: string;
|
|
173
|
+
|
|
174
|
+
/**
|
|
175
|
+
* Result of the tool call.
|
|
176
|
+
*/
|
|
177
|
+
output: LanguageModelV2ToolResultOutput;
|
|
178
|
+
|
|
179
|
+
/**
|
|
180
|
+
* Additional provider-specific options. They are passed through
|
|
181
|
+
* to the provider from the AI SDK and enable provider-specific
|
|
182
|
+
* functionality that can be fully encapsulated in the provider.
|
|
183
|
+
*/
|
|
184
|
+
providerOptions?: SharedV2ProviderOptions;
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
export type LanguageModelV2ToolResultOutput =
|
|
188
|
+
| { type: 'text'; value: string }
|
|
189
|
+
| { type: 'json'; value: JSONValue }
|
|
190
|
+
| { type: 'error-text'; value: string }
|
|
191
|
+
| { type: 'error-json'; value: JSONValue }
|
|
192
|
+
| {
|
|
193
|
+
type: 'content';
|
|
194
|
+
value: Array<
|
|
195
|
+
| {
|
|
196
|
+
type: 'text';
|
|
197
|
+
|
|
198
|
+
/**
|
|
199
|
+
* Text content.
|
|
200
|
+
*/
|
|
201
|
+
text: string;
|
|
202
|
+
}
|
|
203
|
+
| {
|
|
204
|
+
type: 'media';
|
|
205
|
+
|
|
206
|
+
/**
|
|
207
|
+
* Base-64 encoded media data.
|
|
208
|
+
*/
|
|
209
|
+
data: string;
|
|
210
|
+
|
|
211
|
+
/**
|
|
212
|
+
* IANA media type.
|
|
213
|
+
* @see https://www.iana.org/assignments/media-types/media-types.xhtml
|
|
214
|
+
*/
|
|
215
|
+
mediaType: string;
|
|
216
|
+
}
|
|
217
|
+
>;
|
|
218
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* The configuration of a tool that is defined by the provider.
|
|
3
|
+
*/
|
|
4
|
+
export type LanguageModelV2ProviderDefinedTool = {
|
|
5
|
+
/**
|
|
6
|
+
* The type of the tool (always 'provider-defined').
|
|
7
|
+
*/
|
|
8
|
+
type: 'provider-defined';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* The ID of the tool. Should follow the format `<provider-name>.<unique-tool-name>`.
|
|
12
|
+
*/
|
|
13
|
+
id: `${string}.${string}`;
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* The name of the tool that the user must use in the tool set.
|
|
17
|
+
*/
|
|
18
|
+
name: string;
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* The arguments for configuring the tool. Must match the expected arguments defined by the provider for this tool.
|
|
22
|
+
*/
|
|
23
|
+
args: Record<string, unknown>;
|
|
24
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { SharedV2ProviderMetadata } from '../../shared';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Reasoning that the model has generated.
|
|
5
|
+
*/
|
|
6
|
+
export type LanguageModelV2Reasoning = {
|
|
7
|
+
type: 'reasoning';
|
|
8
|
+
text: string;
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Optional provider-specific metadata for the reasoning part.
|
|
12
|
+
*/
|
|
13
|
+
providerMetadata?: SharedV2ProviderMetadata;
|
|
14
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export interface LanguageModelV2ResponseMetadata {
|
|
2
|
+
/**
|
|
3
|
+
* ID for the generated response, if the provider sends one.
|
|
4
|
+
*/
|
|
5
|
+
id?: string;
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Timestamp for the start of the generated response, if the provider sends one.
|
|
9
|
+
*/
|
|
10
|
+
timestamp?: Date;
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* The ID of the response model that was used to generate the response, if the provider sends one.
|
|
14
|
+
*/
|
|
15
|
+
modelId?: string;
|
|
16
|
+
}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { SharedV2ProviderMetadata } from '../../shared/v2/shared-v2-provider-metadata';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* A source that has been used as input to generate the response.
|
|
5
|
+
*/
|
|
6
|
+
export type LanguageModelV2Source =
|
|
7
|
+
| {
|
|
8
|
+
type: 'source';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* The type of source - URL sources reference web content.
|
|
12
|
+
*/
|
|
13
|
+
sourceType: 'url';
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* The ID of the source.
|
|
17
|
+
*/
|
|
18
|
+
id: string;
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* The URL of the source.
|
|
22
|
+
*/
|
|
23
|
+
url: string;
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* The title of the source.
|
|
27
|
+
*/
|
|
28
|
+
title?: string;
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Additional provider metadata for the source.
|
|
32
|
+
*/
|
|
33
|
+
providerMetadata?: SharedV2ProviderMetadata;
|
|
34
|
+
}
|
|
35
|
+
| {
|
|
36
|
+
type: 'source';
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* The type of source - document sources reference files/documents.
|
|
40
|
+
*/
|
|
41
|
+
sourceType: 'document';
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* The ID of the source.
|
|
45
|
+
*/
|
|
46
|
+
id: string;
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* IANA media type of the document (e.g., 'application/pdf').
|
|
50
|
+
*/
|
|
51
|
+
mediaType: string;
|
|
52
|
+
|
|
53
|
+
/**
|
|
54
|
+
* The title of the document.
|
|
55
|
+
*/
|
|
56
|
+
title: string;
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Optional filename of the document.
|
|
60
|
+
*/
|
|
61
|
+
filename?: string;
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Additional provider metadata for the source.
|
|
65
|
+
*/
|
|
66
|
+
providerMetadata?: SharedV2ProviderMetadata;
|
|
67
|
+
};
|