@hebo-ai/gateway 0.9.2 → 0.9.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (213) hide show
  1. package/dist/config.d.ts +2 -0
  2. package/dist/config.js +125 -0
  3. package/dist/endpoints/chat-completions/converters.d.ts +26 -0
  4. package/dist/endpoints/chat-completions/converters.js +525 -0
  5. package/dist/endpoints/chat-completions/handler.d.ts +2 -0
  6. package/dist/endpoints/chat-completions/handler.js +152 -0
  7. package/dist/endpoints/chat-completions/index.d.ts +4 -0
  8. package/dist/endpoints/chat-completions/index.js +4 -0
  9. package/dist/endpoints/chat-completions/otel.d.ts +5 -0
  10. package/dist/endpoints/chat-completions/otel.js +178 -0
  11. package/dist/endpoints/chat-completions/schema.d.ts +1170 -0
  12. package/dist/endpoints/chat-completions/schema.js +252 -0
  13. package/dist/endpoints/conversations/converters.d.ts +8 -0
  14. package/dist/endpoints/conversations/converters.js +29 -0
  15. package/dist/endpoints/conversations/handler.d.ts +2 -0
  16. package/dist/endpoints/conversations/handler.js +259 -0
  17. package/dist/endpoints/conversations/index.d.ts +3 -0
  18. package/dist/endpoints/conversations/index.js +3 -0
  19. package/dist/endpoints/conversations/schema.d.ts +1511 -0
  20. package/dist/endpoints/conversations/schema.js +74 -0
  21. package/dist/endpoints/conversations/storage/dialects/greptime.d.ts +10 -0
  22. package/dist/endpoints/conversations/storage/dialects/greptime.js +87 -0
  23. package/dist/endpoints/conversations/storage/dialects/mysql.d.ts +12 -0
  24. package/dist/endpoints/conversations/storage/dialects/mysql.js +118 -0
  25. package/dist/endpoints/conversations/storage/dialects/postgres.d.ts +16 -0
  26. package/dist/endpoints/conversations/storage/dialects/postgres.js +185 -0
  27. package/dist/endpoints/conversations/storage/dialects/sqlite.d.ts +11 -0
  28. package/dist/endpoints/conversations/storage/dialects/sqlite.js +176 -0
  29. package/dist/endpoints/conversations/storage/dialects/types.d.ts +42 -0
  30. package/dist/endpoints/conversations/storage/dialects/types.js +0 -0
  31. package/dist/endpoints/conversations/storage/dialects/utils.d.ts +25 -0
  32. package/dist/endpoints/conversations/storage/dialects/utils.js +80 -0
  33. package/dist/endpoints/conversations/storage/memory.d.ts +25 -0
  34. package/dist/endpoints/conversations/storage/memory.js +200 -0
  35. package/dist/endpoints/conversations/storage/sql.d.ts +33 -0
  36. package/dist/endpoints/conversations/storage/sql.js +276 -0
  37. package/dist/endpoints/conversations/storage/types.d.ts +39 -0
  38. package/dist/endpoints/conversations/storage/types.js +0 -0
  39. package/dist/endpoints/embeddings/converters.d.ts +10 -0
  40. package/dist/endpoints/embeddings/converters.js +31 -0
  41. package/dist/endpoints/embeddings/handler.d.ts +2 -0
  42. package/dist/endpoints/embeddings/handler.js +99 -0
  43. package/dist/endpoints/embeddings/index.d.ts +4 -0
  44. package/dist/endpoints/embeddings/index.js +4 -0
  45. package/dist/endpoints/embeddings/otel.d.ts +5 -0
  46. package/dist/endpoints/embeddings/otel.js +29 -0
  47. package/dist/endpoints/embeddings/schema.d.ts +44 -0
  48. package/dist/endpoints/embeddings/schema.js +29 -0
  49. package/dist/endpoints/models/converters.d.ts +6 -0
  50. package/dist/endpoints/models/converters.js +42 -0
  51. package/dist/endpoints/models/handler.d.ts +2 -0
  52. package/dist/endpoints/models/handler.js +29 -0
  53. package/dist/endpoints/models/index.d.ts +3 -0
  54. package/dist/endpoints/models/index.js +3 -0
  55. package/dist/endpoints/models/schema.d.ts +42 -0
  56. package/dist/endpoints/models/schema.js +31 -0
  57. package/dist/endpoints/responses/converters.d.ts +17 -0
  58. package/dist/endpoints/responses/converters.js +1037 -0
  59. package/dist/endpoints/responses/handler.d.ts +2 -0
  60. package/dist/endpoints/responses/handler.js +141 -0
  61. package/dist/endpoints/responses/index.d.ts +4 -0
  62. package/dist/endpoints/responses/index.js +4 -0
  63. package/dist/endpoints/responses/otel.d.ts +6 -0
  64. package/dist/endpoints/responses/otel.js +226 -0
  65. package/dist/endpoints/responses/schema.d.ts +2109 -0
  66. package/dist/endpoints/responses/schema.js +314 -0
  67. package/dist/endpoints/shared/converters.d.ts +56 -0
  68. package/dist/endpoints/shared/converters.js +180 -0
  69. package/dist/endpoints/shared/schema.d.ts +70 -0
  70. package/dist/endpoints/shared/schema.js +46 -0
  71. package/dist/errors/ai-sdk.d.ts +2 -0
  72. package/dist/errors/ai-sdk.js +52 -0
  73. package/dist/errors/gateway.d.ts +5 -0
  74. package/dist/errors/gateway.js +13 -0
  75. package/dist/errors/openai.d.ts +15 -0
  76. package/dist/errors/openai.js +40 -0
  77. package/dist/errors/utils.d.ts +24 -0
  78. package/dist/errors/utils.js +46 -0
  79. package/dist/gateway.d.ts +11 -0
  80. package/dist/gateway.js +44 -0
  81. package/dist/index.d.ts +11 -0
  82. package/dist/index.js +10 -0
  83. package/dist/lifecycle.d.ts +3 -0
  84. package/dist/lifecycle.js +114 -0
  85. package/dist/logger/default.d.ts +4 -0
  86. package/dist/logger/default.js +81 -0
  87. package/dist/logger/index.d.ts +11 -0
  88. package/dist/logger/index.js +25 -0
  89. package/dist/middleware/common.d.ts +12 -0
  90. package/dist/middleware/common.js +146 -0
  91. package/dist/middleware/debug.d.ts +3 -0
  92. package/dist/middleware/debug.js +27 -0
  93. package/dist/middleware/matcher.d.ts +28 -0
  94. package/dist/middleware/matcher.js +118 -0
  95. package/dist/middleware/utils.d.ts +2 -0
  96. package/dist/middleware/utils.js +24 -0
  97. package/dist/models/amazon/index.d.ts +2 -0
  98. package/dist/models/amazon/index.js +2 -0
  99. package/dist/models/amazon/middleware.d.ts +3 -0
  100. package/dist/models/amazon/middleware.js +69 -0
  101. package/dist/models/amazon/presets.d.ts +345 -0
  102. package/dist/models/amazon/presets.js +80 -0
  103. package/dist/models/anthropic/index.d.ts +2 -0
  104. package/dist/models/anthropic/index.js +2 -0
  105. package/dist/models/anthropic/middleware.d.ts +5 -0
  106. package/dist/models/anthropic/middleware.js +128 -0
  107. package/dist/models/anthropic/presets.d.ts +711 -0
  108. package/dist/models/anthropic/presets.js +140 -0
  109. package/dist/models/catalog.d.ts +4 -0
  110. package/dist/models/catalog.js +8 -0
  111. package/dist/models/cohere/index.d.ts +2 -0
  112. package/dist/models/cohere/index.js +2 -0
  113. package/dist/models/cohere/middleware.d.ts +3 -0
  114. package/dist/models/cohere/middleware.js +62 -0
  115. package/dist/models/cohere/presets.d.ts +411 -0
  116. package/dist/models/cohere/presets.js +134 -0
  117. package/dist/models/google/index.d.ts +2 -0
  118. package/dist/models/google/index.js +2 -0
  119. package/dist/models/google/middleware.d.ts +8 -0
  120. package/dist/models/google/middleware.js +118 -0
  121. package/dist/models/google/presets.d.ts +815 -0
  122. package/dist/models/google/presets.js +184 -0
  123. package/dist/models/meta/index.d.ts +1 -0
  124. package/dist/models/meta/index.js +1 -0
  125. package/dist/models/meta/presets.d.ts +483 -0
  126. package/dist/models/meta/presets.js +105 -0
  127. package/dist/models/openai/index.d.ts +2 -0
  128. package/dist/models/openai/index.js +2 -0
  129. package/dist/models/openai/middleware.d.ts +4 -0
  130. package/dist/models/openai/middleware.js +89 -0
  131. package/dist/models/openai/presets.d.ts +1319 -0
  132. package/dist/models/openai/presets.js +277 -0
  133. package/dist/models/types.d.ts +20 -0
  134. package/dist/models/types.js +100 -0
  135. package/dist/models/voyage/index.d.ts +2 -0
  136. package/dist/models/voyage/index.js +2 -0
  137. package/dist/models/voyage/middleware.d.ts +2 -0
  138. package/dist/models/voyage/middleware.js +19 -0
  139. package/dist/models/voyage/presets.d.ts +436 -0
  140. package/dist/models/voyage/presets.js +85 -0
  141. package/dist/providers/anthropic/canonical.d.ts +3 -0
  142. package/dist/providers/anthropic/canonical.js +9 -0
  143. package/dist/providers/anthropic/index.d.ts +1 -0
  144. package/dist/providers/anthropic/index.js +1 -0
  145. package/dist/providers/bedrock/canonical.d.ts +17 -0
  146. package/dist/providers/bedrock/canonical.js +64 -0
  147. package/dist/providers/bedrock/index.d.ts +2 -0
  148. package/dist/providers/bedrock/index.js +2 -0
  149. package/dist/providers/bedrock/middleware.d.ts +5 -0
  150. package/dist/providers/bedrock/middleware.js +133 -0
  151. package/dist/providers/cohere/canonical.d.ts +3 -0
  152. package/dist/providers/cohere/canonical.js +17 -0
  153. package/dist/providers/cohere/index.d.ts +1 -0
  154. package/dist/providers/cohere/index.js +1 -0
  155. package/dist/providers/groq/canonical.d.ts +3 -0
  156. package/dist/providers/groq/canonical.js +12 -0
  157. package/dist/providers/groq/index.d.ts +2 -0
  158. package/dist/providers/groq/index.js +2 -0
  159. package/dist/providers/groq/middleware.d.ts +2 -0
  160. package/dist/providers/groq/middleware.js +30 -0
  161. package/dist/providers/openai/canonical.d.ts +3 -0
  162. package/dist/providers/openai/canonical.js +8 -0
  163. package/dist/providers/openai/index.d.ts +1 -0
  164. package/dist/providers/openai/index.js +1 -0
  165. package/dist/providers/registry.d.ts +24 -0
  166. package/dist/providers/registry.js +103 -0
  167. package/dist/providers/types.d.ts +7 -0
  168. package/dist/providers/types.js +11 -0
  169. package/dist/providers/vertex/canonical.d.ts +3 -0
  170. package/dist/providers/vertex/canonical.js +8 -0
  171. package/dist/providers/vertex/index.d.ts +2 -0
  172. package/dist/providers/vertex/index.js +2 -0
  173. package/dist/providers/vertex/middleware.d.ts +2 -0
  174. package/dist/providers/vertex/middleware.js +47 -0
  175. package/dist/providers/voyage/canonical.d.ts +3 -0
  176. package/dist/providers/voyage/canonical.js +7 -0
  177. package/dist/providers/voyage/index.d.ts +1 -0
  178. package/dist/providers/voyage/index.js +1 -0
  179. package/dist/telemetry/ai-sdk.d.ts +2 -0
  180. package/dist/telemetry/ai-sdk.js +31 -0
  181. package/dist/telemetry/baggage.d.ts +1 -0
  182. package/dist/telemetry/baggage.js +24 -0
  183. package/dist/telemetry/fetch.d.ts +2 -0
  184. package/dist/telemetry/fetch.js +49 -0
  185. package/dist/telemetry/gen-ai.d.ts +7 -0
  186. package/dist/telemetry/gen-ai.js +108 -0
  187. package/dist/telemetry/http.d.ts +3 -0
  188. package/dist/telemetry/http.js +54 -0
  189. package/dist/telemetry/index.d.ts +1 -0
  190. package/dist/telemetry/index.js +1 -0
  191. package/dist/telemetry/memory.d.ts +2 -0
  192. package/dist/telemetry/memory.js +43 -0
  193. package/dist/telemetry/span.d.ts +13 -0
  194. package/dist/telemetry/span.js +60 -0
  195. package/dist/types.d.ts +231 -0
  196. package/dist/types.js +2 -0
  197. package/dist/utils/body.d.ts +19 -0
  198. package/dist/utils/body.js +99 -0
  199. package/dist/utils/env.d.ts +2 -0
  200. package/dist/utils/env.js +7 -0
  201. package/dist/utils/headers.d.ts +4 -0
  202. package/dist/utils/headers.js +22 -0
  203. package/dist/utils/preset.d.ts +10 -0
  204. package/dist/utils/preset.js +41 -0
  205. package/dist/utils/request.d.ts +2 -0
  206. package/dist/utils/request.js +43 -0
  207. package/dist/utils/response.d.ts +6 -0
  208. package/dist/utils/response.js +55 -0
  209. package/dist/utils/stream.d.ts +9 -0
  210. package/dist/utils/stream.js +100 -0
  211. package/dist/utils/url.d.ts +4 -0
  212. package/dist/utils/url.js +21 -0
  213. package/package.json +1 -1
