@dexto/core 1.6.1 → 1.6.2

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 (132) hide show
  1. package/dist/agent/DextoAgent.cjs +54 -0
  2. package/dist/agent/DextoAgent.d.ts +12 -1
  3. package/dist/agent/DextoAgent.d.ts.map +1 -1
  4. package/dist/agent/DextoAgent.js +54 -0
  5. package/dist/agent/agent-options.d.ts +6 -1
  6. package/dist/agent/agent-options.d.ts.map +1 -1
  7. package/dist/events/index.d.ts +9 -1
  8. package/dist/events/index.d.ts.map +1 -1
  9. package/dist/llm/executor/provider-options.cjs +223 -28
  10. package/dist/llm/executor/provider-options.d.ts +3 -37
  11. package/dist/llm/executor/provider-options.d.ts.map +1 -1
  12. package/dist/llm/executor/provider-options.js +227 -27
  13. package/dist/llm/executor/stream-processor.cjs +54 -31
  14. package/dist/llm/executor/stream-processor.d.ts +9 -2
  15. package/dist/llm/executor/stream-processor.d.ts.map +1 -1
  16. package/dist/llm/executor/stream-processor.js +52 -29
  17. package/dist/llm/executor/turn-executor.cjs +63 -41
  18. package/dist/llm/executor/turn-executor.d.ts +2 -2
  19. package/dist/llm/executor/turn-executor.d.ts.map +1 -1
  20. package/dist/llm/executor/turn-executor.js +53 -31
  21. package/dist/llm/formatters/vercel.cjs +15 -3
  22. package/dist/llm/formatters/vercel.d.ts +1 -0
  23. package/dist/llm/formatters/vercel.d.ts.map +1 -1
  24. package/dist/llm/formatters/vercel.js +15 -3
  25. package/dist/llm/index.cjs +8 -0
  26. package/dist/llm/index.d.ts +2 -1
  27. package/dist/llm/index.d.ts.map +1 -1
  28. package/dist/llm/index.js +7 -0
  29. package/dist/llm/providers/local/schemas.d.ts +2 -2
  30. package/dist/llm/providers/openrouter-model-registry.cjs +66 -11
  31. package/dist/llm/providers/openrouter-model-registry.d.ts +26 -0
  32. package/dist/llm/providers/openrouter-model-registry.d.ts.map +1 -1
  33. package/dist/llm/providers/openrouter-model-registry.js +65 -11
  34. package/dist/llm/reasoning/anthropic-betas.cjs +31 -0
  35. package/dist/llm/reasoning/anthropic-betas.d.ts +3 -0
  36. package/dist/llm/reasoning/anthropic-betas.d.ts.map +1 -0
  37. package/dist/llm/reasoning/anthropic-betas.js +7 -0
  38. package/dist/llm/reasoning/anthropic-thinking.cjs +79 -0
  39. package/dist/llm/reasoning/anthropic-thinking.d.ts +15 -0
  40. package/dist/llm/reasoning/anthropic-thinking.d.ts.map +1 -0
  41. package/dist/llm/reasoning/anthropic-thinking.js +52 -0
  42. package/dist/llm/reasoning/openai-reasoning-effort.cjs +86 -0
  43. package/dist/llm/reasoning/openai-reasoning-effort.d.ts +5 -0
  44. package/dist/llm/reasoning/openai-reasoning-effort.d.ts.map +1 -0
  45. package/dist/llm/reasoning/openai-reasoning-effort.js +61 -0
  46. package/dist/llm/reasoning/profile.cjs +113 -0
  47. package/dist/llm/reasoning/profile.d.ts +13 -0
  48. package/dist/llm/reasoning/profile.d.ts.map +1 -0
  49. package/dist/llm/reasoning/profile.js +92 -0
  50. package/dist/llm/reasoning/profiles/anthropic.cjs +61 -0
  51. package/dist/llm/reasoning/profiles/anthropic.d.ts +8 -0
  52. package/dist/llm/reasoning/profiles/anthropic.d.ts.map +1 -0
  53. package/dist/llm/reasoning/profiles/anthropic.js +45 -0
  54. package/dist/llm/reasoning/profiles/bedrock.cjs +54 -0
  55. package/dist/llm/reasoning/profiles/bedrock.d.ts +3 -0
  56. package/dist/llm/reasoning/profiles/bedrock.d.ts.map +1 -0
  57. package/dist/llm/reasoning/profiles/bedrock.js +36 -0
  58. package/dist/llm/reasoning/profiles/google.cjs +45 -0
  59. package/dist/llm/reasoning/profiles/google.d.ts +9 -0
  60. package/dist/llm/reasoning/profiles/google.d.ts.map +1 -0
  61. package/dist/llm/reasoning/profiles/google.js +21 -0
  62. package/dist/llm/reasoning/profiles/openai-compatible.cjs +39 -0
  63. package/dist/llm/reasoning/profiles/openai-compatible.d.ts +3 -0
  64. package/dist/llm/reasoning/profiles/openai-compatible.d.ts.map +1 -0
  65. package/dist/llm/reasoning/profiles/openai-compatible.js +16 -0
  66. package/dist/llm/reasoning/profiles/openai.cjs +41 -0
  67. package/dist/llm/reasoning/profiles/openai.d.ts +3 -0
  68. package/dist/llm/reasoning/profiles/openai.d.ts.map +1 -0
  69. package/dist/llm/reasoning/profiles/openai.js +18 -0
  70. package/dist/llm/reasoning/profiles/openrouter.cjs +83 -0
  71. package/dist/llm/reasoning/profiles/openrouter.d.ts +10 -0
  72. package/dist/llm/reasoning/profiles/openrouter.d.ts.map +1 -0
  73. package/dist/llm/reasoning/profiles/openrouter.js +59 -0
  74. package/dist/llm/reasoning/profiles/shared.cjs +80 -0
  75. package/dist/llm/reasoning/profiles/shared.d.ts +25 -0
  76. package/dist/llm/reasoning/profiles/shared.d.ts.map +1 -0
  77. package/dist/llm/reasoning/profiles/shared.js +53 -0
  78. package/dist/llm/reasoning/profiles/vertex.cjs +46 -0
  79. package/dist/llm/reasoning/profiles/vertex.d.ts +3 -0
  80. package/dist/llm/reasoning/profiles/vertex.d.ts.map +1 -0
  81. package/dist/llm/reasoning/profiles/vertex.js +23 -0
  82. package/dist/llm/registry/auto-update.cjs +18 -0
  83. package/dist/llm/registry/auto-update.d.ts.map +1 -1
  84. package/dist/llm/registry/auto-update.js +18 -0
  85. package/dist/llm/registry/index.cjs +126 -26
  86. package/dist/llm/registry/index.d.ts +48 -4
  87. package/dist/llm/registry/index.d.ts.map +1 -1
  88. package/dist/llm/registry/index.js +136 -28
  89. package/dist/llm/registry/models.generated.cjs +5198 -59
  90. package/dist/llm/registry/models.generated.d.ts +1893 -76
  91. package/dist/llm/registry/models.generated.d.ts.map +1 -1
  92. package/dist/llm/registry/models.generated.js +5196 -58
  93. package/dist/llm/registry/sync.cjs +72 -1
  94. package/dist/llm/registry/sync.d.ts +21 -1
  95. package/dist/llm/registry/sync.d.ts.map +1 -1
  96. package/dist/llm/registry/sync.js +72 -1
  97. package/dist/llm/resolver.cjs +13 -1
  98. package/dist/llm/resolver.d.ts.map +1 -1
  99. package/dist/llm/resolver.js +13 -1
  100. package/dist/llm/schemas.cjs +75 -14
  101. package/dist/llm/schemas.d.ts +80 -23
  102. package/dist/llm/schemas.d.ts.map +1 -1
  103. package/dist/llm/schemas.js +75 -14
  104. package/dist/llm/services/factory.cjs +55 -8
  105. package/dist/llm/services/factory.d.ts +1 -1
  106. package/dist/llm/services/factory.d.ts.map +1 -1
  107. package/dist/llm/services/factory.js +58 -8
  108. package/dist/llm/services/vercel.cjs +1 -1
  109. package/dist/llm/services/vercel.js +1 -1
  110. package/dist/llm/types.d.ts +9 -0
  111. package/dist/llm/types.d.ts.map +1 -1
  112. package/dist/prompts/index.cjs +9 -0
  113. package/dist/prompts/index.d.ts +1 -0
  114. package/dist/prompts/index.d.ts.map +1 -1
  115. package/dist/prompts/index.js +10 -0
  116. package/dist/prompts/prompt-manager.cjs +2 -0
  117. package/dist/prompts/prompt-manager.d.ts.map +1 -1
  118. package/dist/prompts/prompt-manager.js +2 -0
  119. package/dist/prompts/providers/config-prompt-provider.cjs +11 -1
  120. package/dist/prompts/providers/config-prompt-provider.d.ts.map +1 -1
  121. package/dist/prompts/providers/config-prompt-provider.js +11 -1
  122. package/dist/prompts/schemas.cjs +2 -2
  123. package/dist/prompts/schemas.js +2 -2
  124. package/dist/prompts/types.d.ts +6 -2
  125. package/dist/prompts/types.d.ts.map +1 -1
  126. package/dist/tools/tool-manager.cjs +88 -2
  127. package/dist/tools/tool-manager.d.ts +15 -1
  128. package/dist/tools/tool-manager.d.ts.map +1 -1
  129. package/dist/tools/tool-manager.js +88 -2
  130. package/dist/utils/service-initializer.d.ts +1 -0
  131. package/dist/utils/service-initializer.d.ts.map +1 -1
  132. package/package.json +6 -4
