@ai-sdk/provider 3.0.1 → 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 (133) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/index.d.mts +60 -2
  3. package/dist/index.d.ts +60 -2
  4. package/dist/index.js.map +1 -1
  5. package/package.json +3 -1
  6. package/src/embedding-model/index.ts +2 -0
  7. package/src/embedding-model/v2/embedding-model-v2-embedding.ts +5 -0
  8. package/src/embedding-model/v2/embedding-model-v2.ts +113 -0
  9. package/src/embedding-model/v2/index.ts +2 -0
  10. package/src/embedding-model/v3/embedding-model-v3-call-options.ts +26 -0
  11. package/src/embedding-model/v3/embedding-model-v3-embedding.ts +5 -0
  12. package/src/embedding-model/v3/embedding-model-v3-result.ts +48 -0
  13. package/src/embedding-model/v3/embedding-model-v3.ts +54 -0
  14. package/src/embedding-model/v3/index.ts +4 -0
  15. package/src/embedding-model-middleware/index.ts +1 -0
  16. package/src/embedding-model-middleware/v3/embedding-model-v3-middleware.ts +69 -0
  17. package/src/embedding-model-middleware/v3/index.ts +1 -0
  18. package/src/errors/ai-sdk-error.ts +62 -0
  19. package/src/errors/api-call-error.ts +59 -0
  20. package/src/errors/empty-response-body-error.ts +17 -0
  21. package/src/errors/get-error-message.ts +15 -0
  22. package/src/errors/index.ts +15 -0
  23. package/src/errors/invalid-argument-error.ts +32 -0
  24. package/src/errors/invalid-prompt-error.ts +33 -0
  25. package/src/errors/invalid-response-data-error.ts +31 -0
  26. package/src/errors/json-parse-error.ts +29 -0
  27. package/src/errors/load-api-key-error.ts +17 -0
  28. package/src/errors/load-setting-error.ts +17 -0
  29. package/src/errors/no-content-generated-error.ts +22 -0
  30. package/src/errors/no-such-model-error.ts +45 -0
  31. package/src/errors/too-many-embedding-values-for-call-error.ts +40 -0
  32. package/src/errors/type-validation-error.ts +51 -0
  33. package/src/errors/unsupported-functionality-error.ts +26 -0
  34. package/src/image-model/index.ts +2 -0
  35. package/src/image-model/v2/image-model-v2-call-options.ts +60 -0
  36. package/src/image-model/v2/image-model-v2-call-warning.ts +16 -0
  37. package/src/image-model/v2/image-model-v2.ts +104 -0
  38. package/src/image-model/v2/index.ts +6 -0
  39. package/src/image-model/v3/image-model-v3-call-options.ts +74 -0
  40. package/src/image-model/v3/image-model-v3-file.ts +44 -0
  41. package/src/image-model/v3/image-model-v3-usage.ts +19 -0
  42. package/src/image-model/v3/image-model-v3.ts +110 -0
  43. package/src/image-model/v3/index.ts +7 -0
  44. package/src/image-model-middleware/index.ts +1 -0
  45. package/src/image-model-middleware/v3/image-model-v3-middleware.ts +61 -0
  46. package/src/image-model-middleware/v3/index.ts +1 -0
  47. package/src/index.ts +15 -0
  48. package/src/json-value/index.ts +2 -0
  49. package/src/json-value/is-json.ts +40 -0
  50. package/src/json-value/json-value.ts +17 -0
  51. package/src/language-model/index.ts +2 -0
  52. package/src/language-model/v2/index.ts +18 -0
  53. package/src/language-model/v2/language-model-v2-call-options.ts +125 -0
  54. package/src/language-model/v2/language-model-v2-call-warning.ts +23 -0
  55. package/src/language-model/v2/language-model-v2-content.ts +14 -0
  56. package/src/language-model/v2/language-model-v2-data-content.ts +4 -0
  57. package/src/language-model/v2/language-model-v2-file.ts +25 -0
  58. package/src/language-model/v2/language-model-v2-finish-reason.ts +20 -0
  59. package/src/language-model/v2/language-model-v2-function-tool.ts +37 -0
  60. package/src/language-model/v2/language-model-v2-prompt.ts +218 -0
  61. package/src/language-model/v2/language-model-v2-provider-defined-tool.ts +24 -0
  62. package/src/language-model/v2/language-model-v2-reasoning.ts +14 -0
  63. package/src/language-model/v2/language-model-v2-response-metadata.ts +16 -0
  64. package/src/language-model/v2/language-model-v2-source.ts +67 -0
  65. package/src/language-model/v2/language-model-v2-stream-part.ts +102 -0
  66. package/src/language-model/v2/language-model-v2-text.ts +15 -0
  67. package/src/language-model/v2/language-model-v2-tool-call.ts +35 -0
  68. package/src/language-model/v2/language-model-v2-tool-choice.ts +5 -0
  69. package/src/language-model/v2/language-model-v2-tool-result.ts +40 -0
  70. package/src/language-model/v2/language-model-v2-usage.ts +34 -0
  71. package/src/language-model/v2/language-model-v2.ts +137 -0
  72. package/src/language-model/v3/index.ts +21 -0
  73. package/src/language-model/v3/language-model-v3-call-options.ts +125 -0
  74. package/src/language-model/v3/language-model-v3-content.ts +16 -0
  75. package/src/language-model/v3/language-model-v3-data-content.ts +4 -0
  76. package/src/language-model/v3/language-model-v3-file.ts +32 -0
  77. package/src/language-model/v3/language-model-v3-finish-reason.ts +33 -0
  78. package/src/language-model/v3/language-model-v3-function-tool.ts +53 -0
  79. package/src/language-model/v3/language-model-v3-generate-result.ts +63 -0
  80. package/src/language-model/v3/language-model-v3-prompt.ts +422 -0
  81. package/src/language-model/v3/language-model-v3-provider-tool.ts +28 -0
  82. package/src/language-model/v3/language-model-v3-reasoning.ts +14 -0
  83. package/src/language-model/v3/language-model-v3-response-metadata.ts +16 -0
  84. package/src/language-model/v3/language-model-v3-source.ts +67 -0
  85. package/src/language-model/v3/language-model-v3-stream-part.ts +106 -0
  86. package/src/language-model/v3/language-model-v3-stream-result.ts +32 -0
  87. package/src/language-model/v3/language-model-v3-text.ts +15 -0
  88. package/src/language-model/v3/language-model-v3-tool-approval-request.ts +27 -0
  89. package/src/language-model/v3/language-model-v3-tool-call.ts +41 -0
  90. package/src/language-model/v3/language-model-v3-tool-choice.ts +5 -0
  91. package/src/language-model/v3/language-model-v3-tool-result.ts +51 -0
  92. package/src/language-model/v3/language-model-v3-usage.ts +59 -0
  93. package/src/language-model/v3/language-model-v3.ts +61 -0
  94. package/src/language-model-middleware/index.ts +2 -0
  95. package/src/language-model-middleware/v2/index.ts +1 -0
  96. package/src/language-model-middleware/v2/language-model-v2-middleware.ts +82 -0
  97. package/src/language-model-middleware/v3/index.ts +1 -0
  98. package/src/language-model-middleware/v3/language-model-v3-middleware.ts +84 -0
  99. package/src/provider/index.ts +2 -0
  100. package/src/provider/v2/index.ts +1 -0
  101. package/src/provider/v2/provider-v2.ts +64 -0
  102. package/src/provider/v3/index.ts +1 -0
  103. package/src/provider/v3/provider-v3.ts +93 -0
  104. package/src/reranking-model/index.ts +1 -0
  105. package/src/reranking-model/v3/index.ts +2 -0
  106. package/src/reranking-model/v3/reranking-model-v3-call-options.ts +40 -0
  107. package/src/reranking-model/v3/reranking-model-v3.ts +90 -0
  108. package/src/shared/index.ts +2 -0
  109. package/src/shared/v2/index.ts +3 -0
  110. package/src/shared/v2/shared-v2-headers.ts +1 -0
  111. package/src/shared/v2/shared-v2-provider-metadata.ts +27 -0
  112. package/src/shared/v2/shared-v2-provider-options.ts +24 -0
  113. package/src/shared/v3/index.ts +4 -0
  114. package/src/shared/v3/shared-v3-headers.ts +1 -0
  115. package/src/shared/v3/shared-v3-provider-metadata.ts +24 -0
  116. package/src/shared/v3/shared-v3-provider-options.ts +24 -0
  117. package/src/shared/v3/shared-v3-warning.ts +50 -0
  118. package/src/speech-model/index.ts +2 -0
  119. package/src/speech-model/v2/index.ts +3 -0
  120. package/src/speech-model/v2/speech-model-v2-call-options.ts +62 -0
  121. package/src/speech-model/v2/speech-model-v2-call-warning.ts +16 -0
  122. package/src/speech-model/v2/speech-model-v2.ts +89 -0
  123. package/src/speech-model/v3/index.ts +2 -0
  124. package/src/speech-model/v3/speech-model-v3-call-options.ts +62 -0
  125. package/src/speech-model/v3/speech-model-v3.ts +89 -0
  126. package/src/transcription-model/index.ts +2 -0
  127. package/src/transcription-model/v2/index.ts +3 -0
  128. package/src/transcription-model/v2/transcription-model-v2-call-options.ts +48 -0
  129. package/src/transcription-model/v2/transcription-model-v2-call-warning.ts +16 -0
  130. package/src/transcription-model/v2/transcription-model-v2.ts +117 -0
  131. package/src/transcription-model/v3/index.ts +2 -0
  132. package/src/transcription-model/v3/transcription-model-v3-call-options.ts +45 -0
  133. package/src/transcription-model/v3/transcription-model-v3.ts +117 -0
