@ai-sdk/provider 0.0.0-4115c213-20260122152721

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 (138) hide show
  1. package/CHANGELOG.md +961 -0
  2. package/LICENSE +13 -0
  3. package/README.md +1 -0
  4. package/dist/index.d.mts +3796 -0
  5. package/dist/index.d.ts +3796 -0
  6. package/dist/index.js +421 -0
  7. package/dist/index.js.map +1 -0
  8. package/dist/index.mjs +377 -0
  9. package/dist/index.mjs.map +1 -0
  10. package/package.json +63 -0
  11. package/src/embedding-model/index.ts +2 -0
  12. package/src/embedding-model/v2/embedding-model-v2-embedding.ts +5 -0
  13. package/src/embedding-model/v2/embedding-model-v2.ts +113 -0
  14. package/src/embedding-model/v2/index.ts +2 -0
  15. package/src/embedding-model/v3/embedding-model-v3-call-options.ts +26 -0
  16. package/src/embedding-model/v3/embedding-model-v3-embedding.ts +5 -0
  17. package/src/embedding-model/v3/embedding-model-v3-result.ts +48 -0
  18. package/src/embedding-model/v3/embedding-model-v3.ts +54 -0
  19. package/src/embedding-model/v3/index.ts +4 -0
  20. package/src/embedding-model-middleware/index.ts +1 -0
  21. package/src/embedding-model-middleware/v3/embedding-model-v3-middleware.ts +69 -0
  22. package/src/embedding-model-middleware/v3/index.ts +1 -0
  23. package/src/errors/ai-sdk-error.ts +62 -0
  24. package/src/errors/api-call-error.ts +59 -0
  25. package/src/errors/empty-response-body-error.ts +17 -0
  26. package/src/errors/get-error-message.ts +15 -0
  27. package/src/errors/index.ts +15 -0
  28. package/src/errors/invalid-argument-error.ts +32 -0
  29. package/src/errors/invalid-prompt-error.ts +33 -0
  30. package/src/errors/invalid-response-data-error.ts +31 -0
  31. package/src/errors/json-parse-error.ts +29 -0
  32. package/src/errors/load-api-key-error.ts +17 -0
  33. package/src/errors/load-setting-error.ts +17 -0
  34. package/src/errors/no-content-generated-error.ts +22 -0
  35. package/src/errors/no-such-model-error.ts +45 -0
  36. package/src/errors/too-many-embedding-values-for-call-error.ts +40 -0
  37. package/src/errors/type-validation-error.ts +51 -0
  38. package/src/errors/unsupported-functionality-error.ts +26 -0
  39. package/src/image-model/index.ts +2 -0
  40. package/src/image-model/v2/image-model-v2-call-options.ts +60 -0
  41. package/src/image-model/v2/image-model-v2-call-warning.ts +16 -0
  42. package/src/image-model/v2/image-model-v2.ts +104 -0
  43. package/src/image-model/v2/index.ts +6 -0
  44. package/src/image-model/v3/image-model-v3-call-options.ts +74 -0
  45. package/src/image-model/v3/image-model-v3-file.ts +44 -0
  46. package/src/image-model/v3/image-model-v3-usage.ts +19 -0
  47. package/src/image-model/v3/image-model-v3.ts +110 -0
  48. package/src/image-model/v3/index.ts +7 -0
  49. package/src/image-model-middleware/index.ts +1 -0
  50. package/src/image-model-middleware/v3/image-model-v3-middleware.ts +61 -0
  51. package/src/image-model-middleware/v3/index.ts +1 -0
  52. package/src/index.ts +15 -0
  53. package/src/json-value/index.ts +2 -0
  54. package/src/json-value/is-json.ts +40 -0
  55. package/src/json-value/json-value.ts +17 -0
  56. package/src/language-model/index.ts +2 -0
  57. package/src/language-model/v2/index.ts +18 -0
  58. package/src/language-model/v2/language-model-v2-call-options.ts +127 -0
  59. package/src/language-model/v2/language-model-v2-call-warning.ts +23 -0
  60. package/src/language-model/v2/language-model-v2-content.ts +14 -0
  61. package/src/language-model/v2/language-model-v2-data-content.ts +4 -0
  62. package/src/language-model/v2/language-model-v2-file.ts +25 -0
  63. package/src/language-model/v2/language-model-v2-finish-reason.ts +20 -0
  64. package/src/language-model/v2/language-model-v2-function-tool.ts +37 -0
  65. package/src/language-model/v2/language-model-v2-prompt.ts +218 -0
  66. package/src/language-model/v2/language-model-v2-provider-defined-tool.ts +24 -0
  67. package/src/language-model/v2/language-model-v2-reasoning.ts +14 -0
  68. package/src/language-model/v2/language-model-v2-response-metadata.ts +16 -0
  69. package/src/language-model/v2/language-model-v2-source.ts +67 -0
  70. package/src/language-model/v2/language-model-v2-stream-part.ts +102 -0
  71. package/src/language-model/v2/language-model-v2-text.ts +15 -0
  72. package/src/language-model/v2/language-model-v2-tool-call.ts +35 -0
  73. package/src/language-model/v2/language-model-v2-tool-choice.ts +5 -0
  74. package/src/language-model/v2/language-model-v2-tool-result.ts +40 -0
  75. package/src/language-model/v2/language-model-v2-usage.ts +34 -0
  76. package/src/language-model/v2/language-model-v2.ts +137 -0
  77. package/src/language-model/v3/index.ts +21 -0
  78. package/src/language-model/v3/language-model-v3-call-options.ts +125 -0
  79. package/src/language-model/v3/language-model-v3-content.ts +16 -0
  80. package/src/language-model/v3/language-model-v3-data-content.ts +4 -0
  81. package/src/language-model/v3/language-model-v3-file.ts +32 -0
  82. package/src/language-model/v3/language-model-v3-finish-reason.ts +33 -0
  83. package/src/language-model/v3/language-model-v3-function-tool.ts +53 -0
  84. package/src/language-model/v3/language-model-v3-generate-result.ts +63 -0
  85. package/src/language-model/v3/language-model-v3-prompt.ts +422 -0
  86. package/src/language-model/v3/language-model-v3-provider-tool.ts +28 -0
  87. package/src/language-model/v3/language-model-v3-reasoning.ts +14 -0
  88. package/src/language-model/v3/language-model-v3-response-metadata.ts +16 -0
  89. package/src/language-model/v3/language-model-v3-source.ts +67 -0
  90. package/src/language-model/v3/language-model-v3-stream-part.ts +106 -0
  91. package/src/language-model/v3/language-model-v3-stream-result.ts +32 -0
  92. package/src/language-model/v3/language-model-v3-text.ts +15 -0
  93. package/src/language-model/v3/language-model-v3-tool-approval-request.ts +27 -0
  94. package/src/language-model/v3/language-model-v3-tool-call.ts +41 -0
  95. package/src/language-model/v3/language-model-v3-tool-choice.ts +5 -0
  96. package/src/language-model/v3/language-model-v3-tool-result.ts +51 -0
  97. package/src/language-model/v3/language-model-v3-usage.ts +59 -0
  98. package/src/language-model/v3/language-model-v3.ts +61 -0
  99. package/src/language-model-middleware/index.ts +2 -0
  100. package/src/language-model-middleware/v2/index.ts +1 -0
  101. package/src/language-model-middleware/v2/language-model-v2-middleware.ts +82 -0
  102. package/src/language-model-middleware/v3/index.ts +1 -0
  103. package/src/language-model-middleware/v3/language-model-v3-middleware.ts +84 -0
  104. package/src/provider/index.ts +2 -0
  105. package/src/provider/v2/index.ts +1 -0
  106. package/src/provider/v2/provider-v2.ts +64 -0
  107. package/src/provider/v3/index.ts +1 -0
  108. package/src/provider/v3/provider-v3.ts +93 -0
  109. package/src/reranking-model/index.ts +1 -0
  110. package/src/reranking-model/v3/index.ts +2 -0
  111. package/src/reranking-model/v3/reranking-model-v3-call-options.ts +40 -0
  112. package/src/reranking-model/v3/reranking-model-v3.ts +90 -0
  113. package/src/shared/index.ts +2 -0
  114. package/src/shared/v2/index.ts +3 -0
  115. package/src/shared/v2/shared-v2-headers.ts +1 -0
  116. package/src/shared/v2/shared-v2-provider-metadata.ts +27 -0
  117. package/src/shared/v2/shared-v2-provider-options.ts +24 -0
  118. package/src/shared/v3/index.ts +4 -0
  119. package/src/shared/v3/shared-v3-headers.ts +1 -0
  120. package/src/shared/v3/shared-v3-provider-metadata.ts +24 -0
  121. package/src/shared/v3/shared-v3-provider-options.ts +24 -0
  122. package/src/shared/v3/shared-v3-warning.ts +50 -0
  123. package/src/speech-model/index.ts +2 -0
  124. package/src/speech-model/v2/index.ts +3 -0
  125. package/src/speech-model/v2/speech-model-v2-call-options.ts +62 -0
  126. package/src/speech-model/v2/speech-model-v2-call-warning.ts +16 -0
  127. package/src/speech-model/v2/speech-model-v2.ts +89 -0
  128. package/src/speech-model/v3/index.ts +2 -0
  129. package/src/speech-model/v3/speech-model-v3-call-options.ts +62 -0
  130. package/src/speech-model/v3/speech-model-v3.ts +89 -0
  131. package/src/transcription-model/index.ts +2 -0
  132. package/src/transcription-model/v2/index.ts +3 -0
  133. package/src/transcription-model/v2/transcription-model-v2-call-options.ts +48 -0
  134. package/src/transcription-model/v2/transcription-model-v2-call-warning.ts +16 -0
  135. package/src/transcription-model/v2/transcription-model-v2.ts +117 -0
  136. package/src/transcription-model/v3/index.ts +2 -0
  137. package/src/transcription-model/v3/transcription-model-v3-call-options.ts +45 -0
  138. package/src/transcription-model/v3/transcription-model-v3.ts +117 -0