@@ -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" | "general" | "reasoning" | "coding" | "vision")[];
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" | "general" | "reasoning" | "coding" | "vision")[];
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
- return this.models.has(normalized) ? "valid" : "invalid";
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
- return this.models.get(normalized) ?? null;
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
- return Array.from(this.models.keys());
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: this.models ? this.models.size : 0,
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, { headers });
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
- models.push({ id, contextLength });
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;CACzB;AAOD,UAAU,cAAc;IACpB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,OAAO,CAAC;CACnB;AAKD,cAAM,uBAAuB;IAQb,OAAO,CAAC,QAAQ,CAAC,SAAS;IAPtC,iDAAiD;IACjD,OAAO,CAAC,MAAM,CAAiD;IAC/D,OAAO,CAAC,aAAa,CAAuB;IAC5C,OAAO,CAAC,cAAc,CAA8B;IACpD,OAAO,CAAC,oBAAoB,CAAuB;IACnD,OAAO,CAAC,cAAc,CAAC,CAAS;gBAEH,SAAS,EAAE,MAAM;IAI9C;;;OAGG;IACH,MAAM,CAAC,OAAO,EAAE,MAAM,GAAG,YAAY;IAqBrC;;;OAGG;IACH,gBAAgB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAchD;;;OAGG;IACH,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,mBAAmB,GAAG,IAAI;IAazD;;OAEG;IACH,eAAe,CAAC,OAAO,CAAC,EAAE,cAAc,GAAG,IAAI;IA+B/C;;OAEG;IACG,OAAO,CAAC,OAAO,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAmCtD;;OAEG;IACH,eAAe,IAAI,MAAM,EAAE,GAAG,IAAI;IAOlC;;OAEG;IACH,uBAAuB,IAAI,mBAAmB,EAAE,GAAG,IAAI;IAOvD;;OAEG;IACH,gBAAgB,IAAI;QAAE,aAAa,EAAE,IAAI,GAAG,IAAI,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,OAAO,CAAA;KAAE;YAQ1E,eAAe;IA6B7B,OAAO,CAAC,iBAAiB;IAsCzB,OAAO,CAAC,gBAAgB;IAOxB,OAAO,CAAC,YAAY;YAON,UAAU;IAwBxB,OAAO,CAAC,aAAa;IAwCrB,OAAO,CAAC,WAAW;CAQtB;AAID,eAAO,MAAM,uBAAuB,yBAAyC,CAAC;AAE9E;;;GAGG;AACH,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,MAAM,GAAG,YAAY,CAEnE;AAED;;GAEG;AACH,wBAAgB,8BAA8B,CAAC,OAAO,CAAC,EAAE,cAAc,GAAG,IAAI,CAE7E;AAED;;GAEG;AACH,wBAAsB,2BAA2B,CAAC,OAAO,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAEzF;AAED;;GAEG;AACH,wBAAgB,yBAAyB,IAAI,MAAM,EAAE,GAAG,IAAI,CAE3D;AAED;;;GAGG;AACH,wBAAgB,+BAA+B,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAE9E;AAED;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,MAAM,GAAG,mBAAmB,GAAG,IAAI,CAElF;AAED;;GAEG;AACH,wBAAgB,2BAA2B,IAAI;IAC3C,aAAa,EAAE,IAAI,GAAG,IAAI,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,OAAO,CAAC;CACpB,CAEA;AAGD,eAAO,MAAM,aAAa;;;CAGzB,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
- return this.models.has(normalized) ? "valid" : "invalid";
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
- return this.models.get(normalized) ?? null;
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
- return Array.from(this.models.keys());
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: this.models ? this.models.size : 0,
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, { headers });
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
- models.push({ id, contextLength });
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,
@@ -0,0 +1,31 @@
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_betas_exports = {};
20
+ __export(anthropic_betas_exports, {
21
+ ANTHROPIC_BETA_HEADER: () => ANTHROPIC_BETA_HEADER,
22
+ ANTHROPIC_INTERLEAVED_THINKING_BETA: () => ANTHROPIC_INTERLEAVED_THINKING_BETA
23
+ });
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
+ // Annotate the CommonJS export names for ESM import in node:
28
+ 0 && (module.exports = {
29
+ ANTHROPIC_BETA_HEADER,
30
+ ANTHROPIC_INTERLEAVED_THINKING_BETA
31
+ });
@@ -0,0 +1,3 @@
1
+ export declare const ANTHROPIC_BETA_HEADER = "anthropic-beta";
2
+ export declare const ANTHROPIC_INTERLEAVED_THINKING_BETA = "interleaved-thinking-2025-05-14";
3
+ //# sourceMappingURL=anthropic-betas.d.ts.map
@@ -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,7 @@
1
+ import "../../chunk-PTJYTZNU.js";
2
+ const ANTHROPIC_BETA_HEADER = "anthropic-beta";
3
+ const ANTHROPIC_INTERLEAVED_THINKING_BETA = "interleaved-thinking-2025-05-14";
4
+ export {
5
+ ANTHROPIC_BETA_HEADER,
6
+ ANTHROPIC_INTERLEAVED_THINKING_BETA
7
+ };
@@ -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
+ };