@hebo-ai/gateway 0.1.2 → 0.2.0

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 (202) hide show
  1. package/README.md +172 -67
  2. package/dist/config.js +2 -12
  3. package/dist/endpoints/chat-completions/converters.d.ts +28 -24
  4. package/dist/endpoints/chat-completions/converters.js +99 -73
  5. package/dist/endpoints/chat-completions/handler.js +36 -30
  6. package/dist/endpoints/chat-completions/schema.d.ts +394 -272
  7. package/dist/endpoints/chat-completions/schema.js +124 -57
  8. package/dist/endpoints/embeddings/converters.d.ts +4 -4
  9. package/dist/endpoints/embeddings/converters.js +8 -9
  10. package/dist/endpoints/embeddings/handler.js +32 -26
  11. package/dist/endpoints/embeddings/schema.d.ts +28 -38
  12. package/dist/endpoints/embeddings/schema.js +10 -10
  13. package/dist/endpoints/models/converters.d.ts +2 -2
  14. package/dist/endpoints/models/converters.js +9 -12
  15. package/dist/endpoints/models/handler.js +8 -9
  16. package/dist/endpoints/models/schema.d.ts +37 -31
  17. package/dist/endpoints/models/schema.js +23 -12
  18. package/dist/gateway.d.ts +8 -9
  19. package/dist/gateway.js +7 -10
  20. package/dist/index.d.ts +2 -0
  21. package/dist/index.js +2 -0
  22. package/dist/lifecycle.d.ts +2 -0
  23. package/dist/{utils/hooks.js → lifecycle.js} +16 -8
  24. package/dist/middleware/common.d.ts +4 -0
  25. package/dist/middleware/common.js +44 -0
  26. package/dist/middleware/matcher.d.ts +18 -0
  27. package/dist/middleware/matcher.js +83 -0
  28. package/dist/models/amazon/index.d.ts +2 -0
  29. package/dist/models/amazon/index.js +2 -0
  30. package/dist/models/amazon/middleware.d.ts +2 -0
  31. package/dist/models/amazon/middleware.js +20 -0
  32. package/dist/models/amazon/presets.d.ts +2390 -0
  33. package/dist/models/amazon/presets.js +80 -0
  34. package/dist/models/anthropic/index.d.ts +2 -0
  35. package/dist/models/anthropic/index.js +2 -0
  36. package/dist/models/anthropic/middleware.d.ts +5 -0
  37. package/dist/models/anthropic/middleware.js +67 -0
  38. package/dist/models/anthropic/presets.d.ts +4106 -0
  39. package/dist/models/anthropic/presets.js +113 -0
  40. package/dist/models/catalog.d.ts +3 -1
  41. package/dist/models/catalog.js +3 -2
  42. package/dist/models/cohere/index.d.ts +2 -0
  43. package/dist/models/cohere/index.js +2 -0
  44. package/dist/models/cohere/middleware.d.ts +2 -0
  45. package/dist/models/cohere/middleware.js +18 -0
  46. package/dist/models/cohere/presets.d.ts +2918 -0
  47. package/dist/models/cohere/presets.js +129 -0
  48. package/dist/models/google/index.d.ts +2 -0
  49. package/dist/models/google/index.js +2 -0
  50. package/dist/models/google/middleware.d.ts +2 -0
  51. package/dist/models/google/middleware.js +20 -0
  52. package/dist/models/{presets/gemini.d.ts → google/presets.d.ts} +400 -174
  53. package/dist/models/{presets/gemini.js → google/presets.js} +20 -5
  54. package/dist/models/meta/index.d.ts +1 -0
  55. package/dist/models/meta/index.js +1 -0
  56. package/dist/models/meta/presets.d.ts +3254 -0
  57. package/dist/models/{presets/llama.js → meta/presets.js} +44 -7
  58. package/dist/models/openai/index.d.ts +2 -0
  59. package/dist/models/openai/index.js +2 -0
  60. package/dist/models/openai/middleware.d.ts +2 -0
  61. package/dist/models/openai/middleware.js +20 -0
  62. package/dist/models/openai/presets.d.ts +6252 -0
  63. package/dist/models/openai/presets.js +206 -0
  64. package/dist/models/types.d.ts +3 -3
  65. package/dist/models/types.js +27 -0
  66. package/dist/models/voyage/index.d.ts +2 -0
  67. package/dist/models/voyage/index.js +2 -0
  68. package/dist/models/voyage/middleware.d.ts +2 -0
  69. package/dist/models/voyage/middleware.js +18 -0
  70. package/dist/models/{presets/voyage.d.ts → voyage/presets.d.ts} +322 -323
  71. package/dist/providers/anthropic/canonical.d.ts +3 -0
  72. package/dist/providers/anthropic/canonical.js +9 -0
  73. package/dist/providers/anthropic/index.d.ts +1 -0
  74. package/dist/providers/anthropic/index.js +1 -0
  75. package/dist/providers/bedrock/canonical.d.ts +15 -0
  76. package/dist/providers/{canonical/bedrock.js → bedrock/canonical.js} +13 -15
  77. package/dist/providers/bedrock/index.d.ts +1 -0
  78. package/dist/providers/bedrock/index.js +1 -0
  79. package/dist/providers/cohere/canonical.d.ts +3 -0
  80. package/dist/providers/{canonical/cohere.js → cohere/canonical.js} +6 -6
  81. package/dist/providers/cohere/index.d.ts +1 -0
  82. package/dist/providers/cohere/index.js +1 -0
  83. package/dist/providers/groq/canonical.d.ts +3 -0
  84. package/dist/providers/groq/canonical.js +12 -0
  85. package/dist/providers/groq/index.d.ts +1 -0
  86. package/dist/providers/groq/index.js +1 -0
  87. package/dist/providers/openai/canonical.d.ts +3 -0
  88. package/dist/providers/openai/canonical.js +8 -0
  89. package/dist/providers/openai/index.d.ts +1 -0
  90. package/dist/providers/openai/index.js +1 -0
  91. package/dist/providers/registry.d.ts +16 -26
  92. package/dist/providers/registry.js +19 -26
  93. package/dist/providers/types.d.ts +1 -1
  94. package/dist/providers/types.js +1 -0
  95. package/dist/providers/vertex/canonical.d.ts +3 -0
  96. package/dist/providers/vertex/canonical.js +8 -0
  97. package/dist/providers/vertex/index.d.ts +1 -0
  98. package/dist/providers/vertex/index.js +1 -0
  99. package/dist/providers/voyage/canonical.d.ts +3 -0
  100. package/dist/providers/voyage/canonical.js +7 -0
  101. package/dist/providers/voyage/index.d.ts +1 -0
  102. package/dist/providers/voyage/index.js +1 -0
  103. package/dist/types.d.ts +60 -30
  104. package/dist/utils/errors.js +2 -0
  105. package/dist/utils/preset.d.ts +1 -7
  106. package/dist/utils/preset.js +1 -1
  107. package/dist/utils/response.d.ts +1 -0
  108. package/dist/utils/response.js +10 -0
  109. package/package.json +79 -70
  110. package/src/config.ts +2 -18
  111. package/src/endpoints/chat-completions/converters.test.ts +39 -0
  112. package/src/endpoints/chat-completions/converters.ts +191 -112
  113. package/src/endpoints/chat-completions/handler.test.ts +47 -18
  114. package/src/endpoints/chat-completions/handler.ts +40 -34
  115. package/src/endpoints/chat-completions/schema.ts +161 -88
  116. package/src/endpoints/embeddings/converters.ts +15 -11
  117. package/src/endpoints/embeddings/handler.test.ts +27 -30
  118. package/src/endpoints/embeddings/handler.ts +34 -28
  119. package/src/endpoints/embeddings/schema.ts +10 -10
  120. package/src/endpoints/models/converters.ts +22 -14
  121. package/src/endpoints/models/handler.test.ts +26 -29
  122. package/src/endpoints/models/handler.ts +10 -12
  123. package/src/endpoints/models/schema.ts +26 -20
  124. package/src/gateway.ts +10 -24
  125. package/src/index.ts +3 -0
  126. package/src/{utils/hooks.ts → lifecycle.ts} +21 -11
  127. package/src/middleware/common.ts +68 -0
  128. package/src/middleware/matcher.ts +117 -0
  129. package/src/models/amazon/index.ts +2 -0
  130. package/src/models/amazon/middleware.ts +25 -0
  131. package/src/models/amazon/presets.ts +104 -0
  132. package/src/models/anthropic/index.ts +2 -0
  133. package/src/models/anthropic/middleware.test.ts +184 -0
  134. package/src/models/anthropic/middleware.ts +75 -0
  135. package/src/models/anthropic/presets.ts +161 -0
  136. package/src/models/catalog.ts +10 -2
  137. package/src/models/cohere/index.ts +2 -0
  138. package/src/models/cohere/middleware.ts +23 -0
  139. package/src/models/cohere/presets.ts +181 -0
  140. package/src/models/google/index.ts +2 -0
  141. package/src/models/google/middleware.ts +25 -0
  142. package/src/models/{presets/gemini.ts → google/presets.ts} +25 -5
  143. package/src/models/meta/index.ts +1 -0
  144. package/src/models/{presets/llama.ts → meta/presets.ts} +68 -7
  145. package/src/models/openai/index.ts +2 -0
  146. package/src/models/openai/middleware.ts +25 -0
  147. package/src/models/openai/presets.ts +269 -0
  148. package/src/models/types.ts +29 -2
  149. package/src/models/voyage/index.ts +2 -0
  150. package/src/models/voyage/middleware.ts +23 -0
  151. package/src/providers/anthropic/canonical.ts +17 -0
  152. package/src/providers/anthropic/index.ts +1 -0
  153. package/src/providers/{canonical/bedrock.ts → bedrock/canonical.ts} +22 -32
  154. package/src/providers/bedrock/index.ts +1 -0
  155. package/src/providers/cohere/canonical.ts +26 -0
  156. package/src/providers/cohere/index.ts +1 -0
  157. package/src/providers/groq/canonical.ts +21 -0
  158. package/src/providers/groq/index.ts +1 -0
  159. package/src/providers/openai/canonical.ts +16 -0
  160. package/src/providers/openai/index.ts +1 -0
  161. package/src/providers/registry.test.ts +12 -10
  162. package/src/providers/registry.ts +43 -43
  163. package/src/providers/types.ts +1 -0
  164. package/src/providers/vertex/canonical.ts +17 -0
  165. package/src/providers/vertex/index.ts +1 -0
  166. package/src/providers/voyage/canonical.ts +16 -0
  167. package/src/providers/voyage/index.ts +1 -0
  168. package/src/types.ts +64 -28
  169. package/src/utils/errors.ts +2 -0
  170. package/src/utils/preset.ts +2 -6
  171. package/src/utils/response.ts +15 -0
  172. package/dist/models/presets/claude.d.ts +0 -1165
  173. package/dist/models/presets/claude.js +0 -40
  174. package/dist/models/presets/cohere.d.ts +0 -383
  175. package/dist/models/presets/cohere.js +0 -26
  176. package/dist/models/presets/gpt-oss.d.ts +0 -779
  177. package/dist/models/presets/gpt-oss.js +0 -40
  178. package/dist/models/presets/llama.d.ts +0 -1400
  179. package/dist/providers/canonical/anthropic.d.ts +0 -25
  180. package/dist/providers/canonical/anthropic.js +0 -14
  181. package/dist/providers/canonical/bedrock.d.ts +0 -26
  182. package/dist/providers/canonical/cohere.d.ts +0 -17
  183. package/dist/providers/canonical/groq.d.ts +0 -17
  184. package/dist/providers/canonical/groq.js +0 -10
  185. package/dist/providers/canonical/openai.d.ts +0 -17
  186. package/dist/providers/canonical/openai.js +0 -8
  187. package/dist/providers/canonical/vertex.d.ts +0 -17
  188. package/dist/providers/canonical/vertex.js +0 -10
  189. package/dist/providers/canonical/voyage.d.ts +0 -17
  190. package/dist/providers/canonical/voyage.js +0 -8
  191. package/dist/utils/hooks.d.ts +0 -2
  192. package/src/models/presets/claude.ts +0 -59
  193. package/src/models/presets/cohere.ts +0 -37
  194. package/src/models/presets/gpt-oss.ts +0 -55
  195. package/src/providers/canonical/anthropic.ts +0 -32
  196. package/src/providers/canonical/cohere.ts +0 -36
  197. package/src/providers/canonical/groq.ts +0 -25
  198. package/src/providers/canonical/openai.ts +0 -16
  199. package/src/providers/canonical/vertex.ts +0 -18
  200. package/src/providers/canonical/voyage.ts +0 -16
  201. package/dist/models/{presets/voyage.js → voyage/presets.js} +10 -10
  202. package/src/models/{presets/voyage.ts → voyage/presets.ts} +10 -10