@@ -0,0 +1,69 @@
1
+ import { EmbeddingModelV3 } from '../../embedding-model/v3/embedding-model-v3';
2
+ import { EmbeddingModelV3CallOptions } from '../../embedding-model/v3/embedding-model-v3-call-options';
3
+
4
+ /**
5
+ * Middleware for EmbeddingModelV3.
6
+ * This type defines the structure for middleware that can be used to modify
7
+ * the behavior of EmbeddingModelV3 operations.
8
+ */
9
+ export type EmbeddingModelV3Middleware = {
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 embedding model instance.
18
+ */
19
+ overrideProvider?: (options: { model: EmbeddingModelV3 }) => string;
20
+
21
+ /**
22
+ * Override the model ID if desired.
23
+ * @param options.model - The embedding model instance.
24
+ */
25
+ overrideModelId?: (options: { model: EmbeddingModelV3 }) => string;
26
+
27
+ /**
28
+ * Override the limit of how many embeddings can be generated in a single API call if desired.
29
+ * @param options.model - The embedding model instance.
30
+ */
31
+ overrideMaxEmbeddingsPerCall?: (options: {
32
+ model: EmbeddingModelV3;
33
+ }) => PromiseLike<number | undefined> | number | undefined;
34
+
35
+ /**
36
+ * Override support for handling multiple embedding calls in parallel, if desired..
37
+ * @param options.model - The embedding model instance.
38
+ */
39
+ overrideSupportsParallelCalls?: (options: {
40
+ model: EmbeddingModelV3;
41
+ }) => PromiseLike<boolean> | boolean;
42
+
43
+ /**
44
+ * Transforms the parameters before they are passed to the embed model.
45
+ * @param options - Object containing the type of operation and the parameters.
46
+ * @param options.params - The original parameters for the embedding model call.
47
+ * @returns A promise that resolves to the transformed parameters.
48
+ */
49
+ transformParams?: (options: {
50
+ params: EmbeddingModelV3CallOptions;
51
+ model: EmbeddingModelV3;
52
+ }) => PromiseLike<EmbeddingModelV3CallOptions>;
53
+
54
+ /**
55
+ * Wraps the embed operation of the embedding model.
56
+ *
57
+ * @param options - Object containing the embed function, parameters, and model.
58
+ * @param options.doEmbed - The original embed function.
59
+ * @param options.params - The parameters for the embed call. If the
60
+ * `transformParams` middleware is used, this will be the transformed parameters.
61
+ * @param options.model - The embedding model instance.
62
+ * @returns A promise that resolves to the result of the generate operation.
63
+ */
64
+ wrapEmbed?: (options: {
65
+ doEmbed: () => ReturnType<EmbeddingModelV3['doEmbed']>;
66
+ params: EmbeddingModelV3CallOptions;
67
+ model: EmbeddingModelV3;
68
+ }) => Promise<Awaited<ReturnType<EmbeddingModelV3['doEmbed']>>>;
69
+ };
@@ -0,0 +1 @@
1
+ export * from './embedding-model-v3-middleware';
@@ -0,0 +1,62 @@
1
+ /**
2
+ * Symbol used for identifying AI SDK Error instances.
3
+ * Enables checking if an error is an instance of AISDKError across package versions.
4
+ */
5
+ const marker = 'vercel.ai.error';
6
+ const symbol = Symbol.for(marker);
7
+
8
+ /**
9
+ * Custom error class for AI SDK related errors.
10
+ * @extends Error
11
+ */
12
+ export class AISDKError extends Error {
13
+ private readonly [symbol] = true; // used in isInstance
14
+
15
+ /**
16
+ * The underlying cause of the error, if any.
17
+ */
18
+ readonly cause?: unknown;
19
+
20
+ /**
21
+ * Creates an AI SDK Error.
22
+ *
23
+ * @param {Object} params - The parameters for creating the error.
24
+ * @param {string} params.name - The name of the error.
25
+ * @param {string} params.message - The error message.
26
+ * @param {unknown} [params.cause] - The underlying cause of the error.
27
+ */
28
+ constructor({
29
+ name,
30
+ message,
31
+ cause,
32
+ }: {
33
+ name: string;
34
+ message: string;
35
+ cause?: unknown;
36
+ }) {
37
+ super(message);
38
+
39
+ this.name = name;
40
+ this.cause = cause;
41
+ }
42
+
43
+ /**
44
+ * Checks if the given error is an AI SDK Error.
45
+ * @param {unknown} error - The error to check.
46
+ * @returns {boolean} True if the error is an AI SDK Error, false otherwise.
47
+ */
48
+ static isInstance(error: unknown): error is AISDKError {
49
+ return AISDKError.hasMarker(error, marker);
50
+ }
51
+
52
+ protected static hasMarker(error: unknown, marker: string): boolean {
53
+ const markerSymbol = Symbol.for(marker);
54
+ return (
55
+ error != null &&
56
+ typeof error === 'object' &&
57
+ markerSymbol in error &&
58
+ typeof error[markerSymbol] === 'boolean' &&
59
+ error[markerSymbol] === true
60
+ );
61
+ }
62
+ }
@@ -0,0 +1,59 @@
1
+ import { AISDKError } from './ai-sdk-error';
2
+
3
+ const name = 'AI_APICallError';
4
+ const marker = `vercel.ai.error.${name}`;
5
+ const symbol = Symbol.for(marker);
6
+
7
+ export class APICallError extends AISDKError {
8
+ private readonly [symbol] = true; // used in isInstance
9
+
10
+ readonly url: string;
11
+ readonly requestBodyValues: unknown;
12
+ readonly statusCode?: number;
13
+
14
+ readonly responseHeaders?: Record<string, string>;
15
+ readonly responseBody?: string;
16
+
17
+ readonly isRetryable: boolean;
18
+ readonly data?: unknown;
19
+
20
+ constructor({
21
+ message,
22
+ url,
23
+ requestBodyValues,
24
+ statusCode,
25
+ responseHeaders,
26
+ responseBody,
27
+ cause,
28
+ isRetryable = statusCode != null &&
29
+ (statusCode === 408 || // request timeout
30
+ statusCode === 409 || // conflict
31
+ statusCode === 429 || // too many requests
32
+ statusCode >= 500), // server error
33
+ data,
34
+ }: {
35
+ message: string;
36
+ url: string;
37
+ requestBodyValues: unknown;
38
+ statusCode?: number;
39
+ responseHeaders?: Record<string, string>;
40
+ responseBody?: string;
41
+ cause?: unknown;
42
+ isRetryable?: boolean;
43
+ data?: unknown;
44
+ }) {
45
+ super({ name, message, cause });
46
+
47
+ this.url = url;
48
+ this.requestBodyValues = requestBodyValues;
49
+ this.statusCode = statusCode;
50
+ this.responseHeaders = responseHeaders;
51
+ this.responseBody = responseBody;
52
+ this.isRetryable = isRetryable;
53
+ this.data = data;
54
+ }
55
+
56
+ static isInstance(error: unknown): error is APICallError {
57
+ return AISDKError.hasMarker(error, marker);
58
+ }
59
+ }
@@ -0,0 +1,17 @@
1
+ import { AISDKError } from './ai-sdk-error';
2
+
3
+ const name = 'AI_EmptyResponseBodyError';
4
+ const marker = `vercel.ai.error.${name}`;
5
+ const symbol = Symbol.for(marker);
6
+
7
+ export class EmptyResponseBodyError extends AISDKError {
8
+ private readonly [symbol] = true; // used in isInstance
9
+
10
+ constructor({ message = 'Empty response body' }: { message?: string } = {}) {
11
+ super({ name, message });
12
+ }
13
+
14
+ static isInstance(error: unknown): error is EmptyResponseBodyError {
15
+ return AISDKError.hasMarker(error, marker);
16
+ }
17
+ }
@@ -0,0 +1,15 @@
1
+ export function getErrorMessage(error: unknown | undefined) {
2
+ if (error == null) {
3
+ return 'unknown error';
4
+ }
5
+
6
+ if (typeof error === 'string') {
7
+ return error;
8
+ }
9
+
10
+ if (error instanceof Error) {
11
+ return error.message;
12
+ }
13
+
14
+ return JSON.stringify(error);
15
+ }
@@ -0,0 +1,15 @@
1
+ export { AISDKError } from './ai-sdk-error';
2
+ export { APICallError } from './api-call-error';
3
+ export { EmptyResponseBodyError } from './empty-response-body-error';
4
+ export { getErrorMessage } from './get-error-message';
5
+ export { InvalidArgumentError } from './invalid-argument-error';
6
+ export { InvalidPromptError } from './invalid-prompt-error';
7
+ export { InvalidResponseDataError } from './invalid-response-data-error';
8
+ export { JSONParseError } from './json-parse-error';
9
+ export { LoadAPIKeyError } from './load-api-key-error';
10
+ export { LoadSettingError } from './load-setting-error';
11
+ export { NoContentGeneratedError } from './no-content-generated-error';
12
+ export { NoSuchModelError } from './no-such-model-error';
13
+ export { TooManyEmbeddingValuesForCallError } from './too-many-embedding-values-for-call-error';
14
+ export { TypeValidationError } from './type-validation-error';
15
+ export { UnsupportedFunctionalityError } from './unsupported-functionality-error';
@@ -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,2 @@
1
+ export * from './v3/index';
2
+ export * from './v2/index';
@@ -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
+ };