@@ -0,0 +1,277 @@
1
+ import { presetFor } from "../../utils/preset";
2
+ const GPT_OSS_BASE = {
3
+ modalities: {
4
+ input: ["text", "file"],
5
+ output: ["text"],
6
+ },
7
+ capabilities: [
8
+ "attachments",
9
+ "reasoning",
10
+ "tool_call",
11
+ "structured_output",
12
+ "temperature",
13
+ ],
14
+ context: 131072,
15
+ providers: ["groq", "bedrock", "vertex"],
16
+ };
17
+ const GPT_BASE = {
18
+ modalities: {
19
+ input: ["text", "image"],
20
+ output: ["text"],
21
+ },
22
+ capabilities: [
23
+ "attachments",
24
+ "reasoning",
25
+ "tool_call",
26
+ "structured_output",
27
+ "temperature",
28
+ ],
29
+ providers: ["openai", "azure"],
30
+ };
31
+ const GPT_PRO_BASE = {
32
+ modalities: {
33
+ input: ["text", "image"],
34
+ output: ["text"],
35
+ },
36
+ capabilities: [
37
+ "attachments",
38
+ "reasoning",
39
+ "tool_call",
40
+ "structured_output",
41
+ "temperature",
42
+ ],
43
+ providers: ["openai", "azure"],
44
+ };
45
+ const EMBEDDINGS_BASE = {
46
+ modalities: {
47
+ input: ["text"],
48
+ output: ["embedding"],
49
+ },
50
+ providers: ["openai", "azure"],
51
+ };
52
+ export const gpt5 = presetFor()("openai/gpt-5", {
53
+ ...GPT_BASE,
54
+ name: "GPT-5",
55
+ created: "2025-08-07",
56
+ knowledge: "2024-09",
57
+ context: 400000,
58
+ });
59
+ export const gpt5Pro = presetFor()("openai/gpt-5-pro", {
60
+ ...GPT_PRO_BASE,
61
+ name: "GPT-5 Pro",
62
+ created: "2025-10-06",
63
+ knowledge: "2024-09",
64
+ context: 400000,
65
+ });
66
+ export const gpt5Mini = presetFor()("openai/gpt-5-mini", {
67
+ ...GPT_BASE,
68
+ name: "GPT-5 Mini",
69
+ created: "2025-08-07",
70
+ knowledge: "2024-05",
71
+ context: 400000,
72
+ });
73
+ export const gpt5Nano = presetFor()("openai/gpt-5-nano", {
74
+ ...GPT_BASE,
75
+ name: "GPT-5 Nano",
76
+ created: "2025-08-07",
77
+ knowledge: "2024-05",
78
+ context: 400000,
79
+ });
80
+ export const gpt51 = presetFor()("openai/gpt-5.1", {
81
+ ...GPT_BASE,
82
+ name: "GPT-5.1",
83
+ created: "2025-11-13",
84
+ knowledge: "2024-09",
85
+ context: 400000,
86
+ });
87
+ export const gpt51Chat = presetFor()("openai/gpt-5.1-chat", {
88
+ ...GPT_BASE,
89
+ name: "GPT-5.1 Chat",
90
+ created: "2025-11-13",
91
+ knowledge: "2024-09",
92
+ context: 128000,
93
+ });
94
+ export const gpt51Codex = presetFor()("openai/gpt-5.1-codex", {
95
+ ...GPT_BASE,
96
+ name: "GPT-5.1 Codex",
97
+ created: "2025-11-13",
98
+ knowledge: "2024-09",
99
+ context: 400000,
100
+ });
101
+ export const gpt51CodexMax = presetFor()("openai/gpt-5.1-codex-max", {
102
+ ...GPT_BASE,
103
+ name: "GPT-5.1 Codex Max",
104
+ created: "2025-11-19",
105
+ knowledge: "2024-09",
106
+ context: 400000,
107
+ });
108
+ export const gpt51CodexMini = presetFor()("openai/gpt-5.1-codex-mini", {
109
+ ...GPT_BASE,
110
+ name: "GPT-5.1 Codex Mini",
111
+ created: "2025-11-13",
112
+ knowledge: "2024-09",
113
+ context: 400000,
114
+ });
115
+ export const gpt5Codex = presetFor()("openai/gpt-5-codex", {
116
+ ...GPT_BASE,
117
+ name: "GPT-5 Codex",
118
+ created: "2025-09-15",
119
+ knowledge: "2024-09",
120
+ context: 400000,
121
+ });
122
+ export const gpt52 = presetFor()("openai/gpt-5.2", {
123
+ ...GPT_BASE,
124
+ name: "GPT-5.2",
125
+ created: "2025-12-11",
126
+ knowledge: "2025-08",
127
+ context: 400000,
128
+ });
129
+ export const gpt52Chat = presetFor()("openai/gpt-5.2-chat", {
130
+ ...GPT_BASE,
131
+ name: "GPT-5.2 Chat",
132
+ created: "2025-12-11",
133
+ knowledge: "2025-08",
134
+ context: 128000,
135
+ });
136
+ export const gpt52Pro = presetFor()("openai/gpt-5.2-pro", {
137
+ ...GPT_PRO_BASE,
138
+ name: "GPT-5.2 Pro",
139
+ created: "2025-12-11",
140
+ knowledge: "2025-08",
141
+ context: 400000,
142
+ });
143
+ export const gpt52Codex = presetFor()("openai/gpt-5.2-codex", {
144
+ ...GPT_BASE,
145
+ name: "GPT-5.2 Codex",
146
+ created: "2025-12-18",
147
+ knowledge: "2025-08",
148
+ });
149
+ export const gpt53Codex = presetFor()("openai/gpt-5.3-codex", {
150
+ ...GPT_BASE,
151
+ name: "GPT-5.3 Codex",
152
+ created: "2026-02-05",
153
+ knowledge: "2025-08",
154
+ });
155
+ export const gpt53CodexSpark = presetFor()("openai/gpt-5.3-codex-spark", {
156
+ ...GPT_BASE,
157
+ name: "GPT-5.3 Codex Spark",
158
+ created: "2026-02-05",
159
+ knowledge: "2025-08",
160
+ context: 128000,
161
+ });
162
+ export const gpt53Chat = presetFor()("openai/gpt-5.3-chat", {
163
+ ...GPT_BASE,
164
+ name: "GPT-5.3 Chat",
165
+ created: "2026-03-03",
166
+ knowledge: "2025-08",
167
+ context: 128000,
168
+ });
169
+ export const gpt54 = presetFor()("openai/gpt-5.4", {
170
+ ...GPT_BASE,
171
+ name: "GPT-5.4",
172
+ created: "2026-03-05",
173
+ knowledge: "2025-08",
174
+ context: 1050000,
175
+ });
176
+ export const gpt54Mini = presetFor()("openai/gpt-5.4-mini", {
177
+ ...GPT_BASE,
178
+ name: "GPT-5.4 Mini",
179
+ created: "2026-03-17",
180
+ knowledge: "2025-08",
181
+ context: 400000,
182
+ });
183
+ export const gpt54Nano = presetFor()("openai/gpt-5.4-nano", {
184
+ ...GPT_BASE,
185
+ name: "GPT-5.4 Nano",
186
+ created: "2026-03-17",
187
+ knowledge: "2025-08",
188
+ context: 400000,
189
+ });
190
+ export const gpt54Pro = presetFor()("openai/gpt-5.4-pro", {
191
+ ...GPT_PRO_BASE,
192
+ name: "GPT-5.4 Pro",
193
+ created: "2026-03-05",
194
+ knowledge: "2025-08",
195
+ context: 1050000,
196
+ });
197
+ export const textEmbedding3Small = presetFor()("openai/text-embedding-3-small", {
198
+ ...EMBEDDINGS_BASE,
199
+ name: "Text Embedding 3 Small",
200
+ created: "2024-01-25",
201
+ context: 8192,
202
+ });
203
+ export const textEmbedding3Large = presetFor()("openai/text-embedding-3-large", {
204
+ ...EMBEDDINGS_BASE,
205
+ name: "Text Embedding 3 Large",
206
+ created: "2024-01-25",
207
+ context: 8192,
208
+ });
209
+ export const gptOss20b = presetFor()("openai/gpt-oss-20b", {
210
+ ...GPT_OSS_BASE,
211
+ name: "GPT-OSS 20B",
212
+ created: "2025-08-05",
213
+ knowledge: "2024-06",
214
+ });
215
+ export const gptOss120b = presetFor()("openai/gpt-oss-120b", {
216
+ ...GPT_OSS_BASE,
217
+ name: "GPT-OSS 120B",
218
+ created: "2025-08-05",
219
+ knowledge: "2024-06",
220
+ });
221
+ const gptOssAtomic = {
222
+ v1: [gptOss20b, gptOss120b],
223
+ };
224
+ const gptOssGroups = {
225
+ "v1.x": [...gptOssAtomic["v1"]],
226
+ };
227
+ const gptAtomic = {
228
+ v5: [gpt5, gpt5Mini, gpt5Nano, gpt5Pro],
229
+ "v5.1": [gpt51, gpt51Chat, gpt51Codex, gpt51CodexMax, gpt51CodexMini],
230
+ "v5.2": [gpt52, gpt52Chat, gpt52Pro, gpt52Codex],
231
+ "v5.3": [gpt53Codex, gpt53CodexSpark, gpt53Chat],
232
+ "v5.4": [gpt54, gpt54Mini, gpt54Nano, gpt54Pro],
233
+ codex: [
234
+ gpt5Codex,
235
+ gpt51Codex,
236
+ gpt51CodexMax,
237
+ gpt51CodexMini,
238
+ gpt52Codex,
239
+ gpt53Codex,
240
+ gpt53CodexSpark,
241
+ ],
242
+ chat: [gpt51Chat, gpt52Chat, gpt53Chat],
243
+ pro: [gpt5Pro, gpt52Pro, gpt54Pro],
244
+ };
245
+ const gptGroups = {
246
+ "v5.x": [
247
+ ...gptAtomic["v5"],
248
+ ...gptAtomic["v5.1"],
249
+ ...gptAtomic["v5.2"],
250
+ ...gptAtomic["v5.3"],
251
+ ...gptAtomic["v5.4"],
252
+ ],
253
+ };
254
+ const textEmbeddingsAtomic = {
255
+ v3: [textEmbedding3Small, textEmbedding3Large],
256
+ };
257
+ const textEmbeddingsGroups = {
258
+ "v3.x": [...textEmbeddingsAtomic["v3"]],
259
+ };
260
+ export const gptOss = {
261
+ ...gptOssAtomic,
262
+ ...gptOssGroups,
263
+ latest: [...gptOssAtomic["v1"]],
264
+ all: Object.values(gptOssAtomic).flat(),
265
+ };
266
+ export const gpt = {
267
+ ...gptAtomic,
268
+ ...gptGroups,
269
+ latest: [gpt54, gpt54Mini, gpt54Nano],
270
+ all: Object.values(gptAtomic).flat(),
271
+ };
272
+ export const textEmbeddings = {
273
+ ...textEmbeddingsAtomic,
274
+ ...textEmbeddingsGroups,
275
+ latest: [...textEmbeddingsAtomic["v3"]],
276
+ all: Object.values(textEmbeddingsAtomic).flat(),
277
+ };
@@ -0,0 +1,20 @@
1
+ import type { ProviderId } from "../providers/types";
2
+ export declare const CANONICAL_MODEL_IDS: readonly ["anthropic/claude-opus-4.6", "anthropic/claude-sonnet-4.6", "anthropic/claude-haiku-4.5", "anthropic/claude-sonnet-4.5", "anthropic/claude-opus-4.5", "anthropic/claude-opus-4.1", "anthropic/claude-opus-4", "anthropic/claude-sonnet-4", "anthropic/claude-sonnet-3.7", "anthropic/claude-sonnet-3.5", "anthropic/claude-haiku-3.5", "anthropic/claude-haiku-3", "openai/gpt-oss-20b", "openai/gpt-oss-120b", "openai/gpt-5", "openai/gpt-5-pro", "openai/gpt-5.2", "openai/gpt-5.2-chat", "openai/gpt-5.2-pro", "openai/gpt-5.2-codex", "openai/gpt-5.3-codex", "openai/gpt-5.3-codex-spark", "openai/gpt-5.3-chat", "openai/gpt-5.4", "openai/gpt-5.4-mini", "openai/gpt-5.4-nano", "openai/gpt-5.4-pro", "openai/gpt-5-mini", "openai/gpt-5-nano", "openai/gpt-5-codex", "openai/gpt-5.1-codex", "openai/gpt-5.1-codex-max", "openai/gpt-5.1-codex-mini", "openai/gpt-5.1-chat", "openai/gpt-5.1", "openai/text-embedding-3-small", "openai/text-embedding-3-large", "amazon/nova-micro", "amazon/nova-lite", "amazon/nova-pro", "amazon/nova-premier", "amazon/nova-2-lite", "amazon/nova-2-multimodal-embeddings", "google/gemini-2.5-flash-lite", "google/gemini-2.5-flash", "google/gemini-2.5-pro", "google/gemini-3-flash-preview", "google/gemini-3.1-flash-lite-preview", "google/gemini-3.1-pro-preview", "google/gemini-embedding-2-preview", "google/embedding-001", "google/gemma-3-1b", "google/gemma-3-4b", "google/gemma-3-12b", "google/gemma-3-27b", "google/gemma-4-e2b", "google/gemma-4-e4b", "google/gemma-4-26b-a4b", "google/gemma-4-31b", "meta/llama-3.1-8b", "meta/llama-3.1-70b", "meta/llama-3.1-405b", "meta/llama-3.2-1b", "meta/llama-3.2-3b", "meta/llama-3.2-11b", "meta/llama-3.2-90b", "meta/llama-3.3-70b", "meta/llama-4-scout", "meta/llama-4-maverick", "cohere/embed-v4.0", "cohere/embed-english-v3.0", "cohere/embed-english-light-v3.0", "cohere/embed-multilingual-v3.0", "cohere/embed-multilingual-light-v3.0", "cohere/command-a", "cohere/command-r7b", "cohere/command-a-translate", "cohere/command-a-reasoning", "cohere/command-a-vision", "cohere/command-r", "cohere/command-r-plus", "voyage/voyage-2-code", "voyage/voyage-2-law", "voyage/voyage-2-finance", "voyage/voyage-3-code", "voyage/voyage-3-large", "voyage/voyage-3.5-lite", "voyage/voyage-3.5", "voyage/voyage-4-lite", "voyage/voyage-4", "voyage/voyage-4-large"];
3
+ export type CanonicalModelId = (typeof CANONICAL_MODEL_IDS)[number];
4
+ export type ModelId = CanonicalModelId | (string & {});
5
+ export type CatalogModel = {
6
+ name?: string;
7
+ created?: string;
8
+ knowledge?: string;
9
+ modalities?: {
10
+ input: readonly ("text" | "image" | "file" | "audio" | "video" | "pdf")[];
11
+ output: readonly ("text" | "image" | "audio" | "video" | "embedding")[];
12
+ };
13
+ context?: number;
14
+ capabilities?: readonly ("attachments" | "reasoning" | "tool_call" | "structured_output" | "temperature")[];
15
+ providers: readonly ProviderId[];
16
+ additionalProperties?: Record<string, unknown>;
17
+ };
18
+ export type ModelCatalog = {
19
+ [K in ModelId]?: CatalogModel;
20
+ };
@@ -0,0 +1,100 @@
1
+ export const CANONICAL_MODEL_IDS = [
2
+ // Anthropic
3
+ "anthropic/claude-opus-4.6",
4
+ "anthropic/claude-sonnet-4.6",
5
+ "anthropic/claude-haiku-4.5",
6
+ "anthropic/claude-sonnet-4.5",
7
+ "anthropic/claude-opus-4.5",
8
+ "anthropic/claude-opus-4.1",
9
+ "anthropic/claude-opus-4",
10
+ "anthropic/claude-sonnet-4",
11
+ "anthropic/claude-sonnet-3.7",
12
+ "anthropic/claude-sonnet-3.5",
13
+ "anthropic/claude-haiku-3.5",
14
+ "anthropic/claude-haiku-3",
15
+ // OpenAI
16
+ "openai/gpt-oss-20b",
17
+ "openai/gpt-oss-120b",
18
+ "openai/gpt-5",
19
+ "openai/gpt-5-pro",
20
+ "openai/gpt-5.2",
21
+ "openai/gpt-5.2-chat",
22
+ "openai/gpt-5.2-pro",
23
+ "openai/gpt-5.2-codex",
24
+ "openai/gpt-5.3-codex",
25
+ "openai/gpt-5.3-codex-spark",
26
+ "openai/gpt-5.3-chat",
27
+ "openai/gpt-5.4",
28
+ "openai/gpt-5.4-mini",
29
+ "openai/gpt-5.4-nano",
30
+ "openai/gpt-5.4-pro",
31
+ "openai/gpt-5-mini",
32
+ "openai/gpt-5-nano",
33
+ "openai/gpt-5-codex",
34
+ "openai/gpt-5.1-codex",
35
+ "openai/gpt-5.1-codex-max",
36
+ "openai/gpt-5.1-codex-mini",
37
+ "openai/gpt-5.1-chat",
38
+ "openai/gpt-5.1",
39
+ "openai/text-embedding-3-small",
40
+ "openai/text-embedding-3-large",
41
+ // Amazon
42
+ "amazon/nova-micro",
43
+ "amazon/nova-lite",
44
+ "amazon/nova-pro",
45
+ "amazon/nova-premier",
46
+ "amazon/nova-2-lite",
47
+ "amazon/nova-2-multimodal-embeddings",
48
+ // Google
49
+ "google/gemini-2.5-flash-lite",
50
+ "google/gemini-2.5-flash",
51
+ "google/gemini-2.5-pro",
52
+ "google/gemini-3-flash-preview",
53
+ "google/gemini-3.1-flash-lite-preview",
54
+ "google/gemini-3.1-pro-preview",
55
+ "google/gemini-embedding-2-preview",
56
+ "google/embedding-001",
57
+ "google/gemma-3-1b",
58
+ "google/gemma-3-4b",
59
+ "google/gemma-3-12b",
60
+ "google/gemma-3-27b",
61
+ "google/gemma-4-e2b",
62
+ "google/gemma-4-e4b",
63
+ "google/gemma-4-26b-a4b",
64
+ "google/gemma-4-31b",
65
+ // Meta
66
+ "meta/llama-3.1-8b",
67
+ "meta/llama-3.1-70b",
68
+ "meta/llama-3.1-405b",
69
+ "meta/llama-3.2-1b",
70
+ "meta/llama-3.2-3b",
71
+ "meta/llama-3.2-11b",
72
+ "meta/llama-3.2-90b",
73
+ "meta/llama-3.3-70b",
74
+ "meta/llama-4-scout",
75
+ "meta/llama-4-maverick",
76
+ // Cohere
77
+ "cohere/embed-v4.0",
78
+ "cohere/embed-english-v3.0",
79
+ "cohere/embed-english-light-v3.0",
80
+ "cohere/embed-multilingual-v3.0",
81
+ "cohere/embed-multilingual-light-v3.0",
82
+ "cohere/command-a",
83
+ "cohere/command-r7b",
84
+ "cohere/command-a-translate",
85
+ "cohere/command-a-reasoning",
86
+ "cohere/command-a-vision",
87
+ "cohere/command-r",
88
+ "cohere/command-r-plus",
89
+ // Voyage
90
+ "voyage/voyage-2-code",
91
+ "voyage/voyage-2-law",
92
+ "voyage/voyage-2-finance",
93
+ "voyage/voyage-3-code",
94
+ "voyage/voyage-3-large",
95
+ "voyage/voyage-3.5-lite",
96
+ "voyage/voyage-3.5",
97
+ "voyage/voyage-4-lite",
98
+ "voyage/voyage-4",
99
+ "voyage/voyage-4-large",
100
+ ];
@@ -0,0 +1,2 @@
1
+ export * from "./middleware";
2
+ export * from "./presets";
@@ -0,0 +1,2 @@
1
+ export * from "./middleware";
2
+ export * from "./presets";
@@ -0,0 +1,2 @@
1
+ import type { EmbeddingModelMiddleware } from "ai";
2
+ export declare const voyageDimensionsMiddleware: EmbeddingModelMiddleware;
@@ -0,0 +1,19 @@
1
+ import { modelMiddlewareMatcher } from "../../middleware/matcher";
2
+ // Convert `dimensions` (OpenAI) to `outputDimension` (Voyage)
3
+ export const voyageDimensionsMiddleware = {
4
+ specificationVersion: "v3",
5
+ // oxlint-disable-next-line require-await
6
+ transformParams: async ({ params }) => {
7
+ const unknown = params.providerOptions?.["unknown"];
8
+ if (!unknown)
9
+ return params;
10
+ const dimensions = unknown["dimensions"];
11
+ if (!dimensions)
12
+ return params;
13
+ const target = (params.providerOptions["voyage"] ??= {});
14
+ target.outputDimension = dimensions;
15
+ delete unknown["dimensions"];
16
+ return params;
17
+ },
18
+ };
19
+ modelMiddlewareMatcher.useForModel("voyage/*", { embedding: [voyageDimensionsMiddleware] });