@ai-sdk/gateway 3.0.18 → 3.0.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/index.d.mts +18 -8
  3. package/dist/index.d.ts +18 -8
  4. package/dist/index.js +62 -25
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.mjs +62 -25
  7. package/dist/index.mjs.map +1 -1
  8. package/package.json +5 -4
  9. package/src/errors/as-gateway-error.ts +33 -0
  10. package/src/errors/create-gateway-error.test.ts +590 -0
  11. package/src/errors/create-gateway-error.ts +132 -0
  12. package/src/errors/extract-api-call-response.test.ts +270 -0
  13. package/src/errors/extract-api-call-response.ts +15 -0
  14. package/src/errors/gateway-authentication-error.ts +84 -0
  15. package/src/errors/gateway-error-types.test.ts +278 -0
  16. package/src/errors/gateway-error.ts +47 -0
  17. package/src/errors/gateway-internal-server-error.ts +33 -0
  18. package/src/errors/gateway-invalid-request-error.ts +33 -0
  19. package/src/errors/gateway-model-not-found-error.ts +47 -0
  20. package/src/errors/gateway-rate-limit-error.ts +33 -0
  21. package/src/errors/gateway-response-error.ts +42 -0
  22. package/src/errors/index.ts +16 -0
  23. package/src/errors/parse-auth-method.test.ts +136 -0
  24. package/src/errors/parse-auth-method.ts +23 -0
  25. package/src/gateway-config.ts +7 -0
  26. package/src/gateway-embedding-model-settings.ts +22 -0
  27. package/src/gateway-embedding-model.test.ts +213 -0
  28. package/src/gateway-embedding-model.ts +109 -0
  29. package/src/gateway-fetch-metadata.test.ts +774 -0
  30. package/src/gateway-fetch-metadata.ts +127 -0
  31. package/src/gateway-image-model-settings.ts +12 -0
  32. package/src/gateway-image-model.test.ts +823 -0
  33. package/src/gateway-image-model.ts +145 -0
  34. package/src/gateway-language-model-settings.ts +159 -0
  35. package/src/gateway-language-model.test.ts +1485 -0
  36. package/src/gateway-language-model.ts +212 -0
  37. package/src/gateway-model-entry.ts +58 -0
  38. package/src/gateway-provider-options.ts +66 -0
  39. package/src/gateway-provider.test.ts +1210 -0
  40. package/src/gateway-provider.ts +284 -0
  41. package/src/gateway-tools.ts +15 -0
  42. package/src/index.ts +27 -0
  43. package/src/tool/perplexity-search.ts +294 -0
  44. package/src/vercel-environment.test.ts +65 -0
  45. package/src/vercel-environment.ts +6 -0
  46. package/src/version.ts +6 -0
@@ -0,0 +1,109 @@
1
+ import type {
2
+ EmbeddingModelV3,
3
+ SharedV3ProviderMetadata,
4
+ } from '@ai-sdk/provider';
5
+ import {
6
+ combineHeaders,
7
+ createJsonErrorResponseHandler,
8
+ createJsonResponseHandler,
9
+ lazySchema,
10
+ postJsonToApi,
11
+ resolve,
12
+ zodSchema,
13
+ type Resolvable,
14
+ } from '@ai-sdk/provider-utils';
15
+ import { z } from 'zod/v4';
16
+ import { asGatewayError } from './errors';
17
+ import { parseAuthMethod } from './errors/parse-auth-method';
18
+ import type { GatewayConfig } from './gateway-config';
19
+
20
+ export class GatewayEmbeddingModel implements EmbeddingModelV3 {
21
+ readonly specificationVersion = 'v3';
22
+ readonly maxEmbeddingsPerCall = 2048;
23
+ readonly supportsParallelCalls = true;
24
+
25
+ constructor(
26
+ readonly modelId: string,
27
+ private readonly config: GatewayConfig & {
28
+ provider: string;
29
+ o11yHeaders: Resolvable<Record<string, string>>;
30
+ },
31
+ ) {}
32
+
33
+ get provider(): string {
34
+ return this.config.provider;
35
+ }
36
+
37
+ async doEmbed({
38
+ values,
39
+ headers,
40
+ abortSignal,
41
+ providerOptions,
42
+ }: Parameters<EmbeddingModelV3['doEmbed']>[0]): Promise<
43
+ Awaited<ReturnType<EmbeddingModelV3['doEmbed']>>
44
+ > {
45
+ const resolvedHeaders = await resolve(this.config.headers());
46
+ try {
47
+ const {
48
+ responseHeaders,
49
+ value: responseBody,
50
+ rawValue,
51
+ } = await postJsonToApi({
52
+ url: this.getUrl(),
53
+ headers: combineHeaders(
54
+ resolvedHeaders,
55
+ headers ?? {},
56
+ this.getModelConfigHeaders(),
57
+ await resolve(this.config.o11yHeaders),
58
+ ),
59
+ body: {
60
+ values,
61
+ ...(providerOptions ? { providerOptions } : {}),
62
+ },
63
+ successfulResponseHandler: createJsonResponseHandler(
64
+ gatewayEmbeddingResponseSchema,
65
+ ),
66
+ failedResponseHandler: createJsonErrorResponseHandler({
67
+ errorSchema: z.any(),
68
+ errorToMessage: data => data,
69
+ }),
70
+ ...(abortSignal && { abortSignal }),
71
+ fetch: this.config.fetch,
72
+ });
73
+
74
+ return {
75
+ embeddings: responseBody.embeddings,
76
+ usage: responseBody.usage ?? undefined,
77
+ providerMetadata:
78
+ responseBody.providerMetadata as unknown as SharedV3ProviderMetadata,
79
+ response: { headers: responseHeaders, body: rawValue },
80
+ warnings: [],
81
+ };
82
+ } catch (error) {
83
+ throw await asGatewayError(error, await parseAuthMethod(resolvedHeaders));
84
+ }
85
+ }
86
+
87
+ private getUrl() {
88
+ return `${this.config.baseURL}/embedding-model`;
89
+ }
90
+
91
+ private getModelConfigHeaders() {
92
+ return {
93
+ 'ai-embedding-model-specification-version': '3',
94
+ 'ai-model-id': this.modelId,
95
+ };
96
+ }
97
+ }
98
+
99
+ const gatewayEmbeddingResponseSchema = lazySchema(() =>
100
+ zodSchema(
101
+ z.object({
102
+ embeddings: z.array(z.array(z.number())),
103
+ usage: z.object({ tokens: z.number() }).nullish(),
104
+ providerMetadata: z
105
+ .record(z.string(), z.record(z.string(), z.unknown()))
106
+ .optional(),
107
+ }),
108
+ ),
109
+ );