@ai-sdk/gateway 4.0.0-canary.89 → 4.0.0-canary.91
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/dist/index.d.ts +9 -2
- package/dist/index.js +24 -16
- package/dist/index.js.map +1 -1
- package/docs/00-ai-gateway.mdx +64 -8
- package/package.json +1 -1
- package/src/errors/gateway-authentication-error.ts +8 -4
- package/src/errors/parse-auth-method.ts +1 -2
- package/src/gateway-headers.ts +3 -0
- package/src/gateway-provider-options.ts +7 -0
- package/src/gateway-provider.ts +30 -14
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
# @ai-sdk/gateway
|
|
2
2
|
|
|
3
|
+
## 4.0.0-canary.91
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- d4d4a5e: Add `serviceTier: 'flex' | 'priority'` to `GatewayProviderOptions`.
|
|
8
|
+
|
|
9
|
+
## 4.0.0-canary.90
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- 8b811d8: feat(provider/gateway): add optional Vercel team scoping for Gateway authentication. The existing `apiKey` option can be used with AI Gateway API keys, Vercel personal access tokens, and Vercel app access tokens.
|
|
14
|
+
|
|
3
15
|
## 4.0.0-canary.89
|
|
4
16
|
|
|
5
17
|
### Patch Changes
|
package/dist/index.d.ts
CHANGED
|
@@ -546,13 +546,19 @@ interface GatewayProvider extends ProviderV4 {
|
|
|
546
546
|
}
|
|
547
547
|
interface GatewayProviderSettings {
|
|
548
548
|
/**
|
|
549
|
-
* The base URL prefix for API calls. Defaults to `https://ai-gateway.vercel.sh/
|
|
549
|
+
* The base URL prefix for API calls. Defaults to `https://ai-gateway.vercel.sh/v4/ai`.
|
|
550
550
|
*/
|
|
551
551
|
baseURL?: string;
|
|
552
552
|
/**
|
|
553
|
-
* API key that is being sent using the `Authorization`
|
|
553
|
+
* API key or Vercel access token that is being sent using the `Authorization`
|
|
554
|
+
* header. It defaults to the `AI_GATEWAY_API_KEY` environment variable.
|
|
554
555
|
*/
|
|
555
556
|
apiKey?: string;
|
|
557
|
+
/**
|
|
558
|
+
* Vercel team ID or slug to scope requests for access tokens that can access
|
|
559
|
+
* multiple teams.
|
|
560
|
+
*/
|
|
561
|
+
teamIdOrSlug?: string;
|
|
556
562
|
/**
|
|
557
563
|
* Custom headers to include in the requests.
|
|
558
564
|
*/
|
|
@@ -588,6 +594,7 @@ declare const gatewayProviderOptions: _ai_sdk_provider_utils.LazySchema<{
|
|
|
588
594
|
providerTimeouts?: {
|
|
589
595
|
byok?: Record<string, number> | undefined;
|
|
590
596
|
} | undefined;
|
|
597
|
+
serviceTier?: "flex" | "priority" | undefined;
|
|
591
598
|
}>;
|
|
592
599
|
type GatewayProviderOptions = InferSchema<typeof gatewayProviderOptions>;
|
|
593
600
|
|
package/dist/index.js
CHANGED
|
@@ -80,17 +80,18 @@ var GatewayAuthenticationError = class _GatewayAuthenticationError extends (_b2
|
|
|
80
80
|
}) {
|
|
81
81
|
let contextualMessage;
|
|
82
82
|
if (apiKeyProvided) {
|
|
83
|
-
contextualMessage = `AI Gateway authentication failed: Invalid API key.
|
|
83
|
+
contextualMessage = `AI Gateway authentication failed: Invalid API key or token.
|
|
84
84
|
|
|
85
85
|
Create a new API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys
|
|
86
86
|
|
|
87
|
-
Provide via 'apiKey' option or 'AI_GATEWAY_API_KEY' environment variable.`;
|
|
87
|
+
Provide an API key or Vercel access token via 'apiKey' option or 'AI_GATEWAY_API_KEY' environment variable.`;
|
|
88
88
|
} else if (oidcTokenProvided) {
|
|
89
89
|
contextualMessage = `AI Gateway authentication failed: Invalid OIDC token.
|
|
90
90
|
|
|
91
91
|
Run 'npx vercel link' to link your project, then 'vc env pull' to fetch the token.
|
|
92
92
|
|
|
93
|
-
Alternatively, use an API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys
|
|
93
|
+
Alternatively, use an API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys
|
|
94
|
+
or pass a Vercel access token via the 'apiKey' option.`;
|
|
94
95
|
} else {
|
|
95
96
|
contextualMessage = `AI Gateway authentication failed: No authentication provided.
|
|
96
97
|
|
|
@@ -98,7 +99,10 @@ Option 1 - API key:
|
|
|
98
99
|
Create an API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys
|
|
99
100
|
Provide via 'apiKey' option or 'AI_GATEWAY_API_KEY' environment variable.
|
|
100
101
|
|
|
101
|
-
Option 2 -
|
|
102
|
+
Option 2 - Vercel access token:
|
|
103
|
+
Pass a Vercel personal access token or Vercel app access token via the 'apiKey' option.
|
|
104
|
+
|
|
105
|
+
Option 3 - OIDC token:
|
|
102
106
|
Run 'npx vercel link' to link your project, then 'vc env pull' to fetch the token.`;
|
|
103
107
|
}
|
|
104
108
|
return new _GatewayAuthenticationError({
|
|
@@ -447,6 +451,10 @@ async function asGatewayError(error, authMethod) {
|
|
|
447
451
|
});
|
|
448
452
|
}
|
|
449
453
|
|
|
454
|
+
// src/gateway-headers.ts
|
|
455
|
+
var GATEWAY_AUTH_METHOD_HEADER = "ai-gateway-auth-method";
|
|
456
|
+
var VERCEL_AI_GATEWAY_TEAM_HEADER = "x-vercel-ai-gateway-team";
|
|
457
|
+
|
|
450
458
|
// src/errors/parse-auth-method.ts
|
|
451
459
|
import { z as z3 } from "zod/v4";
|
|
452
460
|
import {
|
|
@@ -454,7 +462,6 @@ import {
|
|
|
454
462
|
safeValidateTypes as safeValidateTypes2,
|
|
455
463
|
zodSchema as zodSchema3
|
|
456
464
|
} from "@ai-sdk/provider-utils";
|
|
457
|
-
var GATEWAY_AUTH_METHOD_HEADER = "ai-gateway-auth-method";
|
|
458
465
|
async function parseAuthMethod(headers) {
|
|
459
466
|
const result = await safeValidateTypes2({
|
|
460
467
|
value: headers[GATEWAY_AUTH_METHOD_HEADER],
|
|
@@ -1954,7 +1961,7 @@ async function getVercelRequestId() {
|
|
|
1954
1961
|
}
|
|
1955
1962
|
|
|
1956
1963
|
// src/version.ts
|
|
1957
|
-
var VERSION = true ? "4.0.0-canary.
|
|
1964
|
+
var VERSION = true ? "4.0.0-canary.91" : "0.0.0-test";
|
|
1958
1965
|
|
|
1959
1966
|
// src/gateway-provider.ts
|
|
1960
1967
|
var AI_GATEWAY_PROTOCOL_VERSION = "0.0.1";
|
|
@@ -1965,18 +1972,19 @@ function createGateway(options = {}) {
|
|
|
1965
1972
|
const cacheRefreshMillis = (_a9 = options.metadataCacheRefreshMillis) != null ? _a9 : 1e3 * 60 * 5;
|
|
1966
1973
|
let lastFetchTime = 0;
|
|
1967
1974
|
const baseURL = (_b9 = withoutTrailingSlash(options.baseURL)) != null ? _b9 : "https://ai-gateway.vercel.sh/v4/ai";
|
|
1975
|
+
const createAuthHeaders = (auth) => withUserAgentSuffix(
|
|
1976
|
+
{
|
|
1977
|
+
Authorization: `Bearer ${auth.token}`,
|
|
1978
|
+
"ai-gateway-protocol-version": AI_GATEWAY_PROTOCOL_VERSION,
|
|
1979
|
+
[GATEWAY_AUTH_METHOD_HEADER]: auth.authMethod,
|
|
1980
|
+
...options.teamIdOrSlug != null ? { [VERCEL_AI_GATEWAY_TEAM_HEADER]: options.teamIdOrSlug } : {},
|
|
1981
|
+
...options.headers
|
|
1982
|
+
},
|
|
1983
|
+
`ai-sdk/gateway/${VERSION}`
|
|
1984
|
+
);
|
|
1968
1985
|
const getHeaders = async () => {
|
|
1969
1986
|
try {
|
|
1970
|
-
|
|
1971
|
-
return withUserAgentSuffix(
|
|
1972
|
-
{
|
|
1973
|
-
Authorization: `Bearer ${auth.token}`,
|
|
1974
|
-
"ai-gateway-protocol-version": AI_GATEWAY_PROTOCOL_VERSION,
|
|
1975
|
-
[GATEWAY_AUTH_METHOD_HEADER]: auth.authMethod,
|
|
1976
|
-
...options.headers
|
|
1977
|
-
},
|
|
1978
|
-
`ai-sdk/gateway/${VERSION}`
|
|
1979
|
-
);
|
|
1987
|
+
return createAuthHeaders(await getGatewayAuthToken(options));
|
|
1980
1988
|
} catch (error) {
|
|
1981
1989
|
throw GatewayAuthenticationError.createContextualError({
|
|
1982
1990
|
apiKeyProvided: false,
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/gateway-provider.ts","../src/errors/as-gateway-error.ts","../src/errors/create-gateway-error.ts","../src/errors/gateway-error.ts","../src/errors/gateway-authentication-error.ts","../src/errors/gateway-invalid-request-error.ts","../src/errors/gateway-rate-limit-error.ts","../src/errors/gateway-model-not-found-error.ts","../src/errors/gateway-internal-server-error.ts","../src/errors/gateway-response-error.ts","../src/errors/extract-api-call-response.ts","../src/errors/gateway-timeout-error.ts","../src/errors/parse-auth-method.ts","../src/gateway-fetch-metadata.ts","../src/gateway-model-entry.ts","../src/gateway-spend-report.ts","../src/gateway-generation-info.ts","../src/gateway-language-model.ts","../src/gateway-embedding-model.ts","../src/gateway-image-model.ts","../src/gateway-video-model.ts","../src/gateway-reranking-model.ts","../src/gateway-speech-model.ts","../src/gateway-transcription-model.ts","../src/tool/parallel-search.ts","../src/tool/perplexity-search.ts","../src/gateway-tools.ts","../src/vercel-environment.ts","../src/version.ts"],"sourcesContent":["import {\n loadOptionalSetting,\n withoutTrailingSlash,\n withUserAgentSuffix,\n type FetchFunction,\n} from '@ai-sdk/provider-utils';\nimport { asGatewayError, GatewayAuthenticationError } from './errors';\nimport {\n GATEWAY_AUTH_METHOD_HEADER,\n parseAuthMethod,\n} from './errors/parse-auth-method';\nimport {\n GatewayFetchMetadata,\n type GatewayFetchMetadataResponse,\n type GatewayCreditsResponse,\n} from './gateway-fetch-metadata';\nimport {\n GatewaySpendReport,\n type GatewaySpendReportParams,\n type GatewaySpendReportResponse,\n} from './gateway-spend-report';\nimport {\n GatewayGenerationInfoFetcher,\n type GatewayGenerationInfoParams,\n type GatewayGenerationInfo,\n} from './gateway-generation-info';\nimport { GatewayLanguageModel } from './gateway-language-model';\nimport { GatewayEmbeddingModel } from './gateway-embedding-model';\nimport { GatewayImageModel } from './gateway-image-model';\nimport { GatewayVideoModel } from './gateway-video-model';\nimport { GatewayRerankingModel } from './gateway-reranking-model';\nimport { GatewaySpeechModel } from './gateway-speech-model';\nimport { GatewayTranscriptionModel } from './gateway-transcription-model';\nimport type { GatewayEmbeddingModelId } from './gateway-embedding-model-settings';\nimport type { GatewayImageModelId } from './gateway-image-model-settings';\nimport type { GatewayRerankingModelId } from './gateway-reranking-model-settings';\nimport type { GatewaySpeechModelId } from './gateway-speech-model-settings';\nimport type { GatewayTranscriptionModelId } from './gateway-transcription-model-settings';\nimport type { GatewayVideoModelId } from './gateway-video-model-settings';\nimport { gatewayTools } from './gateway-tools';\nimport { getVercelOidcToken, getVercelRequestId } from './vercel-environment';\nimport type { GatewayModelId } from './gateway-language-model-settings';\nimport type {\n LanguageModelV4,\n EmbeddingModelV4,\n ImageModelV4,\n RerankingModelV4,\n SpeechModelV4,\n TranscriptionModelV4,\n Experimental_VideoModelV4,\n ProviderV4,\n} from '@ai-sdk/provider';\nimport { VERSION } from './version';\n\nexport interface GatewayProvider extends ProviderV4 {\n (modelId: GatewayModelId): LanguageModelV4;\n\n /**\n * Creates a model for text generation.\n */\n chat(modelId: GatewayModelId): LanguageModelV4;\n\n /**\n * Creates a model for text generation.\n */\n languageModel(modelId: GatewayModelId): LanguageModelV4;\n\n /**\n * Returns available providers and models for use with the remote provider.\n */\n getAvailableModels(): Promise<GatewayFetchMetadataResponse>;\n\n /**\n * Returns credit information for the authenticated user.\n */\n getCredits(): Promise<GatewayCreditsResponse>;\n\n /**\n * Returns a spend report with cost, token, and request count data,\n * aggregated by the specified dimension.\n */\n getSpendReport(\n params: GatewaySpendReportParams,\n ): Promise<GatewaySpendReportResponse>;\n\n /**\n * Returns detailed information about a specific generation by its ID,\n * including cost, token usage, latency, and provider details.\n */\n getGenerationInfo(\n params: GatewayGenerationInfoParams,\n ): Promise<GatewayGenerationInfo>;\n\n /**\n * Creates a model for generating text embeddings.\n */\n embedding(modelId: GatewayEmbeddingModelId): EmbeddingModelV4;\n\n /**\n * Creates a model for generating text embeddings.\n */\n embeddingModel(modelId: GatewayEmbeddingModelId): EmbeddingModelV4;\n\n /**\n * @deprecated Use `embeddingModel` instead.\n */\n textEmbeddingModel(modelId: GatewayEmbeddingModelId): EmbeddingModelV4;\n\n /**\n * Creates a model for generating images.\n */\n image(modelId: GatewayImageModelId): ImageModelV4;\n\n /**\n * Creates a model for generating images.\n */\n imageModel(modelId: GatewayImageModelId): ImageModelV4;\n\n /**\n * Creates a model for generating videos.\n */\n video(modelId: GatewayVideoModelId): Experimental_VideoModelV4;\n\n /**\n * Creates a model for generating videos.\n */\n videoModel(modelId: GatewayVideoModelId): Experimental_VideoModelV4;\n\n /**\n * Creates a model for reranking documents.\n */\n reranking(modelId: GatewayRerankingModelId): RerankingModelV4;\n\n /**\n * Creates a model for reranking documents.\n */\n rerankingModel(modelId: GatewayRerankingModelId): RerankingModelV4;\n\n /**\n * Creates a model for text-to-speech generation.\n */\n speech(modelId: GatewaySpeechModelId): SpeechModelV4;\n\n /**\n * Creates a model for text-to-speech generation.\n */\n speechModel(modelId: GatewaySpeechModelId): SpeechModelV4;\n\n /**\n * Creates a model for audio transcription.\n */\n transcription(modelId: GatewayTranscriptionModelId): TranscriptionModelV4;\n\n /**\n * Creates a model for audio transcription.\n */\n transcriptionModel(\n modelId: GatewayTranscriptionModelId,\n ): TranscriptionModelV4;\n\n /**\n * Gateway-specific tools executed server-side.\n */\n tools: typeof gatewayTools;\n}\n\nexport interface GatewayProviderSettings {\n /**\n * The base URL prefix for API calls. Defaults to `https://ai-gateway.vercel.sh/v1/ai`.\n */\n baseURL?: string;\n\n /**\n * API key that is being sent using the `Authorization` header.\n */\n apiKey?: string;\n\n /**\n * Custom headers to include in the requests.\n */\n headers?: Record<string, string>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n\n /**\n * How frequently to refresh the metadata cache in milliseconds.\n */\n metadataCacheRefreshMillis?: number;\n\n /**\n * @internal For testing purposes only\n */\n _internal?: {\n currentDate?: () => Date;\n };\n}\n\nconst AI_GATEWAY_PROTOCOL_VERSION = '0.0.1';\n\n/**\n * Create a remote provider instance.\n */\nexport function createGateway(\n options: GatewayProviderSettings = {},\n): GatewayProvider {\n let pendingMetadata: Promise<GatewayFetchMetadataResponse> | null = null;\n let metadataCache: GatewayFetchMetadataResponse | null = null;\n const cacheRefreshMillis =\n options.metadataCacheRefreshMillis ?? 1000 * 60 * 5;\n let lastFetchTime = 0;\n\n const baseURL =\n withoutTrailingSlash(options.baseURL) ??\n 'https://ai-gateway.vercel.sh/v4/ai';\n\n const getHeaders = async () => {\n try {\n const auth = await getGatewayAuthToken(options);\n return withUserAgentSuffix(\n {\n Authorization: `Bearer ${auth.token}`,\n 'ai-gateway-protocol-version': AI_GATEWAY_PROTOCOL_VERSION,\n [GATEWAY_AUTH_METHOD_HEADER]: auth.authMethod,\n ...options.headers,\n },\n `ai-sdk/gateway/${VERSION}`,\n );\n } catch (error) {\n throw GatewayAuthenticationError.createContextualError({\n apiKeyProvided: false,\n oidcTokenProvided: false,\n statusCode: 401,\n cause: error,\n });\n }\n };\n\n const createO11yHeaders = () => {\n const deploymentId = loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'VERCEL_DEPLOYMENT_ID',\n });\n const environment = loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'VERCEL_ENV',\n });\n const region = loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'VERCEL_REGION',\n });\n const projectId = loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'VERCEL_PROJECT_ID',\n });\n\n return async () => {\n const requestId = await getVercelRequestId();\n return {\n ...(deploymentId && { 'ai-o11y-deployment-id': deploymentId }),\n ...(environment && { 'ai-o11y-environment': environment }),\n ...(region && { 'ai-o11y-region': region }),\n ...(requestId && { 'ai-o11y-request-id': requestId }),\n ...(projectId && { 'ai-o11y-project-id': projectId }),\n };\n };\n };\n\n const createLanguageModel = (modelId: GatewayModelId) => {\n return new GatewayLanguageModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n\n const getAvailableModels = async () => {\n const now = options._internal?.currentDate?.().getTime() ?? Date.now();\n if (!pendingMetadata || now - lastFetchTime > cacheRefreshMillis) {\n lastFetchTime = now;\n\n pendingMetadata = new GatewayFetchMetadata({\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n })\n .getAvailableModels()\n .then(metadata => {\n metadataCache = metadata;\n return metadata;\n })\n .catch(async (error: unknown) => {\n throw await asGatewayError(\n error,\n await parseAuthMethod(await getHeaders()),\n );\n });\n }\n\n return metadataCache ? Promise.resolve(metadataCache) : pendingMetadata;\n };\n\n const getCredits = async () => {\n return new GatewayFetchMetadata({\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n })\n .getCredits()\n .catch(async (error: unknown) => {\n throw await asGatewayError(\n error,\n await parseAuthMethod(await getHeaders()),\n );\n });\n };\n\n const getSpendReport = async (params: GatewaySpendReportParams) => {\n return new GatewaySpendReport({\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n })\n .getSpendReport(params)\n .catch(async (error: unknown) => {\n throw await asGatewayError(\n error,\n await parseAuthMethod(await getHeaders()),\n );\n });\n };\n\n const getGenerationInfo = async (params: GatewayGenerationInfoParams) => {\n return new GatewayGenerationInfoFetcher({\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n })\n .getGenerationInfo(params)\n .catch(async (error: unknown) => {\n throw await asGatewayError(\n error,\n await parseAuthMethod(await getHeaders()),\n );\n });\n };\n\n const provider = function (modelId: GatewayModelId) {\n if (new.target) {\n throw new Error(\n 'The Gateway Provider model function cannot be called with the new keyword.',\n );\n }\n\n return createLanguageModel(modelId);\n };\n\n provider.specificationVersion = 'v4' as const;\n provider.getAvailableModels = getAvailableModels;\n provider.getCredits = getCredits;\n provider.getSpendReport = getSpendReport;\n provider.getGenerationInfo = getGenerationInfo;\n provider.imageModel = (modelId: GatewayImageModelId) => {\n return new GatewayImageModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n provider.languageModel = createLanguageModel;\n const createEmbeddingModel = (modelId: GatewayEmbeddingModelId) => {\n return new GatewayEmbeddingModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n provider.embeddingModel = createEmbeddingModel;\n provider.textEmbeddingModel = createEmbeddingModel;\n provider.videoModel = (modelId: GatewayVideoModelId) => {\n return new GatewayVideoModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n const createRerankingModel = (modelId: GatewayRerankingModelId) => {\n return new GatewayRerankingModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n provider.rerankingModel = createRerankingModel;\n provider.reranking = createRerankingModel;\n const createSpeechModel = (modelId: GatewaySpeechModelId) => {\n return new GatewaySpeechModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n provider.speechModel = createSpeechModel;\n provider.speech = createSpeechModel;\n const createTranscriptionModel = (modelId: GatewayTranscriptionModelId) => {\n return new GatewayTranscriptionModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n provider.transcriptionModel = createTranscriptionModel;\n provider.transcription = createTranscriptionModel;\n provider.chat = provider.languageModel;\n provider.embedding = provider.embeddingModel;\n provider.image = provider.imageModel;\n provider.video = provider.videoModel;\n provider.tools = gatewayTools;\n return provider;\n}\n\nexport const gateway = createGateway();\n\nexport async function getGatewayAuthToken(\n options: GatewayProviderSettings,\n): Promise<{ token: string; authMethod: 'api-key' | 'oidc' }> {\n const apiKey = loadOptionalSetting({\n settingValue: options.apiKey,\n environmentVariableName: 'AI_GATEWAY_API_KEY',\n });\n\n if (apiKey) {\n return {\n token: apiKey,\n authMethod: 'api-key',\n };\n }\n\n const oidcToken = await getVercelOidcToken();\n return {\n token: oidcToken,\n authMethod: 'oidc',\n };\n}\n","import { APICallError } from '@ai-sdk/provider';\nimport { createGatewayErrorFromResponse } from './create-gateway-error';\nimport { extractApiCallResponse } from './extract-api-call-response';\nimport { GatewayError } from './gateway-error';\nimport { GatewayTimeoutError } from './gateway-timeout-error';\n\n/**\n * Checks if an error is a timeout error from undici.\n * Only checks undici-specific error codes to avoid false positives.\n */\nfunction isTimeoutError(error: unknown): boolean {\n if (!(error instanceof Error)) {\n return false;\n }\n\n // Check for undici-specific timeout error codes\n const errorCode = (error as any).code;\n if (typeof errorCode === 'string') {\n const undiciTimeoutCodes = [\n 'UND_ERR_HEADERS_TIMEOUT',\n 'UND_ERR_BODY_TIMEOUT',\n 'UND_ERR_CONNECT_TIMEOUT',\n ];\n return undiciTimeoutCodes.includes(errorCode);\n }\n\n return false;\n}\n\nexport async function asGatewayError(\n error: unknown,\n authMethod?: 'api-key' | 'oidc',\n) {\n if (GatewayError.isInstance(error)) {\n return error;\n }\n\n // Check if this is a timeout error (or has a timeout error in the cause chain)\n if (isTimeoutError(error)) {\n return GatewayTimeoutError.createTimeoutError({\n originalMessage: error instanceof Error ? error.message : 'Unknown error',\n cause: error,\n });\n }\n\n // Check if this is an APICallError caused by a timeout\n if (APICallError.isInstance(error)) {\n // Check if the cause is a timeout error\n if (error.cause && isTimeoutError(error.cause)) {\n return GatewayTimeoutError.createTimeoutError({\n originalMessage: error.message,\n cause: error,\n });\n }\n\n return await createGatewayErrorFromResponse({\n response: extractApiCallResponse(error),\n statusCode: error.statusCode ?? 500,\n defaultMessage: 'Gateway request failed',\n cause: error,\n authMethod,\n });\n }\n\n return await createGatewayErrorFromResponse({\n response: {},\n statusCode: 500,\n defaultMessage:\n error instanceof Error\n ? `Gateway request failed: ${error.message}`\n : 'Unknown Gateway error',\n cause: error,\n authMethod,\n });\n}\n","import { z } from 'zod/v4';\nimport type { GatewayError } from './gateway-error';\nimport { GatewayAuthenticationError } from './gateway-authentication-error';\nimport { GatewayInvalidRequestError } from './gateway-invalid-request-error';\nimport { GatewayRateLimitError } from './gateway-rate-limit-error';\nimport {\n GatewayModelNotFoundError,\n modelNotFoundParamSchema,\n} from './gateway-model-not-found-error';\nimport { GatewayInternalServerError } from './gateway-internal-server-error';\nimport { GatewayResponseError } from './gateway-response-error';\nimport {\n lazySchema,\n safeValidateTypes,\n zodSchema,\n type InferSchema,\n} from '@ai-sdk/provider-utils';\nexport async function createGatewayErrorFromResponse({\n response,\n statusCode,\n defaultMessage = 'Gateway request failed',\n cause,\n authMethod,\n}: {\n response: unknown;\n statusCode: number;\n defaultMessage?: string;\n cause?: unknown;\n authMethod?: 'api-key' | 'oidc';\n}): Promise<GatewayError> {\n const parseResult = await safeValidateTypes({\n value: response,\n schema: gatewayErrorResponseSchema,\n });\n\n if (!parseResult.success) {\n // Try to extract generationId even if validation failed\n const rawGenerationId =\n typeof response === 'object' &&\n response !== null &&\n 'generationId' in response\n ? (response as { generationId?: string }).generationId\n : undefined;\n\n return new GatewayResponseError({\n message: `Invalid error response format: ${defaultMessage}`,\n statusCode,\n response,\n validationError: parseResult.error,\n cause,\n generationId: rawGenerationId,\n });\n }\n\n const validatedResponse: GatewayErrorResponse = parseResult.value;\n const errorType = validatedResponse.error.type;\n const message = validatedResponse.error.message;\n const generationId = validatedResponse.generationId ?? undefined;\n\n switch (errorType) {\n case 'authentication_error':\n return GatewayAuthenticationError.createContextualError({\n apiKeyProvided: authMethod === 'api-key',\n oidcTokenProvided: authMethod === 'oidc',\n statusCode,\n cause,\n generationId,\n });\n case 'invalid_request_error':\n return new GatewayInvalidRequestError({\n message,\n statusCode,\n cause,\n generationId,\n });\n case 'rate_limit_exceeded':\n return new GatewayRateLimitError({\n message,\n statusCode,\n cause,\n generationId,\n });\n case 'model_not_found': {\n const modelResult = await safeValidateTypes({\n value: validatedResponse.error.param,\n schema: modelNotFoundParamSchema,\n });\n\n return new GatewayModelNotFoundError({\n message,\n statusCode,\n modelId: modelResult.success ? modelResult.value.modelId : undefined,\n cause,\n generationId,\n });\n }\n case 'internal_server_error':\n return new GatewayInternalServerError({\n message,\n statusCode,\n cause,\n generationId,\n });\n default:\n return new GatewayInternalServerError({\n message,\n statusCode,\n cause,\n generationId,\n });\n }\n}\n\nconst gatewayErrorResponseSchema = lazySchema(() =>\n zodSchema(\n z.object({\n error: z.object({\n message: z.string(),\n type: z.string().nullish(),\n param: z.unknown().nullish(),\n code: z.union([z.string(), z.number()]).nullish(),\n }),\n generationId: z.string().nullish(),\n }),\n ),\n);\n\nexport type GatewayErrorResponse = InferSchema<\n typeof gatewayErrorResponseSchema\n>;\n","const marker = 'vercel.ai.gateway.error';\nconst symbol = Symbol.for(marker);\n\nexport abstract class GatewayError extends Error {\n private readonly [symbol] = true; // used in isInstance\n\n abstract readonly name: string;\n abstract readonly type: string;\n readonly statusCode: number;\n readonly cause?: unknown;\n readonly generationId?: string;\n readonly isRetryable: boolean;\n\n constructor({\n message,\n statusCode = 500,\n cause,\n generationId,\n isRetryable = statusCode != null &&\n (statusCode === 408 || // request timeout\n statusCode === 409 || // conflict\n statusCode === 429 || // too many requests\n statusCode >= 500), // server error\n }: {\n message: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n isRetryable?: boolean;\n }) {\n super(generationId ? `${message} [${generationId}]` : message);\n this.statusCode = statusCode;\n this.cause = cause;\n this.generationId = generationId;\n this.isRetryable = isRetryable;\n }\n\n /**\n * Checks if the given error is a Gateway Error.\n * @param {unknown} error - The error to check.\n * @returns {boolean} True if the error is a Gateway Error, false otherwise.\n */\n static isInstance(error: unknown): error is GatewayError {\n return GatewayError.hasMarker(error);\n }\n\n static hasMarker(error: unknown): error is GatewayError {\n return (\n typeof error === 'object' &&\n error !== null &&\n symbol in error &&\n (error as any)[symbol] === true\n );\n }\n}\n","import { GatewayError } from './gateway-error';\n\nconst name = 'GatewayAuthenticationError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Authentication failed - invalid API key or OIDC token\n */\nexport class GatewayAuthenticationError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'authentication_error';\n\n constructor({\n message = 'Authentication failed',\n statusCode = 401,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n }\n\n static isInstance(error: unknown): error is GatewayAuthenticationError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n\n /**\n * Creates a contextual error message when authentication fails\n */\n static createContextualError({\n apiKeyProvided,\n oidcTokenProvided,\n statusCode = 401,\n cause,\n generationId,\n }: {\n apiKeyProvided: boolean;\n oidcTokenProvided: boolean;\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n }): GatewayAuthenticationError {\n let contextualMessage: string;\n\n if (apiKeyProvided) {\n contextualMessage = `AI Gateway authentication failed: Invalid API key.\n\nCreate a new API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys\n\nProvide via 'apiKey' option or 'AI_GATEWAY_API_KEY' environment variable.`;\n } else if (oidcTokenProvided) {\n contextualMessage = `AI Gateway authentication failed: Invalid OIDC token.\n\nRun 'npx vercel link' to link your project, then 'vc env pull' to fetch the token.\n\nAlternatively, use an API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys`;\n } else {\n contextualMessage = `AI Gateway authentication failed: No authentication provided.\n\nOption 1 - API key:\nCreate an API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys\nProvide via 'apiKey' option or 'AI_GATEWAY_API_KEY' environment variable.\n\nOption 2 - OIDC token:\nRun 'npx vercel link' to link your project, then 'vc env pull' to fetch the token.`;\n }\n\n return new GatewayAuthenticationError({\n message: contextualMessage,\n statusCode,\n cause,\n generationId,\n });\n }\n}\n","import { GatewayError } from './gateway-error';\n\nconst name = 'GatewayInvalidRequestError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Invalid request - missing headers, malformed data, etc.\n */\nexport class GatewayInvalidRequestError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'invalid_request_error';\n\n constructor({\n message = 'Invalid request',\n statusCode = 400,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n }\n\n static isInstance(error: unknown): error is GatewayInvalidRequestError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n}\n","import { GatewayError } from './gateway-error';\n\nconst name = 'GatewayRateLimitError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Rate limit exceeded.\n */\nexport class GatewayRateLimitError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'rate_limit_exceeded';\n\n constructor({\n message = 'Rate limit exceeded',\n statusCode = 429,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n }\n\n static isInstance(error: unknown): error is GatewayRateLimitError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n}\n","import { z } from 'zod/v4';\nimport { GatewayError } from './gateway-error';\nimport { lazySchema, zodSchema } from '@ai-sdk/provider-utils';\n\nconst name = 'GatewayModelNotFoundError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\nexport const modelNotFoundParamSchema = lazySchema(() =>\n zodSchema(\n z.object({\n modelId: z.string(),\n }),\n ),\n);\n\n/**\n * Model not found or not available\n */\nexport class GatewayModelNotFoundError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'model_not_found';\n readonly modelId?: string;\n\n constructor({\n message = 'Model not found',\n statusCode = 404,\n modelId,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n modelId?: string;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n this.modelId = modelId;\n }\n\n static isInstance(error: unknown): error is GatewayModelNotFoundError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n}\n","import { GatewayError } from './gateway-error';\n\nconst name = 'GatewayInternalServerError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Internal server error from the Gateway\n */\nexport class GatewayInternalServerError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'internal_server_error';\n\n constructor({\n message = 'Internal server error',\n statusCode = 500,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n }\n\n static isInstance(error: unknown): error is GatewayInternalServerError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n}\n","import type { TypeValidationError } from '@ai-sdk/provider';\nimport { GatewayError } from './gateway-error';\n\nconst name = 'GatewayResponseError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Gateway response parsing error\n */\nexport class GatewayResponseError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'response_error';\n readonly response?: unknown;\n readonly validationError?: TypeValidationError;\n\n constructor({\n message = 'Invalid response from Gateway',\n statusCode = 502,\n response,\n validationError,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n response?: unknown;\n validationError?: TypeValidationError;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n this.response = response;\n this.validationError = validationError;\n }\n\n static isInstance(error: unknown): error is GatewayResponseError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n}\n","import type { APICallError } from '@ai-sdk/provider';\n\nexport function extractApiCallResponse(error: APICallError): unknown {\n if (error.data !== undefined) {\n return error.data;\n }\n if (error.responseBody != null) {\n try {\n return JSON.parse(error.responseBody);\n } catch {\n return error.responseBody;\n }\n }\n return {};\n}\n","import { GatewayError } from './gateway-error';\n\nconst name = 'GatewayTimeoutError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Client request timed out before receiving a response.\n */\nexport class GatewayTimeoutError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'timeout_error';\n\n constructor({\n message = 'Request timed out',\n statusCode = 408,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n }\n\n static isInstance(error: unknown): error is GatewayTimeoutError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n\n /**\n * Creates a helpful timeout error message with troubleshooting guidance\n */\n static createTimeoutError({\n originalMessage,\n statusCode = 408,\n cause,\n generationId,\n }: {\n originalMessage: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n }): GatewayTimeoutError {\n const message = `Gateway request timed out: ${originalMessage}\n\n This is a client-side timeout. To resolve this, increase your timeout configuration: https://vercel.com/docs/ai-gateway/capabilities/video-generation#extending-timeouts-for-node.js`;\n\n return new GatewayTimeoutError({\n message,\n statusCode,\n cause,\n generationId,\n });\n }\n}\n","import { z } from 'zod/v4';\nimport {\n lazySchema,\n safeValidateTypes,\n zodSchema,\n} from '@ai-sdk/provider-utils';\n\nexport const GATEWAY_AUTH_METHOD_HEADER = 'ai-gateway-auth-method' as const;\n\nexport async function parseAuthMethod(\n headers: Record<string, string | undefined>,\n) {\n const result = await safeValidateTypes({\n value: headers[GATEWAY_AUTH_METHOD_HEADER],\n schema: gatewayAuthMethodSchema,\n });\n\n return result.success ? result.value : undefined;\n}\n\nconst gatewayAuthMethodSchema = lazySchema(() =>\n zodSchema(z.union([z.literal('api-key'), z.literal('oidc')])),\n);\n","import {\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n getFromApi,\n lazySchema,\n resolve,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport type { GatewayConfig } from './gateway-config';\nimport {\n KNOWN_MODEL_TYPES,\n type GatewayLanguageModelEntry,\n type KnownModelType,\n} from './gateway-model-entry';\ntype GatewayFetchMetadataConfig = GatewayConfig;\n\nexport interface GatewayFetchMetadataResponse {\n models: GatewayLanguageModelEntry[];\n}\n\nexport interface GatewayCreditsResponse {\n /** The remaining gateway credit balance available for API usage */\n balance: string;\n /** The total amount of gateway credits that have been consumed */\n totalUsed: string;\n}\n\nexport class GatewayFetchMetadata {\n constructor(private readonly config: GatewayFetchMetadataConfig) {}\n\n async getAvailableModels(): Promise<GatewayFetchMetadataResponse> {\n try {\n const { value } = await getFromApi({\n url: `${this.config.baseURL}/config`,\n headers: this.config.headers\n ? await resolve(this.config.headers)\n : undefined,\n successfulResponseHandler: createJsonResponseHandler(\n gatewayAvailableModelsResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n fetch: this.config.fetch,\n });\n\n return value;\n } catch (error) {\n throw await asGatewayError(error);\n }\n }\n\n async getCredits(): Promise<GatewayCreditsResponse> {\n try {\n const baseUrl = new URL(this.config.baseURL);\n\n const { value } = await getFromApi({\n url: `${baseUrl.origin}/v1/credits`,\n headers: this.config.headers\n ? await resolve(this.config.headers)\n : undefined,\n successfulResponseHandler: createJsonResponseHandler(\n gatewayCreditsResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n fetch: this.config.fetch,\n });\n\n return value;\n } catch (error) {\n throw await asGatewayError(error);\n }\n }\n}\n\nconst gatewayAvailableModelsResponseSchema = lazySchema(() =>\n zodSchema(\n z.object({\n models: z\n .array(\n z.object({\n id: z.string(),\n name: z.string(),\n description: z.string().nullish(),\n pricing: z\n .object({\n input: z.string(),\n output: z.string(),\n input_cache_read: z.string().nullish(),\n input_cache_write: z.string().nullish(),\n })\n .transform(\n ({ input, output, input_cache_read, input_cache_write }) => ({\n input,\n output,\n ...(input_cache_read\n ? { cachedInputTokens: input_cache_read }\n : {}),\n ...(input_cache_write\n ? { cacheCreationInputTokens: input_cache_write }\n : {}),\n }),\n )\n .nullish(),\n specification: z.object({\n specificationVersion: z.literal('v4'),\n provider: z.string(),\n modelId: z.string(),\n }),\n modelType: z.string().nullish(),\n }),\n )\n .transform(models =>\n models.filter(\n (m): m is typeof m & { modelType?: KnownModelType | null } =>\n m.modelType == null ||\n KNOWN_MODEL_TYPES.includes(m.modelType as KnownModelType),\n ),\n ),\n }),\n ),\n);\n\nconst gatewayCreditsResponseSchema = lazySchema(() =>\n zodSchema(\n z\n .object({\n balance: z.string(),\n total_used: z.string(),\n })\n .transform(({ balance, total_used }) => ({\n balance,\n totalUsed: total_used,\n })),\n ),\n);\n","import type { LanguageModelV4 } from '@ai-sdk/provider';\n\nexport const KNOWN_MODEL_TYPES = [\n 'embedding',\n 'image',\n 'language',\n 'reranking',\n 'speech',\n 'transcription',\n 'video',\n] as const;\n\nexport type KnownModelType = (typeof KNOWN_MODEL_TYPES)[number];\n\nexport interface GatewayLanguageModelEntry {\n /**\n * The model id used by the remote provider in model settings and for specifying the\n * intended model for text generation.\n */\n id: string;\n\n /**\n * The display name of the model for presentation in user-facing contexts.\n */\n name: string;\n\n /**\n * Optional description of the model.\n */\n description?: string | null;\n\n /**\n * Optional pricing information for the model.\n */\n pricing?: {\n /**\n * Cost per input token in USD.\n */\n input: string;\n /**\n * Cost per output token in USD.\n */\n output: string;\n /**\n * Cost per cached input token in USD.\n * Only present for providers/models that support prompt caching.\n */\n cachedInputTokens?: string;\n /**\n * Cost per input token to create/write cache entries in USD.\n * Only present for providers/models that support prompt caching.\n */\n cacheCreationInputTokens?: string;\n } | null;\n\n /**\n * Additional AI SDK language model specifications for the model.\n */\n specification: GatewayLanguageModelSpecification;\n\n /**\n * Optional field to differentiate between model types.\n */\n modelType?: KnownModelType | null;\n}\n\nexport type GatewayLanguageModelSpecification = Pick<\n LanguageModelV4,\n 'specificationVersion' | 'provider' | 'modelId'\n>;\n","import {\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n getFromApi,\n lazySchema,\n resolve,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport type { GatewayConfig } from './gateway-config';\n\nexport interface GatewaySpendReportParams {\n /** Start date in YYYY-MM-DD format (inclusive) */\n startDate: string;\n /** End date in YYYY-MM-DD format (inclusive) */\n endDate: string;\n /** Primary aggregation dimension. Defaults to 'day'. */\n groupBy?: 'day' | 'user' | 'model' | 'tag' | 'provider' | 'credential_type';\n /** Time granularity when groupBy is 'day'. */\n datePart?: 'day' | 'hour';\n /** Filter to a specific user's spend. */\n userId?: string;\n /** Filter to a specific model (e.g. 'anthropic/claude-sonnet-4.5'). */\n model?: string;\n /** Filter to a specific provider (e.g. 'anthropic'). */\n provider?: string;\n /** Filter to BYOK or system credentials. */\n credentialType?: 'byok' | 'system';\n /** Filter to requests with these tags. */\n tags?: string[];\n}\n\nexport interface GatewaySpendReportRow {\n /** Date string (present when groupBy is 'day') */\n day?: string;\n /** Hour timestamp (present when groupBy is 'day' and datePart is 'hour') */\n hour?: string;\n /** User identifier (present when groupBy is 'user') */\n user?: string;\n /** Model identifier (present when groupBy is 'model') */\n model?: string;\n /** Tag value (present when groupBy is 'tag') */\n tag?: string;\n /** Provider name (present when groupBy is 'provider') */\n provider?: string;\n /** Credential type (present when groupBy is 'credential_type') */\n credentialType?: 'byok' | 'system';\n\n /** Total cost in USD */\n totalCost: number;\n /** Market cost in USD */\n marketCost?: number;\n /** Number of input tokens */\n inputTokens?: number;\n /** Number of output tokens */\n outputTokens?: number;\n /** Number of cached input tokens */\n cachedInputTokens?: number;\n /** Number of cache creation input tokens */\n cacheCreationInputTokens?: number;\n /** Number of reasoning tokens */\n reasoningTokens?: number;\n /** Number of requests */\n requestCount?: number;\n}\n\nexport interface GatewaySpendReportResponse {\n results: GatewaySpendReportRow[];\n}\n\nexport class GatewaySpendReport {\n constructor(private readonly config: GatewayConfig) {}\n\n async getSpendReport(\n params: GatewaySpendReportParams,\n ): Promise<GatewaySpendReportResponse> {\n try {\n const baseUrl = new URL(this.config.baseURL);\n\n const searchParams = new URLSearchParams();\n searchParams.set('start_date', params.startDate);\n searchParams.set('end_date', params.endDate);\n\n if (params.groupBy) {\n searchParams.set('group_by', params.groupBy);\n }\n if (params.datePart) {\n searchParams.set('date_part', params.datePart);\n }\n if (params.userId) {\n searchParams.set('user_id', params.userId);\n }\n if (params.model) {\n searchParams.set('model', params.model);\n }\n if (params.provider) {\n searchParams.set('provider', params.provider);\n }\n if (params.credentialType) {\n searchParams.set('credential_type', params.credentialType);\n }\n if (params.tags && params.tags.length > 0) {\n searchParams.set('tags', params.tags.join(','));\n }\n\n const { value } = await getFromApi({\n url: `${baseUrl.origin}/v1/report?${searchParams.toString()}`,\n headers: this.config.headers\n ? await resolve(this.config.headers)\n : undefined,\n successfulResponseHandler: createJsonResponseHandler(\n gatewaySpendReportResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n fetch: this.config.fetch,\n });\n\n return value;\n } catch (error) {\n throw await asGatewayError(error);\n }\n }\n}\n\nconst gatewaySpendReportResponseSchema = lazySchema(() =>\n zodSchema(\n z.object({\n results: z.array(\n z\n .object({\n day: z.string().optional(),\n hour: z.string().optional(),\n user: z.string().optional(),\n model: z.string().optional(),\n tag: z.string().optional(),\n provider: z.string().optional(),\n credential_type: z.enum(['byok', 'system']).optional(),\n total_cost: z.number(),\n market_cost: z.number().optional(),\n input_tokens: z.number().optional(),\n output_tokens: z.number().optional(),\n cached_input_tokens: z.number().optional(),\n cache_creation_input_tokens: z.number().optional(),\n reasoning_tokens: z.number().optional(),\n request_count: z.number().optional(),\n })\n .transform(\n ({\n credential_type,\n total_cost,\n market_cost,\n input_tokens,\n output_tokens,\n cached_input_tokens,\n cache_creation_input_tokens,\n reasoning_tokens,\n request_count,\n ...rest\n }) => ({\n ...rest,\n ...(credential_type !== undefined\n ? { credentialType: credential_type }\n : {}),\n totalCost: total_cost,\n ...(market_cost !== undefined ? { marketCost: market_cost } : {}),\n ...(input_tokens !== undefined\n ? { inputTokens: input_tokens }\n : {}),\n ...(output_tokens !== undefined\n ? { outputTokens: output_tokens }\n : {}),\n ...(cached_input_tokens !== undefined\n ? { cachedInputTokens: cached_input_tokens }\n : {}),\n ...(cache_creation_input_tokens !== undefined\n ? { cacheCreationInputTokens: cache_creation_input_tokens }\n : {}),\n ...(reasoning_tokens !== undefined\n ? { reasoningTokens: reasoning_tokens }\n : {}),\n ...(request_count !== undefined\n ? { requestCount: request_count }\n : {}),\n }),\n ),\n ),\n }),\n ),\n);\n","import {\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n getFromApi,\n lazySchema,\n resolve,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport type { GatewayConfig } from './gateway-config';\n\nexport interface GatewayGenerationInfoParams {\n /** The generation ID to look up (format: gen_<ulid>) */\n id: string;\n}\n\nexport interface GatewayGenerationInfo {\n /** The generation ID */\n id: string;\n /** Total cost in USD */\n totalCost: number;\n /** Upstream inference cost in USD (BYOK only) */\n upstreamInferenceCost: number;\n /** Usage cost in USD (same as totalCost) */\n usage: number;\n /** ISO 8601 timestamp when the generation was created */\n createdAt: string;\n /** Model identifier */\n model: string;\n /** Whether BYOK credentials were used */\n isByok: boolean;\n /** Provider that served this generation */\n providerName: string;\n /** Whether streaming was used */\n streamed: boolean;\n /** Finish reason (e.g. 'stop') */\n finishReason: string;\n /** Time to first token in milliseconds */\n latency: number;\n /** Total generation time in milliseconds */\n generationTime: number;\n /** Number of prompt tokens */\n promptTokens: number;\n /** Number of completion tokens */\n completionTokens: number;\n /** Reasoning tokens used */\n reasoningTokens: number;\n /** Cached tokens used */\n cachedTokens: number;\n /** Cache creation input tokens */\n cacheCreationTokens: number;\n /** Billable web search calls */\n billableWebSearchCalls: number;\n}\n\nexport class GatewayGenerationInfoFetcher {\n constructor(private readonly config: GatewayConfig) {}\n\n async getGenerationInfo(\n params: GatewayGenerationInfoParams,\n ): Promise<GatewayGenerationInfo> {\n try {\n const baseUrl = new URL(this.config.baseURL);\n\n const { value } = await getFromApi({\n url: `${baseUrl.origin}/v1/generation?id=${encodeURIComponent(params.id)}`,\n headers: this.config.headers\n ? await resolve(this.config.headers)\n : undefined,\n successfulResponseHandler: createJsonResponseHandler(\n gatewayGenerationInfoResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n fetch: this.config.fetch,\n });\n\n return value;\n } catch (error) {\n throw await asGatewayError(error);\n }\n }\n}\n\nconst gatewayGenerationInfoResponseSchema = lazySchema(() =>\n zodSchema(\n z\n .object({\n data: z\n .object({\n id: z.string(),\n total_cost: z.number(),\n upstream_inference_cost: z.number(),\n usage: z.number(),\n created_at: z.string(),\n model: z.string(),\n is_byok: z.boolean(),\n provider_name: z.string(),\n streamed: z.boolean(),\n finish_reason: z.string(),\n latency: z.number(),\n generation_time: z.number(),\n native_tokens_prompt: z.number(),\n native_tokens_completion: z.number(),\n native_tokens_reasoning: z.number(),\n native_tokens_cached: z.number(),\n native_tokens_cache_creation: z.number(),\n billable_web_search_calls: z.number(),\n })\n .transform(\n ({\n total_cost,\n upstream_inference_cost,\n created_at,\n is_byok,\n provider_name,\n finish_reason,\n generation_time,\n native_tokens_prompt,\n native_tokens_completion,\n native_tokens_reasoning,\n native_tokens_cached,\n native_tokens_cache_creation,\n billable_web_search_calls,\n ...rest\n }) => ({\n ...rest,\n totalCost: total_cost,\n upstreamInferenceCost: upstream_inference_cost,\n createdAt: created_at,\n isByok: is_byok,\n providerName: provider_name,\n finishReason: finish_reason,\n generationTime: generation_time,\n promptTokens: native_tokens_prompt,\n completionTokens: native_tokens_completion,\n reasoningTokens: native_tokens_reasoning,\n cachedTokens: native_tokens_cached,\n cacheCreationTokens: native_tokens_cache_creation,\n billableWebSearchCalls: billable_web_search_calls,\n }),\n ),\n })\n .transform(({ data }) => data),\n ),\n);\n","import type {\n LanguageModelV4,\n LanguageModelV4CallOptions,\n LanguageModelV4FilePart,\n LanguageModelV4StreamPart,\n LanguageModelV4GenerateResult,\n LanguageModelV4StreamResult,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n createEventSourceResponseHandler,\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n postJsonToApi,\n resolve,\n serializeModelOptions,\n WORKFLOW_SERIALIZE,\n WORKFLOW_DESERIALIZE,\n type ParseResult,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport type { GatewayConfig } from './gateway-config';\nimport type { GatewayModelId } from './gateway-language-model-settings';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\n\ntype GatewayChatConfig = GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n};\n\nexport class GatewayLanguageModel implements LanguageModelV4 {\n readonly specificationVersion = 'v4';\n readonly supportedUrls = { '*/*': [/.*/] };\n\n static [WORKFLOW_SERIALIZE](model: GatewayLanguageModel) {\n return serializeModelOptions({\n modelId: model.modelId,\n config: model.config,\n });\n }\n\n static [WORKFLOW_DESERIALIZE](options: {\n modelId: GatewayModelId;\n config: GatewayChatConfig;\n }) {\n return new GatewayLanguageModel(options.modelId, options.config);\n }\n\n constructor(\n readonly modelId: GatewayModelId,\n private readonly config: GatewayChatConfig,\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n private async getArgs(options: LanguageModelV4CallOptions) {\n const { abortSignal: _abortSignal, ...optionsWithoutSignal } = options;\n\n return {\n args: this.maybeEncodeFileParts(optionsWithoutSignal),\n warnings: [],\n };\n }\n\n async doGenerate(\n options: LanguageModelV4CallOptions,\n ): Promise<LanguageModelV4GenerateResult> {\n const { args, warnings } = await this.getArgs(options);\n const { abortSignal } = options;\n\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n\n try {\n const {\n responseHeaders,\n value: responseBody,\n rawValue: rawResponse,\n } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n options.headers,\n this.getModelConfigHeaders(this.modelId, false),\n await resolve(this.config.o11yHeaders),\n ),\n body: args,\n successfulResponseHandler: createJsonResponseHandler(z.any()),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n ...responseBody,\n request: { body: args },\n response: { headers: responseHeaders, body: rawResponse },\n warnings,\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n async doStream(\n options: LanguageModelV4CallOptions,\n ): Promise<LanguageModelV4StreamResult> {\n const { args, warnings } = await this.getArgs(options);\n const { abortSignal } = options;\n\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n\n try {\n const { value: response, responseHeaders } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n options.headers,\n this.getModelConfigHeaders(this.modelId, true),\n await resolve(this.config.o11yHeaders),\n ),\n body: args,\n successfulResponseHandler: createEventSourceResponseHandler(z.any()),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n stream: response.pipeThrough(\n new TransformStream<\n ParseResult<LanguageModelV4StreamPart>,\n LanguageModelV4StreamPart\n >({\n start(controller) {\n if (warnings.length > 0) {\n controller.enqueue({ type: 'stream-start', warnings });\n }\n },\n transform(chunk, controller) {\n if (chunk.success) {\n const streamPart = chunk.value;\n\n // Handle raw chunks: if this is a raw chunk from the gateway API,\n // only emit it if includeRawChunks is true\n if (streamPart.type === 'raw' && !options.includeRawChunks) {\n return; // Skip raw chunks if not requested\n }\n\n if (\n streamPart.type === 'response-metadata' &&\n streamPart.timestamp &&\n typeof streamPart.timestamp === 'string'\n ) {\n streamPart.timestamp = new Date(streamPart.timestamp);\n }\n\n controller.enqueue(streamPart);\n } else {\n controller.error(\n (chunk as { success: false; error: unknown }).error,\n );\n }\n },\n }),\n ),\n request: { body: args },\n response: { headers: responseHeaders },\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private isFilePart(part: unknown) {\n return (\n part && typeof part === 'object' && 'type' in part && part.type === 'file'\n );\n }\n\n /**\n * Encodes inline `Uint8Array` file part data to a base64 string in place.\n * @param options - The options to encode.\n * @returns The options with the file parts encoded.\n */\n private maybeEncodeFileParts(options: LanguageModelV4CallOptions) {\n for (const message of options.prompt) {\n for (const part of message.content) {\n if (this.isFilePart(part)) {\n const filePart = part as LanguageModelV4FilePart;\n if (\n filePart.data.type === 'data' &&\n filePart.data.data instanceof Uint8Array\n ) {\n filePart.data = {\n type: 'data',\n data: Buffer.from(filePart.data.data).toString('base64'),\n };\n }\n }\n }\n }\n return options;\n }\n\n private getUrl() {\n return `${this.config.baseURL}/language-model`;\n }\n\n private getModelConfigHeaders(modelId: string, streaming: boolean) {\n return {\n 'ai-language-model-specification-version': '4',\n 'ai-language-model-id': modelId,\n 'ai-language-model-streaming': String(streaming),\n };\n }\n}\n","import type {\n EmbeddingModelV4,\n SharedV4ProviderMetadata,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n lazySchema,\n postJsonToApi,\n resolve,\n serializeModelOptions,\n WORKFLOW_SERIALIZE,\n WORKFLOW_DESERIALIZE,\n zodSchema,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\nimport type { GatewayConfig } from './gateway-config';\n\ntype GatewayEmbeddingConfig = GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n};\n\nexport class GatewayEmbeddingModel implements EmbeddingModelV4 {\n readonly specificationVersion = 'v4';\n readonly maxEmbeddingsPerCall = 2048;\n readonly supportsParallelCalls = true;\n\n static [WORKFLOW_SERIALIZE](model: GatewayEmbeddingModel) {\n return serializeModelOptions({\n modelId: model.modelId,\n config: model.config,\n });\n }\n\n static [WORKFLOW_DESERIALIZE](options: {\n modelId: string;\n config: GatewayEmbeddingConfig;\n }) {\n return new GatewayEmbeddingModel(options.modelId, options.config);\n }\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayEmbeddingConfig,\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doEmbed({\n values,\n headers,\n abortSignal,\n providerOptions,\n }: Parameters<EmbeddingModelV4['doEmbed']>[0]): Promise<\n Awaited<ReturnType<EmbeddingModelV4['doEmbed']>>\n > {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const {\n responseHeaders,\n value: responseBody,\n rawValue,\n } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n ),\n body: {\n values,\n ...(providerOptions ? { providerOptions } : {}),\n },\n successfulResponseHandler: createJsonResponseHandler(\n gatewayEmbeddingResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n embeddings: responseBody.embeddings,\n usage: responseBody.usage ?? undefined,\n providerMetadata:\n responseBody.providerMetadata as unknown as SharedV4ProviderMetadata,\n response: { headers: responseHeaders, body: rawValue },\n warnings: [],\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/embedding-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-embedding-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nconst gatewayEmbeddingResponseSchema = lazySchema(() =>\n zodSchema(\n z.object({\n embeddings: z.array(z.array(z.number())),\n usage: z.object({ tokens: z.number() }).nullish(),\n providerMetadata: z\n .record(z.string(), z.record(z.string(), z.unknown()))\n .optional(),\n }),\n ),\n);\n","import type {\n ImageModelV4,\n ImageModelV4File,\n ImageModelV4ProviderMetadata,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n convertUint8ArrayToBase64,\n createJsonResponseHandler,\n createJsonErrorResponseHandler,\n postJsonToApi,\n resolve,\n serializeModelOptions,\n WORKFLOW_SERIALIZE,\n WORKFLOW_DESERIALIZE,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport type { GatewayConfig } from './gateway-config';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\n\ntype GatewayImageConfig = GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n};\n\nexport class GatewayImageModel implements ImageModelV4 {\n readonly specificationVersion = 'v4' as const;\n // Set a very large number to prevent client-side splitting of requests\n readonly maxImagesPerCall = Number.MAX_SAFE_INTEGER;\n\n static [WORKFLOW_SERIALIZE](model: GatewayImageModel) {\n return serializeModelOptions({\n modelId: model.modelId,\n config: model.config,\n });\n }\n\n static [WORKFLOW_DESERIALIZE](options: {\n modelId: string;\n config: GatewayImageConfig;\n }) {\n return new GatewayImageModel(options.modelId, options.config);\n }\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayImageConfig,\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doGenerate({\n prompt,\n n,\n size,\n aspectRatio,\n seed,\n files,\n mask,\n providerOptions,\n headers,\n abortSignal,\n }: Parameters<ImageModelV4['doGenerate']>[0]): Promise<\n Awaited<ReturnType<ImageModelV4['doGenerate']>>\n > {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const { responseHeaders, value: responseBody } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n ),\n body: {\n prompt,\n n,\n ...(size && { size }),\n ...(aspectRatio && { aspectRatio }),\n ...(seed && { seed }),\n ...(providerOptions && { providerOptions }),\n ...(files && {\n files: files.map(file => maybeEncodeImageFile(file)),\n }),\n ...(mask && { mask: maybeEncodeImageFile(mask) }),\n },\n successfulResponseHandler: createJsonResponseHandler(\n gatewayImageResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n images: responseBody.images, // Always base64 strings from server\n warnings: responseBody.warnings ?? [],\n providerMetadata:\n responseBody.providerMetadata as ImageModelV4ProviderMetadata,\n response: {\n timestamp: new Date(),\n modelId: this.modelId,\n headers: responseHeaders,\n },\n ...(responseBody.usage != null && {\n usage: {\n inputTokens: responseBody.usage.inputTokens ?? undefined,\n outputTokens: responseBody.usage.outputTokens ?? undefined,\n totalTokens: responseBody.usage.totalTokens ?? undefined,\n },\n }),\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/image-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-image-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nfunction maybeEncodeImageFile(file: ImageModelV4File) {\n if (file.type === 'file' && file.data instanceof Uint8Array) {\n return {\n ...file,\n data: convertUint8ArrayToBase64(file.data),\n };\n }\n return file;\n}\n\nconst providerMetadataEntrySchema = z\n .object({\n images: z.array(z.unknown()).optional(),\n })\n .catchall(z.unknown());\n\nconst gatewayImageWarningSchema = z.discriminatedUnion('type', [\n z.object({\n type: z.literal('unsupported'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('compatibility'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('other'),\n message: z.string(),\n }),\n]);\n\nconst gatewayImageUsageSchema = z.object({\n inputTokens: z.number().nullish(),\n outputTokens: z.number().nullish(),\n totalTokens: z.number().nullish(),\n});\n\nconst gatewayImageResponseSchema = z.object({\n images: z.array(z.string()), // Always base64 strings over the wire\n warnings: z.array(gatewayImageWarningSchema).optional(),\n providerMetadata: z\n .record(z.string(), providerMetadataEntrySchema)\n .optional(),\n usage: gatewayImageUsageSchema.optional(),\n});\n","import {\n APICallError,\n type Experimental_VideoModelV4,\n type Experimental_VideoModelV4CallOptions,\n type Experimental_VideoModelV4File,\n type Experimental_VideoModelV4VideoData,\n type SharedV4ProviderMetadata,\n type SharedV4Warning,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n convertUint8ArrayToBase64,\n createJsonErrorResponseHandler,\n parseJsonEventStream,\n postJsonToApi,\n resolve,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport type { GatewayConfig } from './gateway-config';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\n\nexport class GatewayVideoModel implements Experimental_VideoModelV4 {\n readonly specificationVersion = 'v4' as const;\n // Set a very large number to prevent client-side splitting of requests\n readonly maxVideosPerCall = Number.MAX_SAFE_INTEGER;\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n },\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doGenerate({\n prompt,\n n,\n aspectRatio,\n resolution,\n duration,\n fps,\n seed,\n image,\n providerOptions,\n headers,\n abortSignal,\n }: Experimental_VideoModelV4CallOptions): Promise<{\n videos: Array<Experimental_VideoModelV4VideoData>;\n warnings: Array<SharedV4Warning>;\n providerMetadata?: SharedV4ProviderMetadata;\n response: {\n timestamp: Date;\n modelId: string;\n headers: Record<string, string> | undefined;\n };\n }> {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const { responseHeaders, value: responseBody } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n { accept: 'text/event-stream' },\n ),\n body: {\n prompt,\n n,\n ...(aspectRatio && { aspectRatio }),\n ...(resolution && { resolution }),\n ...(duration && { duration }),\n ...(fps && { fps }),\n ...(seed && { seed }),\n ...(providerOptions && { providerOptions }),\n ...(image && { image: maybeEncodeVideoFile(image) }),\n },\n successfulResponseHandler: async ({\n response,\n url,\n requestBodyValues,\n }: {\n url: string;\n requestBodyValues: unknown;\n response: Response;\n }) => {\n if (response.body == null) {\n throw new APICallError({\n message: 'SSE response body is empty',\n url,\n requestBodyValues,\n statusCode: response.status,\n });\n }\n\n const eventStream = parseJsonEventStream({\n stream: response.body,\n schema: gatewayVideoEventSchema,\n });\n\n const reader = eventStream.getReader();\n const { done, value: parseResult } = await reader.read();\n reader.releaseLock();\n\n if (done || !parseResult) {\n throw new APICallError({\n message: 'SSE stream ended without a data event',\n url,\n requestBodyValues,\n statusCode: response.status,\n });\n }\n\n if (!parseResult.success) {\n throw new APICallError({\n message: 'Failed to parse video SSE event',\n cause: parseResult.error,\n url,\n requestBodyValues,\n statusCode: response.status,\n });\n }\n\n const event = parseResult.value;\n\n if (event.type === 'error') {\n throw new APICallError({\n message: event.message,\n statusCode: event.statusCode,\n url,\n requestBodyValues,\n responseHeaders: Object.fromEntries([...response.headers]),\n responseBody: JSON.stringify(event),\n data: {\n error: {\n message: event.message,\n type: event.errorType,\n param: event.param,\n },\n },\n });\n }\n\n // event.type === 'result'\n return {\n value: {\n videos: event.videos,\n warnings: event.warnings,\n providerMetadata: event.providerMetadata,\n },\n responseHeaders: Object.fromEntries([...response.headers]),\n };\n },\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n videos: responseBody.videos,\n warnings: responseBody.warnings ?? [],\n providerMetadata:\n responseBody.providerMetadata as SharedV4ProviderMetadata,\n response: {\n timestamp: new Date(),\n modelId: this.modelId,\n headers: responseHeaders,\n },\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/video-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-video-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nfunction maybeEncodeVideoFile(file: Experimental_VideoModelV4File) {\n if (file.type === 'file' && file.data instanceof Uint8Array) {\n return {\n ...file,\n data: convertUint8ArrayToBase64(file.data),\n };\n }\n return file;\n}\n\nconst providerMetadataEntrySchema = z\n .object({\n videos: z.array(z.unknown()).optional(),\n })\n .catchall(z.unknown());\n\nconst gatewayVideoDataSchema = z.union([\n z.object({\n type: z.literal('url'),\n url: z.string(),\n mediaType: z.string(),\n }),\n z.object({\n type: z.literal('base64'),\n data: z.string(),\n mediaType: z.string(),\n }),\n]);\n\nconst gatewayVideoWarningSchema = z.discriminatedUnion('type', [\n z.object({\n type: z.literal('unsupported'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('compatibility'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('other'),\n message: z.string(),\n }),\n]);\n\nconst gatewayVideoEventSchema = z.discriminatedUnion('type', [\n z.object({\n type: z.literal('result'),\n videos: z.array(gatewayVideoDataSchema),\n warnings: z.array(gatewayVideoWarningSchema).optional(),\n providerMetadata: z\n .record(z.string(), providerMetadataEntrySchema)\n .optional(),\n }),\n z.object({\n type: z.literal('error'),\n message: z.string(),\n errorType: z.string(),\n statusCode: z.number(),\n param: z.unknown().nullable(),\n }),\n]);\n","import type {\n RerankingModelV4,\n SharedV4ProviderMetadata,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n lazySchema,\n postJsonToApi,\n resolve,\n zodSchema,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\nimport type { GatewayConfig } from './gateway-config';\n\nexport class GatewayRerankingModel implements RerankingModelV4 {\n readonly specificationVersion = 'v4';\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n },\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doRerank({\n documents,\n query,\n topN,\n headers,\n abortSignal,\n providerOptions,\n }: Parameters<RerankingModelV4['doRerank']>[0]): Promise<\n Awaited<ReturnType<RerankingModelV4['doRerank']>>\n > {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const {\n responseHeaders,\n value: responseBody,\n rawValue,\n } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n ),\n body: {\n documents,\n query,\n ...(topN != null ? { topN } : {}),\n ...(providerOptions ? { providerOptions } : {}),\n },\n successfulResponseHandler: createJsonResponseHandler(\n gatewayRerankingResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n ranking: responseBody.ranking,\n providerMetadata:\n responseBody.providerMetadata as unknown as SharedV4ProviderMetadata,\n response: { headers: responseHeaders, body: rawValue },\n warnings: [],\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/reranking-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-reranking-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nconst gatewayRerankingResponseSchema = lazySchema(() =>\n zodSchema(\n z.object({\n ranking: z.array(\n z.object({\n index: z.number(),\n relevanceScore: z.number(),\n }),\n ),\n providerMetadata: z\n .record(z.string(), z.record(z.string(), z.unknown()))\n .optional(),\n }),\n ),\n);\n","import type {\n SharedV4ProviderMetadata,\n SharedV4Warning,\n SpeechModelV4,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n postJsonToApi,\n resolve,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\nimport type { GatewayConfig } from './gateway-config';\n\nexport class GatewaySpeechModel implements SpeechModelV4 {\n readonly specificationVersion = 'v4' as const;\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n },\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doGenerate({\n text,\n voice,\n outputFormat,\n instructions,\n speed,\n language,\n providerOptions,\n headers,\n abortSignal,\n }: Parameters<SpeechModelV4['doGenerate']>[0]): Promise<\n Awaited<ReturnType<SpeechModelV4['doGenerate']>>\n > {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const {\n responseHeaders,\n value: responseBody,\n rawValue,\n } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n ),\n body: {\n text,\n ...(voice && { voice }),\n ...(outputFormat && { outputFormat }),\n ...(instructions && { instructions }),\n ...(speed != null && { speed }),\n ...(language && { language }),\n ...(providerOptions && { providerOptions }),\n },\n successfulResponseHandler: createJsonResponseHandler(\n gatewaySpeechResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n audio: responseBody.audio,\n warnings: (responseBody.warnings ?? []) as Array<SharedV4Warning>,\n providerMetadata:\n responseBody.providerMetadata as SharedV4ProviderMetadata,\n response: {\n timestamp: new Date(),\n modelId: this.modelId,\n headers: responseHeaders,\n body: rawValue,\n },\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/speech-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-speech-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nconst providerMetadataEntrySchema = z.object({}).catchall(z.unknown());\n\nconst gatewaySpeechWarningSchema = z.discriminatedUnion('type', [\n z.object({\n type: z.literal('unsupported'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('compatibility'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('other'),\n message: z.string(),\n }),\n]);\n\nconst gatewaySpeechResponseSchema = z.object({\n audio: z.string(),\n warnings: z.array(gatewaySpeechWarningSchema).optional(),\n providerMetadata: z\n .record(z.string(), providerMetadataEntrySchema)\n .optional(),\n});\n","import type {\n SharedV4ProviderMetadata,\n SharedV4Warning,\n TranscriptionModelV4,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n convertUint8ArrayToBase64,\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n postJsonToApi,\n resolve,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\nimport type { GatewayConfig } from './gateway-config';\n\nexport class GatewayTranscriptionModel implements TranscriptionModelV4 {\n readonly specificationVersion = 'v4' as const;\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n },\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doGenerate({\n audio,\n mediaType,\n providerOptions,\n headers,\n abortSignal,\n }: Parameters<TranscriptionModelV4['doGenerate']>[0]): Promise<\n Awaited<ReturnType<TranscriptionModelV4['doGenerate']>>\n > {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const {\n responseHeaders,\n value: responseBody,\n rawValue,\n } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n ),\n body: {\n audio:\n audio instanceof Uint8Array\n ? convertUint8ArrayToBase64(audio)\n : audio,\n mediaType,\n ...(providerOptions && { providerOptions }),\n },\n successfulResponseHandler: createJsonResponseHandler(\n gatewayTranscriptionResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n text: responseBody.text,\n segments: responseBody.segments ?? [],\n language: responseBody.language ?? undefined,\n durationInSeconds: responseBody.durationInSeconds ?? undefined,\n warnings: (responseBody.warnings ?? []) as Array<SharedV4Warning>,\n providerMetadata:\n responseBody.providerMetadata as SharedV4ProviderMetadata,\n response: {\n timestamp: new Date(),\n modelId: this.modelId,\n headers: responseHeaders,\n body: rawValue,\n },\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/transcription-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-transcription-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nconst providerMetadataEntrySchema = z.object({}).catchall(z.unknown());\n\nconst gatewayTranscriptionWarningSchema = z.discriminatedUnion('type', [\n z.object({\n type: z.literal('unsupported'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('compatibility'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('other'),\n message: z.string(),\n }),\n]);\n\nconst gatewayTranscriptionResponseSchema = z.object({\n text: z.string(),\n segments: z\n .array(\n z.object({\n text: z.string(),\n startSecond: z.number(),\n endSecond: z.number(),\n }),\n )\n .optional(),\n language: z.string().nullish(),\n durationInSeconds: z.number().nullish(),\n warnings: z.array(gatewayTranscriptionWarningSchema).optional(),\n providerMetadata: z\n .record(z.string(), providerMetadataEntrySchema)\n .optional(),\n});\n","import {\n createProviderExecutedToolFactory,\n lazySchema,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod';\n\nexport interface ParallelSearchSourcePolicy {\n /**\n * List of domains to include in search results.\n * Example: ['wikipedia.org', 'nature.com']\n */\n includeDomains?: string[];\n\n /**\n * List of domains to exclude from search results.\n * Example: ['reddit.com', 'twitter.com']\n */\n excludeDomains?: string[];\n\n /**\n * Only include results published after this date (ISO 8601 format).\n * Example: '2024-01-01'\n */\n afterDate?: string;\n}\n\nexport interface ParallelSearchExcerpts {\n /**\n * Maximum characters per result.\n */\n maxCharsPerResult?: number;\n\n /**\n * Maximum total characters across all results.\n */\n maxCharsTotal?: number;\n}\n\nexport interface ParallelSearchFetchPolicy {\n /**\n * Maximum age in seconds for cached content.\n * Set to 0 to always fetch fresh content.\n */\n maxAgeSeconds?: number;\n}\n\nexport interface ParallelSearchConfig {\n /**\n * Mode preset for different use cases:\n * - \"one-shot\": Comprehensive results with longer excerpts for single-response answers (default)\n * - \"agentic\": Concise, token-efficient results for multi-step agentic workflows\n */\n mode?: 'one-shot' | 'agentic';\n\n /**\n * Default maximum number of results to return (1-20).\n * Defaults to 10 if not specified.\n */\n maxResults?: number;\n\n /**\n * Default source policy for controlling which domains to include/exclude.\n */\n sourcePolicy?: ParallelSearchSourcePolicy;\n\n /**\n * Default excerpt configuration for controlling result length.\n */\n excerpts?: ParallelSearchExcerpts;\n\n /**\n * Default fetch policy for controlling content freshness.\n */\n fetchPolicy?: ParallelSearchFetchPolicy;\n}\n\nexport interface ParallelSearchResult {\n /** URL of the search result */\n url: string;\n /** Title of the search result */\n title: string;\n /** Extracted text excerpt/content from the page */\n excerpt: string;\n /** Publication date of the content (may be null) */\n publishDate?: string | null;\n /** Relevance score for the result */\n relevanceScore?: number;\n}\n\nexport interface ParallelSearchResponse {\n /** Unique identifier for this search request */\n searchId: string;\n /** Array of search results */\n results: ParallelSearchResult[];\n}\n\nexport interface ParallelSearchError {\n /** Error type */\n error:\n | 'api_error'\n | 'rate_limit'\n | 'timeout'\n | 'invalid_input'\n | 'configuration_error'\n | 'unknown';\n /** HTTP status code if applicable */\n statusCode?: number;\n /** Human-readable error message */\n message: string;\n}\n\nexport interface ParallelSearchInput {\n /**\n * Natural-language description of the web research goal.\n * Include source or freshness guidance and broader context from the task.\n * Maximum 5000 characters.\n */\n objective: string;\n\n /**\n * Optional search queries to supplement the objective.\n * Maximum 200 characters per query.\n */\n search_queries?: string[];\n\n /**\n * Mode preset for different use cases:\n * - \"one-shot\": Comprehensive results with longer excerpts\n * - \"agentic\": Concise, token-efficient results for multi-step workflows\n */\n mode?: 'one-shot' | 'agentic';\n\n /**\n * Maximum number of results to return (1-20).\n * Defaults to 10 if not specified.\n */\n max_results?: number;\n\n /**\n * Source policy for controlling which domains to include/exclude.\n */\n source_policy?: {\n include_domains?: string[];\n exclude_domains?: string[];\n after_date?: string;\n };\n\n /**\n * Excerpt configuration for controlling result length.\n */\n excerpts?: {\n max_chars_per_result?: number;\n max_chars_total?: number;\n };\n\n /**\n * Fetch policy for controlling content freshness.\n */\n fetch_policy?: {\n max_age_seconds?: number;\n };\n}\n\nexport type ParallelSearchOutput = ParallelSearchResponse | ParallelSearchError;\n\nconst parallelSearchInputSchema = lazySchema(() =>\n zodSchema(\n z.object({\n objective: z\n .string()\n .describe(\n 'Natural-language description of the web research goal, including source or freshness guidance and broader context from the task. Maximum 5000 characters.',\n ),\n\n search_queries: z\n .array(z.string())\n .optional()\n .describe(\n 'Optional search queries to supplement the objective. Maximum 200 characters per query.',\n ),\n\n mode: z\n .enum(['one-shot', 'agentic'])\n .optional()\n .describe(\n 'Mode preset: \"one-shot\" for comprehensive results with longer excerpts (default), \"agentic\" for concise, token-efficient results for multi-step workflows.',\n ),\n\n max_results: z\n .number()\n .optional()\n .describe(\n 'Maximum number of results to return (1-20). Defaults to 10 if not specified.',\n ),\n\n source_policy: z\n .object({\n include_domains: z\n .array(z.string())\n .optional()\n .describe('List of domains to include in search results.'),\n exclude_domains: z\n .array(z.string())\n .optional()\n .describe('List of domains to exclude from search results.'),\n after_date: z\n .string()\n .optional()\n .describe(\n 'Only include results published after this date (ISO 8601 format).',\n ),\n })\n .optional()\n .describe(\n 'Source policy for controlling which domains to include/exclude and freshness.',\n ),\n\n excerpts: z\n .object({\n max_chars_per_result: z\n .number()\n .optional()\n .describe('Maximum characters per result.'),\n max_chars_total: z\n .number()\n .optional()\n .describe('Maximum total characters across all results.'),\n })\n .optional()\n .describe('Excerpt configuration for controlling result length.'),\n\n fetch_policy: z\n .object({\n max_age_seconds: z\n .number()\n .optional()\n .describe(\n 'Maximum age in seconds for cached content. Set to 0 to always fetch fresh content.',\n ),\n })\n .optional()\n .describe('Fetch policy for controlling content freshness.'),\n }),\n ),\n);\n\nconst parallelSearchOutputSchema = lazySchema(() =>\n zodSchema(\n z.union([\n // Success response\n z.object({\n searchId: z.string(),\n results: z.array(\n z.object({\n url: z.string(),\n title: z.string(),\n excerpt: z.string(),\n publishDate: z.string().nullable().optional(),\n relevanceScore: z.number().optional(),\n }),\n ),\n }),\n // Error response\n z.object({\n error: z.enum([\n 'api_error',\n 'rate_limit',\n 'timeout',\n 'invalid_input',\n 'configuration_error',\n 'unknown',\n ]),\n statusCode: z.number().optional(),\n message: z.string(),\n }),\n ]),\n ),\n);\n\nexport const parallelSearchToolFactory = createProviderExecutedToolFactory<\n ParallelSearchInput,\n ParallelSearchOutput,\n ParallelSearchConfig\n>({\n id: 'gateway.parallel_search',\n inputSchema: parallelSearchInputSchema,\n outputSchema: parallelSearchOutputSchema,\n});\n\nexport const parallelSearch = (\n config: ParallelSearchConfig = {},\n): ReturnType<typeof parallelSearchToolFactory> =>\n parallelSearchToolFactory(config);\n","import {\n createProviderExecutedToolFactory,\n lazySchema,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod';\n\nexport interface PerplexitySearchConfig {\n /**\n * Default maximum number of search results to return (1-20, default: 10).\n */\n maxResults?: number;\n\n /**\n * Default maximum tokens to extract per search result page (256-2048, default: 2048).\n */\n maxTokensPerPage?: number;\n\n /**\n * Default maximum total tokens across all search results (default: 25000, max: 1000000).\n */\n maxTokens?: number;\n\n /**\n * Default two-letter ISO 3166-1 alpha-2 country code for regional search results.\n * Examples: 'US', 'GB', 'FR'\n */\n country?: string;\n\n /**\n * Default list of domains to include or exclude from search results (max 20).\n * To include: ['nature.com', 'science.org']\n * To exclude: ['-example.com', '-spam.net']\n */\n searchDomainFilter?: string[];\n\n /**\n * Default list of ISO 639-1 language codes to filter results (max 10, lowercase).\n * Examples: ['en', 'fr', 'de']\n */\n searchLanguageFilter?: string[];\n\n /**\n * Default recency filter for results.\n * Cannot be combined with searchAfterDate/searchBeforeDate at runtime.\n */\n searchRecencyFilter?: 'day' | 'week' | 'month' | 'year';\n}\n\nexport interface PerplexitySearchResult {\n /** Title of the search result */\n title: string;\n /** URL of the search result */\n url: string;\n /** Text snippet/preview of the content */\n snippet: string;\n /** Publication date of the content */\n date?: string;\n /** Last updated date of the content */\n lastUpdated?: string;\n}\n\nexport interface PerplexitySearchResponse {\n /** Array of search results */\n results: PerplexitySearchResult[];\n /** Unique identifier for this search request */\n id: string;\n}\n\nexport interface PerplexitySearchError {\n /** Error type */\n error: 'api_error' | 'rate_limit' | 'timeout' | 'invalid_input' | 'unknown';\n /** HTTP status code if applicable */\n statusCode?: number;\n /** Human-readable error message */\n message: string;\n}\n\nexport interface PerplexitySearchInput {\n /**\n * Search query (string) or multiple queries (array of up to 5 strings).\n * Multi-query searches return combined results from all queries.\n */\n query: string | string[];\n\n /**\n * Maximum number of search results to return (1-20, default: 10).\n */\n max_results?: number;\n\n /**\n * Maximum number of tokens to extract per search result page (256-2048, default: 2048).\n */\n max_tokens_per_page?: number;\n\n /**\n * Maximum total tokens across all search results (default: 25000, max: 1000000).\n */\n max_tokens?: number;\n\n /**\n * Two-letter ISO 3166-1 alpha-2 country code for regional search results.\n * Examples: 'US', 'GB', 'FR'\n */\n country?: string;\n\n /**\n * List of domains to include or exclude from search results (max 20).\n * To include: ['nature.com', 'science.org']\n * To exclude: ['-example.com', '-spam.net']\n */\n search_domain_filter?: string[];\n\n /**\n * List of ISO 639-1 language codes to filter results (max 10, lowercase).\n * Examples: ['en', 'fr', 'de']\n */\n search_language_filter?: string[];\n\n /**\n * Include only results published after this date.\n * Format: 'MM/DD/YYYY' (e.g., '3/1/2025')\n * Cannot be used with search_recency_filter.\n */\n search_after_date?: string;\n\n /**\n * Include only results published before this date.\n * Format: 'MM/DD/YYYY' (e.g., '3/15/2025')\n * Cannot be used with search_recency_filter.\n */\n search_before_date?: string;\n\n /**\n * Include only results last updated after this date.\n * Format: 'MM/DD/YYYY' (e.g., '3/1/2025')\n * Cannot be used with search_recency_filter.\n */\n last_updated_after_filter?: string;\n\n /**\n * Include only results last updated before this date.\n * Format: 'MM/DD/YYYY' (e.g., '3/15/2025')\n * Cannot be used with search_recency_filter.\n */\n last_updated_before_filter?: string;\n\n /**\n * Filter results by relative time period.\n * Cannot be used with search_after_date or search_before_date.\n */\n search_recency_filter?: 'day' | 'week' | 'month' | 'year';\n}\n\nexport type PerplexitySearchOutput =\n | PerplexitySearchResponse\n | PerplexitySearchError;\n\nconst perplexitySearchInputSchema = lazySchema(() =>\n zodSchema(\n z.object({\n query: z\n .union([z.string(), z.array(z.string())])\n .describe(\n 'Search query (string) or multiple queries (array of up to 5 strings). Multi-query searches return combined results from all queries.',\n ),\n\n max_results: z\n .number()\n .optional()\n .describe(\n 'Maximum number of search results to return (1-20, default: 10)',\n ),\n\n max_tokens_per_page: z\n .number()\n .optional()\n .describe(\n 'Maximum number of tokens to extract per search result page (256-2048, default: 2048)',\n ),\n\n max_tokens: z\n .number()\n .optional()\n .describe(\n 'Maximum total tokens across all search results (default: 25000, max: 1000000)',\n ),\n\n country: z\n .string()\n .optional()\n .describe(\n \"Two-letter ISO 3166-1 alpha-2 country code for regional search results (e.g., 'US', 'GB', 'FR')\",\n ),\n\n search_domain_filter: z\n .array(z.string())\n .optional()\n .describe(\n \"List of domains to include or exclude from search results (max 20). To include: ['nature.com', 'science.org']. To exclude: ['-example.com', '-spam.net']\",\n ),\n\n search_language_filter: z\n .array(z.string())\n .optional()\n .describe(\n \"List of ISO 639-1 language codes to filter results (max 10, lowercase). Examples: ['en', 'fr', 'de']\",\n ),\n\n search_after_date: z\n .string()\n .optional()\n .describe(\n \"Include only results published after this date. Format: 'MM/DD/YYYY' (e.g., '3/1/2025'). Cannot be used with search_recency_filter.\",\n ),\n\n search_before_date: z\n .string()\n .optional()\n .describe(\n \"Include only results published before this date. Format: 'MM/DD/YYYY' (e.g., '3/15/2025'). Cannot be used with search_recency_filter.\",\n ),\n\n last_updated_after_filter: z\n .string()\n .optional()\n .describe(\n \"Include only results last updated after this date. Format: 'MM/DD/YYYY' (e.g., '3/1/2025'). Cannot be used with search_recency_filter.\",\n ),\n\n last_updated_before_filter: z\n .string()\n .optional()\n .describe(\n \"Include only results last updated before this date. Format: 'MM/DD/YYYY' (e.g., '3/15/2025'). Cannot be used with search_recency_filter.\",\n ),\n\n search_recency_filter: z\n .enum(['day', 'week', 'month', 'year'])\n .optional()\n .describe(\n 'Filter results by relative time period. Cannot be used with search_after_date or search_before_date.',\n ),\n }),\n ),\n);\n\nconst perplexitySearchOutputSchema = lazySchema(() =>\n zodSchema(\n z.union([\n // Success response\n z.object({\n results: z.array(\n z.object({\n title: z.string(),\n url: z.string(),\n snippet: z.string(),\n date: z.string().optional(),\n lastUpdated: z.string().optional(),\n }),\n ),\n id: z.string(),\n }),\n // Error response\n z.object({\n error: z.enum([\n 'api_error',\n 'rate_limit',\n 'timeout',\n 'invalid_input',\n 'unknown',\n ]),\n statusCode: z.number().optional(),\n message: z.string(),\n }),\n ]),\n ),\n);\n\nexport const perplexitySearchToolFactory = createProviderExecutedToolFactory<\n PerplexitySearchInput,\n PerplexitySearchOutput,\n PerplexitySearchConfig\n>({\n id: 'gateway.perplexity_search',\n inputSchema: perplexitySearchInputSchema,\n outputSchema: perplexitySearchOutputSchema,\n});\n\nexport const perplexitySearch = (\n config: PerplexitySearchConfig = {},\n): ReturnType<typeof perplexitySearchToolFactory> =>\n perplexitySearchToolFactory(config);\n","import { parallelSearch } from './tool/parallel-search';\nimport { perplexitySearch } from './tool/perplexity-search';\n\n/**\n * Gateway-specific provider-defined tools.\n */\nexport const gatewayTools = {\n /**\n * Search the web using Parallel AI's Search API for LLM-optimized excerpts.\n *\n * Takes a natural language objective and returns relevant excerpts,\n * replacing multiple keyword searches with a single call for broad\n * or complex queries. Supports different search types for depth vs\n * breadth tradeoffs.\n */\n parallelSearch,\n\n /**\n * Search the web using Perplexity's Search API for real-time information,\n * news, research papers, and articles.\n *\n * Provides ranked search results with advanced filtering options including\n * domain, language, date range, and recency filters.\n */\n perplexitySearch,\n};\n","import { getContext } from '@vercel/oidc';\nexport { getVercelOidcToken } from '@vercel/oidc';\n\nexport async function getVercelRequestId(): Promise<string | undefined> {\n return getContext().headers?.['x-vercel-id'];\n}\n","// Version string of this package injected at build time.\ndeclare const __PACKAGE_VERSION__: string | undefined;\nexport const VERSION: string =\n typeof __PACKAGE_VERSION__ !== 'undefined'\n ? __PACKAGE_VERSION__\n : '0.0.0-test';\n"],"mappings":"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","names":["z","marker","symbol","_a","_b","name","marker","symbol","_a","_b","name","marker","symbol","_a","_b","name","marker","symbol","_a","_b","name","marker","symbol","_a","_b","name","marker","symbol","_a","_b","lazySchema","zodSchema","_a","z","name","marker","symbol","_a","_b","_a","z","lazySchema","safeValidateTypes","zodSchema","lazySchema","zodSchema","z","z","lazySchema","zodSchema","createJsonErrorResponseHandler","createJsonResponseHandler","getFromApi","lazySchema","resolve","zodSchema","z","getFromApi","resolve","createJsonResponseHandler","createJsonErrorResponseHandler","z","lazySchema","zodSchema","createJsonErrorResponseHandler","createJsonResponseHandler","getFromApi","lazySchema","resolve","zodSchema","z","getFromApi","resolve","createJsonResponseHandler","createJsonErrorResponseHandler","z","lazySchema","zodSchema","createJsonErrorResponseHandler","createJsonResponseHandler","resolve","z","resolve","createJsonResponseHandler","z","createJsonErrorResponseHandler","combineHeaders","createJsonErrorResponseHandler","createJsonResponseHandler","lazySchema","postJsonToApi","resolve","serializeModelOptions","WORKFLOW_SERIALIZE","WORKFLOW_DESERIALIZE","zodSchema","z","WORKFLOW_SERIALIZE","serializeModelOptions","WORKFLOW_DESERIALIZE","_a","resolve","postJsonToApi","combineHeaders","createJsonResponseHandler","createJsonErrorResponseHandler","z","lazySchema","zodSchema","combineHeaders","createJsonResponseHandler","createJsonErrorResponseHandler","postJsonToApi","resolve","serializeModelOptions","WORKFLOW_SERIALIZE","WORKFLOW_DESERIALIZE","z","WORKFLOW_SERIALIZE","serializeModelOptions","WORKFLOW_DESERIALIZE","_a","_b","resolve","postJsonToApi","combineHeaders","createJsonResponseHandler","createJsonErrorResponseHandler","z","APICallError","combineHeaders","convertUint8ArrayToBase64","createJsonErrorResponseHandler","postJsonToApi","resolve","z","_a","resolve","postJsonToApi","combineHeaders","APICallError","createJsonErrorResponseHandler","z","convertUint8ArrayToBase64","providerMetadataEntrySchema","combineHeaders","createJsonErrorResponseHandler","createJsonResponseHandler","lazySchema","postJsonToApi","resolve","zodSchema","z","resolve","postJsonToApi","combineHeaders","createJsonResponseHandler","createJsonErrorResponseHandler","z","lazySchema","zodSchema","combineHeaders","createJsonErrorResponseHandler","createJsonResponseHandler","postJsonToApi","resolve","z","_a","resolve","postJsonToApi","combineHeaders","createJsonResponseHandler","createJsonErrorResponseHandler","z","providerMetadataEntrySchema","combineHeaders","convertUint8ArrayToBase64","createJsonErrorResponseHandler","createJsonResponseHandler","postJsonToApi","resolve","z","_a","_b","resolve","postJsonToApi","combineHeaders","convertUint8ArrayToBase64","createJsonResponseHandler","createJsonErrorResponseHandler","z","providerMetadataEntrySchema","lazySchema","zodSchema","z","createProviderExecutedToolFactory","lazySchema","zodSchema","z","_a","_a","_b"]}
|
|
1
|
+
{"version":3,"sources":["../src/gateway-provider.ts","../src/errors/as-gateway-error.ts","../src/errors/create-gateway-error.ts","../src/errors/gateway-error.ts","../src/errors/gateway-authentication-error.ts","../src/errors/gateway-invalid-request-error.ts","../src/errors/gateway-rate-limit-error.ts","../src/errors/gateway-model-not-found-error.ts","../src/errors/gateway-internal-server-error.ts","../src/errors/gateway-response-error.ts","../src/errors/extract-api-call-response.ts","../src/errors/gateway-timeout-error.ts","../src/gateway-headers.ts","../src/errors/parse-auth-method.ts","../src/gateway-fetch-metadata.ts","../src/gateway-model-entry.ts","../src/gateway-spend-report.ts","../src/gateway-generation-info.ts","../src/gateway-language-model.ts","../src/gateway-embedding-model.ts","../src/gateway-image-model.ts","../src/gateway-video-model.ts","../src/gateway-reranking-model.ts","../src/gateway-speech-model.ts","../src/gateway-transcription-model.ts","../src/tool/parallel-search.ts","../src/tool/perplexity-search.ts","../src/gateway-tools.ts","../src/vercel-environment.ts","../src/version.ts"],"sourcesContent":["import {\n loadOptionalSetting,\n withoutTrailingSlash,\n withUserAgentSuffix,\n type FetchFunction,\n} from '@ai-sdk/provider-utils';\nimport { asGatewayError, GatewayAuthenticationError } from './errors';\nimport {\n GATEWAY_AUTH_METHOD_HEADER,\n VERCEL_AI_GATEWAY_TEAM_HEADER,\n} from './gateway-headers';\nimport { parseAuthMethod } from './errors/parse-auth-method';\nimport {\n GatewayFetchMetadata,\n type GatewayFetchMetadataResponse,\n type GatewayCreditsResponse,\n} from './gateway-fetch-metadata';\nimport {\n GatewaySpendReport,\n type GatewaySpendReportParams,\n type GatewaySpendReportResponse,\n} from './gateway-spend-report';\nimport {\n GatewayGenerationInfoFetcher,\n type GatewayGenerationInfoParams,\n type GatewayGenerationInfo,\n} from './gateway-generation-info';\nimport { GatewayLanguageModel } from './gateway-language-model';\nimport { GatewayEmbeddingModel } from './gateway-embedding-model';\nimport { GatewayImageModel } from './gateway-image-model';\nimport { GatewayVideoModel } from './gateway-video-model';\nimport { GatewayRerankingModel } from './gateway-reranking-model';\nimport { GatewaySpeechModel } from './gateway-speech-model';\nimport { GatewayTranscriptionModel } from './gateway-transcription-model';\nimport type { GatewayEmbeddingModelId } from './gateway-embedding-model-settings';\nimport type { GatewayImageModelId } from './gateway-image-model-settings';\nimport type { GatewayRerankingModelId } from './gateway-reranking-model-settings';\nimport type { GatewaySpeechModelId } from './gateway-speech-model-settings';\nimport type { GatewayTranscriptionModelId } from './gateway-transcription-model-settings';\nimport type { GatewayVideoModelId } from './gateway-video-model-settings';\nimport { gatewayTools } from './gateway-tools';\nimport { getVercelOidcToken, getVercelRequestId } from './vercel-environment';\nimport type { GatewayModelId } from './gateway-language-model-settings';\nimport type {\n LanguageModelV4,\n EmbeddingModelV4,\n ImageModelV4,\n RerankingModelV4,\n SpeechModelV4,\n TranscriptionModelV4,\n Experimental_VideoModelV4,\n ProviderV4,\n} from '@ai-sdk/provider';\nimport { VERSION } from './version';\n\nexport interface GatewayProvider extends ProviderV4 {\n (modelId: GatewayModelId): LanguageModelV4;\n\n /**\n * Creates a model for text generation.\n */\n chat(modelId: GatewayModelId): LanguageModelV4;\n\n /**\n * Creates a model for text generation.\n */\n languageModel(modelId: GatewayModelId): LanguageModelV4;\n\n /**\n * Returns available providers and models for use with the remote provider.\n */\n getAvailableModels(): Promise<GatewayFetchMetadataResponse>;\n\n /**\n * Returns credit information for the authenticated user.\n */\n getCredits(): Promise<GatewayCreditsResponse>;\n\n /**\n * Returns a spend report with cost, token, and request count data,\n * aggregated by the specified dimension.\n */\n getSpendReport(\n params: GatewaySpendReportParams,\n ): Promise<GatewaySpendReportResponse>;\n\n /**\n * Returns detailed information about a specific generation by its ID,\n * including cost, token usage, latency, and provider details.\n */\n getGenerationInfo(\n params: GatewayGenerationInfoParams,\n ): Promise<GatewayGenerationInfo>;\n\n /**\n * Creates a model for generating text embeddings.\n */\n embedding(modelId: GatewayEmbeddingModelId): EmbeddingModelV4;\n\n /**\n * Creates a model for generating text embeddings.\n */\n embeddingModel(modelId: GatewayEmbeddingModelId): EmbeddingModelV4;\n\n /**\n * @deprecated Use `embeddingModel` instead.\n */\n textEmbeddingModel(modelId: GatewayEmbeddingModelId): EmbeddingModelV4;\n\n /**\n * Creates a model for generating images.\n */\n image(modelId: GatewayImageModelId): ImageModelV4;\n\n /**\n * Creates a model for generating images.\n */\n imageModel(modelId: GatewayImageModelId): ImageModelV4;\n\n /**\n * Creates a model for generating videos.\n */\n video(modelId: GatewayVideoModelId): Experimental_VideoModelV4;\n\n /**\n * Creates a model for generating videos.\n */\n videoModel(modelId: GatewayVideoModelId): Experimental_VideoModelV4;\n\n /**\n * Creates a model for reranking documents.\n */\n reranking(modelId: GatewayRerankingModelId): RerankingModelV4;\n\n /**\n * Creates a model for reranking documents.\n */\n rerankingModel(modelId: GatewayRerankingModelId): RerankingModelV4;\n\n /**\n * Creates a model for text-to-speech generation.\n */\n speech(modelId: GatewaySpeechModelId): SpeechModelV4;\n\n /**\n * Creates a model for text-to-speech generation.\n */\n speechModel(modelId: GatewaySpeechModelId): SpeechModelV4;\n\n /**\n * Creates a model for audio transcription.\n */\n transcription(modelId: GatewayTranscriptionModelId): TranscriptionModelV4;\n\n /**\n * Creates a model for audio transcription.\n */\n transcriptionModel(\n modelId: GatewayTranscriptionModelId,\n ): TranscriptionModelV4;\n\n /**\n * Gateway-specific tools executed server-side.\n */\n tools: typeof gatewayTools;\n}\n\nexport interface GatewayProviderSettings {\n /**\n * The base URL prefix for API calls. Defaults to `https://ai-gateway.vercel.sh/v4/ai`.\n */\n baseURL?: string;\n\n /**\n * API key or Vercel access token that is being sent using the `Authorization`\n * header. It defaults to the `AI_GATEWAY_API_KEY` environment variable.\n */\n apiKey?: string;\n\n /**\n * Vercel team ID or slug to scope requests for access tokens that can access\n * multiple teams.\n */\n teamIdOrSlug?: string;\n\n /**\n * Custom headers to include in the requests.\n */\n headers?: Record<string, string>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n\n /**\n * How frequently to refresh the metadata cache in milliseconds.\n */\n metadataCacheRefreshMillis?: number;\n\n /**\n * @internal For testing purposes only\n */\n _internal?: {\n currentDate?: () => Date;\n };\n}\n\nconst AI_GATEWAY_PROTOCOL_VERSION = '0.0.1';\n\n/**\n * Create a remote provider instance.\n */\nexport function createGateway(\n options: GatewayProviderSettings = {},\n): GatewayProvider {\n let pendingMetadata: Promise<GatewayFetchMetadataResponse> | null = null;\n let metadataCache: GatewayFetchMetadataResponse | null = null;\n const cacheRefreshMillis =\n options.metadataCacheRefreshMillis ?? 1000 * 60 * 5;\n let lastFetchTime = 0;\n\n const baseURL =\n withoutTrailingSlash(options.baseURL) ??\n 'https://ai-gateway.vercel.sh/v4/ai';\n\n const createAuthHeaders = (auth: {\n token: string;\n authMethod: 'api-key' | 'oidc';\n }) =>\n withUserAgentSuffix(\n {\n Authorization: `Bearer ${auth.token}`,\n 'ai-gateway-protocol-version': AI_GATEWAY_PROTOCOL_VERSION,\n [GATEWAY_AUTH_METHOD_HEADER]: auth.authMethod,\n ...(options.teamIdOrSlug != null\n ? { [VERCEL_AI_GATEWAY_TEAM_HEADER]: options.teamIdOrSlug }\n : {}),\n ...options.headers,\n },\n `ai-sdk/gateway/${VERSION}`,\n );\n\n const getHeaders = async () => {\n try {\n return createAuthHeaders(await getGatewayAuthToken(options));\n } catch (error) {\n throw GatewayAuthenticationError.createContextualError({\n apiKeyProvided: false,\n oidcTokenProvided: false,\n statusCode: 401,\n cause: error,\n });\n }\n };\n\n const createO11yHeaders = () => {\n const deploymentId = loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'VERCEL_DEPLOYMENT_ID',\n });\n const environment = loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'VERCEL_ENV',\n });\n const region = loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'VERCEL_REGION',\n });\n const projectId = loadOptionalSetting({\n settingValue: undefined,\n environmentVariableName: 'VERCEL_PROJECT_ID',\n });\n\n return async () => {\n const requestId = await getVercelRequestId();\n return {\n ...(deploymentId && { 'ai-o11y-deployment-id': deploymentId }),\n ...(environment && { 'ai-o11y-environment': environment }),\n ...(region && { 'ai-o11y-region': region }),\n ...(requestId && { 'ai-o11y-request-id': requestId }),\n ...(projectId && { 'ai-o11y-project-id': projectId }),\n };\n };\n };\n\n const createLanguageModel = (modelId: GatewayModelId) => {\n return new GatewayLanguageModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n\n const getAvailableModels = async () => {\n const now = options._internal?.currentDate?.().getTime() ?? Date.now();\n if (!pendingMetadata || now - lastFetchTime > cacheRefreshMillis) {\n lastFetchTime = now;\n\n pendingMetadata = new GatewayFetchMetadata({\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n })\n .getAvailableModels()\n .then(metadata => {\n metadataCache = metadata;\n return metadata;\n })\n .catch(async (error: unknown) => {\n throw await asGatewayError(\n error,\n await parseAuthMethod(await getHeaders()),\n );\n });\n }\n\n return metadataCache ? Promise.resolve(metadataCache) : pendingMetadata;\n };\n\n const getCredits = async () => {\n return new GatewayFetchMetadata({\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n })\n .getCredits()\n .catch(async (error: unknown) => {\n throw await asGatewayError(\n error,\n await parseAuthMethod(await getHeaders()),\n );\n });\n };\n\n const getSpendReport = async (params: GatewaySpendReportParams) => {\n return new GatewaySpendReport({\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n })\n .getSpendReport(params)\n .catch(async (error: unknown) => {\n throw await asGatewayError(\n error,\n await parseAuthMethod(await getHeaders()),\n );\n });\n };\n\n const getGenerationInfo = async (params: GatewayGenerationInfoParams) => {\n return new GatewayGenerationInfoFetcher({\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n })\n .getGenerationInfo(params)\n .catch(async (error: unknown) => {\n throw await asGatewayError(\n error,\n await parseAuthMethod(await getHeaders()),\n );\n });\n };\n\n const provider = function (modelId: GatewayModelId) {\n if (new.target) {\n throw new Error(\n 'The Gateway Provider model function cannot be called with the new keyword.',\n );\n }\n\n return createLanguageModel(modelId);\n };\n\n provider.specificationVersion = 'v4' as const;\n provider.getAvailableModels = getAvailableModels;\n provider.getCredits = getCredits;\n provider.getSpendReport = getSpendReport;\n provider.getGenerationInfo = getGenerationInfo;\n provider.imageModel = (modelId: GatewayImageModelId) => {\n return new GatewayImageModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n provider.languageModel = createLanguageModel;\n const createEmbeddingModel = (modelId: GatewayEmbeddingModelId) => {\n return new GatewayEmbeddingModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n provider.embeddingModel = createEmbeddingModel;\n provider.textEmbeddingModel = createEmbeddingModel;\n provider.videoModel = (modelId: GatewayVideoModelId) => {\n return new GatewayVideoModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n const createRerankingModel = (modelId: GatewayRerankingModelId) => {\n return new GatewayRerankingModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n provider.rerankingModel = createRerankingModel;\n provider.reranking = createRerankingModel;\n const createSpeechModel = (modelId: GatewaySpeechModelId) => {\n return new GatewaySpeechModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n provider.speechModel = createSpeechModel;\n provider.speech = createSpeechModel;\n const createTranscriptionModel = (modelId: GatewayTranscriptionModelId) => {\n return new GatewayTranscriptionModel(modelId, {\n provider: 'gateway',\n baseURL,\n headers: getHeaders,\n fetch: options.fetch,\n o11yHeaders: createO11yHeaders(),\n });\n };\n provider.transcriptionModel = createTranscriptionModel;\n provider.transcription = createTranscriptionModel;\n provider.chat = provider.languageModel;\n provider.embedding = provider.embeddingModel;\n provider.image = provider.imageModel;\n provider.video = provider.videoModel;\n provider.tools = gatewayTools;\n return provider;\n}\n\nexport const gateway = createGateway();\n\nexport async function getGatewayAuthToken(\n options: GatewayProviderSettings,\n): Promise<{ token: string; authMethod: 'api-key' | 'oidc' }> {\n const apiKey = loadOptionalSetting({\n settingValue: options.apiKey,\n environmentVariableName: 'AI_GATEWAY_API_KEY',\n });\n\n if (apiKey) {\n return {\n token: apiKey,\n authMethod: 'api-key',\n };\n }\n\n const oidcToken = await getVercelOidcToken();\n return {\n token: oidcToken,\n authMethod: 'oidc',\n };\n}\n","import { APICallError } from '@ai-sdk/provider';\nimport { createGatewayErrorFromResponse } from './create-gateway-error';\nimport { extractApiCallResponse } from './extract-api-call-response';\nimport { GatewayError } from './gateway-error';\nimport { GatewayTimeoutError } from './gateway-timeout-error';\n\n/**\n * Checks if an error is a timeout error from undici.\n * Only checks undici-specific error codes to avoid false positives.\n */\nfunction isTimeoutError(error: unknown): boolean {\n if (!(error instanceof Error)) {\n return false;\n }\n\n // Check for undici-specific timeout error codes\n const errorCode = (error as any).code;\n if (typeof errorCode === 'string') {\n const undiciTimeoutCodes = [\n 'UND_ERR_HEADERS_TIMEOUT',\n 'UND_ERR_BODY_TIMEOUT',\n 'UND_ERR_CONNECT_TIMEOUT',\n ];\n return undiciTimeoutCodes.includes(errorCode);\n }\n\n return false;\n}\n\nexport async function asGatewayError(\n error: unknown,\n authMethod?: 'api-key' | 'oidc',\n) {\n if (GatewayError.isInstance(error)) {\n return error;\n }\n\n // Check if this is a timeout error (or has a timeout error in the cause chain)\n if (isTimeoutError(error)) {\n return GatewayTimeoutError.createTimeoutError({\n originalMessage: error instanceof Error ? error.message : 'Unknown error',\n cause: error,\n });\n }\n\n // Check if this is an APICallError caused by a timeout\n if (APICallError.isInstance(error)) {\n // Check if the cause is a timeout error\n if (error.cause && isTimeoutError(error.cause)) {\n return GatewayTimeoutError.createTimeoutError({\n originalMessage: error.message,\n cause: error,\n });\n }\n\n return await createGatewayErrorFromResponse({\n response: extractApiCallResponse(error),\n statusCode: error.statusCode ?? 500,\n defaultMessage: 'Gateway request failed',\n cause: error,\n authMethod,\n });\n }\n\n return await createGatewayErrorFromResponse({\n response: {},\n statusCode: 500,\n defaultMessage:\n error instanceof Error\n ? `Gateway request failed: ${error.message}`\n : 'Unknown Gateway error',\n cause: error,\n authMethod,\n });\n}\n","import { z } from 'zod/v4';\nimport type { GatewayError } from './gateway-error';\nimport { GatewayAuthenticationError } from './gateway-authentication-error';\nimport { GatewayInvalidRequestError } from './gateway-invalid-request-error';\nimport { GatewayRateLimitError } from './gateway-rate-limit-error';\nimport {\n GatewayModelNotFoundError,\n modelNotFoundParamSchema,\n} from './gateway-model-not-found-error';\nimport { GatewayInternalServerError } from './gateway-internal-server-error';\nimport { GatewayResponseError } from './gateway-response-error';\nimport {\n lazySchema,\n safeValidateTypes,\n zodSchema,\n type InferSchema,\n} from '@ai-sdk/provider-utils';\nexport async function createGatewayErrorFromResponse({\n response,\n statusCode,\n defaultMessage = 'Gateway request failed',\n cause,\n authMethod,\n}: {\n response: unknown;\n statusCode: number;\n defaultMessage?: string;\n cause?: unknown;\n authMethod?: 'api-key' | 'oidc';\n}): Promise<GatewayError> {\n const parseResult = await safeValidateTypes({\n value: response,\n schema: gatewayErrorResponseSchema,\n });\n\n if (!parseResult.success) {\n // Try to extract generationId even if validation failed\n const rawGenerationId =\n typeof response === 'object' &&\n response !== null &&\n 'generationId' in response\n ? (response as { generationId?: string }).generationId\n : undefined;\n\n return new GatewayResponseError({\n message: `Invalid error response format: ${defaultMessage}`,\n statusCode,\n response,\n validationError: parseResult.error,\n cause,\n generationId: rawGenerationId,\n });\n }\n\n const validatedResponse: GatewayErrorResponse = parseResult.value;\n const errorType = validatedResponse.error.type;\n const message = validatedResponse.error.message;\n const generationId = validatedResponse.generationId ?? undefined;\n\n switch (errorType) {\n case 'authentication_error':\n return GatewayAuthenticationError.createContextualError({\n apiKeyProvided: authMethod === 'api-key',\n oidcTokenProvided: authMethod === 'oidc',\n statusCode,\n cause,\n generationId,\n });\n case 'invalid_request_error':\n return new GatewayInvalidRequestError({\n message,\n statusCode,\n cause,\n generationId,\n });\n case 'rate_limit_exceeded':\n return new GatewayRateLimitError({\n message,\n statusCode,\n cause,\n generationId,\n });\n case 'model_not_found': {\n const modelResult = await safeValidateTypes({\n value: validatedResponse.error.param,\n schema: modelNotFoundParamSchema,\n });\n\n return new GatewayModelNotFoundError({\n message,\n statusCode,\n modelId: modelResult.success ? modelResult.value.modelId : undefined,\n cause,\n generationId,\n });\n }\n case 'internal_server_error':\n return new GatewayInternalServerError({\n message,\n statusCode,\n cause,\n generationId,\n });\n default:\n return new GatewayInternalServerError({\n message,\n statusCode,\n cause,\n generationId,\n });\n }\n}\n\nconst gatewayErrorResponseSchema = lazySchema(() =>\n zodSchema(\n z.object({\n error: z.object({\n message: z.string(),\n type: z.string().nullish(),\n param: z.unknown().nullish(),\n code: z.union([z.string(), z.number()]).nullish(),\n }),\n generationId: z.string().nullish(),\n }),\n ),\n);\n\nexport type GatewayErrorResponse = InferSchema<\n typeof gatewayErrorResponseSchema\n>;\n","const marker = 'vercel.ai.gateway.error';\nconst symbol = Symbol.for(marker);\n\nexport abstract class GatewayError extends Error {\n private readonly [symbol] = true; // used in isInstance\n\n abstract readonly name: string;\n abstract readonly type: string;\n readonly statusCode: number;\n readonly cause?: unknown;\n readonly generationId?: string;\n readonly isRetryable: boolean;\n\n constructor({\n message,\n statusCode = 500,\n cause,\n generationId,\n isRetryable = statusCode != null &&\n (statusCode === 408 || // request timeout\n statusCode === 409 || // conflict\n statusCode === 429 || // too many requests\n statusCode >= 500), // server error\n }: {\n message: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n isRetryable?: boolean;\n }) {\n super(generationId ? `${message} [${generationId}]` : message);\n this.statusCode = statusCode;\n this.cause = cause;\n this.generationId = generationId;\n this.isRetryable = isRetryable;\n }\n\n /**\n * Checks if the given error is a Gateway Error.\n * @param {unknown} error - The error to check.\n * @returns {boolean} True if the error is a Gateway Error, false otherwise.\n */\n static isInstance(error: unknown): error is GatewayError {\n return GatewayError.hasMarker(error);\n }\n\n static hasMarker(error: unknown): error is GatewayError {\n return (\n typeof error === 'object' &&\n error !== null &&\n symbol in error &&\n (error as any)[symbol] === true\n );\n }\n}\n","import { GatewayError } from './gateway-error';\n\nconst name = 'GatewayAuthenticationError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Authentication failed - invalid API key or OIDC token\n */\nexport class GatewayAuthenticationError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'authentication_error';\n\n constructor({\n message = 'Authentication failed',\n statusCode = 401,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n }\n\n static isInstance(error: unknown): error is GatewayAuthenticationError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n\n /**\n * Creates a contextual error message when authentication fails\n */\n static createContextualError({\n apiKeyProvided,\n oidcTokenProvided,\n statusCode = 401,\n cause,\n generationId,\n }: {\n apiKeyProvided: boolean;\n oidcTokenProvided: boolean;\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n }): GatewayAuthenticationError {\n let contextualMessage: string;\n\n if (apiKeyProvided) {\n contextualMessage = `AI Gateway authentication failed: Invalid API key or token.\n\nCreate a new API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys\n\nProvide an API key or Vercel access token via 'apiKey' option or 'AI_GATEWAY_API_KEY' environment variable.`;\n } else if (oidcTokenProvided) {\n contextualMessage = `AI Gateway authentication failed: Invalid OIDC token.\n\nRun 'npx vercel link' to link your project, then 'vc env pull' to fetch the token.\n\nAlternatively, use an API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys\nor pass a Vercel access token via the 'apiKey' option.`;\n } else {\n contextualMessage = `AI Gateway authentication failed: No authentication provided.\n\nOption 1 - API key:\nCreate an API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys\nProvide via 'apiKey' option or 'AI_GATEWAY_API_KEY' environment variable.\n\nOption 2 - Vercel access token:\nPass a Vercel personal access token or Vercel app access token via the 'apiKey' option.\n\nOption 3 - OIDC token:\nRun 'npx vercel link' to link your project, then 'vc env pull' to fetch the token.`;\n }\n\n return new GatewayAuthenticationError({\n message: contextualMessage,\n statusCode,\n cause,\n generationId,\n });\n }\n}\n","import { GatewayError } from './gateway-error';\n\nconst name = 'GatewayInvalidRequestError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Invalid request - missing headers, malformed data, etc.\n */\nexport class GatewayInvalidRequestError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'invalid_request_error';\n\n constructor({\n message = 'Invalid request',\n statusCode = 400,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n }\n\n static isInstance(error: unknown): error is GatewayInvalidRequestError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n}\n","import { GatewayError } from './gateway-error';\n\nconst name = 'GatewayRateLimitError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Rate limit exceeded.\n */\nexport class GatewayRateLimitError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'rate_limit_exceeded';\n\n constructor({\n message = 'Rate limit exceeded',\n statusCode = 429,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n }\n\n static isInstance(error: unknown): error is GatewayRateLimitError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n}\n","import { z } from 'zod/v4';\nimport { GatewayError } from './gateway-error';\nimport { lazySchema, zodSchema } from '@ai-sdk/provider-utils';\n\nconst name = 'GatewayModelNotFoundError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\nexport const modelNotFoundParamSchema = lazySchema(() =>\n zodSchema(\n z.object({\n modelId: z.string(),\n }),\n ),\n);\n\n/**\n * Model not found or not available\n */\nexport class GatewayModelNotFoundError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'model_not_found';\n readonly modelId?: string;\n\n constructor({\n message = 'Model not found',\n statusCode = 404,\n modelId,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n modelId?: string;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n this.modelId = modelId;\n }\n\n static isInstance(error: unknown): error is GatewayModelNotFoundError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n}\n","import { GatewayError } from './gateway-error';\n\nconst name = 'GatewayInternalServerError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Internal server error from the Gateway\n */\nexport class GatewayInternalServerError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'internal_server_error';\n\n constructor({\n message = 'Internal server error',\n statusCode = 500,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n }\n\n static isInstance(error: unknown): error is GatewayInternalServerError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n}\n","import type { TypeValidationError } from '@ai-sdk/provider';\nimport { GatewayError } from './gateway-error';\n\nconst name = 'GatewayResponseError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Gateway response parsing error\n */\nexport class GatewayResponseError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'response_error';\n readonly response?: unknown;\n readonly validationError?: TypeValidationError;\n\n constructor({\n message = 'Invalid response from Gateway',\n statusCode = 502,\n response,\n validationError,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n response?: unknown;\n validationError?: TypeValidationError;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n this.response = response;\n this.validationError = validationError;\n }\n\n static isInstance(error: unknown): error is GatewayResponseError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n}\n","import type { APICallError } from '@ai-sdk/provider';\n\nexport function extractApiCallResponse(error: APICallError): unknown {\n if (error.data !== undefined) {\n return error.data;\n }\n if (error.responseBody != null) {\n try {\n return JSON.parse(error.responseBody);\n } catch {\n return error.responseBody;\n }\n }\n return {};\n}\n","import { GatewayError } from './gateway-error';\n\nconst name = 'GatewayTimeoutError';\nconst marker = `vercel.ai.gateway.error.${name}`;\nconst symbol = Symbol.for(marker);\n\n/**\n * Client request timed out before receiving a response.\n */\nexport class GatewayTimeoutError extends GatewayError {\n private readonly [symbol] = true; // used in isInstance\n\n readonly name = name;\n readonly type = 'timeout_error';\n\n constructor({\n message = 'Request timed out',\n statusCode = 408,\n cause,\n generationId,\n }: {\n message?: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n } = {}) {\n super({ message, statusCode, cause, generationId });\n }\n\n static isInstance(error: unknown): error is GatewayTimeoutError {\n return GatewayError.hasMarker(error) && symbol in error;\n }\n\n /**\n * Creates a helpful timeout error message with troubleshooting guidance\n */\n static createTimeoutError({\n originalMessage,\n statusCode = 408,\n cause,\n generationId,\n }: {\n originalMessage: string;\n statusCode?: number;\n cause?: unknown;\n generationId?: string;\n }): GatewayTimeoutError {\n const message = `Gateway request timed out: ${originalMessage}\n\n This is a client-side timeout. To resolve this, increase your timeout configuration: https://vercel.com/docs/ai-gateway/capabilities/video-generation#extending-timeouts-for-node.js`;\n\n return new GatewayTimeoutError({\n message,\n statusCode,\n cause,\n generationId,\n });\n }\n}\n","export const GATEWAY_AUTH_METHOD_HEADER = 'ai-gateway-auth-method' as const;\nexport const VERCEL_AI_GATEWAY_TEAM_HEADER =\n 'x-vercel-ai-gateway-team' as const;\n","import { z } from 'zod/v4';\nimport {\n lazySchema,\n safeValidateTypes,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { GATEWAY_AUTH_METHOD_HEADER } from '../gateway-headers';\n\nexport async function parseAuthMethod(\n headers: Record<string, string | undefined>,\n) {\n const result = await safeValidateTypes({\n value: headers[GATEWAY_AUTH_METHOD_HEADER],\n schema: gatewayAuthMethodSchema,\n });\n\n return result.success ? result.value : undefined;\n}\n\nconst gatewayAuthMethodSchema = lazySchema(() =>\n zodSchema(z.union([z.literal('api-key'), z.literal('oidc')])),\n);\n","import {\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n getFromApi,\n lazySchema,\n resolve,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport type { GatewayConfig } from './gateway-config';\nimport {\n KNOWN_MODEL_TYPES,\n type GatewayLanguageModelEntry,\n type KnownModelType,\n} from './gateway-model-entry';\ntype GatewayFetchMetadataConfig = GatewayConfig;\n\nexport interface GatewayFetchMetadataResponse {\n models: GatewayLanguageModelEntry[];\n}\n\nexport interface GatewayCreditsResponse {\n /** The remaining gateway credit balance available for API usage */\n balance: string;\n /** The total amount of gateway credits that have been consumed */\n totalUsed: string;\n}\n\nexport class GatewayFetchMetadata {\n constructor(private readonly config: GatewayFetchMetadataConfig) {}\n\n async getAvailableModels(): Promise<GatewayFetchMetadataResponse> {\n try {\n const { value } = await getFromApi({\n url: `${this.config.baseURL}/config`,\n headers: this.config.headers\n ? await resolve(this.config.headers)\n : undefined,\n successfulResponseHandler: createJsonResponseHandler(\n gatewayAvailableModelsResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n fetch: this.config.fetch,\n });\n\n return value;\n } catch (error) {\n throw await asGatewayError(error);\n }\n }\n\n async getCredits(): Promise<GatewayCreditsResponse> {\n try {\n const baseUrl = new URL(this.config.baseURL);\n\n const { value } = await getFromApi({\n url: `${baseUrl.origin}/v1/credits`,\n headers: this.config.headers\n ? await resolve(this.config.headers)\n : undefined,\n successfulResponseHandler: createJsonResponseHandler(\n gatewayCreditsResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n fetch: this.config.fetch,\n });\n\n return value;\n } catch (error) {\n throw await asGatewayError(error);\n }\n }\n}\n\nconst gatewayAvailableModelsResponseSchema = lazySchema(() =>\n zodSchema(\n z.object({\n models: z\n .array(\n z.object({\n id: z.string(),\n name: z.string(),\n description: z.string().nullish(),\n pricing: z\n .object({\n input: z.string(),\n output: z.string(),\n input_cache_read: z.string().nullish(),\n input_cache_write: z.string().nullish(),\n })\n .transform(\n ({ input, output, input_cache_read, input_cache_write }) => ({\n input,\n output,\n ...(input_cache_read\n ? { cachedInputTokens: input_cache_read }\n : {}),\n ...(input_cache_write\n ? { cacheCreationInputTokens: input_cache_write }\n : {}),\n }),\n )\n .nullish(),\n specification: z.object({\n specificationVersion: z.literal('v4'),\n provider: z.string(),\n modelId: z.string(),\n }),\n modelType: z.string().nullish(),\n }),\n )\n .transform(models =>\n models.filter(\n (m): m is typeof m & { modelType?: KnownModelType | null } =>\n m.modelType == null ||\n KNOWN_MODEL_TYPES.includes(m.modelType as KnownModelType),\n ),\n ),\n }),\n ),\n);\n\nconst gatewayCreditsResponseSchema = lazySchema(() =>\n zodSchema(\n z\n .object({\n balance: z.string(),\n total_used: z.string(),\n })\n .transform(({ balance, total_used }) => ({\n balance,\n totalUsed: total_used,\n })),\n ),\n);\n","import type { LanguageModelV4 } from '@ai-sdk/provider';\n\nexport const KNOWN_MODEL_TYPES = [\n 'embedding',\n 'image',\n 'language',\n 'reranking',\n 'speech',\n 'transcription',\n 'video',\n] as const;\n\nexport type KnownModelType = (typeof KNOWN_MODEL_TYPES)[number];\n\nexport interface GatewayLanguageModelEntry {\n /**\n * The model id used by the remote provider in model settings and for specifying the\n * intended model for text generation.\n */\n id: string;\n\n /**\n * The display name of the model for presentation in user-facing contexts.\n */\n name: string;\n\n /**\n * Optional description of the model.\n */\n description?: string | null;\n\n /**\n * Optional pricing information for the model.\n */\n pricing?: {\n /**\n * Cost per input token in USD.\n */\n input: string;\n /**\n * Cost per output token in USD.\n */\n output: string;\n /**\n * Cost per cached input token in USD.\n * Only present for providers/models that support prompt caching.\n */\n cachedInputTokens?: string;\n /**\n * Cost per input token to create/write cache entries in USD.\n * Only present for providers/models that support prompt caching.\n */\n cacheCreationInputTokens?: string;\n } | null;\n\n /**\n * Additional AI SDK language model specifications for the model.\n */\n specification: GatewayLanguageModelSpecification;\n\n /**\n * Optional field to differentiate between model types.\n */\n modelType?: KnownModelType | null;\n}\n\nexport type GatewayLanguageModelSpecification = Pick<\n LanguageModelV4,\n 'specificationVersion' | 'provider' | 'modelId'\n>;\n","import {\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n getFromApi,\n lazySchema,\n resolve,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport type { GatewayConfig } from './gateway-config';\n\nexport interface GatewaySpendReportParams {\n /** Start date in YYYY-MM-DD format (inclusive) */\n startDate: string;\n /** End date in YYYY-MM-DD format (inclusive) */\n endDate: string;\n /** Primary aggregation dimension. Defaults to 'day'. */\n groupBy?: 'day' | 'user' | 'model' | 'tag' | 'provider' | 'credential_type';\n /** Time granularity when groupBy is 'day'. */\n datePart?: 'day' | 'hour';\n /** Filter to a specific user's spend. */\n userId?: string;\n /** Filter to a specific model (e.g. 'anthropic/claude-sonnet-4.5'). */\n model?: string;\n /** Filter to a specific provider (e.g. 'anthropic'). */\n provider?: string;\n /** Filter to BYOK or system credentials. */\n credentialType?: 'byok' | 'system';\n /** Filter to requests with these tags. */\n tags?: string[];\n}\n\nexport interface GatewaySpendReportRow {\n /** Date string (present when groupBy is 'day') */\n day?: string;\n /** Hour timestamp (present when groupBy is 'day' and datePart is 'hour') */\n hour?: string;\n /** User identifier (present when groupBy is 'user') */\n user?: string;\n /** Model identifier (present when groupBy is 'model') */\n model?: string;\n /** Tag value (present when groupBy is 'tag') */\n tag?: string;\n /** Provider name (present when groupBy is 'provider') */\n provider?: string;\n /** Credential type (present when groupBy is 'credential_type') */\n credentialType?: 'byok' | 'system';\n\n /** Total cost in USD */\n totalCost: number;\n /** Market cost in USD */\n marketCost?: number;\n /** Number of input tokens */\n inputTokens?: number;\n /** Number of output tokens */\n outputTokens?: number;\n /** Number of cached input tokens */\n cachedInputTokens?: number;\n /** Number of cache creation input tokens */\n cacheCreationInputTokens?: number;\n /** Number of reasoning tokens */\n reasoningTokens?: number;\n /** Number of requests */\n requestCount?: number;\n}\n\nexport interface GatewaySpendReportResponse {\n results: GatewaySpendReportRow[];\n}\n\nexport class GatewaySpendReport {\n constructor(private readonly config: GatewayConfig) {}\n\n async getSpendReport(\n params: GatewaySpendReportParams,\n ): Promise<GatewaySpendReportResponse> {\n try {\n const baseUrl = new URL(this.config.baseURL);\n\n const searchParams = new URLSearchParams();\n searchParams.set('start_date', params.startDate);\n searchParams.set('end_date', params.endDate);\n\n if (params.groupBy) {\n searchParams.set('group_by', params.groupBy);\n }\n if (params.datePart) {\n searchParams.set('date_part', params.datePart);\n }\n if (params.userId) {\n searchParams.set('user_id', params.userId);\n }\n if (params.model) {\n searchParams.set('model', params.model);\n }\n if (params.provider) {\n searchParams.set('provider', params.provider);\n }\n if (params.credentialType) {\n searchParams.set('credential_type', params.credentialType);\n }\n if (params.tags && params.tags.length > 0) {\n searchParams.set('tags', params.tags.join(','));\n }\n\n const { value } = await getFromApi({\n url: `${baseUrl.origin}/v1/report?${searchParams.toString()}`,\n headers: this.config.headers\n ? await resolve(this.config.headers)\n : undefined,\n successfulResponseHandler: createJsonResponseHandler(\n gatewaySpendReportResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n fetch: this.config.fetch,\n });\n\n return value;\n } catch (error) {\n throw await asGatewayError(error);\n }\n }\n}\n\nconst gatewaySpendReportResponseSchema = lazySchema(() =>\n zodSchema(\n z.object({\n results: z.array(\n z\n .object({\n day: z.string().optional(),\n hour: z.string().optional(),\n user: z.string().optional(),\n model: z.string().optional(),\n tag: z.string().optional(),\n provider: z.string().optional(),\n credential_type: z.enum(['byok', 'system']).optional(),\n total_cost: z.number(),\n market_cost: z.number().optional(),\n input_tokens: z.number().optional(),\n output_tokens: z.number().optional(),\n cached_input_tokens: z.number().optional(),\n cache_creation_input_tokens: z.number().optional(),\n reasoning_tokens: z.number().optional(),\n request_count: z.number().optional(),\n })\n .transform(\n ({\n credential_type,\n total_cost,\n market_cost,\n input_tokens,\n output_tokens,\n cached_input_tokens,\n cache_creation_input_tokens,\n reasoning_tokens,\n request_count,\n ...rest\n }) => ({\n ...rest,\n ...(credential_type !== undefined\n ? { credentialType: credential_type }\n : {}),\n totalCost: total_cost,\n ...(market_cost !== undefined ? { marketCost: market_cost } : {}),\n ...(input_tokens !== undefined\n ? { inputTokens: input_tokens }\n : {}),\n ...(output_tokens !== undefined\n ? { outputTokens: output_tokens }\n : {}),\n ...(cached_input_tokens !== undefined\n ? { cachedInputTokens: cached_input_tokens }\n : {}),\n ...(cache_creation_input_tokens !== undefined\n ? { cacheCreationInputTokens: cache_creation_input_tokens }\n : {}),\n ...(reasoning_tokens !== undefined\n ? { reasoningTokens: reasoning_tokens }\n : {}),\n ...(request_count !== undefined\n ? { requestCount: request_count }\n : {}),\n }),\n ),\n ),\n }),\n ),\n);\n","import {\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n getFromApi,\n lazySchema,\n resolve,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport type { GatewayConfig } from './gateway-config';\n\nexport interface GatewayGenerationInfoParams {\n /** The generation ID to look up (format: gen_<ulid>) */\n id: string;\n}\n\nexport interface GatewayGenerationInfo {\n /** The generation ID */\n id: string;\n /** Total cost in USD */\n totalCost: number;\n /** Upstream inference cost in USD (BYOK only) */\n upstreamInferenceCost: number;\n /** Usage cost in USD (same as totalCost) */\n usage: number;\n /** ISO 8601 timestamp when the generation was created */\n createdAt: string;\n /** Model identifier */\n model: string;\n /** Whether BYOK credentials were used */\n isByok: boolean;\n /** Provider that served this generation */\n providerName: string;\n /** Whether streaming was used */\n streamed: boolean;\n /** Finish reason (e.g. 'stop') */\n finishReason: string;\n /** Time to first token in milliseconds */\n latency: number;\n /** Total generation time in milliseconds */\n generationTime: number;\n /** Number of prompt tokens */\n promptTokens: number;\n /** Number of completion tokens */\n completionTokens: number;\n /** Reasoning tokens used */\n reasoningTokens: number;\n /** Cached tokens used */\n cachedTokens: number;\n /** Cache creation input tokens */\n cacheCreationTokens: number;\n /** Billable web search calls */\n billableWebSearchCalls: number;\n}\n\nexport class GatewayGenerationInfoFetcher {\n constructor(private readonly config: GatewayConfig) {}\n\n async getGenerationInfo(\n params: GatewayGenerationInfoParams,\n ): Promise<GatewayGenerationInfo> {\n try {\n const baseUrl = new URL(this.config.baseURL);\n\n const { value } = await getFromApi({\n url: `${baseUrl.origin}/v1/generation?id=${encodeURIComponent(params.id)}`,\n headers: this.config.headers\n ? await resolve(this.config.headers)\n : undefined,\n successfulResponseHandler: createJsonResponseHandler(\n gatewayGenerationInfoResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n fetch: this.config.fetch,\n });\n\n return value;\n } catch (error) {\n throw await asGatewayError(error);\n }\n }\n}\n\nconst gatewayGenerationInfoResponseSchema = lazySchema(() =>\n zodSchema(\n z\n .object({\n data: z\n .object({\n id: z.string(),\n total_cost: z.number(),\n upstream_inference_cost: z.number(),\n usage: z.number(),\n created_at: z.string(),\n model: z.string(),\n is_byok: z.boolean(),\n provider_name: z.string(),\n streamed: z.boolean(),\n finish_reason: z.string(),\n latency: z.number(),\n generation_time: z.number(),\n native_tokens_prompt: z.number(),\n native_tokens_completion: z.number(),\n native_tokens_reasoning: z.number(),\n native_tokens_cached: z.number(),\n native_tokens_cache_creation: z.number(),\n billable_web_search_calls: z.number(),\n })\n .transform(\n ({\n total_cost,\n upstream_inference_cost,\n created_at,\n is_byok,\n provider_name,\n finish_reason,\n generation_time,\n native_tokens_prompt,\n native_tokens_completion,\n native_tokens_reasoning,\n native_tokens_cached,\n native_tokens_cache_creation,\n billable_web_search_calls,\n ...rest\n }) => ({\n ...rest,\n totalCost: total_cost,\n upstreamInferenceCost: upstream_inference_cost,\n createdAt: created_at,\n isByok: is_byok,\n providerName: provider_name,\n finishReason: finish_reason,\n generationTime: generation_time,\n promptTokens: native_tokens_prompt,\n completionTokens: native_tokens_completion,\n reasoningTokens: native_tokens_reasoning,\n cachedTokens: native_tokens_cached,\n cacheCreationTokens: native_tokens_cache_creation,\n billableWebSearchCalls: billable_web_search_calls,\n }),\n ),\n })\n .transform(({ data }) => data),\n ),\n);\n","import type {\n LanguageModelV4,\n LanguageModelV4CallOptions,\n LanguageModelV4FilePart,\n LanguageModelV4StreamPart,\n LanguageModelV4GenerateResult,\n LanguageModelV4StreamResult,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n createEventSourceResponseHandler,\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n postJsonToApi,\n resolve,\n serializeModelOptions,\n WORKFLOW_SERIALIZE,\n WORKFLOW_DESERIALIZE,\n type ParseResult,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport type { GatewayConfig } from './gateway-config';\nimport type { GatewayModelId } from './gateway-language-model-settings';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\n\ntype GatewayChatConfig = GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n};\n\nexport class GatewayLanguageModel implements LanguageModelV4 {\n readonly specificationVersion = 'v4';\n readonly supportedUrls = { '*/*': [/.*/] };\n\n static [WORKFLOW_SERIALIZE](model: GatewayLanguageModel) {\n return serializeModelOptions({\n modelId: model.modelId,\n config: model.config,\n });\n }\n\n static [WORKFLOW_DESERIALIZE](options: {\n modelId: GatewayModelId;\n config: GatewayChatConfig;\n }) {\n return new GatewayLanguageModel(options.modelId, options.config);\n }\n\n constructor(\n readonly modelId: GatewayModelId,\n private readonly config: GatewayChatConfig,\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n private async getArgs(options: LanguageModelV4CallOptions) {\n const { abortSignal: _abortSignal, ...optionsWithoutSignal } = options;\n\n return {\n args: this.maybeEncodeFileParts(optionsWithoutSignal),\n warnings: [],\n };\n }\n\n async doGenerate(\n options: LanguageModelV4CallOptions,\n ): Promise<LanguageModelV4GenerateResult> {\n const { args, warnings } = await this.getArgs(options);\n const { abortSignal } = options;\n\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n\n try {\n const {\n responseHeaders,\n value: responseBody,\n rawValue: rawResponse,\n } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n options.headers,\n this.getModelConfigHeaders(this.modelId, false),\n await resolve(this.config.o11yHeaders),\n ),\n body: args,\n successfulResponseHandler: createJsonResponseHandler(z.any()),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n ...responseBody,\n request: { body: args },\n response: { headers: responseHeaders, body: rawResponse },\n warnings,\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n async doStream(\n options: LanguageModelV4CallOptions,\n ): Promise<LanguageModelV4StreamResult> {\n const { args, warnings } = await this.getArgs(options);\n const { abortSignal } = options;\n\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n\n try {\n const { value: response, responseHeaders } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n options.headers,\n this.getModelConfigHeaders(this.modelId, true),\n await resolve(this.config.o11yHeaders),\n ),\n body: args,\n successfulResponseHandler: createEventSourceResponseHandler(z.any()),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n stream: response.pipeThrough(\n new TransformStream<\n ParseResult<LanguageModelV4StreamPart>,\n LanguageModelV4StreamPart\n >({\n start(controller) {\n if (warnings.length > 0) {\n controller.enqueue({ type: 'stream-start', warnings });\n }\n },\n transform(chunk, controller) {\n if (chunk.success) {\n const streamPart = chunk.value;\n\n // Handle raw chunks: if this is a raw chunk from the gateway API,\n // only emit it if includeRawChunks is true\n if (streamPart.type === 'raw' && !options.includeRawChunks) {\n return; // Skip raw chunks if not requested\n }\n\n if (\n streamPart.type === 'response-metadata' &&\n streamPart.timestamp &&\n typeof streamPart.timestamp === 'string'\n ) {\n streamPart.timestamp = new Date(streamPart.timestamp);\n }\n\n controller.enqueue(streamPart);\n } else {\n controller.error(\n (chunk as { success: false; error: unknown }).error,\n );\n }\n },\n }),\n ),\n request: { body: args },\n response: { headers: responseHeaders },\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private isFilePart(part: unknown) {\n return (\n part && typeof part === 'object' && 'type' in part && part.type === 'file'\n );\n }\n\n /**\n * Encodes inline `Uint8Array` file part data to a base64 string in place.\n * @param options - The options to encode.\n * @returns The options with the file parts encoded.\n */\n private maybeEncodeFileParts(options: LanguageModelV4CallOptions) {\n for (const message of options.prompt) {\n for (const part of message.content) {\n if (this.isFilePart(part)) {\n const filePart = part as LanguageModelV4FilePart;\n if (\n filePart.data.type === 'data' &&\n filePart.data.data instanceof Uint8Array\n ) {\n filePart.data = {\n type: 'data',\n data: Buffer.from(filePart.data.data).toString('base64'),\n };\n }\n }\n }\n }\n return options;\n }\n\n private getUrl() {\n return `${this.config.baseURL}/language-model`;\n }\n\n private getModelConfigHeaders(modelId: string, streaming: boolean) {\n return {\n 'ai-language-model-specification-version': '4',\n 'ai-language-model-id': modelId,\n 'ai-language-model-streaming': String(streaming),\n };\n }\n}\n","import type {\n EmbeddingModelV4,\n SharedV4ProviderMetadata,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n lazySchema,\n postJsonToApi,\n resolve,\n serializeModelOptions,\n WORKFLOW_SERIALIZE,\n WORKFLOW_DESERIALIZE,\n zodSchema,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\nimport type { GatewayConfig } from './gateway-config';\n\ntype GatewayEmbeddingConfig = GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n};\n\nexport class GatewayEmbeddingModel implements EmbeddingModelV4 {\n readonly specificationVersion = 'v4';\n readonly maxEmbeddingsPerCall = 2048;\n readonly supportsParallelCalls = true;\n\n static [WORKFLOW_SERIALIZE](model: GatewayEmbeddingModel) {\n return serializeModelOptions({\n modelId: model.modelId,\n config: model.config,\n });\n }\n\n static [WORKFLOW_DESERIALIZE](options: {\n modelId: string;\n config: GatewayEmbeddingConfig;\n }) {\n return new GatewayEmbeddingModel(options.modelId, options.config);\n }\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayEmbeddingConfig,\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doEmbed({\n values,\n headers,\n abortSignal,\n providerOptions,\n }: Parameters<EmbeddingModelV4['doEmbed']>[0]): Promise<\n Awaited<ReturnType<EmbeddingModelV4['doEmbed']>>\n > {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const {\n responseHeaders,\n value: responseBody,\n rawValue,\n } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n ),\n body: {\n values,\n ...(providerOptions ? { providerOptions } : {}),\n },\n successfulResponseHandler: createJsonResponseHandler(\n gatewayEmbeddingResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n embeddings: responseBody.embeddings,\n usage: responseBody.usage ?? undefined,\n providerMetadata:\n responseBody.providerMetadata as unknown as SharedV4ProviderMetadata,\n response: { headers: responseHeaders, body: rawValue },\n warnings: [],\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/embedding-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-embedding-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nconst gatewayEmbeddingResponseSchema = lazySchema(() =>\n zodSchema(\n z.object({\n embeddings: z.array(z.array(z.number())),\n usage: z.object({ tokens: z.number() }).nullish(),\n providerMetadata: z\n .record(z.string(), z.record(z.string(), z.unknown()))\n .optional(),\n }),\n ),\n);\n","import type {\n ImageModelV4,\n ImageModelV4File,\n ImageModelV4ProviderMetadata,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n convertUint8ArrayToBase64,\n createJsonResponseHandler,\n createJsonErrorResponseHandler,\n postJsonToApi,\n resolve,\n serializeModelOptions,\n WORKFLOW_SERIALIZE,\n WORKFLOW_DESERIALIZE,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport type { GatewayConfig } from './gateway-config';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\n\ntype GatewayImageConfig = GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n};\n\nexport class GatewayImageModel implements ImageModelV4 {\n readonly specificationVersion = 'v4' as const;\n // Set a very large number to prevent client-side splitting of requests\n readonly maxImagesPerCall = Number.MAX_SAFE_INTEGER;\n\n static [WORKFLOW_SERIALIZE](model: GatewayImageModel) {\n return serializeModelOptions({\n modelId: model.modelId,\n config: model.config,\n });\n }\n\n static [WORKFLOW_DESERIALIZE](options: {\n modelId: string;\n config: GatewayImageConfig;\n }) {\n return new GatewayImageModel(options.modelId, options.config);\n }\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayImageConfig,\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doGenerate({\n prompt,\n n,\n size,\n aspectRatio,\n seed,\n files,\n mask,\n providerOptions,\n headers,\n abortSignal,\n }: Parameters<ImageModelV4['doGenerate']>[0]): Promise<\n Awaited<ReturnType<ImageModelV4['doGenerate']>>\n > {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const { responseHeaders, value: responseBody } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n ),\n body: {\n prompt,\n n,\n ...(size && { size }),\n ...(aspectRatio && { aspectRatio }),\n ...(seed && { seed }),\n ...(providerOptions && { providerOptions }),\n ...(files && {\n files: files.map(file => maybeEncodeImageFile(file)),\n }),\n ...(mask && { mask: maybeEncodeImageFile(mask) }),\n },\n successfulResponseHandler: createJsonResponseHandler(\n gatewayImageResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n images: responseBody.images, // Always base64 strings from server\n warnings: responseBody.warnings ?? [],\n providerMetadata:\n responseBody.providerMetadata as ImageModelV4ProviderMetadata,\n response: {\n timestamp: new Date(),\n modelId: this.modelId,\n headers: responseHeaders,\n },\n ...(responseBody.usage != null && {\n usage: {\n inputTokens: responseBody.usage.inputTokens ?? undefined,\n outputTokens: responseBody.usage.outputTokens ?? undefined,\n totalTokens: responseBody.usage.totalTokens ?? undefined,\n },\n }),\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/image-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-image-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nfunction maybeEncodeImageFile(file: ImageModelV4File) {\n if (file.type === 'file' && file.data instanceof Uint8Array) {\n return {\n ...file,\n data: convertUint8ArrayToBase64(file.data),\n };\n }\n return file;\n}\n\nconst providerMetadataEntrySchema = z\n .object({\n images: z.array(z.unknown()).optional(),\n })\n .catchall(z.unknown());\n\nconst gatewayImageWarningSchema = z.discriminatedUnion('type', [\n z.object({\n type: z.literal('unsupported'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('compatibility'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('other'),\n message: z.string(),\n }),\n]);\n\nconst gatewayImageUsageSchema = z.object({\n inputTokens: z.number().nullish(),\n outputTokens: z.number().nullish(),\n totalTokens: z.number().nullish(),\n});\n\nconst gatewayImageResponseSchema = z.object({\n images: z.array(z.string()), // Always base64 strings over the wire\n warnings: z.array(gatewayImageWarningSchema).optional(),\n providerMetadata: z\n .record(z.string(), providerMetadataEntrySchema)\n .optional(),\n usage: gatewayImageUsageSchema.optional(),\n});\n","import {\n APICallError,\n type Experimental_VideoModelV4,\n type Experimental_VideoModelV4CallOptions,\n type Experimental_VideoModelV4File,\n type Experimental_VideoModelV4VideoData,\n type SharedV4ProviderMetadata,\n type SharedV4Warning,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n convertUint8ArrayToBase64,\n createJsonErrorResponseHandler,\n parseJsonEventStream,\n postJsonToApi,\n resolve,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport type { GatewayConfig } from './gateway-config';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\n\nexport class GatewayVideoModel implements Experimental_VideoModelV4 {\n readonly specificationVersion = 'v4' as const;\n // Set a very large number to prevent client-side splitting of requests\n readonly maxVideosPerCall = Number.MAX_SAFE_INTEGER;\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n },\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doGenerate({\n prompt,\n n,\n aspectRatio,\n resolution,\n duration,\n fps,\n seed,\n image,\n providerOptions,\n headers,\n abortSignal,\n }: Experimental_VideoModelV4CallOptions): Promise<{\n videos: Array<Experimental_VideoModelV4VideoData>;\n warnings: Array<SharedV4Warning>;\n providerMetadata?: SharedV4ProviderMetadata;\n response: {\n timestamp: Date;\n modelId: string;\n headers: Record<string, string> | undefined;\n };\n }> {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const { responseHeaders, value: responseBody } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n { accept: 'text/event-stream' },\n ),\n body: {\n prompt,\n n,\n ...(aspectRatio && { aspectRatio }),\n ...(resolution && { resolution }),\n ...(duration && { duration }),\n ...(fps && { fps }),\n ...(seed && { seed }),\n ...(providerOptions && { providerOptions }),\n ...(image && { image: maybeEncodeVideoFile(image) }),\n },\n successfulResponseHandler: async ({\n response,\n url,\n requestBodyValues,\n }: {\n url: string;\n requestBodyValues: unknown;\n response: Response;\n }) => {\n if (response.body == null) {\n throw new APICallError({\n message: 'SSE response body is empty',\n url,\n requestBodyValues,\n statusCode: response.status,\n });\n }\n\n const eventStream = parseJsonEventStream({\n stream: response.body,\n schema: gatewayVideoEventSchema,\n });\n\n const reader = eventStream.getReader();\n const { done, value: parseResult } = await reader.read();\n reader.releaseLock();\n\n if (done || !parseResult) {\n throw new APICallError({\n message: 'SSE stream ended without a data event',\n url,\n requestBodyValues,\n statusCode: response.status,\n });\n }\n\n if (!parseResult.success) {\n throw new APICallError({\n message: 'Failed to parse video SSE event',\n cause: parseResult.error,\n url,\n requestBodyValues,\n statusCode: response.status,\n });\n }\n\n const event = parseResult.value;\n\n if (event.type === 'error') {\n throw new APICallError({\n message: event.message,\n statusCode: event.statusCode,\n url,\n requestBodyValues,\n responseHeaders: Object.fromEntries([...response.headers]),\n responseBody: JSON.stringify(event),\n data: {\n error: {\n message: event.message,\n type: event.errorType,\n param: event.param,\n },\n },\n });\n }\n\n // event.type === 'result'\n return {\n value: {\n videos: event.videos,\n warnings: event.warnings,\n providerMetadata: event.providerMetadata,\n },\n responseHeaders: Object.fromEntries([...response.headers]),\n };\n },\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n videos: responseBody.videos,\n warnings: responseBody.warnings ?? [],\n providerMetadata:\n responseBody.providerMetadata as SharedV4ProviderMetadata,\n response: {\n timestamp: new Date(),\n modelId: this.modelId,\n headers: responseHeaders,\n },\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/video-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-video-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nfunction maybeEncodeVideoFile(file: Experimental_VideoModelV4File) {\n if (file.type === 'file' && file.data instanceof Uint8Array) {\n return {\n ...file,\n data: convertUint8ArrayToBase64(file.data),\n };\n }\n return file;\n}\n\nconst providerMetadataEntrySchema = z\n .object({\n videos: z.array(z.unknown()).optional(),\n })\n .catchall(z.unknown());\n\nconst gatewayVideoDataSchema = z.union([\n z.object({\n type: z.literal('url'),\n url: z.string(),\n mediaType: z.string(),\n }),\n z.object({\n type: z.literal('base64'),\n data: z.string(),\n mediaType: z.string(),\n }),\n]);\n\nconst gatewayVideoWarningSchema = z.discriminatedUnion('type', [\n z.object({\n type: z.literal('unsupported'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('compatibility'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('other'),\n message: z.string(),\n }),\n]);\n\nconst gatewayVideoEventSchema = z.discriminatedUnion('type', [\n z.object({\n type: z.literal('result'),\n videos: z.array(gatewayVideoDataSchema),\n warnings: z.array(gatewayVideoWarningSchema).optional(),\n providerMetadata: z\n .record(z.string(), providerMetadataEntrySchema)\n .optional(),\n }),\n z.object({\n type: z.literal('error'),\n message: z.string(),\n errorType: z.string(),\n statusCode: z.number(),\n param: z.unknown().nullable(),\n }),\n]);\n","import type {\n RerankingModelV4,\n SharedV4ProviderMetadata,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n lazySchema,\n postJsonToApi,\n resolve,\n zodSchema,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\nimport type { GatewayConfig } from './gateway-config';\n\nexport class GatewayRerankingModel implements RerankingModelV4 {\n readonly specificationVersion = 'v4';\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n },\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doRerank({\n documents,\n query,\n topN,\n headers,\n abortSignal,\n providerOptions,\n }: Parameters<RerankingModelV4['doRerank']>[0]): Promise<\n Awaited<ReturnType<RerankingModelV4['doRerank']>>\n > {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const {\n responseHeaders,\n value: responseBody,\n rawValue,\n } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n ),\n body: {\n documents,\n query,\n ...(topN != null ? { topN } : {}),\n ...(providerOptions ? { providerOptions } : {}),\n },\n successfulResponseHandler: createJsonResponseHandler(\n gatewayRerankingResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n ranking: responseBody.ranking,\n providerMetadata:\n responseBody.providerMetadata as unknown as SharedV4ProviderMetadata,\n response: { headers: responseHeaders, body: rawValue },\n warnings: [],\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/reranking-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-reranking-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nconst gatewayRerankingResponseSchema = lazySchema(() =>\n zodSchema(\n z.object({\n ranking: z.array(\n z.object({\n index: z.number(),\n relevanceScore: z.number(),\n }),\n ),\n providerMetadata: z\n .record(z.string(), z.record(z.string(), z.unknown()))\n .optional(),\n }),\n ),\n);\n","import type {\n SharedV4ProviderMetadata,\n SharedV4Warning,\n SpeechModelV4,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n postJsonToApi,\n resolve,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\nimport type { GatewayConfig } from './gateway-config';\n\nexport class GatewaySpeechModel implements SpeechModelV4 {\n readonly specificationVersion = 'v4' as const;\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n },\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doGenerate({\n text,\n voice,\n outputFormat,\n instructions,\n speed,\n language,\n providerOptions,\n headers,\n abortSignal,\n }: Parameters<SpeechModelV4['doGenerate']>[0]): Promise<\n Awaited<ReturnType<SpeechModelV4['doGenerate']>>\n > {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const {\n responseHeaders,\n value: responseBody,\n rawValue,\n } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n ),\n body: {\n text,\n ...(voice && { voice }),\n ...(outputFormat && { outputFormat }),\n ...(instructions && { instructions }),\n ...(speed != null && { speed }),\n ...(language && { language }),\n ...(providerOptions && { providerOptions }),\n },\n successfulResponseHandler: createJsonResponseHandler(\n gatewaySpeechResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n audio: responseBody.audio,\n warnings: (responseBody.warnings ?? []) as Array<SharedV4Warning>,\n providerMetadata:\n responseBody.providerMetadata as SharedV4ProviderMetadata,\n response: {\n timestamp: new Date(),\n modelId: this.modelId,\n headers: responseHeaders,\n body: rawValue,\n },\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/speech-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-speech-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nconst providerMetadataEntrySchema = z.object({}).catchall(z.unknown());\n\nconst gatewaySpeechWarningSchema = z.discriminatedUnion('type', [\n z.object({\n type: z.literal('unsupported'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('compatibility'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('other'),\n message: z.string(),\n }),\n]);\n\nconst gatewaySpeechResponseSchema = z.object({\n audio: z.string(),\n warnings: z.array(gatewaySpeechWarningSchema).optional(),\n providerMetadata: z\n .record(z.string(), providerMetadataEntrySchema)\n .optional(),\n});\n","import type {\n SharedV4ProviderMetadata,\n SharedV4Warning,\n TranscriptionModelV4,\n} from '@ai-sdk/provider';\nimport {\n combineHeaders,\n convertUint8ArrayToBase64,\n createJsonErrorResponseHandler,\n createJsonResponseHandler,\n postJsonToApi,\n resolve,\n type Resolvable,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { asGatewayError } from './errors';\nimport { parseAuthMethod } from './errors/parse-auth-method';\nimport type { GatewayConfig } from './gateway-config';\n\nexport class GatewayTranscriptionModel implements TranscriptionModelV4 {\n readonly specificationVersion = 'v4' as const;\n\n constructor(\n readonly modelId: string,\n private readonly config: GatewayConfig & {\n provider: string;\n o11yHeaders: Resolvable<Record<string, string>>;\n },\n ) {}\n\n get provider(): string {\n return this.config.provider;\n }\n\n async doGenerate({\n audio,\n mediaType,\n providerOptions,\n headers,\n abortSignal,\n }: Parameters<TranscriptionModelV4['doGenerate']>[0]): Promise<\n Awaited<ReturnType<TranscriptionModelV4['doGenerate']>>\n > {\n const resolvedHeaders = this.config.headers\n ? await resolve(this.config.headers)\n : undefined;\n try {\n const {\n responseHeaders,\n value: responseBody,\n rawValue,\n } = await postJsonToApi({\n url: this.getUrl(),\n headers: combineHeaders(\n resolvedHeaders,\n headers ?? {},\n this.getModelConfigHeaders(),\n await resolve(this.config.o11yHeaders),\n ),\n body: {\n audio:\n audio instanceof Uint8Array\n ? convertUint8ArrayToBase64(audio)\n : audio,\n mediaType,\n ...(providerOptions && { providerOptions }),\n },\n successfulResponseHandler: createJsonResponseHandler(\n gatewayTranscriptionResponseSchema,\n ),\n failedResponseHandler: createJsonErrorResponseHandler({\n errorSchema: z.any(),\n errorToMessage: data => data,\n }),\n ...(abortSignal && { abortSignal }),\n fetch: this.config.fetch,\n });\n\n return {\n text: responseBody.text,\n segments: responseBody.segments ?? [],\n language: responseBody.language ?? undefined,\n durationInSeconds: responseBody.durationInSeconds ?? undefined,\n warnings: (responseBody.warnings ?? []) as Array<SharedV4Warning>,\n providerMetadata:\n responseBody.providerMetadata as SharedV4ProviderMetadata,\n response: {\n timestamp: new Date(),\n modelId: this.modelId,\n headers: responseHeaders,\n body: rawValue,\n },\n };\n } catch (error) {\n throw await asGatewayError(\n error,\n await parseAuthMethod(resolvedHeaders ?? {}),\n );\n }\n }\n\n private getUrl() {\n return `${this.config.baseURL}/transcription-model`;\n }\n\n private getModelConfigHeaders() {\n return {\n 'ai-transcription-model-specification-version': '4',\n 'ai-model-id': this.modelId,\n };\n }\n}\n\nconst providerMetadataEntrySchema = z.object({}).catchall(z.unknown());\n\nconst gatewayTranscriptionWarningSchema = z.discriminatedUnion('type', [\n z.object({\n type: z.literal('unsupported'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('compatibility'),\n feature: z.string(),\n details: z.string().optional(),\n }),\n z.object({\n type: z.literal('other'),\n message: z.string(),\n }),\n]);\n\nconst gatewayTranscriptionResponseSchema = z.object({\n text: z.string(),\n segments: z\n .array(\n z.object({\n text: z.string(),\n startSecond: z.number(),\n endSecond: z.number(),\n }),\n )\n .optional(),\n language: z.string().nullish(),\n durationInSeconds: z.number().nullish(),\n warnings: z.array(gatewayTranscriptionWarningSchema).optional(),\n providerMetadata: z\n .record(z.string(), providerMetadataEntrySchema)\n .optional(),\n});\n","import {\n createProviderExecutedToolFactory,\n lazySchema,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod';\n\nexport interface ParallelSearchSourcePolicy {\n /**\n * List of domains to include in search results.\n * Example: ['wikipedia.org', 'nature.com']\n */\n includeDomains?: string[];\n\n /**\n * List of domains to exclude from search results.\n * Example: ['reddit.com', 'twitter.com']\n */\n excludeDomains?: string[];\n\n /**\n * Only include results published after this date (ISO 8601 format).\n * Example: '2024-01-01'\n */\n afterDate?: string;\n}\n\nexport interface ParallelSearchExcerpts {\n /**\n * Maximum characters per result.\n */\n maxCharsPerResult?: number;\n\n /**\n * Maximum total characters across all results.\n */\n maxCharsTotal?: number;\n}\n\nexport interface ParallelSearchFetchPolicy {\n /**\n * Maximum age in seconds for cached content.\n * Set to 0 to always fetch fresh content.\n */\n maxAgeSeconds?: number;\n}\n\nexport interface ParallelSearchConfig {\n /**\n * Mode preset for different use cases:\n * - \"one-shot\": Comprehensive results with longer excerpts for single-response answers (default)\n * - \"agentic\": Concise, token-efficient results for multi-step agentic workflows\n */\n mode?: 'one-shot' | 'agentic';\n\n /**\n * Default maximum number of results to return (1-20).\n * Defaults to 10 if not specified.\n */\n maxResults?: number;\n\n /**\n * Default source policy for controlling which domains to include/exclude.\n */\n sourcePolicy?: ParallelSearchSourcePolicy;\n\n /**\n * Default excerpt configuration for controlling result length.\n */\n excerpts?: ParallelSearchExcerpts;\n\n /**\n * Default fetch policy for controlling content freshness.\n */\n fetchPolicy?: ParallelSearchFetchPolicy;\n}\n\nexport interface ParallelSearchResult {\n /** URL of the search result */\n url: string;\n /** Title of the search result */\n title: string;\n /** Extracted text excerpt/content from the page */\n excerpt: string;\n /** Publication date of the content (may be null) */\n publishDate?: string | null;\n /** Relevance score for the result */\n relevanceScore?: number;\n}\n\nexport interface ParallelSearchResponse {\n /** Unique identifier for this search request */\n searchId: string;\n /** Array of search results */\n results: ParallelSearchResult[];\n}\n\nexport interface ParallelSearchError {\n /** Error type */\n error:\n | 'api_error'\n | 'rate_limit'\n | 'timeout'\n | 'invalid_input'\n | 'configuration_error'\n | 'unknown';\n /** HTTP status code if applicable */\n statusCode?: number;\n /** Human-readable error message */\n message: string;\n}\n\nexport interface ParallelSearchInput {\n /**\n * Natural-language description of the web research goal.\n * Include source or freshness guidance and broader context from the task.\n * Maximum 5000 characters.\n */\n objective: string;\n\n /**\n * Optional search queries to supplement the objective.\n * Maximum 200 characters per query.\n */\n search_queries?: string[];\n\n /**\n * Mode preset for different use cases:\n * - \"one-shot\": Comprehensive results with longer excerpts\n * - \"agentic\": Concise, token-efficient results for multi-step workflows\n */\n mode?: 'one-shot' | 'agentic';\n\n /**\n * Maximum number of results to return (1-20).\n * Defaults to 10 if not specified.\n */\n max_results?: number;\n\n /**\n * Source policy for controlling which domains to include/exclude.\n */\n source_policy?: {\n include_domains?: string[];\n exclude_domains?: string[];\n after_date?: string;\n };\n\n /**\n * Excerpt configuration for controlling result length.\n */\n excerpts?: {\n max_chars_per_result?: number;\n max_chars_total?: number;\n };\n\n /**\n * Fetch policy for controlling content freshness.\n */\n fetch_policy?: {\n max_age_seconds?: number;\n };\n}\n\nexport type ParallelSearchOutput = ParallelSearchResponse | ParallelSearchError;\n\nconst parallelSearchInputSchema = lazySchema(() =>\n zodSchema(\n z.object({\n objective: z\n .string()\n .describe(\n 'Natural-language description of the web research goal, including source or freshness guidance and broader context from the task. Maximum 5000 characters.',\n ),\n\n search_queries: z\n .array(z.string())\n .optional()\n .describe(\n 'Optional search queries to supplement the objective. Maximum 200 characters per query.',\n ),\n\n mode: z\n .enum(['one-shot', 'agentic'])\n .optional()\n .describe(\n 'Mode preset: \"one-shot\" for comprehensive results with longer excerpts (default), \"agentic\" for concise, token-efficient results for multi-step workflows.',\n ),\n\n max_results: z\n .number()\n .optional()\n .describe(\n 'Maximum number of results to return (1-20). Defaults to 10 if not specified.',\n ),\n\n source_policy: z\n .object({\n include_domains: z\n .array(z.string())\n .optional()\n .describe('List of domains to include in search results.'),\n exclude_domains: z\n .array(z.string())\n .optional()\n .describe('List of domains to exclude from search results.'),\n after_date: z\n .string()\n .optional()\n .describe(\n 'Only include results published after this date (ISO 8601 format).',\n ),\n })\n .optional()\n .describe(\n 'Source policy for controlling which domains to include/exclude and freshness.',\n ),\n\n excerpts: z\n .object({\n max_chars_per_result: z\n .number()\n .optional()\n .describe('Maximum characters per result.'),\n max_chars_total: z\n .number()\n .optional()\n .describe('Maximum total characters across all results.'),\n })\n .optional()\n .describe('Excerpt configuration for controlling result length.'),\n\n fetch_policy: z\n .object({\n max_age_seconds: z\n .number()\n .optional()\n .describe(\n 'Maximum age in seconds for cached content. Set to 0 to always fetch fresh content.',\n ),\n })\n .optional()\n .describe('Fetch policy for controlling content freshness.'),\n }),\n ),\n);\n\nconst parallelSearchOutputSchema = lazySchema(() =>\n zodSchema(\n z.union([\n // Success response\n z.object({\n searchId: z.string(),\n results: z.array(\n z.object({\n url: z.string(),\n title: z.string(),\n excerpt: z.string(),\n publishDate: z.string().nullable().optional(),\n relevanceScore: z.number().optional(),\n }),\n ),\n }),\n // Error response\n z.object({\n error: z.enum([\n 'api_error',\n 'rate_limit',\n 'timeout',\n 'invalid_input',\n 'configuration_error',\n 'unknown',\n ]),\n statusCode: z.number().optional(),\n message: z.string(),\n }),\n ]),\n ),\n);\n\nexport const parallelSearchToolFactory = createProviderExecutedToolFactory<\n ParallelSearchInput,\n ParallelSearchOutput,\n ParallelSearchConfig\n>({\n id: 'gateway.parallel_search',\n inputSchema: parallelSearchInputSchema,\n outputSchema: parallelSearchOutputSchema,\n});\n\nexport const parallelSearch = (\n config: ParallelSearchConfig = {},\n): ReturnType<typeof parallelSearchToolFactory> =>\n parallelSearchToolFactory(config);\n","import {\n createProviderExecutedToolFactory,\n lazySchema,\n zodSchema,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod';\n\nexport interface PerplexitySearchConfig {\n /**\n * Default maximum number of search results to return (1-20, default: 10).\n */\n maxResults?: number;\n\n /**\n * Default maximum tokens to extract per search result page (256-2048, default: 2048).\n */\n maxTokensPerPage?: number;\n\n /**\n * Default maximum total tokens across all search results (default: 25000, max: 1000000).\n */\n maxTokens?: number;\n\n /**\n * Default two-letter ISO 3166-1 alpha-2 country code for regional search results.\n * Examples: 'US', 'GB', 'FR'\n */\n country?: string;\n\n /**\n * Default list of domains to include or exclude from search results (max 20).\n * To include: ['nature.com', 'science.org']\n * To exclude: ['-example.com', '-spam.net']\n */\n searchDomainFilter?: string[];\n\n /**\n * Default list of ISO 639-1 language codes to filter results (max 10, lowercase).\n * Examples: ['en', 'fr', 'de']\n */\n searchLanguageFilter?: string[];\n\n /**\n * Default recency filter for results.\n * Cannot be combined with searchAfterDate/searchBeforeDate at runtime.\n */\n searchRecencyFilter?: 'day' | 'week' | 'month' | 'year';\n}\n\nexport interface PerplexitySearchResult {\n /** Title of the search result */\n title: string;\n /** URL of the search result */\n url: string;\n /** Text snippet/preview of the content */\n snippet: string;\n /** Publication date of the content */\n date?: string;\n /** Last updated date of the content */\n lastUpdated?: string;\n}\n\nexport interface PerplexitySearchResponse {\n /** Array of search results */\n results: PerplexitySearchResult[];\n /** Unique identifier for this search request */\n id: string;\n}\n\nexport interface PerplexitySearchError {\n /** Error type */\n error: 'api_error' | 'rate_limit' | 'timeout' | 'invalid_input' | 'unknown';\n /** HTTP status code if applicable */\n statusCode?: number;\n /** Human-readable error message */\n message: string;\n}\n\nexport interface PerplexitySearchInput {\n /**\n * Search query (string) or multiple queries (array of up to 5 strings).\n * Multi-query searches return combined results from all queries.\n */\n query: string | string[];\n\n /**\n * Maximum number of search results to return (1-20, default: 10).\n */\n max_results?: number;\n\n /**\n * Maximum number of tokens to extract per search result page (256-2048, default: 2048).\n */\n max_tokens_per_page?: number;\n\n /**\n * Maximum total tokens across all search results (default: 25000, max: 1000000).\n */\n max_tokens?: number;\n\n /**\n * Two-letter ISO 3166-1 alpha-2 country code for regional search results.\n * Examples: 'US', 'GB', 'FR'\n */\n country?: string;\n\n /**\n * List of domains to include or exclude from search results (max 20).\n * To include: ['nature.com', 'science.org']\n * To exclude: ['-example.com', '-spam.net']\n */\n search_domain_filter?: string[];\n\n /**\n * List of ISO 639-1 language codes to filter results (max 10, lowercase).\n * Examples: ['en', 'fr', 'de']\n */\n search_language_filter?: string[];\n\n /**\n * Include only results published after this date.\n * Format: 'MM/DD/YYYY' (e.g., '3/1/2025')\n * Cannot be used with search_recency_filter.\n */\n search_after_date?: string;\n\n /**\n * Include only results published before this date.\n * Format: 'MM/DD/YYYY' (e.g., '3/15/2025')\n * Cannot be used with search_recency_filter.\n */\n search_before_date?: string;\n\n /**\n * Include only results last updated after this date.\n * Format: 'MM/DD/YYYY' (e.g., '3/1/2025')\n * Cannot be used with search_recency_filter.\n */\n last_updated_after_filter?: string;\n\n /**\n * Include only results last updated before this date.\n * Format: 'MM/DD/YYYY' (e.g., '3/15/2025')\n * Cannot be used with search_recency_filter.\n */\n last_updated_before_filter?: string;\n\n /**\n * Filter results by relative time period.\n * Cannot be used with search_after_date or search_before_date.\n */\n search_recency_filter?: 'day' | 'week' | 'month' | 'year';\n}\n\nexport type PerplexitySearchOutput =\n | PerplexitySearchResponse\n | PerplexitySearchError;\n\nconst perplexitySearchInputSchema = lazySchema(() =>\n zodSchema(\n z.object({\n query: z\n .union([z.string(), z.array(z.string())])\n .describe(\n 'Search query (string) or multiple queries (array of up to 5 strings). Multi-query searches return combined results from all queries.',\n ),\n\n max_results: z\n .number()\n .optional()\n .describe(\n 'Maximum number of search results to return (1-20, default: 10)',\n ),\n\n max_tokens_per_page: z\n .number()\n .optional()\n .describe(\n 'Maximum number of tokens to extract per search result page (256-2048, default: 2048)',\n ),\n\n max_tokens: z\n .number()\n .optional()\n .describe(\n 'Maximum total tokens across all search results (default: 25000, max: 1000000)',\n ),\n\n country: z\n .string()\n .optional()\n .describe(\n \"Two-letter ISO 3166-1 alpha-2 country code for regional search results (e.g., 'US', 'GB', 'FR')\",\n ),\n\n search_domain_filter: z\n .array(z.string())\n .optional()\n .describe(\n \"List of domains to include or exclude from search results (max 20). To include: ['nature.com', 'science.org']. To exclude: ['-example.com', '-spam.net']\",\n ),\n\n search_language_filter: z\n .array(z.string())\n .optional()\n .describe(\n \"List of ISO 639-1 language codes to filter results (max 10, lowercase). Examples: ['en', 'fr', 'de']\",\n ),\n\n search_after_date: z\n .string()\n .optional()\n .describe(\n \"Include only results published after this date. Format: 'MM/DD/YYYY' (e.g., '3/1/2025'). Cannot be used with search_recency_filter.\",\n ),\n\n search_before_date: z\n .string()\n .optional()\n .describe(\n \"Include only results published before this date. Format: 'MM/DD/YYYY' (e.g., '3/15/2025'). Cannot be used with search_recency_filter.\",\n ),\n\n last_updated_after_filter: z\n .string()\n .optional()\n .describe(\n \"Include only results last updated after this date. Format: 'MM/DD/YYYY' (e.g., '3/1/2025'). Cannot be used with search_recency_filter.\",\n ),\n\n last_updated_before_filter: z\n .string()\n .optional()\n .describe(\n \"Include only results last updated before this date. Format: 'MM/DD/YYYY' (e.g., '3/15/2025'). Cannot be used with search_recency_filter.\",\n ),\n\n search_recency_filter: z\n .enum(['day', 'week', 'month', 'year'])\n .optional()\n .describe(\n 'Filter results by relative time period. Cannot be used with search_after_date or search_before_date.',\n ),\n }),\n ),\n);\n\nconst perplexitySearchOutputSchema = lazySchema(() =>\n zodSchema(\n z.union([\n // Success response\n z.object({\n results: z.array(\n z.object({\n title: z.string(),\n url: z.string(),\n snippet: z.string(),\n date: z.string().optional(),\n lastUpdated: z.string().optional(),\n }),\n ),\n id: z.string(),\n }),\n // Error response\n z.object({\n error: z.enum([\n 'api_error',\n 'rate_limit',\n 'timeout',\n 'invalid_input',\n 'unknown',\n ]),\n statusCode: z.number().optional(),\n message: z.string(),\n }),\n ]),\n ),\n);\n\nexport const perplexitySearchToolFactory = createProviderExecutedToolFactory<\n PerplexitySearchInput,\n PerplexitySearchOutput,\n PerplexitySearchConfig\n>({\n id: 'gateway.perplexity_search',\n inputSchema: perplexitySearchInputSchema,\n outputSchema: perplexitySearchOutputSchema,\n});\n\nexport const perplexitySearch = (\n config: PerplexitySearchConfig = {},\n): ReturnType<typeof perplexitySearchToolFactory> =>\n perplexitySearchToolFactory(config);\n","import { parallelSearch } from './tool/parallel-search';\nimport { perplexitySearch } from './tool/perplexity-search';\n\n/**\n * Gateway-specific provider-defined tools.\n */\nexport const gatewayTools = {\n /**\n * Search the web using Parallel AI's Search API for LLM-optimized excerpts.\n *\n * Takes a natural language objective and returns relevant excerpts,\n * replacing multiple keyword searches with a single call for broad\n * or complex queries. Supports different search types for depth vs\n * breadth tradeoffs.\n */\n parallelSearch,\n\n /**\n * Search the web using Perplexity's Search API for real-time information,\n * news, research papers, and articles.\n *\n * Provides ranked search results with advanced filtering options including\n * domain, language, date range, and recency filters.\n */\n perplexitySearch,\n};\n","import { getContext } from '@vercel/oidc';\nexport { getVercelOidcToken } from '@vercel/oidc';\n\nexport async function getVercelRequestId(): Promise<string | undefined> {\n return getContext().headers?.['x-vercel-id'];\n}\n","// Version string of this package injected at build time.\ndeclare const __PACKAGE_VERSION__: string | undefined;\nexport const VERSION: string =\n typeof __PACKAGE_VERSION__ !== 'undefined'\n ? __PACKAGE_VERSION__\n : '0.0.0-test';\n"],"mappings":"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","names":["z","marker","symbol","_a","_b","name","marker","symbol","_a","_b","name","marker","symbol","_a","_b","name","marker","symbol","_a","_b","name","marker","symbol","_a","_b","name","marker","symbol","_a","_b","lazySchema","zodSchema","_a","z","name","marker","symbol","_a","_b","_a","z","lazySchema","safeValidateTypes","zodSchema","safeValidateTypes","lazySchema","zodSchema","z","lazySchema","zodSchema","z","z","lazySchema","zodSchema","createJsonErrorResponseHandler","createJsonResponseHandler","getFromApi","lazySchema","resolve","zodSchema","z","getFromApi","resolve","createJsonResponseHandler","createJsonErrorResponseHandler","z","lazySchema","zodSchema","createJsonErrorResponseHandler","createJsonResponseHandler","getFromApi","lazySchema","resolve","zodSchema","z","getFromApi","resolve","createJsonResponseHandler","createJsonErrorResponseHandler","z","lazySchema","zodSchema","createJsonErrorResponseHandler","createJsonResponseHandler","resolve","z","resolve","createJsonResponseHandler","z","createJsonErrorResponseHandler","combineHeaders","createJsonErrorResponseHandler","createJsonResponseHandler","lazySchema","postJsonToApi","resolve","serializeModelOptions","WORKFLOW_SERIALIZE","WORKFLOW_DESERIALIZE","zodSchema","z","WORKFLOW_SERIALIZE","serializeModelOptions","WORKFLOW_DESERIALIZE","_a","resolve","postJsonToApi","combineHeaders","createJsonResponseHandler","createJsonErrorResponseHandler","z","lazySchema","zodSchema","combineHeaders","createJsonResponseHandler","createJsonErrorResponseHandler","postJsonToApi","resolve","serializeModelOptions","WORKFLOW_SERIALIZE","WORKFLOW_DESERIALIZE","z","WORKFLOW_SERIALIZE","serializeModelOptions","WORKFLOW_DESERIALIZE","_a","_b","resolve","postJsonToApi","combineHeaders","createJsonResponseHandler","createJsonErrorResponseHandler","z","APICallError","combineHeaders","convertUint8ArrayToBase64","createJsonErrorResponseHandler","postJsonToApi","resolve","z","_a","resolve","postJsonToApi","combineHeaders","APICallError","createJsonErrorResponseHandler","z","convertUint8ArrayToBase64","providerMetadataEntrySchema","combineHeaders","createJsonErrorResponseHandler","createJsonResponseHandler","lazySchema","postJsonToApi","resolve","zodSchema","z","resolve","postJsonToApi","combineHeaders","createJsonResponseHandler","createJsonErrorResponseHandler","z","lazySchema","zodSchema","combineHeaders","createJsonErrorResponseHandler","createJsonResponseHandler","postJsonToApi","resolve","z","_a","resolve","postJsonToApi","combineHeaders","createJsonResponseHandler","createJsonErrorResponseHandler","z","providerMetadataEntrySchema","combineHeaders","convertUint8ArrayToBase64","createJsonErrorResponseHandler","createJsonResponseHandler","postJsonToApi","resolve","z","_a","_b","resolve","postJsonToApi","combineHeaders","convertUint8ArrayToBase64","createJsonResponseHandler","createJsonErrorResponseHandler","z","providerMetadataEntrySchema","lazySchema","zodSchema","z","createProviderExecutedToolFactory","lazySchema","zodSchema","z","_a","_a","_b"]}
|
package/docs/00-ai-gateway.mdx
CHANGED
|
@@ -61,7 +61,7 @@ import { gateway } from 'ai';
|
|
|
61
61
|
|
|
62
62
|
You may want to create a custom provider instance when you need to:
|
|
63
63
|
|
|
64
|
-
- Set custom configuration options (API key, base URL, headers)
|
|
64
|
+
- Set custom configuration options (API key, Vercel access token, base URL, headers)
|
|
65
65
|
- Use the provider in a [provider registry](/docs/ai-sdk-core/provider-management)
|
|
66
66
|
- Wrap the provider with [middleware](/docs/ai-sdk-core/middleware)
|
|
67
67
|
- Use different settings for different parts of your application
|
|
@@ -84,8 +84,15 @@ You can use the following optional settings to customize the AI Gateway provider
|
|
|
84
84
|
|
|
85
85
|
- **apiKey** _string_
|
|
86
86
|
|
|
87
|
-
API key that is being sent using the `Authorization`
|
|
88
|
-
the `AI_GATEWAY_API_KEY` environment variable.
|
|
87
|
+
API key or Vercel access token that is being sent using the `Authorization`
|
|
88
|
+
header. It defaults to the `AI_GATEWAY_API_KEY` environment variable.
|
|
89
|
+
Supports AI Gateway API keys, Vercel personal access tokens, and Vercel app
|
|
90
|
+
access tokens.
|
|
91
|
+
|
|
92
|
+
- **teamIdOrSlug** _string_
|
|
93
|
+
|
|
94
|
+
Vercel team ID or slug used to scope model requests when authenticating with
|
|
95
|
+
multi-team Vercel access tokens.
|
|
89
96
|
|
|
90
97
|
- **headers** _Record<string,string>_
|
|
91
98
|
|
|
@@ -104,7 +111,7 @@ You can use the following optional settings to customize the AI Gateway provider
|
|
|
104
111
|
|
|
105
112
|
## Authentication
|
|
106
113
|
|
|
107
|
-
The Gateway provider supports
|
|
114
|
+
The Gateway provider supports the following authentication methods:
|
|
108
115
|
|
|
109
116
|
### API Key Authentication
|
|
110
117
|
|
|
@@ -124,10 +131,33 @@ const gateway = createGateway({
|
|
|
124
131
|
});
|
|
125
132
|
```
|
|
126
133
|
|
|
134
|
+
### Vercel Access Token Authentication for Model Requests
|
|
135
|
+
|
|
136
|
+
For dynamic runtime authentication of model requests, pass a Vercel personal
|
|
137
|
+
access token or Vercel app access token to a custom Gateway provider instance:
|
|
138
|
+
|
|
139
|
+
```ts
|
|
140
|
+
import { createGateway } from 'ai';
|
|
141
|
+
|
|
142
|
+
const gateway = createGateway({
|
|
143
|
+
apiKey: 'your_vercel_access_token_here',
|
|
144
|
+
teamIdOrSlug: 'your-team', // required for multi-team tokens
|
|
145
|
+
});
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
`apiKey` takes precedence over `AI_GATEWAY_API_KEY` and OIDC.
|
|
149
|
+
|
|
150
|
+
<Note>
|
|
151
|
+
Vercel access tokens with `teamIdOrSlug` are supported for model requests.
|
|
152
|
+
Gateway helper methods such as `getCredits`, `getSpendReport`, and
|
|
153
|
+
`getGenerationInfo` require an AI Gateway API key or OIDC authentication.
|
|
154
|
+
</Note>
|
|
155
|
+
|
|
127
156
|
### OIDC Authentication (Vercel Deployments)
|
|
128
157
|
|
|
129
|
-
When deployed to Vercel, the AI Gateway provider supports authenticating
|
|
130
|
-
tokens](https://vercel.com/docs/oidc)
|
|
158
|
+
When deployed to Vercel, the AI Gateway provider supports authenticating model
|
|
159
|
+
requests using [OIDC (OpenID Connect) tokens](https://vercel.com/docs/oidc)
|
|
160
|
+
without API Keys.
|
|
131
161
|
|
|
132
162
|
#### How OIDC Authentication Works
|
|
133
163
|
|
|
@@ -146,8 +176,8 @@ tokens](https://vercel.com/docs/oidc) without API Keys.
|
|
|
146
176
|
- You'll need to run `vercel env pull` again to refresh the token before it expires
|
|
147
177
|
|
|
148
178
|
<Note>
|
|
149
|
-
If an API
|
|
150
|
-
always be used, even if invalid.
|
|
179
|
+
If an API key or Vercel access token is present (either passed directly or via
|
|
180
|
+
environment), it will always be used instead of OIDC, even if invalid.
|
|
151
181
|
</Note>
|
|
152
182
|
|
|
153
183
|
Read more about using OIDC tokens in the [Vercel AI Gateway docs](https://vercel.com/docs/ai-gateway#using-the-ai-gateway-with-a-vercel-oidc-token).
|
|
@@ -844,6 +874,32 @@ The following gateway provider options are available:
|
|
|
844
874
|
|
|
845
875
|
For full details, see [Provider Timeouts](https://vercel.com/docs/ai-gateway/models-and-providers/provider-timeouts).
|
|
846
876
|
|
|
877
|
+
- **serviceTier** _'flex' | 'priority'_
|
|
878
|
+
|
|
879
|
+
Unified service tier intent. The gateway translates it into whichever
|
|
880
|
+
per-provider option each provider expects, and overrides any tier
|
|
881
|
+
also set in the per-provider options. Leave unset for provider
|
|
882
|
+
default. See the [OpenAI](/providers/ai-sdk-providers/openai),
|
|
883
|
+
[Google Generative AI](/providers/ai-sdk-providers/google-generative-ai),
|
|
884
|
+
and [Google Vertex AI](/providers/ai-sdk-providers/google-vertex)
|
|
885
|
+
provider docs for tier semantics, model availability, and graceful
|
|
886
|
+
downgrade behavior on each provider.
|
|
887
|
+
|
|
888
|
+
```ts
|
|
889
|
+
import type { GatewayProviderOptions } from '@ai-sdk/gateway';
|
|
890
|
+
import { generateText } from 'ai';
|
|
891
|
+
|
|
892
|
+
const { text } = await generateText({
|
|
893
|
+
model: 'openai/gpt-5-mini',
|
|
894
|
+
prompt: 'Hello',
|
|
895
|
+
providerOptions: {
|
|
896
|
+
gateway: {
|
|
897
|
+
serviceTier: 'priority',
|
|
898
|
+
} satisfies GatewayProviderOptions,
|
|
899
|
+
},
|
|
900
|
+
});
|
|
901
|
+
```
|
|
902
|
+
|
|
847
903
|
You can combine these options to have fine-grained control over routing and tracking:
|
|
848
904
|
|
|
849
905
|
```ts
|
package/package.json
CHANGED
|
@@ -51,17 +51,18 @@ export class GatewayAuthenticationError extends GatewayError {
|
|
|
51
51
|
let contextualMessage: string;
|
|
52
52
|
|
|
53
53
|
if (apiKeyProvided) {
|
|
54
|
-
contextualMessage = `AI Gateway authentication failed: Invalid API key.
|
|
54
|
+
contextualMessage = `AI Gateway authentication failed: Invalid API key or token.
|
|
55
55
|
|
|
56
56
|
Create a new API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys
|
|
57
57
|
|
|
58
|
-
Provide via 'apiKey' option or 'AI_GATEWAY_API_KEY' environment variable.`;
|
|
58
|
+
Provide an API key or Vercel access token via 'apiKey' option or 'AI_GATEWAY_API_KEY' environment variable.`;
|
|
59
59
|
} else if (oidcTokenProvided) {
|
|
60
60
|
contextualMessage = `AI Gateway authentication failed: Invalid OIDC token.
|
|
61
61
|
|
|
62
62
|
Run 'npx vercel link' to link your project, then 'vc env pull' to fetch the token.
|
|
63
63
|
|
|
64
|
-
Alternatively, use an API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys
|
|
64
|
+
Alternatively, use an API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys
|
|
65
|
+
or pass a Vercel access token via the 'apiKey' option.`;
|
|
65
66
|
} else {
|
|
66
67
|
contextualMessage = `AI Gateway authentication failed: No authentication provided.
|
|
67
68
|
|
|
@@ -69,7 +70,10 @@ Option 1 - API key:
|
|
|
69
70
|
Create an API key: https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai%2Fapi-keys
|
|
70
71
|
Provide via 'apiKey' option or 'AI_GATEWAY_API_KEY' environment variable.
|
|
71
72
|
|
|
72
|
-
Option 2 -
|
|
73
|
+
Option 2 - Vercel access token:
|
|
74
|
+
Pass a Vercel personal access token or Vercel app access token via the 'apiKey' option.
|
|
75
|
+
|
|
76
|
+
Option 3 - OIDC token:
|
|
73
77
|
Run 'npx vercel link' to link your project, then 'vc env pull' to fetch the token.`;
|
|
74
78
|
}
|
|
75
79
|
|
|
@@ -4,8 +4,7 @@ import {
|
|
|
4
4
|
safeValidateTypes,
|
|
5
5
|
zodSchema,
|
|
6
6
|
} from '@ai-sdk/provider-utils';
|
|
7
|
-
|
|
8
|
-
export const GATEWAY_AUTH_METHOD_HEADER = 'ai-gateway-auth-method' as const;
|
|
7
|
+
import { GATEWAY_AUTH_METHOD_HEADER } from '../gateway-headers';
|
|
9
8
|
|
|
10
9
|
export async function parseAuthMethod(
|
|
11
10
|
headers: Record<string, string | undefined>,
|
|
@@ -104,6 +104,13 @@ const gatewayProviderOptions = lazySchema(() =>
|
|
|
104
104
|
byok: z.record(z.string(), z.number().int().min(1000)).optional(),
|
|
105
105
|
})
|
|
106
106
|
.optional(),
|
|
107
|
+
/**
|
|
108
|
+
* Unified service tier intent. Translated by the gateway into the
|
|
109
|
+
* per-provider option each provider expects, and overrides any tier
|
|
110
|
+
* also set in the per-provider options. Leave unset for provider
|
|
111
|
+
* default.
|
|
112
|
+
*/
|
|
113
|
+
serviceTier: z.enum(['flex', 'priority']).optional(),
|
|
107
114
|
}),
|
|
108
115
|
),
|
|
109
116
|
);
|
package/src/gateway-provider.ts
CHANGED
|
@@ -7,8 +7,9 @@ import {
|
|
|
7
7
|
import { asGatewayError, GatewayAuthenticationError } from './errors';
|
|
8
8
|
import {
|
|
9
9
|
GATEWAY_AUTH_METHOD_HEADER,
|
|
10
|
-
|
|
11
|
-
} from './
|
|
10
|
+
VERCEL_AI_GATEWAY_TEAM_HEADER,
|
|
11
|
+
} from './gateway-headers';
|
|
12
|
+
import { parseAuthMethod } from './errors/parse-auth-method';
|
|
12
13
|
import {
|
|
13
14
|
GatewayFetchMetadata,
|
|
14
15
|
type GatewayFetchMetadataResponse,
|
|
@@ -166,15 +167,22 @@ export interface GatewayProvider extends ProviderV4 {
|
|
|
166
167
|
|
|
167
168
|
export interface GatewayProviderSettings {
|
|
168
169
|
/**
|
|
169
|
-
* The base URL prefix for API calls. Defaults to `https://ai-gateway.vercel.sh/
|
|
170
|
+
* The base URL prefix for API calls. Defaults to `https://ai-gateway.vercel.sh/v4/ai`.
|
|
170
171
|
*/
|
|
171
172
|
baseURL?: string;
|
|
172
173
|
|
|
173
174
|
/**
|
|
174
|
-
* API key that is being sent using the `Authorization`
|
|
175
|
+
* API key or Vercel access token that is being sent using the `Authorization`
|
|
176
|
+
* header. It defaults to the `AI_GATEWAY_API_KEY` environment variable.
|
|
175
177
|
*/
|
|
176
178
|
apiKey?: string;
|
|
177
179
|
|
|
180
|
+
/**
|
|
181
|
+
* Vercel team ID or slug to scope requests for access tokens that can access
|
|
182
|
+
* multiple teams.
|
|
183
|
+
*/
|
|
184
|
+
teamIdOrSlug?: string;
|
|
185
|
+
|
|
178
186
|
/**
|
|
179
187
|
* Custom headers to include in the requests.
|
|
180
188
|
*/
|
|
@@ -217,18 +225,26 @@ export function createGateway(
|
|
|
217
225
|
withoutTrailingSlash(options.baseURL) ??
|
|
218
226
|
'https://ai-gateway.vercel.sh/v4/ai';
|
|
219
227
|
|
|
228
|
+
const createAuthHeaders = (auth: {
|
|
229
|
+
token: string;
|
|
230
|
+
authMethod: 'api-key' | 'oidc';
|
|
231
|
+
}) =>
|
|
232
|
+
withUserAgentSuffix(
|
|
233
|
+
{
|
|
234
|
+
Authorization: `Bearer ${auth.token}`,
|
|
235
|
+
'ai-gateway-protocol-version': AI_GATEWAY_PROTOCOL_VERSION,
|
|
236
|
+
[GATEWAY_AUTH_METHOD_HEADER]: auth.authMethod,
|
|
237
|
+
...(options.teamIdOrSlug != null
|
|
238
|
+
? { [VERCEL_AI_GATEWAY_TEAM_HEADER]: options.teamIdOrSlug }
|
|
239
|
+
: {}),
|
|
240
|
+
...options.headers,
|
|
241
|
+
},
|
|
242
|
+
`ai-sdk/gateway/${VERSION}`,
|
|
243
|
+
);
|
|
244
|
+
|
|
220
245
|
const getHeaders = async () => {
|
|
221
246
|
try {
|
|
222
|
-
|
|
223
|
-
return withUserAgentSuffix(
|
|
224
|
-
{
|
|
225
|
-
Authorization: `Bearer ${auth.token}`,
|
|
226
|
-
'ai-gateway-protocol-version': AI_GATEWAY_PROTOCOL_VERSION,
|
|
227
|
-
[GATEWAY_AUTH_METHOD_HEADER]: auth.authMethod,
|
|
228
|
-
...options.headers,
|
|
229
|
-
},
|
|
230
|
-
`ai-sdk/gateway/${VERSION}`,
|
|
231
|
-
);
|
|
247
|
+
return createAuthHeaders(await getGatewayAuthToken(options));
|
|
232
248
|
} catch (error) {
|
|
233
249
|
throw GatewayAuthenticationError.createContextualError({
|
|
234
250
|
apiKeyProvided: false,
|