@ai-sdk/provider 3.0.2 → 3.0.3

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.
Files changed (132) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/dist/index.d.mts +1 -1
  3. package/dist/index.d.ts +1 -1
  4. package/package.json +3 -1
  5. package/src/embedding-model/index.ts +2 -0
  6. package/src/embedding-model/v2/embedding-model-v2-embedding.ts +5 -0
  7. package/src/embedding-model/v2/embedding-model-v2.ts +113 -0
  8. package/src/embedding-model/v2/index.ts +2 -0
  9. package/src/embedding-model/v3/embedding-model-v3-call-options.ts +26 -0
  10. package/src/embedding-model/v3/embedding-model-v3-embedding.ts +5 -0
  11. package/src/embedding-model/v3/embedding-model-v3-result.ts +48 -0
  12. package/src/embedding-model/v3/embedding-model-v3.ts +54 -0
  13. package/src/embedding-model/v3/index.ts +4 -0
  14. package/src/embedding-model-middleware/index.ts +1 -0
  15. package/src/embedding-model-middleware/v3/embedding-model-v3-middleware.ts +69 -0
  16. package/src/embedding-model-middleware/v3/index.ts +1 -0
  17. package/src/errors/ai-sdk-error.ts +62 -0
  18. package/src/errors/api-call-error.ts +59 -0
  19. package/src/errors/empty-response-body-error.ts +17 -0
  20. package/src/errors/get-error-message.ts +15 -0
  21. package/src/errors/index.ts +15 -0
  22. package/src/errors/invalid-argument-error.ts +32 -0
  23. package/src/errors/invalid-prompt-error.ts +33 -0
  24. package/src/errors/invalid-response-data-error.ts +31 -0
  25. package/src/errors/json-parse-error.ts +29 -0
  26. package/src/errors/load-api-key-error.ts +17 -0
  27. package/src/errors/load-setting-error.ts +17 -0
  28. package/src/errors/no-content-generated-error.ts +22 -0
  29. package/src/errors/no-such-model-error.ts +45 -0
  30. package/src/errors/too-many-embedding-values-for-call-error.ts +40 -0
  31. package/src/errors/type-validation-error.ts +51 -0
  32. package/src/errors/unsupported-functionality-error.ts +26 -0
  33. package/src/image-model/index.ts +2 -0
  34. package/src/image-model/v2/image-model-v2-call-options.ts +60 -0
  35. package/src/image-model/v2/image-model-v2-call-warning.ts +16 -0
  36. package/src/image-model/v2/image-model-v2.ts +104 -0
  37. package/src/image-model/v2/index.ts +6 -0
  38. package/src/image-model/v3/image-model-v3-call-options.ts +74 -0
  39. package/src/image-model/v3/image-model-v3-file.ts +44 -0
  40. package/src/image-model/v3/image-model-v3-usage.ts +19 -0
  41. package/src/image-model/v3/image-model-v3.ts +110 -0
  42. package/src/image-model/v3/index.ts +7 -0
  43. package/src/image-model-middleware/index.ts +1 -0
  44. package/src/image-model-middleware/v3/image-model-v3-middleware.ts +61 -0
  45. package/src/image-model-middleware/v3/index.ts +1 -0
  46. package/src/index.ts +15 -0
  47. package/src/json-value/index.ts +2 -0
  48. package/src/json-value/is-json.ts +40 -0
  49. package/src/json-value/json-value.ts +17 -0
  50. package/src/language-model/index.ts +2 -0
  51. package/src/language-model/v2/index.ts +18 -0
  52. package/src/language-model/v2/language-model-v2-call-options.ts +125 -0
  53. package/src/language-model/v2/language-model-v2-call-warning.ts +23 -0
  54. package/src/language-model/v2/language-model-v2-content.ts +14 -0
  55. package/src/language-model/v2/language-model-v2-data-content.ts +4 -0
  56. package/src/language-model/v2/language-model-v2-file.ts +25 -0
  57. package/src/language-model/v2/language-model-v2-finish-reason.ts +20 -0
  58. package/src/language-model/v2/language-model-v2-function-tool.ts +37 -0
  59. package/src/language-model/v2/language-model-v2-prompt.ts +218 -0
  60. package/src/language-model/v2/language-model-v2-provider-defined-tool.ts +24 -0
  61. package/src/language-model/v2/language-model-v2-reasoning.ts +14 -0
  62. package/src/language-model/v2/language-model-v2-response-metadata.ts +16 -0
  63. package/src/language-model/v2/language-model-v2-source.ts +67 -0
  64. package/src/language-model/v2/language-model-v2-stream-part.ts +102 -0
  65. package/src/language-model/v2/language-model-v2-text.ts +15 -0
  66. package/src/language-model/v2/language-model-v2-tool-call.ts +35 -0
  67. package/src/language-model/v2/language-model-v2-tool-choice.ts +5 -0
  68. package/src/language-model/v2/language-model-v2-tool-result.ts +40 -0
  69. package/src/language-model/v2/language-model-v2-usage.ts +34 -0
  70. package/src/language-model/v2/language-model-v2.ts +137 -0
  71. package/src/language-model/v3/index.ts +21 -0
  72. package/src/language-model/v3/language-model-v3-call-options.ts +125 -0
  73. package/src/language-model/v3/language-model-v3-content.ts +16 -0
  74. package/src/language-model/v3/language-model-v3-data-content.ts +4 -0
  75. package/src/language-model/v3/language-model-v3-file.ts +32 -0
  76. package/src/language-model/v3/language-model-v3-finish-reason.ts +33 -0
  77. package/src/language-model/v3/language-model-v3-function-tool.ts +53 -0
  78. package/src/language-model/v3/language-model-v3-generate-result.ts +63 -0
  79. package/src/language-model/v3/language-model-v3-prompt.ts +422 -0
  80. package/src/language-model/v3/language-model-v3-provider-tool.ts +28 -0
  81. package/src/language-model/v3/language-model-v3-reasoning.ts +14 -0
  82. package/src/language-model/v3/language-model-v3-response-metadata.ts +16 -0
  83. package/src/language-model/v3/language-model-v3-source.ts +67 -0
  84. package/src/language-model/v3/language-model-v3-stream-part.ts +106 -0
  85. package/src/language-model/v3/language-model-v3-stream-result.ts +32 -0
  86. package/src/language-model/v3/language-model-v3-text.ts +15 -0
  87. package/src/language-model/v3/language-model-v3-tool-approval-request.ts +27 -0
  88. package/src/language-model/v3/language-model-v3-tool-call.ts +41 -0
  89. package/src/language-model/v3/language-model-v3-tool-choice.ts +5 -0
  90. package/src/language-model/v3/language-model-v3-tool-result.ts +51 -0
  91. package/src/language-model/v3/language-model-v3-usage.ts +59 -0
  92. package/src/language-model/v3/language-model-v3.ts +61 -0
  93. package/src/language-model-middleware/index.ts +2 -0
  94. package/src/language-model-middleware/v2/index.ts +1 -0
  95. package/src/language-model-middleware/v2/language-model-v2-middleware.ts +82 -0
  96. package/src/language-model-middleware/v3/index.ts +1 -0
  97. package/src/language-model-middleware/v3/language-model-v3-middleware.ts +84 -0
  98. package/src/provider/index.ts +2 -0
  99. package/src/provider/v2/index.ts +1 -0
  100. package/src/provider/v2/provider-v2.ts +64 -0
  101. package/src/provider/v3/index.ts +1 -0
  102. package/src/provider/v3/provider-v3.ts +93 -0
  103. package/src/reranking-model/index.ts +1 -0
  104. package/src/reranking-model/v3/index.ts +2 -0
  105. package/src/reranking-model/v3/reranking-model-v3-call-options.ts +40 -0
  106. package/src/reranking-model/v3/reranking-model-v3.ts +90 -0
  107. package/src/shared/index.ts +2 -0
  108. package/src/shared/v2/index.ts +3 -0
  109. package/src/shared/v2/shared-v2-headers.ts +1 -0
  110. package/src/shared/v2/shared-v2-provider-metadata.ts +27 -0
  111. package/src/shared/v2/shared-v2-provider-options.ts +24 -0
  112. package/src/shared/v3/index.ts +4 -0
  113. package/src/shared/v3/shared-v3-headers.ts +1 -0
  114. package/src/shared/v3/shared-v3-provider-metadata.ts +24 -0
  115. package/src/shared/v3/shared-v3-provider-options.ts +24 -0
  116. package/src/shared/v3/shared-v3-warning.ts +50 -0
  117. package/src/speech-model/index.ts +2 -0
  118. package/src/speech-model/v2/index.ts +3 -0
  119. package/src/speech-model/v2/speech-model-v2-call-options.ts +62 -0
  120. package/src/speech-model/v2/speech-model-v2-call-warning.ts +16 -0
  121. package/src/speech-model/v2/speech-model-v2.ts +89 -0
  122. package/src/speech-model/v3/index.ts +2 -0
  123. package/src/speech-model/v3/speech-model-v3-call-options.ts +62 -0
  124. package/src/speech-model/v3/speech-model-v3.ts +89 -0
  125. package/src/transcription-model/index.ts +2 -0
  126. package/src/transcription-model/v2/index.ts +3 -0
  127. package/src/transcription-model/v2/transcription-model-v2-call-options.ts +48 -0
  128. package/src/transcription-model/v2/transcription-model-v2-call-warning.ts +16 -0
  129. package/src/transcription-model/v2/transcription-model-v2.ts +117 -0
  130. package/src/transcription-model/v3/index.ts +2 -0
  131. package/src/transcription-model/v3/transcription-model-v3-call-options.ts +45 -0
  132. package/src/transcription-model/v3/transcription-model-v3.ts +117 -0
