@dexto/core 1.6.1 → 1.6.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.
- package/dist/agent/DextoAgent.cjs +54 -0
- package/dist/agent/DextoAgent.d.ts +12 -1
- package/dist/agent/DextoAgent.d.ts.map +1 -1
- package/dist/agent/DextoAgent.js +54 -0
- package/dist/agent/agent-options.d.ts +6 -1
- package/dist/agent/agent-options.d.ts.map +1 -1
- package/dist/events/index.d.ts +9 -1
- package/dist/events/index.d.ts.map +1 -1
- package/dist/llm/executor/provider-options.cjs +223 -28
- package/dist/llm/executor/provider-options.d.ts +3 -37
- package/dist/llm/executor/provider-options.d.ts.map +1 -1
- package/dist/llm/executor/provider-options.js +227 -27
- package/dist/llm/executor/stream-processor.cjs +54 -31
- package/dist/llm/executor/stream-processor.d.ts +9 -2
- package/dist/llm/executor/stream-processor.d.ts.map +1 -1
- package/dist/llm/executor/stream-processor.js +52 -29
- package/dist/llm/executor/turn-executor.cjs +63 -41
- package/dist/llm/executor/turn-executor.d.ts +2 -2
- package/dist/llm/executor/turn-executor.d.ts.map +1 -1
- package/dist/llm/executor/turn-executor.js +53 -31
- package/dist/llm/formatters/vercel.cjs +15 -3
- package/dist/llm/formatters/vercel.d.ts +1 -0
- package/dist/llm/formatters/vercel.d.ts.map +1 -1
- package/dist/llm/formatters/vercel.js +15 -3
- package/dist/llm/index.cjs +8 -0
- package/dist/llm/index.d.ts +2 -1
- package/dist/llm/index.d.ts.map +1 -1
- package/dist/llm/index.js +7 -0
- package/dist/llm/providers/local/schemas.d.ts +2 -2
- package/dist/llm/providers/openrouter-model-registry.cjs +66 -11
- package/dist/llm/providers/openrouter-model-registry.d.ts +26 -0
- package/dist/llm/providers/openrouter-model-registry.d.ts.map +1 -1
- package/dist/llm/providers/openrouter-model-registry.js +65 -11
- package/dist/{utils/user-info.cjs → llm/reasoning/anthropic-betas.cjs} +9 -8
- package/dist/llm/reasoning/anthropic-betas.d.ts +3 -0
- package/dist/llm/reasoning/anthropic-betas.d.ts.map +1 -0
- package/dist/llm/reasoning/anthropic-betas.js +7 -0
- package/dist/llm/reasoning/anthropic-thinking.cjs +79 -0
- package/dist/llm/reasoning/anthropic-thinking.d.ts +15 -0
- package/dist/llm/reasoning/anthropic-thinking.d.ts.map +1 -0
- package/dist/llm/reasoning/anthropic-thinking.js +52 -0
- package/dist/llm/reasoning/openai-reasoning-effort.cjs +86 -0
- package/dist/llm/reasoning/openai-reasoning-effort.d.ts +5 -0
- package/dist/llm/reasoning/openai-reasoning-effort.d.ts.map +1 -0
- package/dist/llm/reasoning/openai-reasoning-effort.js +61 -0
- package/dist/llm/reasoning/profile.cjs +113 -0
- package/dist/llm/reasoning/profile.d.ts +13 -0
- package/dist/llm/reasoning/profile.d.ts.map +1 -0
- package/dist/llm/reasoning/profile.js +92 -0
- package/dist/llm/reasoning/profiles/anthropic.cjs +61 -0
- package/dist/llm/reasoning/profiles/anthropic.d.ts +8 -0
- package/dist/llm/reasoning/profiles/anthropic.d.ts.map +1 -0
- package/dist/llm/reasoning/profiles/anthropic.js +45 -0
- package/dist/llm/reasoning/profiles/bedrock.cjs +54 -0
- package/dist/llm/reasoning/profiles/bedrock.d.ts +3 -0
- package/dist/llm/reasoning/profiles/bedrock.d.ts.map +1 -0
- package/dist/llm/reasoning/profiles/bedrock.js +36 -0
- package/dist/llm/reasoning/profiles/google.cjs +45 -0
- package/dist/llm/reasoning/profiles/google.d.ts +9 -0
- package/dist/llm/reasoning/profiles/google.d.ts.map +1 -0
- package/dist/llm/reasoning/profiles/google.js +21 -0
- package/dist/llm/reasoning/profiles/openai-compatible.cjs +39 -0
- package/dist/llm/reasoning/profiles/openai-compatible.d.ts +3 -0
- package/dist/llm/reasoning/profiles/openai-compatible.d.ts.map +1 -0
- package/dist/llm/reasoning/profiles/openai-compatible.js +16 -0
- package/dist/llm/reasoning/profiles/openai.cjs +41 -0
- package/dist/llm/reasoning/profiles/openai.d.ts +3 -0
- package/dist/llm/reasoning/profiles/openai.d.ts.map +1 -0
- package/dist/llm/reasoning/profiles/openai.js +18 -0
- package/dist/llm/reasoning/profiles/openrouter.cjs +83 -0
- package/dist/llm/reasoning/profiles/openrouter.d.ts +10 -0
- package/dist/llm/reasoning/profiles/openrouter.d.ts.map +1 -0
- package/dist/llm/reasoning/profiles/openrouter.js +59 -0
- package/dist/llm/reasoning/profiles/shared.cjs +80 -0
- package/dist/llm/reasoning/profiles/shared.d.ts +25 -0
- package/dist/llm/reasoning/profiles/shared.d.ts.map +1 -0
- package/dist/llm/reasoning/profiles/shared.js +53 -0
- package/dist/llm/reasoning/profiles/vertex.cjs +46 -0
- package/dist/llm/reasoning/profiles/vertex.d.ts +3 -0
- package/dist/llm/reasoning/profiles/vertex.d.ts.map +1 -0
- package/dist/llm/reasoning/profiles/vertex.js +23 -0
- package/dist/llm/registry/auto-update.cjs +18 -0
- package/dist/llm/registry/auto-update.d.ts.map +1 -1
- package/dist/llm/registry/auto-update.js +18 -0
- package/dist/llm/registry/index.cjs +126 -26
- package/dist/llm/registry/index.d.ts +48 -4
- package/dist/llm/registry/index.d.ts.map +1 -1
- package/dist/llm/registry/index.js +136 -28
- package/dist/llm/registry/models.generated.cjs +5198 -59
- package/dist/llm/registry/models.generated.d.ts +1893 -76
- package/dist/llm/registry/models.generated.d.ts.map +1 -1
- package/dist/llm/registry/models.generated.js +5196 -58
- package/dist/llm/registry/sync.cjs +72 -1
- package/dist/llm/registry/sync.d.ts +21 -1
- package/dist/llm/registry/sync.d.ts.map +1 -1
- package/dist/llm/registry/sync.js +72 -1
- package/dist/llm/resolver.cjs +13 -1
- package/dist/llm/resolver.d.ts.map +1 -1
- package/dist/llm/resolver.js +13 -1
- package/dist/llm/schemas.cjs +75 -14
- package/dist/llm/schemas.d.ts +80 -23
- package/dist/llm/schemas.d.ts.map +1 -1
- package/dist/llm/schemas.js +75 -14
- package/dist/llm/services/factory.cjs +55 -8
- package/dist/llm/services/factory.d.ts +1 -1
- package/dist/llm/services/factory.d.ts.map +1 -1
- package/dist/llm/services/factory.js +58 -8
- package/dist/llm/services/vercel.cjs +1 -1
- package/dist/llm/services/vercel.js +1 -1
- package/dist/llm/types.d.ts +9 -0
- package/dist/llm/types.d.ts.map +1 -1
- package/dist/prompts/index.cjs +9 -0
- package/dist/prompts/index.d.ts +1 -0
- package/dist/prompts/index.d.ts.map +1 -1
- package/dist/prompts/index.js +10 -0
- package/dist/prompts/prompt-manager.cjs +2 -0
- package/dist/prompts/prompt-manager.d.ts.map +1 -1
- package/dist/prompts/prompt-manager.js +2 -0
- package/dist/prompts/providers/config-prompt-provider.cjs +11 -1
- package/dist/prompts/providers/config-prompt-provider.d.ts.map +1 -1
- package/dist/prompts/providers/config-prompt-provider.js +11 -1
- package/dist/prompts/schemas.cjs +2 -2
- package/dist/prompts/schemas.js +2 -2
- package/dist/prompts/types.d.ts +6 -2
- package/dist/prompts/types.d.ts.map +1 -1
- package/dist/tools/confirmation/allowed-tools-provider/types.d.ts +1 -1
- package/dist/tools/tool-manager.cjs +88 -2
- package/dist/tools/tool-manager.d.ts +15 -1
- package/dist/tools/tool-manager.d.ts.map +1 -1
- package/dist/tools/tool-manager.js +88 -2
- package/dist/utils/service-initializer.d.ts +1 -0
- package/dist/utils/service-initializer.d.ts.map +1 -1
- package/package.json +7 -5
- package/dist/utils/schema-metadata.cjs +0 -235
- package/dist/utils/schema-metadata.d.ts +0 -82
- package/dist/utils/schema-metadata.d.ts.map +0 -1
- package/dist/utils/schema-metadata.js +0 -208
- package/dist/utils/user-info.d.ts +0 -2
- package/dist/utils/user-info.d.ts.map +0 -1
- package/dist/utils/user-info.js +0 -7
|
@@ -51,7 +51,7 @@ export declare const LocalModelInfoSchema: z.ZodObject<{
|
|
|
51
51
|
quantization: "Q2_K" | "Q3_K_S" | "Q3_K_M" | "Q3_K_L" | "Q4_0" | "Q4_K_S" | "Q4_K_M" | "Q5_0" | "Q5_K_S" | "Q5_K_M" | "Q6_K" | "Q8_0" | "F16" | "F32";
|
|
52
52
|
sizeBytes: number;
|
|
53
53
|
contextLength: number;
|
|
54
|
-
categories: ("small" | "
|
|
54
|
+
categories: ("small" | "reasoning" | "general" | "coding" | "vision")[];
|
|
55
55
|
license?: string | undefined;
|
|
56
56
|
supportsVision?: boolean | undefined;
|
|
57
57
|
supportsTools?: boolean | undefined;
|
|
@@ -68,7 +68,7 @@ export declare const LocalModelInfoSchema: z.ZodObject<{
|
|
|
68
68
|
quantization: "Q2_K" | "Q3_K_S" | "Q3_K_M" | "Q3_K_L" | "Q4_0" | "Q4_K_S" | "Q4_K_M" | "Q5_0" | "Q5_K_S" | "Q5_K_M" | "Q6_K" | "Q8_0" | "F16" | "F32";
|
|
69
69
|
sizeBytes: number;
|
|
70
70
|
contextLength: number;
|
|
71
|
-
categories: ("small" | "
|
|
71
|
+
categories: ("small" | "reasoning" | "general" | "coding" | "vision")[];
|
|
72
72
|
license?: string | undefined;
|
|
73
73
|
supportsVision?: boolean | undefined;
|
|
74
74
|
supportsTools?: boolean | undefined;
|
|
@@ -30,6 +30,7 @@ var openrouter_model_registry_exports = {};
|
|
|
30
30
|
__export(openrouter_model_registry_exports, {
|
|
31
31
|
__TEST_ONLY__: () => __TEST_ONLY__,
|
|
32
32
|
getCachedOpenRouterModels: () => getCachedOpenRouterModels,
|
|
33
|
+
getCachedOpenRouterModelsWithInfo: () => getCachedOpenRouterModelsWithInfo,
|
|
33
34
|
getOpenRouterModelCacheInfo: () => getOpenRouterModelCacheInfo,
|
|
34
35
|
getOpenRouterModelContextLength: () => getOpenRouterModelContextLength,
|
|
35
36
|
getOpenRouterModelInfo: () => getOpenRouterModelInfo,
|
|
@@ -61,6 +62,23 @@ class OpenRouterModelRegistry {
|
|
|
61
62
|
refreshPromise = null;
|
|
62
63
|
lastRefreshAttemptAt = null;
|
|
63
64
|
lastUsedApiKey;
|
|
65
|
+
parseExpirationDateEndUtc(expirationDate) {
|
|
66
|
+
const match = /^(\d{4})-(\d{2})-(\d{2})$/.exec(expirationDate.trim());
|
|
67
|
+
if (!match) return null;
|
|
68
|
+
const year = Number(match[1]);
|
|
69
|
+
const monthIndex = Number(match[2]) - 1;
|
|
70
|
+
const day = Number(match[3]);
|
|
71
|
+
if (!Number.isFinite(year) || !Number.isFinite(monthIndex) || !Number.isFinite(day)) {
|
|
72
|
+
return null;
|
|
73
|
+
}
|
|
74
|
+
return Date.UTC(year, monthIndex, day, 23, 59, 59, 999);
|
|
75
|
+
}
|
|
76
|
+
isExpired(model) {
|
|
77
|
+
if (!model.expirationDate) return false;
|
|
78
|
+
const expiresAt = this.parseExpirationDateEndUtc(model.expirationDate);
|
|
79
|
+
if (!expiresAt) return false;
|
|
80
|
+
return Date.now() > expiresAt;
|
|
81
|
+
}
|
|
64
82
|
/**
|
|
65
83
|
* Look up a model ID against the OpenRouter catalog.
|
|
66
84
|
* @returns 'valid' if model exists, 'invalid' if not found, 'unknown' if cache is stale/empty
|
|
@@ -78,7 +96,11 @@ class OpenRouterModelRegistry {
|
|
|
78
96
|
this.scheduleRefresh();
|
|
79
97
|
return "unknown";
|
|
80
98
|
}
|
|
81
|
-
|
|
99
|
+
const info = this.models.get(normalized);
|
|
100
|
+
if (info && this.isExpired(info)) {
|
|
101
|
+
return "invalid";
|
|
102
|
+
}
|
|
103
|
+
return info ? "valid" : "invalid";
|
|
82
104
|
}
|
|
83
105
|
/**
|
|
84
106
|
* Get context length for a model ID.
|
|
@@ -93,6 +115,7 @@ class OpenRouterModelRegistry {
|
|
|
93
115
|
return null;
|
|
94
116
|
}
|
|
95
117
|
const info = this.models.get(normalized);
|
|
118
|
+
if (info && this.isExpired(info)) return null;
|
|
96
119
|
return info?.contextLength ?? null;
|
|
97
120
|
}
|
|
98
121
|
/**
|
|
@@ -107,7 +130,9 @@ class OpenRouterModelRegistry {
|
|
|
107
130
|
if (!this.models || this.models.size === 0 || !this.isCacheFresh()) {
|
|
108
131
|
return null;
|
|
109
132
|
}
|
|
110
|
-
|
|
133
|
+
const info = this.models.get(normalized) ?? null;
|
|
134
|
+
if (info && this.isExpired(info)) return null;
|
|
135
|
+
return info;
|
|
111
136
|
}
|
|
112
137
|
/**
|
|
113
138
|
* Schedule a non-blocking background refresh of the model cache.
|
|
@@ -117,6 +142,9 @@ class OpenRouterModelRegistry {
|
|
|
117
142
|
if (apiKey) {
|
|
118
143
|
this.lastUsedApiKey = apiKey;
|
|
119
144
|
}
|
|
145
|
+
if ((process.env.NODE_ENV === "test" || process.env.VITEST) && options?.allowInTests !== true) {
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
120
148
|
if (this.refreshPromise) {
|
|
121
149
|
return;
|
|
122
150
|
}
|
|
@@ -125,7 +153,7 @@ class OpenRouterModelRegistry {
|
|
|
125
153
|
return;
|
|
126
154
|
}
|
|
127
155
|
this.lastRefreshAttemptAt = now;
|
|
128
|
-
this.refreshPromise = this.refreshInternal(apiKey).catch((error) => {
|
|
156
|
+
this.refreshPromise = this.refreshInternal(apiKey, options?.timeoutMs).catch((error) => {
|
|
129
157
|
import_logger.logger.warn(
|
|
130
158
|
`Failed to refresh OpenRouter model registry: ${error instanceof Error ? error.message : String(error)}`
|
|
131
159
|
);
|
|
@@ -141,6 +169,9 @@ class OpenRouterModelRegistry {
|
|
|
141
169
|
if (apiKey) {
|
|
142
170
|
this.lastUsedApiKey = apiKey;
|
|
143
171
|
}
|
|
172
|
+
if ((process.env.NODE_ENV === "test" || process.env.VITEST) && options?.allowInTests !== true) {
|
|
173
|
+
return;
|
|
174
|
+
}
|
|
144
175
|
if (!options?.force && this.refreshPromise) {
|
|
145
176
|
await this.refreshPromise;
|
|
146
177
|
return;
|
|
@@ -157,7 +188,7 @@ class OpenRouterModelRegistry {
|
|
|
157
188
|
} else {
|
|
158
189
|
this.lastRefreshAttemptAt = Date.now();
|
|
159
190
|
}
|
|
160
|
-
const promise = this.refreshInternal(apiKey).finally(() => {
|
|
191
|
+
const promise = this.refreshInternal(apiKey, options?.timeoutMs).finally(() => {
|
|
161
192
|
this.refreshPromise = null;
|
|
162
193
|
});
|
|
163
194
|
this.refreshPromise = promise;
|
|
@@ -170,7 +201,12 @@ class OpenRouterModelRegistry {
|
|
|
170
201
|
if (!this.models || this.models.size === 0) {
|
|
171
202
|
return null;
|
|
172
203
|
}
|
|
173
|
-
|
|
204
|
+
const ids = [];
|
|
205
|
+
for (const info of this.models.values()) {
|
|
206
|
+
if (this.isExpired(info)) continue;
|
|
207
|
+
ids.push(info.id);
|
|
208
|
+
}
|
|
209
|
+
return ids;
|
|
174
210
|
}
|
|
175
211
|
/**
|
|
176
212
|
* Get all cached model info (or null if cache is empty).
|
|
@@ -179,19 +215,20 @@ class OpenRouterModelRegistry {
|
|
|
179
215
|
if (!this.models || this.models.size === 0) {
|
|
180
216
|
return null;
|
|
181
217
|
}
|
|
182
|
-
return Array.from(this.models.values());
|
|
218
|
+
return Array.from(this.models.values()).filter((info) => !this.isExpired(info));
|
|
183
219
|
}
|
|
184
220
|
/**
|
|
185
221
|
* Get cache metadata for debugging/monitoring.
|
|
186
222
|
*/
|
|
187
223
|
getCacheMetadata() {
|
|
224
|
+
const modelCount = this.models ? Array.from(this.models.values()).filter((info) => !this.isExpired(info)).length : 0;
|
|
188
225
|
return {
|
|
189
226
|
lastFetchedAt: this.lastFetchedAt ? new Date(this.lastFetchedAt) : null,
|
|
190
|
-
modelCount
|
|
227
|
+
modelCount,
|
|
191
228
|
isFresh: this.isCacheFresh()
|
|
192
229
|
};
|
|
193
230
|
}
|
|
194
|
-
async refreshInternal(apiKey) {
|
|
231
|
+
async refreshInternal(apiKey, timeoutMs) {
|
|
195
232
|
try {
|
|
196
233
|
const headers = {
|
|
197
234
|
Accept: "application/json"
|
|
@@ -200,7 +237,10 @@ class OpenRouterModelRegistry {
|
|
|
200
237
|
headers.Authorization = `Bearer ${apiKey}`;
|
|
201
238
|
}
|
|
202
239
|
import_logger.logger.debug("Refreshing OpenRouter model registry from remote source");
|
|
203
|
-
const response = await fetch(OPENROUTER_MODELS_ENDPOINT, {
|
|
240
|
+
const response = await fetch(OPENROUTER_MODELS_ENDPOINT, {
|
|
241
|
+
headers,
|
|
242
|
+
signal: AbortSignal.timeout(timeoutMs ?? 3e4)
|
|
243
|
+
});
|
|
204
244
|
if (!response.ok) {
|
|
205
245
|
const body = await response.text();
|
|
206
246
|
throw new Error(`HTTP ${response.status}: ${body}`);
|
|
@@ -229,7 +269,7 @@ class OpenRouterModelRegistry {
|
|
|
229
269
|
}
|
|
230
270
|
this.models = /* @__PURE__ */ new Map();
|
|
231
271
|
for (const model of parsed.models) {
|
|
232
|
-
if (typeof model === "object" && model.id && typeof model.contextLength === "number") {
|
|
272
|
+
if (typeof model === "object" && typeof model.id === "string" && model.id.trim().length > 0 && typeof model.contextLength === "number") {
|
|
233
273
|
this.models.set(model.id.toLowerCase(), model);
|
|
234
274
|
}
|
|
235
275
|
}
|
|
@@ -294,7 +334,18 @@ class OpenRouterModelRegistry {
|
|
|
294
334
|
} else if (record.top_provider && typeof record.top_provider === "object" && typeof record.top_provider.context_length === "number") {
|
|
295
335
|
contextLength = record.top_provider.context_length;
|
|
296
336
|
}
|
|
297
|
-
|
|
337
|
+
const displayName = typeof record.name === "string" && record.name.trim().length > 0 ? record.name : void 0;
|
|
338
|
+
const expirationDate = typeof record.expiration_date === "string" && record.expiration_date.trim().length > 0 ? record.expiration_date : void 0;
|
|
339
|
+
const supportedParameters = Array.isArray(record.supported_parameters) ? record.supported_parameters.filter(
|
|
340
|
+
(p) => typeof p === "string" && p.trim().length > 0
|
|
341
|
+
) : void 0;
|
|
342
|
+
models.push({
|
|
343
|
+
id,
|
|
344
|
+
contextLength,
|
|
345
|
+
...displayName ? { displayName } : {},
|
|
346
|
+
...expirationDate ? { expirationDate } : {},
|
|
347
|
+
...supportedParameters ? { supportedParameters } : {}
|
|
348
|
+
});
|
|
298
349
|
}
|
|
299
350
|
}
|
|
300
351
|
}
|
|
@@ -323,6 +374,9 @@ async function refreshOpenRouterModelCache(options) {
|
|
|
323
374
|
function getCachedOpenRouterModels() {
|
|
324
375
|
return openRouterModelRegistry.getCachedModels();
|
|
325
376
|
}
|
|
377
|
+
function getCachedOpenRouterModelsWithInfo() {
|
|
378
|
+
return openRouterModelRegistry.getCachedModelsWithInfo();
|
|
379
|
+
}
|
|
326
380
|
function getOpenRouterModelContextLength(modelId) {
|
|
327
381
|
return openRouterModelRegistry.getContextLength(modelId);
|
|
328
382
|
}
|
|
@@ -340,6 +394,7 @@ const __TEST_ONLY__ = {
|
|
|
340
394
|
0 && (module.exports = {
|
|
341
395
|
__TEST_ONLY__,
|
|
342
396
|
getCachedOpenRouterModels,
|
|
397
|
+
getCachedOpenRouterModelsWithInfo,
|
|
343
398
|
getOpenRouterModelCacheInfo,
|
|
344
399
|
getOpenRouterModelContextLength,
|
|
345
400
|
getOpenRouterModelInfo,
|
|
@@ -15,10 +15,29 @@ export type LookupStatus = 'valid' | 'invalid' | 'unknown';
|
|
|
15
15
|
export interface OpenRouterModelInfo {
|
|
16
16
|
id: string;
|
|
17
17
|
contextLength: number;
|
|
18
|
+
/**
|
|
19
|
+
* Human-friendly model name from OpenRouter (e.g. "Claude Sonnet 4.5").
|
|
20
|
+
*/
|
|
21
|
+
displayName?: string;
|
|
22
|
+
/**
|
|
23
|
+
* OpenRouter expiration date (YYYY-MM-DD) when present.
|
|
24
|
+
* Models past this date should be treated as invalid/deprecated.
|
|
25
|
+
*/
|
|
26
|
+
expirationDate?: string;
|
|
27
|
+
/**
|
|
28
|
+
* OpenRouter supported parameters (e.g. includes "reasoning" for reasoning-capable models).
|
|
29
|
+
*/
|
|
30
|
+
supportedParameters?: string[];
|
|
18
31
|
}
|
|
19
32
|
interface RefreshOptions {
|
|
20
33
|
apiKey?: string;
|
|
21
34
|
force?: boolean;
|
|
35
|
+
timeoutMs?: number;
|
|
36
|
+
/**
|
|
37
|
+
* Test-only escape hatch for unit tests that want to validate refresh behavior.
|
|
38
|
+
* Network fetch is disabled by default when NODE_ENV === 'test' or VITEST is set.
|
|
39
|
+
*/
|
|
40
|
+
allowInTests?: boolean;
|
|
22
41
|
}
|
|
23
42
|
declare class OpenRouterModelRegistry {
|
|
24
43
|
private readonly cachePath;
|
|
@@ -29,6 +48,8 @@ declare class OpenRouterModelRegistry {
|
|
|
29
48
|
private lastRefreshAttemptAt;
|
|
30
49
|
private lastUsedApiKey?;
|
|
31
50
|
constructor(cachePath: string);
|
|
51
|
+
private parseExpirationDateEndUtc;
|
|
52
|
+
private isExpired;
|
|
32
53
|
/**
|
|
33
54
|
* Look up a model ID against the OpenRouter catalog.
|
|
34
55
|
* @returns 'valid' if model exists, 'invalid' if not found, 'unknown' if cache is stale/empty
|
|
@@ -94,6 +115,11 @@ export declare function refreshOpenRouterModelCache(options?: RefreshOptions): P
|
|
|
94
115
|
* Get all cached OpenRouter model IDs (or null if cache is empty).
|
|
95
116
|
*/
|
|
96
117
|
export declare function getCachedOpenRouterModels(): string[] | null;
|
|
118
|
+
/**
|
|
119
|
+
* Get all cached OpenRouter model info (or null if cache is empty).
|
|
120
|
+
* Expired models are filtered out.
|
|
121
|
+
*/
|
|
122
|
+
export declare function getCachedOpenRouterModelsWithInfo(): OpenRouterModelInfo[] | null;
|
|
97
123
|
/**
|
|
98
124
|
* Get context length for an OpenRouter model.
|
|
99
125
|
* @returns context length if model is in cache, null if not found or cache is stale
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"openrouter-model-registry.d.ts","sourceRoot":"","sources":["../../../src/llm/providers/openrouter-model-registry.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAcH,MAAM,MAAM,YAAY,GAAG,OAAO,GAAG,SAAS,GAAG,SAAS,CAAC;AAE3D,iCAAiC;AACjC,MAAM,WAAW,mBAAmB;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,aAAa,EAAE,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"openrouter-model-registry.d.ts","sourceRoot":"","sources":["../../../src/llm/providers/openrouter-model-registry.ts"],"names":[],"mappings":"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"}
|
|
@@ -21,6 +21,23 @@ class OpenRouterModelRegistry {
|
|
|
21
21
|
refreshPromise = null;
|
|
22
22
|
lastRefreshAttemptAt = null;
|
|
23
23
|
lastUsedApiKey;
|
|
24
|
+
parseExpirationDateEndUtc(expirationDate) {
|
|
25
|
+
const match = /^(\d{4})-(\d{2})-(\d{2})$/.exec(expirationDate.trim());
|
|
26
|
+
if (!match) return null;
|
|
27
|
+
const year = Number(match[1]);
|
|
28
|
+
const monthIndex = Number(match[2]) - 1;
|
|
29
|
+
const day = Number(match[3]);
|
|
30
|
+
if (!Number.isFinite(year) || !Number.isFinite(monthIndex) || !Number.isFinite(day)) {
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
return Date.UTC(year, monthIndex, day, 23, 59, 59, 999);
|
|
34
|
+
}
|
|
35
|
+
isExpired(model) {
|
|
36
|
+
if (!model.expirationDate) return false;
|
|
37
|
+
const expiresAt = this.parseExpirationDateEndUtc(model.expirationDate);
|
|
38
|
+
if (!expiresAt) return false;
|
|
39
|
+
return Date.now() > expiresAt;
|
|
40
|
+
}
|
|
24
41
|
/**
|
|
25
42
|
* Look up a model ID against the OpenRouter catalog.
|
|
26
43
|
* @returns 'valid' if model exists, 'invalid' if not found, 'unknown' if cache is stale/empty
|
|
@@ -38,7 +55,11 @@ class OpenRouterModelRegistry {
|
|
|
38
55
|
this.scheduleRefresh();
|
|
39
56
|
return "unknown";
|
|
40
57
|
}
|
|
41
|
-
|
|
58
|
+
const info = this.models.get(normalized);
|
|
59
|
+
if (info && this.isExpired(info)) {
|
|
60
|
+
return "invalid";
|
|
61
|
+
}
|
|
62
|
+
return info ? "valid" : "invalid";
|
|
42
63
|
}
|
|
43
64
|
/**
|
|
44
65
|
* Get context length for a model ID.
|
|
@@ -53,6 +74,7 @@ class OpenRouterModelRegistry {
|
|
|
53
74
|
return null;
|
|
54
75
|
}
|
|
55
76
|
const info = this.models.get(normalized);
|
|
77
|
+
if (info && this.isExpired(info)) return null;
|
|
56
78
|
return info?.contextLength ?? null;
|
|
57
79
|
}
|
|
58
80
|
/**
|
|
@@ -67,7 +89,9 @@ class OpenRouterModelRegistry {
|
|
|
67
89
|
if (!this.models || this.models.size === 0 || !this.isCacheFresh()) {
|
|
68
90
|
return null;
|
|
69
91
|
}
|
|
70
|
-
|
|
92
|
+
const info = this.models.get(normalized) ?? null;
|
|
93
|
+
if (info && this.isExpired(info)) return null;
|
|
94
|
+
return info;
|
|
71
95
|
}
|
|
72
96
|
/**
|
|
73
97
|
* Schedule a non-blocking background refresh of the model cache.
|
|
@@ -77,6 +101,9 @@ class OpenRouterModelRegistry {
|
|
|
77
101
|
if (apiKey) {
|
|
78
102
|
this.lastUsedApiKey = apiKey;
|
|
79
103
|
}
|
|
104
|
+
if ((process.env.NODE_ENV === "test" || process.env.VITEST) && options?.allowInTests !== true) {
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
80
107
|
if (this.refreshPromise) {
|
|
81
108
|
return;
|
|
82
109
|
}
|
|
@@ -85,7 +112,7 @@ class OpenRouterModelRegistry {
|
|
|
85
112
|
return;
|
|
86
113
|
}
|
|
87
114
|
this.lastRefreshAttemptAt = now;
|
|
88
|
-
this.refreshPromise = this.refreshInternal(apiKey).catch((error) => {
|
|
115
|
+
this.refreshPromise = this.refreshInternal(apiKey, options?.timeoutMs).catch((error) => {
|
|
89
116
|
logger.warn(
|
|
90
117
|
`Failed to refresh OpenRouter model registry: ${error instanceof Error ? error.message : String(error)}`
|
|
91
118
|
);
|
|
@@ -101,6 +128,9 @@ class OpenRouterModelRegistry {
|
|
|
101
128
|
if (apiKey) {
|
|
102
129
|
this.lastUsedApiKey = apiKey;
|
|
103
130
|
}
|
|
131
|
+
if ((process.env.NODE_ENV === "test" || process.env.VITEST) && options?.allowInTests !== true) {
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
104
134
|
if (!options?.force && this.refreshPromise) {
|
|
105
135
|
await this.refreshPromise;
|
|
106
136
|
return;
|
|
@@ -117,7 +147,7 @@ class OpenRouterModelRegistry {
|
|
|
117
147
|
} else {
|
|
118
148
|
this.lastRefreshAttemptAt = Date.now();
|
|
119
149
|
}
|
|
120
|
-
const promise = this.refreshInternal(apiKey).finally(() => {
|
|
150
|
+
const promise = this.refreshInternal(apiKey, options?.timeoutMs).finally(() => {
|
|
121
151
|
this.refreshPromise = null;
|
|
122
152
|
});
|
|
123
153
|
this.refreshPromise = promise;
|
|
@@ -130,7 +160,12 @@ class OpenRouterModelRegistry {
|
|
|
130
160
|
if (!this.models || this.models.size === 0) {
|
|
131
161
|
return null;
|
|
132
162
|
}
|
|
133
|
-
|
|
163
|
+
const ids = [];
|
|
164
|
+
for (const info of this.models.values()) {
|
|
165
|
+
if (this.isExpired(info)) continue;
|
|
166
|
+
ids.push(info.id);
|
|
167
|
+
}
|
|
168
|
+
return ids;
|
|
134
169
|
}
|
|
135
170
|
/**
|
|
136
171
|
* Get all cached model info (or null if cache is empty).
|
|
@@ -139,19 +174,20 @@ class OpenRouterModelRegistry {
|
|
|
139
174
|
if (!this.models || this.models.size === 0) {
|
|
140
175
|
return null;
|
|
141
176
|
}
|
|
142
|
-
return Array.from(this.models.values());
|
|
177
|
+
return Array.from(this.models.values()).filter((info) => !this.isExpired(info));
|
|
143
178
|
}
|
|
144
179
|
/**
|
|
145
180
|
* Get cache metadata for debugging/monitoring.
|
|
146
181
|
*/
|
|
147
182
|
getCacheMetadata() {
|
|
183
|
+
const modelCount = this.models ? Array.from(this.models.values()).filter((info) => !this.isExpired(info)).length : 0;
|
|
148
184
|
return {
|
|
149
185
|
lastFetchedAt: this.lastFetchedAt ? new Date(this.lastFetchedAt) : null,
|
|
150
|
-
modelCount
|
|
186
|
+
modelCount,
|
|
151
187
|
isFresh: this.isCacheFresh()
|
|
152
188
|
};
|
|
153
189
|
}
|
|
154
|
-
async refreshInternal(apiKey) {
|
|
190
|
+
async refreshInternal(apiKey, timeoutMs) {
|
|
155
191
|
try {
|
|
156
192
|
const headers = {
|
|
157
193
|
Accept: "application/json"
|
|
@@ -160,7 +196,10 @@ class OpenRouterModelRegistry {
|
|
|
160
196
|
headers.Authorization = `Bearer ${apiKey}`;
|
|
161
197
|
}
|
|
162
198
|
logger.debug("Refreshing OpenRouter model registry from remote source");
|
|
163
|
-
const response = await fetch(OPENROUTER_MODELS_ENDPOINT, {
|
|
199
|
+
const response = await fetch(OPENROUTER_MODELS_ENDPOINT, {
|
|
200
|
+
headers,
|
|
201
|
+
signal: AbortSignal.timeout(timeoutMs ?? 3e4)
|
|
202
|
+
});
|
|
164
203
|
if (!response.ok) {
|
|
165
204
|
const body = await response.text();
|
|
166
205
|
throw new Error(`HTTP ${response.status}: ${body}`);
|
|
@@ -189,7 +228,7 @@ class OpenRouterModelRegistry {
|
|
|
189
228
|
}
|
|
190
229
|
this.models = /* @__PURE__ */ new Map();
|
|
191
230
|
for (const model of parsed.models) {
|
|
192
|
-
if (typeof model === "object" && model.id && typeof model.contextLength === "number") {
|
|
231
|
+
if (typeof model === "object" && typeof model.id === "string" && model.id.trim().length > 0 && typeof model.contextLength === "number") {
|
|
193
232
|
this.models.set(model.id.toLowerCase(), model);
|
|
194
233
|
}
|
|
195
234
|
}
|
|
@@ -254,7 +293,18 @@ class OpenRouterModelRegistry {
|
|
|
254
293
|
} else if (record.top_provider && typeof record.top_provider === "object" && typeof record.top_provider.context_length === "number") {
|
|
255
294
|
contextLength = record.top_provider.context_length;
|
|
256
295
|
}
|
|
257
|
-
|
|
296
|
+
const displayName = typeof record.name === "string" && record.name.trim().length > 0 ? record.name : void 0;
|
|
297
|
+
const expirationDate = typeof record.expiration_date === "string" && record.expiration_date.trim().length > 0 ? record.expiration_date : void 0;
|
|
298
|
+
const supportedParameters = Array.isArray(record.supported_parameters) ? record.supported_parameters.filter(
|
|
299
|
+
(p) => typeof p === "string" && p.trim().length > 0
|
|
300
|
+
) : void 0;
|
|
301
|
+
models.push({
|
|
302
|
+
id,
|
|
303
|
+
contextLength,
|
|
304
|
+
...displayName ? { displayName } : {},
|
|
305
|
+
...expirationDate ? { expirationDate } : {},
|
|
306
|
+
...supportedParameters ? { supportedParameters } : {}
|
|
307
|
+
});
|
|
258
308
|
}
|
|
259
309
|
}
|
|
260
310
|
}
|
|
@@ -283,6 +333,9 @@ async function refreshOpenRouterModelCache(options) {
|
|
|
283
333
|
function getCachedOpenRouterModels() {
|
|
284
334
|
return openRouterModelRegistry.getCachedModels();
|
|
285
335
|
}
|
|
336
|
+
function getCachedOpenRouterModelsWithInfo() {
|
|
337
|
+
return openRouterModelRegistry.getCachedModelsWithInfo();
|
|
338
|
+
}
|
|
286
339
|
function getOpenRouterModelContextLength(modelId) {
|
|
287
340
|
return openRouterModelRegistry.getContextLength(modelId);
|
|
288
341
|
}
|
|
@@ -299,6 +352,7 @@ const __TEST_ONLY__ = {
|
|
|
299
352
|
export {
|
|
300
353
|
__TEST_ONLY__,
|
|
301
354
|
getCachedOpenRouterModels,
|
|
355
|
+
getCachedOpenRouterModelsWithInfo,
|
|
302
356
|
getOpenRouterModelCacheInfo,
|
|
303
357
|
getOpenRouterModelContextLength,
|
|
304
358
|
getOpenRouterModelInfo,
|
|
@@ -16,15 +16,16 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
16
|
return to;
|
|
17
17
|
};
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var
|
|
20
|
-
__export(
|
|
21
|
-
|
|
19
|
+
var anthropic_betas_exports = {};
|
|
20
|
+
__export(anthropic_betas_exports, {
|
|
21
|
+
ANTHROPIC_BETA_HEADER: () => ANTHROPIC_BETA_HEADER,
|
|
22
|
+
ANTHROPIC_INTERLEAVED_THINKING_BETA: () => ANTHROPIC_INTERLEAVED_THINKING_BETA
|
|
22
23
|
});
|
|
23
|
-
module.exports = __toCommonJS(
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
24
|
+
module.exports = __toCommonJS(anthropic_betas_exports);
|
|
25
|
+
const ANTHROPIC_BETA_HEADER = "anthropic-beta";
|
|
26
|
+
const ANTHROPIC_INTERLEAVED_THINKING_BETA = "interleaved-thinking-2025-05-14";
|
|
27
27
|
// Annotate the CommonJS export names for ESM import in node:
|
|
28
28
|
0 && (module.exports = {
|
|
29
|
-
|
|
29
|
+
ANTHROPIC_BETA_HEADER,
|
|
30
|
+
ANTHROPIC_INTERLEAVED_THINKING_BETA
|
|
30
31
|
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"anthropic-betas.d.ts","sourceRoot":"","sources":["../../../src/llm/reasoning/anthropic-betas.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,qBAAqB,mBAAmB,CAAC;AAMtD,eAAO,MAAM,mCAAmC,oCAAoC,CAAC"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var anthropic_thinking_exports = {};
|
|
20
|
+
__export(anthropic_thinking_exports, {
|
|
21
|
+
isAnthropicAdaptiveThinkingModel: () => isAnthropicAdaptiveThinkingModel,
|
|
22
|
+
isAnthropicOpusAdaptiveThinkingModel: () => isAnthropicOpusAdaptiveThinkingModel,
|
|
23
|
+
isClaudeVersionAtLeast: () => isClaudeVersionAtLeast,
|
|
24
|
+
parseClaudeVersion: () => parseClaudeVersion,
|
|
25
|
+
supportsAnthropicInterleavedThinking: () => supportsAnthropicInterleavedThinking
|
|
26
|
+
});
|
|
27
|
+
module.exports = __toCommonJS(anthropic_thinking_exports);
|
|
28
|
+
function parseClaudeVersion(model) {
|
|
29
|
+
const modelLower = model.toLowerCase();
|
|
30
|
+
const variantFirst = /claude-(opus|sonnet|haiku)-(\d+)(?:[.-](\d{1,2})(?!\d))?/i.exec(
|
|
31
|
+
modelLower
|
|
32
|
+
);
|
|
33
|
+
if (variantFirst) {
|
|
34
|
+
const [, variant, majorRaw, minorRaw] = variantFirst;
|
|
35
|
+
if (!variant || !majorRaw) return null;
|
|
36
|
+
const major = Number.parseInt(majorRaw, 10);
|
|
37
|
+
const minor = minorRaw ? Number.parseInt(minorRaw, 10) : 0;
|
|
38
|
+
if (!Number.isFinite(major) || !Number.isFinite(minor)) return null;
|
|
39
|
+
return { major, minor, variant };
|
|
40
|
+
}
|
|
41
|
+
const versionFirst = /claude-(\d+)(?:[.-](\d{1,2})(?!\d))?-(opus|sonnet|haiku)/i.exec(
|
|
42
|
+
modelLower
|
|
43
|
+
);
|
|
44
|
+
if (versionFirst) {
|
|
45
|
+
const [, majorRaw, minorRaw, variant] = versionFirst;
|
|
46
|
+
if (!majorRaw || !variant) return null;
|
|
47
|
+
const major = Number.parseInt(majorRaw, 10);
|
|
48
|
+
const minor = minorRaw ? Number.parseInt(minorRaw, 10) : 0;
|
|
49
|
+
if (!Number.isFinite(major) || !Number.isFinite(minor)) return null;
|
|
50
|
+
return { major, minor, variant };
|
|
51
|
+
}
|
|
52
|
+
return null;
|
|
53
|
+
}
|
|
54
|
+
function isClaudeVersionAtLeast(version, min) {
|
|
55
|
+
return version.major > min.major || version.major === min.major && version.minor >= min.minor;
|
|
56
|
+
}
|
|
57
|
+
function isAnthropicAdaptiveThinkingModel(model) {
|
|
58
|
+
const version = parseClaudeVersion(model);
|
|
59
|
+
if (!version) return false;
|
|
60
|
+
return isClaudeVersionAtLeast(version, { major: 4, minor: 6 });
|
|
61
|
+
}
|
|
62
|
+
function isAnthropicOpusAdaptiveThinkingModel(model) {
|
|
63
|
+
const version = parseClaudeVersion(model);
|
|
64
|
+
if (!version || version.variant !== "opus") return false;
|
|
65
|
+
return isClaudeVersionAtLeast(version, { major: 4, minor: 6 });
|
|
66
|
+
}
|
|
67
|
+
function supportsAnthropicInterleavedThinking(model) {
|
|
68
|
+
const version = parseClaudeVersion(model);
|
|
69
|
+
if (!version) return false;
|
|
70
|
+
return version.major >= 4;
|
|
71
|
+
}
|
|
72
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
73
|
+
0 && (module.exports = {
|
|
74
|
+
isAnthropicAdaptiveThinkingModel,
|
|
75
|
+
isAnthropicOpusAdaptiveThinkingModel,
|
|
76
|
+
isClaudeVersionAtLeast,
|
|
77
|
+
parseClaudeVersion,
|
|
78
|
+
supportsAnthropicInterleavedThinking
|
|
79
|
+
});
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export type ClaudeVariant = 'opus' | 'sonnet' | 'haiku';
|
|
2
|
+
export type ParsedClaudeVersion = {
|
|
3
|
+
major: number;
|
|
4
|
+
minor: number;
|
|
5
|
+
variant?: ClaudeVariant;
|
|
6
|
+
};
|
|
7
|
+
export declare function parseClaudeVersion(model: string): ParsedClaudeVersion | null;
|
|
8
|
+
export declare function isClaudeVersionAtLeast(version: Pick<ParsedClaudeVersion, 'major' | 'minor'>, min: {
|
|
9
|
+
major: number;
|
|
10
|
+
minor: number;
|
|
11
|
+
}): boolean;
|
|
12
|
+
export declare function isAnthropicAdaptiveThinkingModel(model: string): boolean;
|
|
13
|
+
export declare function isAnthropicOpusAdaptiveThinkingModel(model: string): boolean;
|
|
14
|
+
export declare function supportsAnthropicInterleavedThinking(model: string): boolean;
|
|
15
|
+
//# sourceMappingURL=anthropic-thinking.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"anthropic-thinking.d.ts","sourceRoot":"","sources":["../../../src/llm/reasoning/anthropic-thinking.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;AAExD,MAAM,MAAM,mBAAmB,GAAG;IAC9B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,aAAa,CAAC;CAC3B,CAAC;AAEF,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,mBAAmB,GAAG,IAAI,CAmC5E;AAED,wBAAgB,sBAAsB,CAClC,OAAO,EAAE,IAAI,CAAC,mBAAmB,EAAE,OAAO,GAAG,OAAO,CAAC,EACrD,GAAG,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,GACtC,OAAO,CAET;AAED,wBAAgB,gCAAgC,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAMvE;AAED,wBAAgB,oCAAoC,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAI3E;AAED,wBAAgB,oCAAoC,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAM3E"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import "../../chunk-PTJYTZNU.js";
|
|
2
|
+
function parseClaudeVersion(model) {
|
|
3
|
+
const modelLower = model.toLowerCase();
|
|
4
|
+
const variantFirst = /claude-(opus|sonnet|haiku)-(\d+)(?:[.-](\d{1,2})(?!\d))?/i.exec(
|
|
5
|
+
modelLower
|
|
6
|
+
);
|
|
7
|
+
if (variantFirst) {
|
|
8
|
+
const [, variant, majorRaw, minorRaw] = variantFirst;
|
|
9
|
+
if (!variant || !majorRaw) return null;
|
|
10
|
+
const major = Number.parseInt(majorRaw, 10);
|
|
11
|
+
const minor = minorRaw ? Number.parseInt(minorRaw, 10) : 0;
|
|
12
|
+
if (!Number.isFinite(major) || !Number.isFinite(minor)) return null;
|
|
13
|
+
return { major, minor, variant };
|
|
14
|
+
}
|
|
15
|
+
const versionFirst = /claude-(\d+)(?:[.-](\d{1,2})(?!\d))?-(opus|sonnet|haiku)/i.exec(
|
|
16
|
+
modelLower
|
|
17
|
+
);
|
|
18
|
+
if (versionFirst) {
|
|
19
|
+
const [, majorRaw, minorRaw, variant] = versionFirst;
|
|
20
|
+
if (!majorRaw || !variant) return null;
|
|
21
|
+
const major = Number.parseInt(majorRaw, 10);
|
|
22
|
+
const minor = minorRaw ? Number.parseInt(minorRaw, 10) : 0;
|
|
23
|
+
if (!Number.isFinite(major) || !Number.isFinite(minor)) return null;
|
|
24
|
+
return { major, minor, variant };
|
|
25
|
+
}
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
function isClaudeVersionAtLeast(version, min) {
|
|
29
|
+
return version.major > min.major || version.major === min.major && version.minor >= min.minor;
|
|
30
|
+
}
|
|
31
|
+
function isAnthropicAdaptiveThinkingModel(model) {
|
|
32
|
+
const version = parseClaudeVersion(model);
|
|
33
|
+
if (!version) return false;
|
|
34
|
+
return isClaudeVersionAtLeast(version, { major: 4, minor: 6 });
|
|
35
|
+
}
|
|
36
|
+
function isAnthropicOpusAdaptiveThinkingModel(model) {
|
|
37
|
+
const version = parseClaudeVersion(model);
|
|
38
|
+
if (!version || version.variant !== "opus") return false;
|
|
39
|
+
return isClaudeVersionAtLeast(version, { major: 4, minor: 6 });
|
|
40
|
+
}
|
|
41
|
+
function supportsAnthropicInterleavedThinking(model) {
|
|
42
|
+
const version = parseClaudeVersion(model);
|
|
43
|
+
if (!version) return false;
|
|
44
|
+
return version.major >= 4;
|
|
45
|
+
}
|
|
46
|
+
export {
|
|
47
|
+
isAnthropicAdaptiveThinkingModel,
|
|
48
|
+
isAnthropicOpusAdaptiveThinkingModel,
|
|
49
|
+
isClaudeVersionAtLeast,
|
|
50
|
+
parseClaudeVersion,
|
|
51
|
+
supportsAnthropicInterleavedThinking
|
|
52
|
+
};
|