@@ -0,0 +1,206 @@
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: ["embeddings"],
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 gpt5Codex = presetFor()("openai/gpt-5-codex", {
109
+ ...GPT_BASE,
110
+ name: "GPT-5 Codex",
111
+ created: "2025-09-15",
112
+ knowledge: "2024-09",
113
+ context: 400000,
114
+ });
115
+ export const gpt52 = presetFor()("openai/gpt-5.2", {
116
+ ...GPT_BASE,
117
+ name: "GPT-5.2",
118
+ created: "2025-12-11",
119
+ knowledge: "2025-08",
120
+ context: 400000,
121
+ });
122
+ export const gpt52Chat = presetFor()("openai/gpt-5.2-chat", {
123
+ ...GPT_BASE,
124
+ name: "GPT-5.2 Chat",
125
+ created: "2025-12-11",
126
+ knowledge: "2025-08",
127
+ context: 128000,
128
+ });
129
+ export const gpt52Pro = presetFor()("openai/gpt-5.2-pro", {
130
+ ...GPT_PRO_BASE,
131
+ name: "GPT-5.2 Pro",
132
+ created: "2025-12-11",
133
+ knowledge: "2025-08",
134
+ context: 400000,
135
+ });
136
+ export const gpt52Codex = presetFor()("openai/gpt-5.2-codex", {
137
+ ...GPT_BASE,
138
+ name: "GPT-5.2 Codex",
139
+ created: "2025-12-18",
140
+ knowledge: "2025-08",
141
+ });
142
+ export const textEmbedding3Small = presetFor()("openai/text-embedding-3-small", {
143
+ ...EMBEDDINGS_BASE,
144
+ name: "Text Embedding 3 Small",
145
+ created: "2024-01-25",
146
+ context: 8192,
147
+ });
148
+ export const textEmbedding3Large = presetFor()("openai/text-embedding-3-large", {
149
+ ...EMBEDDINGS_BASE,
150
+ name: "Text Embedding 3 Large",
151
+ created: "2024-01-25",
152
+ context: 8192,
153
+ });
154
+ export const gptOss20b = presetFor()("openai/gpt-oss-20b", {
155
+ ...GPT_OSS_BASE,
156
+ name: "GPT-OSS 20B",
157
+ created: "2025-08-05",
158
+ knowledge: "2024-06",
159
+ });
160
+ export const gptOss120b = presetFor()("openai/gpt-oss-120b", {
161
+ ...GPT_OSS_BASE,
162
+ name: "GPT-OSS 120B",
163
+ created: "2025-08-05",
164
+ knowledge: "2024-06",
165
+ });
166
+ const gptOssAtomic = {
167
+ v1: [gptOss20b, gptOss120b],
168
+ };
169
+ const gptOssGroups = {
170
+ "v1.x": [...gptOssAtomic["v1"]],
171
+ };
172
+ const gptAtomic = {
173
+ v5: [gpt5, gpt5Mini, gpt5Nano, gpt5Pro],
174
+ "v5.1": [gpt51, gpt51Chat, gpt51Codex, gpt51CodexMax],
175
+ "v5.2": [gpt52, gpt52Chat, gpt52Pro, gpt52Codex],
176
+ codex: [gpt5Codex, gpt51Codex, gpt51CodexMax, gpt52Codex],
177
+ chat: [gpt51Chat, gpt52Chat],
178
+ pro: [gpt5Pro, gpt52Pro],
179
+ };
180
+ const gptGroups = {
181
+ "v5.x": [...gptAtomic["v5"], ...gptAtomic["v5.1"], ...gptAtomic["v5.2"]],
182
+ };
183
+ const textEmbeddingsAtomic = {
184
+ v3: [textEmbedding3Small, textEmbedding3Large],
185
+ };
186
+ const textEmbeddingsGroups = {
187
+ "v3.x": [...textEmbeddingsAtomic["v3"]],
188
+ };
189
+ export const gptOss = {
190
+ ...gptOssAtomic,
191
+ ...gptOssGroups,
192
+ latest: [...gptOssAtomic["v1"]],
193
+ all: Object.values(gptOssAtomic).flat(),
194
+ };
195
+ export const gpt = {
196
+ ...gptAtomic,
197
+ ...gptGroups,
198
+ latest: [gpt52, gpt5Mini, gpt5Nano],
199
+ all: Object.values(gptAtomic).flat(),
200
+ };
201
+ export const textEmbeddings = {
202
+ ...textEmbeddingsAtomic,
203
+ ...textEmbeddingsGroups,
204
+ latest: [...textEmbeddingsAtomic["v3"]],
205
+ all: Object.values(textEmbeddingsAtomic).flat(),
206
+ };
@@ -1,12 +1,12 @@
1
1
  import type { ProviderId } from "../providers/types";