@@ -0,0 +1,110 @@
1
+ import { JSONArray, JSONValue } from '../../json-value';
2
+ import { ImageModelV3Usage } from './image-model-v3-usage';
3
+ import { ImageModelV3CallOptions } from './image-model-v3-call-options';
4
+ import { SharedV3Warning } from '../../shared/v3/shared-v3-warning';
5
+
6
+ export type ImageModelV3ProviderMetadata = 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 ImageModelV3 = {
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: 'v3';
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: ImageModelV3CallOptions): 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<SharedV3Warning>;
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?: ImageModelV3ProviderMetadata;
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?: ImageModelV3Usage;
109
+ }>;
110
+ };
@@ -0,0 +1,7 @@
1
+ export type {
2
+ ImageModelV3,
3
+ ImageModelV3ProviderMetadata,
4
+ } from './image-model-v3';
5
+ export type { ImageModelV3CallOptions } from './image-model-v3-call-options';
6
+ export type { ImageModelV3Usage } from './image-model-v3-usage';
7
+ export type { ImageModelV3File } from './image-model-v3-file';
@@ -0,0 +1 @@
1
+ export * from './v3/index';
@@ -0,0 +1,61 @@
1
+ import { ImageModelV3 } from '../../image-model/v3/image-model-v3';
2
+ import { ImageModelV3CallOptions } from '../../image-model/v3/image-model-v3-call-options';
3
+
4
+ /**
5
+ * Middleware for ImageModelV3.
6
+ * This type defines the structure for middleware that can be used to modify
7
+ * the behavior of ImageModelV3 operations.
8
+ */
9
+ export type ImageModelV3Middleware = {
10
+ /**
11
+ * Middleware specification version. Use `v3` for the current version.
12
+ */
13
+ readonly specificationVersion: 'v3';
14
+
15
+ /**
16
+ * Override the provider name if desired.
17
+ * @param options.model - The image model instance.
18
+ */
19
+ overrideProvider?: (options: { model: ImageModelV3 }) => string;
20
+
21
+ /**
22
+ * Override the model ID if desired.
23
+ * @param options.model - The image model instance.
24
+ */
25
+ overrideModelId?: (options: { model: ImageModelV3 }) => 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: ImageModelV3;
33
+ }) => ImageModelV3['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: ImageModelV3CallOptions;
43
+ model: ImageModelV3;
44
+ }) => PromiseLike<ImageModelV3CallOptions>;
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<ImageModelV3['doGenerate']>;
58
+ params: ImageModelV3CallOptions;
59
+ model: ImageModelV3;
60
+ }) => Promise<Awaited<ReturnType<ImageModelV3['doGenerate']>>>;
61
+ };
@@ -0,0 +1 @@
1
+ export * from './image-model-v3-middleware';
package/src/index.ts ADDED
@@ -0,0 +1,15 @@
1
+ export * from './embedding-model/index';
2
+ export * from './errors/index';
3
+ export * from './image-model/index';
4
+ export * from './image-model-middleware/index';
5
+ export * from './json-value/index';
6
+ export * from './language-model-middleware/index';
7
+ export * from './embedding-model-middleware/index';
8
+ export * from './language-model/index';
9
+ export * from './provider/index';
10
+ export * from './reranking-model/index';
11
+ export * from './shared/index';
12
+ export * from './speech-model/index';
13
+ export * from './transcription-model/index';
14
+
15
+ export type { JSONSchema7, JSONSchema7Definition } from 'json-schema';
@@ -0,0 +1,2 @@
1
+ export { isJSONArray, isJSONObject, isJSONValue } from './is-json';
2
+ export type { JSONArray, JSONObject, JSONValue } from './json-value';
@@ -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,2 @@
1
+ export * from './v3/index';
2
+ export * from './v2/index';
@@ -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,125 @@
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 { LanguageModelV2ProviderTool } 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<LanguageModelV2FunctionTool | LanguageModelV2ProviderTool>;
97
+
98
+ /**
99
+ Specifies how the tool should be selected. Defaults to 'auto'.
100
+ */
101
+ toolChoice?: LanguageModelV2ToolChoice;
102
+
103
+ /**
104
+ Include raw chunks in the stream. Only applicable for streaming calls.
105
+ */
106
+ includeRawChunks?: boolean;
107
+
108
+ /**
109
+ Abort signal for cancelling the operation.
110
+ */
111
+ abortSignal?: AbortSignal;
112
+
113
+ /**
114
+ Additional HTTP headers to be sent with the request.
115
+ Only applicable for HTTP-based providers.
116
+ */
117
+ headers?: Record<string, string | undefined>;
118
+
119
+ /**
120
+ * Additional provider-specific options. They are passed through
121
+ * to the provider from the AI SDK and enable provider-specific
122
+ * functionality that can be fully encapsulated in the provider.
123
+ */
124
+ providerOptions?: SharedV2ProviderOptions;
125
+ };
@@ -0,0 +1,23 @@
1
+ import { LanguageModelV2CallOptions } from './language-model-v2-call-options';
2
+ import { LanguageModelV2FunctionTool } from './language-model-v2-function-tool';
3
+ import { LanguageModelV2ProviderTool } 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 | LanguageModelV2ProviderTool;
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,4 @@
1
+ /**
2
+ Data content. Can be a Uint8Array, base64 encoded data as a string or a URL.
3
+ */
4
+ export type LanguageModelV2DataContent = Uint8Array | string | URL;
@@ -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
+ };