@@ -0,0 +1,15 @@
1
+ import { SharedV2ProviderMetadata } from '../../shared/v2/shared-v2-provider-metadata';
2
+
3
+ /**
4
+ Text that the model has generated.
5
+ */
6
+ export type LanguageModelV2Text = {
7
+ type: 'text';
8
+
9
+ /**
10
+ The text content.
11
+ */
12
+ text: string;
13
+
14
+ providerMetadata?: SharedV2ProviderMetadata;
15
+ };
@@ -0,0 +1,35 @@
1
+ import { SharedV2ProviderMetadata } from '../../shared/v2/shared-v2-provider-metadata';
2
+
3
+ /**
4
+ * Tool calls that the model has generated.
5
+ */
6
+ export type LanguageModelV2ToolCall = {
7
+ type: 'tool-call';
8
+
9
+ /**
10
+ * The identifier of the tool call. It must be unique across all tool calls.
11
+ */
12
+ toolCallId: string;
13
+
14
+ /**
15
+ * The name of the tool that should be called.
16
+ */
17
+ toolName: string;
18
+
19
+ /**
20
+ * Stringified JSON object with the tool call arguments. Must match the
21
+ * parameters schema of the tool.
22
+ */
23
+ input: string;
24
+
25
+ /**
26
+ * Whether the tool call will be executed by the provider.
27
+ * If this flag is not set or is false, the tool call will be executed by the client.
28
+ */
29
+ providerExecuted?: boolean;
30
+
31
+ /**
32
+ * Additional provider-specific metadata for the tool call.
33
+ */
34
+ providerMetadata?: SharedV2ProviderMetadata;
35
+ };
@@ -0,0 +1,5 @@
1
+ export type LanguageModelV2ToolChoice =
2
+ | { type: 'auto' } // the tool selection is automatic (can be no tool)
3
+ | { type: 'none' } // no tool must be selected
4
+ | { type: 'required' } // one of the available tools must be selected
5
+ | { type: 'tool'; toolName: string }; // a specific tool must be selected:
@@ -0,0 +1,40 @@
1
+ import { SharedV2ProviderMetadata } from '../../shared/v2/shared-v2-provider-metadata';
2
+
3
+ /**
4
+ Result of a tool call that has been executed by the provider.
5
+ */
6
+ export type LanguageModelV2ToolResult = {
7
+ type: 'tool-result';
8
+
9
+ /**
10
+ * The ID of the tool call that this result is associated with.
11
+ */
12
+ toolCallId: string;
13
+
14
+ /**
15
+ * Name of the tool that generated this result.
16
+ */
17
+ toolName: string;
18
+
19
+ /**
20
+ * Result of the tool call. This is a JSON-serializable object.
21
+ */
22
+ result: unknown;
23
+
24
+ /**
25
+ * Optional flag if the result is an error or an error message.
26
+ */
27
+ isError?: boolean;
28
+
29
+ /**
30
+ * Whether the tool result was generated by the provider.
31
+ * If this flag is set to true, the tool result was generated by the provider.
32
+ * If this flag is not set or is false, the tool result was generated by the client.
33
+ */
34
+ providerExecuted?: boolean;
35
+
36
+ /**
37
+ * Additional provider-specific metadata for the tool result.
38
+ */
39
+ providerMetadata?: SharedV2ProviderMetadata;
40
+ };
@@ -0,0 +1,34 @@
1
+ /**
2
+ Usage information for a language model call.
3
+
4
+ If your API return additional usage information, you can add it to the
5
+ provider metadata under your provider's key.
6
+ */
7
+ export type LanguageModelV2Usage = {
8
+ /**
9
+ The number of input (prompt) tokens used.
10
+ */
11
+ inputTokens: number | undefined;
12
+
13
+ /**
14
+ The number of output (completion) tokens used.
15
+ */
16
+ outputTokens: number | undefined;
17
+
18
+ /**
19
+ The total number of tokens as reported by the provider.
20
+ This number might be different from the sum of `inputTokens` and `outputTokens`
21
+ and e.g. include reasoning tokens or other overhead.
22
+ */
23
+ totalTokens: number | undefined;
24
+
25
+ /**
26
+ The number of reasoning tokens used.
27
+ */
28
+ reasoningTokens?: number | undefined;
29
+
30
+ /**
31
+ The number of cached input tokens.
32
+ */
33
+ cachedInputTokens?: number | undefined;
34
+ };
@@ -0,0 +1,137 @@
1
+ import { SharedV2Headers } from '../../shared';
2
+ import { SharedV2ProviderMetadata } from '../../shared/v2/shared-v2-provider-metadata';
3
+ import { LanguageModelV2CallOptions } from './language-model-v2-call-options';
4
+ import { LanguageModelV2CallWarning } from './language-model-v2-call-warning';
5
+ import { LanguageModelV2Content } from './language-model-v2-content';
6
+ import { LanguageModelV2FinishReason } from './language-model-v2-finish-reason';
7
+ import { LanguageModelV2ResponseMetadata } from './language-model-v2-response-metadata';
8
+ import { LanguageModelV2StreamPart } from './language-model-v2-stream-part';
9
+ import { LanguageModelV2Usage } from './language-model-v2-usage';
10
+
11
+ /**
12
+ Specification for a language model that implements the language model interface version 2.
13
+ */
14
+ export type LanguageModelV2 = {
15
+ /**
16
+ The language model must specify which language model interface version it implements.
17
+ */
18
+ readonly specificationVersion: 'v2';
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
+ Supported URL patterns by media type for the provider.
32
+
33
+ The keys are media type patterns or full media types (e.g. `*\/*` for everything, `audio/*`, `video/*`, or `application/pdf`).
34
+ and the values are arrays of regular expressions that match the URL paths.
35
+
36
+ The matching should be against lower-case URLs.
37
+
38
+ Matched URLs are supported natively by the model and are not downloaded.
39
+
40
+ @returns A map of supported URL patterns by media type (as a promise or a plain object).
41
+ */
42
+ supportedUrls:
43
+ | PromiseLike<Record<string, RegExp[]>>
44
+ | Record<string, RegExp[]>;
45
+
46
+ /**
47
+ Generates a language model output (non-streaming).
48
+
49
+ Naming: "do" prefix to prevent accidental direct usage of the method
50
+ by the user.
51
+ */
52
+ doGenerate(options: LanguageModelV2CallOptions): PromiseLike<{
53
+ /**
54
+ Ordered content that the model has generated.
55
+ */
56
+ content: Array<LanguageModelV2Content>;
57
+
58
+ /**
59
+ Finish reason.
60
+ */
61
+ finishReason: LanguageModelV2FinishReason;
62
+
63
+ /**
64
+ Usage information.
65
+ */
66
+ usage: LanguageModelV2Usage;
67
+
68
+ /**
69
+ Additional provider-specific metadata. They are passed through
70
+ from the provider to the AI SDK and enable provider-specific
71
+ results that can be fully encapsulated in the provider.
72
+ */
73
+ providerMetadata?: SharedV2ProviderMetadata;
74
+
75
+ /**
76
+ Optional request information for telemetry and debugging purposes.
77
+ */
78
+ request?: {
79
+ /**
80
+ Request HTTP body that was sent to the provider API.
81
+ */
82
+ body?: unknown;
83
+ };
84
+
85
+ /**
86
+ Optional response information for telemetry and debugging purposes.
87
+ */
88
+ response?: LanguageModelV2ResponseMetadata & {
89
+ /**
90
+ Response headers.
91
+ */
92
+ headers?: SharedV2Headers;
93
+
94
+ /**
95
+ Response HTTP body.
96
+ */
97
+ body?: unknown;
98
+ };
99
+
100
+ /**
101
+ Warnings for the call, e.g. unsupported settings.
102
+ */
103
+ warnings: Array<LanguageModelV2CallWarning>;
104
+ }>;
105
+
106
+ /**
107
+ Generates a language model output (streaming).
108
+
109
+ Naming: "do" prefix to prevent accidental direct usage of the method
110
+ by the user.
111
+ *
112
+ @return A stream of higher-level language model output parts.
113
+ */
114
+ doStream(options: LanguageModelV2CallOptions): PromiseLike<{
115
+ stream: ReadableStream<LanguageModelV2StreamPart>;
116
+
117
+ /**
118
+ Optional request information for telemetry and debugging purposes.
119
+ */
120
+ request?: {
121
+ /**
122
+ Request HTTP body that was sent to the provider API.
123
+ */
124
+ body?: unknown;
125
+ };
126
+
127
+ /**
128
+ Optional response data.
129
+ */
130
+ response?: {
131
+ /**
132
+ Response headers.
133
+ */
134
+ headers?: SharedV2Headers;
135
+ };
136
+ }>;
137
+ };
@@ -0,0 +1,21 @@
1
+ export * from './language-model-v3';
2
+ export * from './language-model-v3-call-options';
3
+ export * from './language-model-v3-content';
4
+ export * from './language-model-v3-data-content';
5
+ export * from './language-model-v3-file';
6
+ export * from './language-model-v3-finish-reason';
7
+ export * from './language-model-v3-function-tool';
8
+ export * from './language-model-v3-generate-result';
9
+ export * from './language-model-v3-prompt';
10
+ export * from './language-model-v3-provider-tool';
11
+ export * from './language-model-v3-reasoning';
12
+ export * from './language-model-v3-response-metadata';
13
+ export * from './language-model-v3-source';
14
+ export * from './language-model-v3-stream-part';
15
+ export * from './language-model-v3-stream-result';
16
+ export * from './language-model-v3-text';
17
+ export * from './language-model-v3-tool-approval-request';
18
+ export * from './language-model-v3-tool-call';
19
+ export * from './language-model-v3-tool-choice';
20
+ export * from './language-model-v3-tool-result';
21
+ export * from './language-model-v3-usage';
@@ -0,0 +1,125 @@
1
+ import { JSONSchema7 } from 'json-schema';
2
+ import { SharedV3ProviderOptions } from '../../shared/v3/shared-v3-provider-options';
3
+ import { LanguageModelV3FunctionTool } from './language-model-v3-function-tool';
4
+ import { LanguageModelV3Prompt } from './language-model-v3-prompt';
5
+ import { LanguageModelV3ProviderTool } from './language-model-v3-provider-tool';
6
+ import { LanguageModelV3ToolChoice } from './language-model-v3-tool-choice';
7
+
8
+ export type LanguageModelV3CallOptions = {
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: LanguageModelV3Prompt;
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<LanguageModelV3FunctionTool | LanguageModelV3ProviderTool>;
97
+
98
+ /**
99
+ Specifies how the tool should be selected. Defaults to 'auto'.
100
+ */
101
+ toolChoice?: LanguageModelV3ToolChoice;
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?: SharedV3ProviderOptions;
125
+ };
@@ -0,0 +1,16 @@
1
+ import { LanguageModelV3File } from './language-model-v3-file';
2
+ import { LanguageModelV3Reasoning } from './language-model-v3-reasoning';
3
+ import { LanguageModelV3Source } from './language-model-v3-source';
4
+ import { LanguageModelV3Text } from './language-model-v3-text';
5
+ import { LanguageModelV3ToolApprovalRequest } from './language-model-v3-tool-approval-request';
6
+ import { LanguageModelV3ToolCall } from './language-model-v3-tool-call';
7
+ import { LanguageModelV3ToolResult } from './language-model-v3-tool-result';
8
+
9
+ export type LanguageModelV3Content =
10
+ | LanguageModelV3Text
11
+ | LanguageModelV3Reasoning
12
+ | LanguageModelV3File
13
+ | LanguageModelV3ToolApprovalRequest
14
+ | LanguageModelV3Source
15
+ | LanguageModelV3ToolCall
16
+ | LanguageModelV3ToolResult;
@@ -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 LanguageModelV3DataContent = Uint8Array | string | URL;
@@ -0,0 +1,32 @@
1
+ import { SharedV3ProviderMetadata } from '../../shared';
2
+
3
+ /**
4
+ A file that has been generated by the model.
5
+ Generated files as base64 encoded strings or binary data.
6
+ The files should be returned without any unnecessary conversion.
7
+ */
8
+ export type LanguageModelV3File = {
9
+ type: 'file';
10
+
11
+ /**
12
+ The IANA media type of the file, e.g. `image/png` or `audio/mp3`.
13
+
14
+ @see https://www.iana.org/assignments/media-types/media-types.xhtml
15
+ */
16
+ mediaType: string;
17
+
18
+ /**
19
+ Generated file data as base64 encoded strings or binary data.
20
+
21
+ The file data should be returned without any unnecessary conversion.
22
+ If the API returns base64 encoded strings, the file data should be returned
23
+ as base64 encoded strings. If the API returns binary data, the file data should
24
+ be returned as binary data.
25
+ */
26
+ data: string | Uint8Array;
27
+
28
+ /**
29
+ * Optional provider-specific metadata for the file part.
30
+ */
31
+ providerMetadata?: SharedV3ProviderMetadata;
32
+ };
@@ -0,0 +1,33 @@
1
+ /**
2
+ * Reason why a language model finished generating a response.
3
+ *
4
+ * Contains both a unified finish reason and a raw finish reason from the provider.
5
+ * The unified finish reason is used to provide a consistent finish reason across different providers.
6
+ * The raw finish reason is used to provide the original finish reason from the provider.
7
+ */
8
+ export type LanguageModelV3FinishReason = {
9
+ /**
10
+ * Unified finish reason. This enables using the same finish reason across different providers.
11
+ *
12
+ * Can be one of the following:
13
+ * - `stop`: model generated stop sequence
14
+ * - `length`: model generated maximum number of tokens
15
+ * - `content-filter`: content filter violation stopped the model
16
+ * - `tool-calls`: model triggered tool calls
17
+ * - `error`: model stopped because of an error
18
+ * - `other`: model stopped for other reasons
19
+ */
20
+ unified:
21
+ | 'stop'
22
+ | 'length'
23
+ | 'content-filter'
24
+ | 'tool-calls'
25
+ | 'error'
26
+ | 'other';
27
+
28
+ /**
29
+ * Raw finish reason from the provider.
30
+ * This is the original finish reason from the provider.
31
+ */
32
+ raw: string | undefined;
33
+ };
@@ -0,0 +1,53 @@
1
+ import { JSONSchema7 } from 'json-schema';
2
+ import { SharedV3ProviderOptions } from '../../shared';
3
+ import { JSONObject } from '../../json-value';
4
+
5
+ /**
6
+ A tool has a name, a description, and a set of parameters.
7
+
8
+ Note: this is **not** the user-facing tool definition. The AI SDK methods will
9
+ map the user-facing tool definitions to this format.
10
+ */
11
+ export type LanguageModelV3FunctionTool = {
12
+ /**
13
+ The type of the tool (always 'function').
14
+ */
15
+ type: 'function';
16
+
17
+ /**
18
+ The name of the tool. Unique within this model call.
19
+ */
20
+ name: string;
21
+
22
+ /**
23
+ A description of the tool. The language model uses this to understand the
24
+ tool's purpose and to provide better completion suggestions.
25
+ */
26
+ description?: string;
27
+
28
+ /**
29
+ The parameters that the tool expects. The language model uses this to
30
+ understand the tool's input requirements and to provide matching suggestions.
31
+ */
32
+ inputSchema: JSONSchema7;
33
+
34
+ /**
35
+ * An optional list of input examples that show the language
36
+ * model what the input should look like.
37
+ */
38
+ inputExamples?: Array<{ input: JSONObject }>;
39
+
40
+ /**
41
+ * Strict mode setting for the tool.
42
+ *
43
+ * Providers that support strict mode will use this setting to determine
44
+ * how the input should be generated. Strict mode will always produce
45
+ * valid inputs, but it might limit what input schemas are supported.
46
+ */
47
+ strict?: boolean;
48
+
49
+ /**
50
+ The provider-specific options for the tool.
51
+ */
52
+ providerOptions?: SharedV3ProviderOptions;
53
+ };
@@ -0,0 +1,63 @@
1
+ import { SharedV3Headers, SharedV3Warning } from '../../shared';
2
+ import { SharedV3ProviderMetadata } from '../../shared/v3/shared-v3-provider-metadata';
3
+ import { LanguageModelV3Content } from './language-model-v3-content';
4
+ import { LanguageModelV3FinishReason } from './language-model-v3-finish-reason';
5
+ import { LanguageModelV3ResponseMetadata } from './language-model-v3-response-metadata';
6
+ import { LanguageModelV3Usage } from './language-model-v3-usage';
7
+
8
+ /**
9
+ * The result of a language model doGenerate call.
10
+ */
11
+ export type LanguageModelV3GenerateResult = {
12
+ /**
13
+ * Ordered content that the model has generated.
14
+ */
15
+ content: Array<LanguageModelV3Content>;
16
+
17
+ /**
18
+ * The finish reason.
19
+ */
20
+ finishReason: LanguageModelV3FinishReason;
21
+
22
+ /**
23
+ * The usage information.
24
+ */
25
+ usage: LanguageModelV3Usage;
26
+
27
+ /**
28
+ * Additional provider-specific metadata. They are passed through
29
+ * from the provider to the AI SDK and enable provider-specific
30
+ * results that can be fully encapsulated in the provider.
31
+ */
32
+ providerMetadata?: SharedV3ProviderMetadata;
33
+
34
+ /**
35
+ * Optional request information for telemetry and debugging purposes.
36
+ */
37
+ request?: {
38
+ /**
39
+ * Request HTTP body that was sent to the provider API.
40
+ */
41
+ body?: unknown;
42
+ };
43
+
44
+ /**
45
+ * Optional response information for telemetry and debugging purposes.
46
+ */
47
+ response?: LanguageModelV3ResponseMetadata & {
48
+ /**
49
+ * Response headers.
50
+ */
51
+ headers?: SharedV3Headers;
52
+
53
+ /**
54
+ * Response HTTP body.
55
+ */
56
+ body?: unknown;
57
+ };
58
+
59
+ /**
60
+ * Warnings for the call, e.g. unsupported settings.
61
+ */
62
+ warnings: Array<SharedV3Warning>;
63
+ };