2
- export declare const CANONICAL_MODEL_IDS: readonly ["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", "google/gemini-2.5-flash-lite", "google/gemini-2.5-flash", "google/gemini-2.5-pro", "google/gemini-3-flash-preview", "google/gemini-3-pro-preview", "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/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"];
2
+ export declare const CANONICAL_MODEL_IDS: readonly ["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-mini", "openai/gpt-5-nano", "openai/gpt-5-codex", "openai/gpt-5.1-codex", "openai/gpt-5.1-codex-max", "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-pro-preview", "google/embedding-001", "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
3
  export type CanonicalModelId = (typeof CANONICAL_MODEL_IDS)[number];
4
4
  export type ModelId = CanonicalModelId | (string & {});
5
5
  export type CatalogModel = {
6
- name: string;
6
+ name?: string;
7
7
  created?: string;
8
8
  knowledge?: string;
9
- modalities: {
9
+ modalities?: {
10
10
  input: readonly ("text" | "image" | "file" | "audio" | "video" | "pdf")[];
11
11
  output: readonly ("text" | "image" | "audio" | "video" | "embeddings")[];
12
12
  };
@@ -13,12 +13,35 @@ export const CANONICAL_MODEL_IDS = [
13
13
  // OpenAI
14
14
  "openai/gpt-oss-20b",
15
15
  "openai/gpt-oss-120b",
16
+ "openai/gpt-5",
17
+ "openai/gpt-5-pro",
18
+ "openai/gpt-5.2",
19
+ "openai/gpt-5.2-chat",
20
+ "openai/gpt-5.2-pro",
21
+ "openai/gpt-5.2-codex",
22
+ "openai/gpt-5-mini",
23
+ "openai/gpt-5-nano",
24
+ "openai/gpt-5-codex",
25
+ "openai/gpt-5.1-codex",
26
+ "openai/gpt-5.1-codex-max",
27
+ "openai/gpt-5.1-chat",
28
+ "openai/gpt-5.1",
29
+ "openai/text-embedding-3-small",
30
+ "openai/text-embedding-3-large",
31
+ // Amazon
32
+ "amazon/nova-micro",
33
+ "amazon/nova-lite",
34
+ "amazon/nova-pro",
35
+ "amazon/nova-premier",
36
+ "amazon/nova-2-lite",
37
+ "amazon/nova-2-multimodal-embeddings",
16
38
  // Google
17
39
  "google/gemini-2.5-flash-lite",
18
40
  "google/gemini-2.5-flash",
19
41
  "google/gemini-2.5-pro",
20
42
  "google/gemini-3-flash-preview",
21
43
  "google/gemini-3-pro-preview",
44
+ "google/embedding-001",
22
45
  // Meta
23
46
  "meta/llama-3.1-8b",
24
47
  "meta/llama-3.1-70b",
@@ -32,6 +55,10 @@ export const CANONICAL_MODEL_IDS = [
32
55
  "meta/llama-4-maverick",
33
56
  // Cohere
34
57
  "cohere/embed-v4.0",
58
+ "cohere/embed-english-v3.0",
59
+ "cohere/embed-english-light-v3.0",
60
+ "cohere/embed-multilingual-v3.0",
61
+ "cohere/embed-multilingual-light-v3.0",
35
62
  "cohere/command-a",
36
63
  "cohere/command-r7b",
37
64
  "cohere/command-a-translate",
@@ -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 voyageEmbeddingModelMiddleware: EmbeddingModelMiddleware;
@@ -0,0 +1,18 @@
1
+ import { modelMiddlewareMatcher } from "../../middleware/matcher";
2
+ // Convert `dimensions` (OpenAI) to `outputDimension` (Voyage)
3
+ export const voyageEmbeddingModelMiddleware = {
4
+ specificationVersion: "v3",
5
+ // eslint-disable-next-line require-await
6
+ transformParams: async ({ params }) => {
7
+ const unknown = params.providerOptions?.["unknown"];
8
+ if (!unknown)
9
+ return params;
10
+ let dimensions = unknown["dimensions"];
11
+ if (!dimensions)
12
+ dimensions = 1024;
13
+ (params.providerOptions["voyage"] ??= {})["outputDimension"] = dimensions;
14
+ delete unknown["dimensions"];
15
+ return params;
16
+ },
17
+ };
18
+ modelMiddlewareMatcher.useForModel("voyage/*", { embedding: voyageEmbeddingModelMiddleware });