@dexto/core 1.3.0 → 1.5.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 (781) hide show
  1. package/README.md +53 -9
  2. package/dist/agent/DextoAgent.cjs +570 -210
  3. package/dist/agent/DextoAgent.d.ts +175 -35
  4. package/dist/agent/DextoAgent.d.ts.map +1 -1
  5. package/dist/agent/DextoAgent.js +568 -208
  6. package/dist/agent/agentCard.js +1 -1
  7. package/dist/agent/error-codes.cjs +1 -0
  8. package/dist/agent/error-codes.d.ts +2 -1
  9. package/dist/agent/error-codes.d.ts.map +1 -1
  10. package/dist/agent/error-codes.js +2 -1
  11. package/dist/agent/errors.cjs +13 -0
  12. package/dist/agent/errors.d.ts +4 -0
  13. package/dist/agent/errors.d.ts.map +1 -1
  14. package/dist/agent/errors.js +14 -1
  15. package/dist/agent/index.cjs +4 -1
  16. package/dist/agent/index.d.ts +2 -2
  17. package/dist/agent/index.d.ts.map +1 -1
  18. package/dist/agent/index.js +6 -2
  19. package/dist/agent/schemas.cjs +90 -68
  20. package/dist/agent/schemas.d.ts +5998 -146
  21. package/dist/agent/schemas.d.ts.map +1 -1
  22. package/dist/agent/schemas.js +90 -65
  23. package/dist/agent/state-manager.cjs +5 -5
  24. package/dist/agent/state-manager.d.ts +4 -4
  25. package/dist/agent/state-manager.js +6 -6
  26. package/dist/agent/types.d.ts +24 -10
  27. package/dist/agent/types.d.ts.map +1 -1
  28. package/dist/approval/error-codes.js +1 -1
  29. package/dist/approval/errors.js +1 -1
  30. package/dist/approval/factory.js +1 -1
  31. package/dist/approval/index.js +1 -1
  32. package/dist/approval/manager.cjs +234 -4
  33. package/dist/approval/manager.d.ts +131 -4
  34. package/dist/approval/manager.d.ts.map +1 -1
  35. package/dist/approval/manager.js +225 -5
  36. package/dist/approval/schemas.cjs +57 -7
  37. package/dist/approval/schemas.d.ts +344 -33
  38. package/dist/approval/schemas.d.ts.map +1 -1
  39. package/dist/approval/schemas.js +54 -8
  40. package/dist/approval/types.cjs +1 -0
  41. package/dist/approval/types.d.ts +32 -1
  42. package/dist/approval/types.d.ts.map +1 -1
  43. package/dist/approval/types.js +2 -1
  44. package/dist/{chunk-C6A6W6XS.js → chunk-PTJYTZNU.js} +44 -1
  45. package/dist/context/compaction/factory.cjs +57 -0
  46. package/dist/context/compaction/factory.d.ts +17 -0
  47. package/dist/context/compaction/factory.d.ts.map +1 -0
  48. package/dist/context/compaction/factory.js +34 -0
  49. package/dist/context/compaction/index.cjs +49 -0
  50. package/dist/context/compaction/index.d.ts +11 -0
  51. package/dist/context/compaction/index.d.ts.map +1 -0
  52. package/dist/context/compaction/index.js +19 -0
  53. package/dist/context/compaction/overflow.cjs +43 -0
  54. package/dist/context/compaction/overflow.d.ts +33 -0
  55. package/dist/context/compaction/overflow.d.ts.map +1 -0
  56. package/dist/context/compaction/overflow.js +19 -0
  57. package/dist/context/compaction/provider.cjs +16 -0
  58. package/dist/context/compaction/provider.d.ts +48 -0
  59. package/dist/context/compaction/provider.d.ts.map +1 -0
  60. package/dist/context/compaction/providers/noop-provider.cjs +48 -0
  61. package/dist/context/compaction/providers/noop-provider.d.ts +24 -0
  62. package/dist/context/compaction/providers/noop-provider.d.ts.map +1 -0
  63. package/dist/context/compaction/providers/noop-provider.js +24 -0
  64. package/dist/context/compaction/providers/reactive-overflow-provider.cjs +61 -0
  65. package/dist/context/compaction/providers/reactive-overflow-provider.d.ts +36 -0
  66. package/dist/context/compaction/providers/reactive-overflow-provider.d.ts.map +1 -0
  67. package/dist/context/compaction/providers/reactive-overflow-provider.js +37 -0
  68. package/dist/{llm/tokenizer/factory.cjs → context/compaction/registry.cjs} +15 -20
  69. package/dist/context/compaction/registry.d.ts +19 -0
  70. package/dist/context/compaction/registry.d.ts.map +1 -0
  71. package/dist/context/compaction/registry.js +16 -0
  72. package/dist/context/compaction/schemas.cjs +38 -0
  73. package/dist/context/compaction/schemas.d.ts +24 -0
  74. package/dist/context/compaction/schemas.d.ts.map +1 -0
  75. package/dist/context/compaction/schemas.js +14 -0
  76. package/dist/{llm/tokenizer/types.cjs → context/compaction/strategies/noop.cjs} +12 -9
  77. package/dist/context/compaction/strategies/noop.d.ts +18 -0
  78. package/dist/context/compaction/strategies/noop.d.ts.map +1 -0
  79. package/dist/context/compaction/strategies/noop.js +13 -0
  80. package/dist/context/compaction/strategies/reactive-overflow.cjs +201 -0
  81. package/dist/context/compaction/strategies/reactive-overflow.d.ts +81 -0
  82. package/dist/context/compaction/strategies/reactive-overflow.d.ts.map +1 -0
  83. package/dist/context/compaction/strategies/reactive-overflow.js +178 -0
  84. package/dist/context/compaction/types.d.ts +20 -0
  85. package/dist/context/compaction/types.d.ts.map +1 -0
  86. package/dist/context/error-codes.cjs +7 -0
  87. package/dist/context/error-codes.d.ts +8 -1
  88. package/dist/context/error-codes.d.ts.map +1 -1
  89. package/dist/context/error-codes.js +8 -1
  90. package/dist/context/errors.cjs +68 -0
  91. package/dist/context/errors.d.ts +21 -0
  92. package/dist/context/errors.d.ts.map +1 -1
  93. package/dist/context/errors.js +69 -1
  94. package/dist/context/index.cjs +3 -1
  95. package/dist/context/index.d.ts +1 -0
  96. package/dist/context/index.d.ts.map +1 -1
  97. package/dist/context/index.js +2 -1
  98. package/dist/context/manager.cjs +280 -323
  99. package/dist/context/manager.d.ts +65 -111
  100. package/dist/context/manager.d.ts.map +1 -1
  101. package/dist/context/manager.js +280 -328
  102. package/dist/context/media-helpers.js +1 -1
  103. package/dist/context/types.cjs +49 -0
  104. package/dist/context/types.d.ts +187 -72
  105. package/dist/context/types.d.ts.map +1 -1
  106. package/dist/context/types.js +35 -0
  107. package/dist/context/utils.cjs +293 -290
  108. package/dist/context/utils.d.ts +32 -18
  109. package/dist/context/utils.d.ts.map +1 -1
  110. package/dist/context/utils.js +293 -290
  111. package/dist/errors/DextoBaseError.js +1 -1
  112. package/dist/errors/DextoRuntimeError.js +1 -1
  113. package/dist/errors/DextoValidationError.js +1 -1
  114. package/dist/errors/index.js +1 -1
  115. package/dist/errors/result-bridge.cjs +2 -3
  116. package/dist/errors/result-bridge.d.ts.map +1 -1
  117. package/dist/errors/result-bridge.js +3 -4
  118. package/dist/errors/types.js +1 -1
  119. package/dist/events/index.cjs +18 -1
  120. package/dist/events/index.d.ts +149 -12
  121. package/dist/events/index.d.ts.map +1 -1
  122. package/dist/events/index.js +19 -2
  123. package/dist/filesystem/error-codes.js +1 -1
  124. package/dist/filesystem/errors.js +1 -1
  125. package/dist/filesystem/filesystem-service.cjs +39 -0
  126. package/dist/filesystem/filesystem-service.d.ts +32 -0
  127. package/dist/filesystem/filesystem-service.d.ts.map +1 -1
  128. package/dist/filesystem/filesystem-service.js +40 -1
  129. package/dist/filesystem/index.d.ts +1 -1
  130. package/dist/filesystem/index.d.ts.map +1 -1
  131. package/dist/filesystem/index.js +1 -1
  132. package/dist/filesystem/path-validator.cjs +69 -1
  133. package/dist/filesystem/path-validator.d.ts +43 -2
  134. package/dist/filesystem/path-validator.d.ts.map +1 -1
  135. package/dist/filesystem/path-validator.js +70 -2
  136. package/dist/image/define-image.cjs +146 -0
  137. package/dist/image/define-image.d.ts +71 -0
  138. package/dist/image/define-image.d.ts.map +1 -0
  139. package/dist/image/define-image.js +121 -0
  140. package/dist/{llm/tokenizer/default.cjs → image/index.cjs} +10 -19
  141. package/dist/image/index.d.ts +53 -0
  142. package/dist/image/index.d.ts.map +1 -0
  143. package/dist/image/index.js +7 -0
  144. package/dist/image/types.d.ts +231 -0
  145. package/dist/image/types.d.ts.map +1 -0
  146. package/dist/image/types.js +0 -0
  147. package/dist/index.browser.cjs +23 -8
  148. package/dist/index.browser.d.ts +4 -3
  149. package/dist/index.browser.d.ts.map +1 -1
  150. package/dist/index.browser.js +20 -3
  151. package/dist/index.cjs +5 -1
  152. package/dist/index.d.ts +2 -0
  153. package/dist/index.d.ts.map +1 -1
  154. package/dist/index.js +3 -1
  155. package/dist/llm/error-codes.cjs +1 -1
  156. package/dist/llm/error-codes.d.ts +1 -1
  157. package/dist/llm/error-codes.d.ts.map +1 -1
  158. package/dist/llm/error-codes.js +2 -2
  159. package/dist/llm/errors.cjs +34 -10
  160. package/dist/llm/errors.d.ts +23 -11
  161. package/dist/llm/errors.d.ts.map +1 -1
  162. package/dist/llm/errors.js +36 -12
  163. package/dist/llm/executor/stream-processor.cjs +375 -0
  164. package/dist/llm/executor/stream-processor.d.ts +55 -0
  165. package/dist/llm/executor/stream-processor.d.ts.map +1 -0
  166. package/dist/llm/executor/stream-processor.js +352 -0
  167. package/dist/llm/executor/tool-output-truncator.cjs +75 -0
  168. package/dist/llm/executor/tool-output-truncator.d.ts +27 -0
  169. package/dist/llm/executor/tool-output-truncator.d.ts.map +1 -0
  170. package/dist/llm/executor/tool-output-truncator.js +48 -0
  171. package/dist/llm/executor/turn-executor.cjs +780 -0
  172. package/dist/llm/executor/turn-executor.d.ts +167 -0
  173. package/dist/llm/executor/turn-executor.d.ts.map +1 -0
  174. package/dist/llm/executor/turn-executor.js +711 -0
  175. package/dist/llm/executor/types.cjs +16 -0
  176. package/dist/llm/executor/types.d.ts +27 -0
  177. package/dist/llm/executor/types.d.ts.map +1 -0
  178. package/dist/llm/executor/types.js +0 -0
  179. package/dist/llm/formatters/vercel.cjs +26 -188
  180. package/dist/llm/formatters/vercel.d.ts +2 -14
  181. package/dist/llm/formatters/vercel.d.ts.map +1 -1
  182. package/dist/llm/formatters/vercel.js +25 -187
  183. package/dist/llm/index.cjs +18 -1
  184. package/dist/llm/index.d.ts +2 -0
  185. package/dist/llm/index.d.ts.map +1 -1
  186. package/dist/llm/index.js +14 -0
  187. package/dist/llm/providers/local/ai-sdk-adapter.cjs +308 -0
  188. package/dist/llm/providers/local/ai-sdk-adapter.d.ts +29 -0
  189. package/dist/llm/providers/local/ai-sdk-adapter.d.ts.map +1 -0
  190. package/dist/llm/providers/local/ai-sdk-adapter.js +278 -0
  191. package/dist/llm/providers/local/downloader.cjs +291 -0
  192. package/dist/llm/providers/local/downloader.d.ts +82 -0
  193. package/dist/llm/providers/local/downloader.d.ts.map +1 -0
  194. package/dist/llm/providers/local/downloader.js +251 -0
  195. package/dist/llm/providers/local/error-codes.cjs +57 -0
  196. package/dist/llm/providers/local/error-codes.d.ts +66 -0
  197. package/dist/llm/providers/local/error-codes.d.ts.map +1 -0
  198. package/dist/llm/providers/local/error-codes.js +34 -0
  199. package/dist/llm/providers/local/errors.cjs +240 -0
  200. package/dist/llm/providers/local/errors.d.ts +31 -0
  201. package/dist/llm/providers/local/errors.d.ts.map +1 -0
  202. package/dist/llm/providers/local/errors.js +217 -0
  203. package/dist/llm/providers/local/gpu-detector.cjs +214 -0
  204. package/dist/llm/providers/local/gpu-detector.d.ts +28 -0
  205. package/dist/llm/providers/local/gpu-detector.d.ts.map +1 -0
  206. package/dist/llm/providers/local/gpu-detector.js +178 -0
  207. package/dist/llm/providers/local/index.cjs +147 -0
  208. package/dist/llm/providers/local/index.d.ts +21 -0
  209. package/dist/llm/providers/local/index.d.ts.map +1 -0
  210. package/dist/llm/providers/local/index.js +126 -0
  211. package/dist/llm/providers/local/node-llama-provider.cjs +216 -0
  212. package/dist/llm/providers/local/node-llama-provider.d.ts +90 -0
  213. package/dist/llm/providers/local/node-llama-provider.d.ts.map +1 -0
  214. package/dist/llm/providers/local/node-llama-provider.js +176 -0
  215. package/dist/llm/providers/local/ollama-provider.cjs +230 -0
  216. package/dist/llm/providers/local/ollama-provider.d.ts +70 -0
  217. package/dist/llm/providers/local/ollama-provider.d.ts.map +1 -0
  218. package/dist/llm/providers/local/ollama-provider.js +198 -0
  219. package/dist/llm/providers/local/registry.cjs +343 -0
  220. package/dist/llm/providers/local/registry.d.ts +51 -0
  221. package/dist/llm/providers/local/registry.d.ts.map +1 -0
  222. package/dist/llm/providers/local/registry.js +312 -0
  223. package/dist/llm/providers/local/schemas.cjs +169 -0
  224. package/dist/llm/providers/local/schemas.d.ts +395 -0
  225. package/dist/llm/providers/local/schemas.d.ts.map +1 -0
  226. package/dist/llm/providers/local/schemas.js +133 -0
  227. package/dist/llm/providers/local/types.cjs +16 -0
  228. package/dist/llm/providers/local/types.d.ts +219 -0
  229. package/dist/llm/providers/local/types.d.ts.map +1 -0
  230. package/dist/llm/providers/local/types.js +0 -0
  231. package/dist/llm/providers/openrouter-model-registry.cjs +350 -0
  232. package/dist/llm/providers/openrouter-model-registry.d.ts +120 -0
  233. package/dist/llm/providers/openrouter-model-registry.d.ts.map +1 -0
  234. package/dist/llm/providers/openrouter-model-registry.js +309 -0
  235. package/dist/llm/registry.cjs +569 -52
  236. package/dist/llm/registry.d.ts +79 -39
  237. package/dist/llm/registry.d.ts.map +1 -1
  238. package/dist/llm/registry.js +564 -49
  239. package/dist/llm/resolver.cjs +62 -34
  240. package/dist/llm/resolver.d.ts +3 -3
  241. package/dist/llm/resolver.d.ts.map +1 -1
  242. package/dist/llm/resolver.js +69 -38
  243. package/dist/llm/schemas.cjs +92 -97
  244. package/dist/llm/schemas.d.ts +162 -39
  245. package/dist/llm/schemas.d.ts.map +1 -1
  246. package/dist/llm/schemas.js +93 -100
  247. package/dist/llm/services/factory.cjs +88 -103
  248. package/dist/llm/services/factory.d.ts +17 -4
  249. package/dist/llm/services/factory.d.ts.map +1 -1
  250. package/dist/llm/services/factory.js +87 -93
  251. package/dist/llm/services/test-utils.integration.cjs +28 -10
  252. package/dist/llm/services/test-utils.integration.d.ts +7 -1
  253. package/dist/llm/services/test-utils.integration.d.ts.map +1 -1
  254. package/dist/llm/services/test-utils.integration.js +33 -12
  255. package/dist/llm/services/types.d.ts +1 -28
  256. package/dist/llm/services/types.d.ts.map +1 -1
  257. package/dist/llm/services/vercel.cjs +58 -469
  258. package/dist/llm/services/vercel.d.ts +39 -21
  259. package/dist/llm/services/vercel.d.ts.map +1 -1
  260. package/dist/llm/services/vercel.js +60 -476
  261. package/dist/llm/types.cjs +11 -4
  262. package/dist/llm/types.d.ts +9 -9
  263. package/dist/llm/types.d.ts.map +1 -1
  264. package/dist/llm/types.js +12 -4
  265. package/dist/llm/validation.js +1 -1
  266. package/dist/logger/browser.js +1 -1
  267. package/dist/logger/factory.js +1 -1
  268. package/dist/logger/index.js +1 -1
  269. package/dist/logger/logger.js +1 -1
  270. package/dist/logger/v2/dexto-logger.cjs +34 -6
  271. package/dist/logger/v2/dexto-logger.d.ts +20 -2
  272. package/dist/logger/v2/dexto-logger.d.ts.map +1 -1
  273. package/dist/logger/v2/dexto-logger.js +35 -7
  274. package/dist/logger/v2/error-codes.js +1 -1
  275. package/dist/logger/v2/errors.js +1 -1
  276. package/dist/logger/v2/schemas.js +1 -1
  277. package/dist/logger/v2/test-utils.cjs +70 -0
  278. package/dist/logger/v2/test-utils.d.ts +17 -0
  279. package/dist/logger/v2/test-utils.d.ts.map +1 -0
  280. package/dist/logger/v2/test-utils.js +46 -0
  281. package/dist/logger/v2/transport-factory.js +1 -1
  282. package/dist/logger/v2/transports/console-transport.js +1 -1
  283. package/dist/logger/v2/transports/file-transport.cjs +6 -0
  284. package/dist/logger/v2/transports/file-transport.d.ts +4 -0
  285. package/dist/logger/v2/transports/file-transport.d.ts.map +1 -1
  286. package/dist/logger/v2/transports/file-transport.js +7 -1
  287. package/dist/logger/v2/types.cjs +1 -0
  288. package/dist/logger/v2/types.d.ts +18 -2
  289. package/dist/logger/v2/types.d.ts.map +1 -1
  290. package/dist/logger/v2/types.js +2 -1
  291. package/dist/mcp/error-codes.cjs +1 -0
  292. package/dist/mcp/error-codes.d.ts +1 -0
  293. package/dist/mcp/error-codes.d.ts.map +1 -1
  294. package/dist/mcp/error-codes.js +2 -1
  295. package/dist/mcp/errors.cjs +13 -0
  296. package/dist/mcp/errors.d.ts +7 -0
  297. package/dist/mcp/errors.d.ts.map +1 -1
  298. package/dist/mcp/errors.js +14 -1
  299. package/dist/mcp/manager.cjs +12 -0
  300. package/dist/mcp/manager.d.ts +17 -0
  301. package/dist/mcp/manager.d.ts.map +1 -1
  302. package/dist/mcp/manager.js +13 -1
  303. package/dist/mcp/mcp-client.cjs +0 -3
  304. package/dist/mcp/mcp-client.d.ts.map +1 -1
  305. package/dist/mcp/mcp-client.js +1 -4
  306. package/dist/mcp/resolver.js +1 -1
  307. package/dist/mcp/schemas.cjs +6 -0
  308. package/dist/mcp/schemas.d.ts +52 -0
  309. package/dist/mcp/schemas.d.ts.map +1 -1
  310. package/dist/mcp/schemas.js +6 -1
  311. package/dist/memory/error-codes.js +1 -1
  312. package/dist/memory/errors.js +1 -1
  313. package/dist/memory/index.js +1 -1
  314. package/dist/memory/manager.js +1 -1
  315. package/dist/memory/schemas.d.ts +3 -3
  316. package/dist/memory/schemas.js +1 -1
  317. package/dist/plugins/builtins/content-policy.js +1 -1
  318. package/dist/plugins/builtins/response-sanitizer.js +1 -1
  319. package/dist/plugins/error-codes.cjs +3 -0
  320. package/dist/plugins/error-codes.d.ts +7 -1
  321. package/dist/plugins/error-codes.d.ts.map +1 -1
  322. package/dist/plugins/error-codes.js +4 -1
  323. package/dist/plugins/index.cjs +7 -0
  324. package/dist/plugins/index.d.ts +4 -2
  325. package/dist/plugins/index.d.ts.map +1 -1
  326. package/dist/plugins/index.js +7 -2
  327. package/dist/plugins/loader.js +1 -1
  328. package/dist/plugins/manager.cjs +92 -7
  329. package/dist/plugins/manager.d.ts +10 -3
  330. package/dist/plugins/manager.d.ts.map +1 -1
  331. package/dist/plugins/manager.js +93 -8
  332. package/dist/plugins/registrations/builtins.js +1 -1
  333. package/dist/plugins/registry.cjs +63 -0
  334. package/dist/plugins/registry.d.ts +101 -0
  335. package/dist/plugins/registry.d.ts.map +1 -0
  336. package/dist/plugins/registry.js +39 -0
  337. package/dist/plugins/schemas.cjs +17 -5
  338. package/dist/plugins/schemas.d.ts +65 -8
  339. package/dist/plugins/schemas.d.ts.map +1 -1
  340. package/dist/plugins/schemas.js +16 -5
  341. package/dist/plugins/types.d.ts +0 -1
  342. package/dist/plugins/types.d.ts.map +1 -1
  343. package/dist/process/command-validator.js +1 -1
  344. package/dist/process/error-codes.js +1 -1
  345. package/dist/process/errors.js +1 -1
  346. package/dist/process/index.js +1 -1
  347. package/dist/process/process-service.cjs +78 -26
  348. package/dist/process/process-service.d.ts +6 -1
  349. package/dist/process/process-service.d.ts.map +1 -1
  350. package/dist/process/process-service.js +79 -27
  351. package/dist/process/types.d.ts +2 -2
  352. package/dist/process/types.d.ts.map +1 -1
  353. package/dist/prompts/error-codes.cjs +1 -0
  354. package/dist/prompts/error-codes.d.ts +2 -1
  355. package/dist/prompts/error-codes.d.ts.map +1 -1
  356. package/dist/prompts/error-codes.js +2 -1
  357. package/dist/prompts/errors.cjs +15 -0
  358. package/dist/prompts/errors.d.ts +4 -0
  359. package/dist/prompts/errors.d.ts.map +1 -1
  360. package/dist/prompts/errors.js +16 -1
  361. package/dist/prompts/index.js +1 -1
  362. package/dist/prompts/name-validation.js +1 -1
  363. package/dist/prompts/prompt-manager.cjs +13 -2
  364. package/dist/prompts/prompt-manager.d.ts +7 -0
  365. package/dist/prompts/prompt-manager.d.ts.map +1 -1
  366. package/dist/prompts/prompt-manager.js +14 -3
  367. package/dist/prompts/providers/config-prompt-provider.cjs +12 -3
  368. package/dist/prompts/providers/config-prompt-provider.d.ts +2 -1
  369. package/dist/prompts/providers/config-prompt-provider.d.ts.map +1 -1
  370. package/dist/prompts/providers/config-prompt-provider.js +13 -4
  371. package/dist/prompts/providers/custom-prompt-provider.js +1 -1
  372. package/dist/prompts/providers/mcp-prompt-provider.js +1 -1
  373. package/dist/prompts/schemas.d.ts +12 -0
  374. package/dist/prompts/schemas.d.ts.map +1 -1
  375. package/dist/prompts/schemas.js +1 -1
  376. package/dist/prompts/types.d.ts +2 -0
  377. package/dist/prompts/types.d.ts.map +1 -1
  378. package/dist/prompts/utils.js +1 -1
  379. package/dist/providers/base-registry.cjs +147 -0
  380. package/dist/providers/base-registry.d.ts +147 -0
  381. package/dist/providers/base-registry.d.ts.map +1 -0
  382. package/dist/providers/base-registry.js +123 -0
  383. package/dist/providers/discovery.cjs +95 -0
  384. package/dist/providers/discovery.d.ts +94 -0
  385. package/dist/providers/discovery.d.ts.map +1 -0
  386. package/dist/providers/discovery.js +70 -0
  387. package/dist/providers/index.cjs +24 -0
  388. package/dist/providers/index.d.ts +32 -0
  389. package/dist/providers/index.d.ts.map +1 -0
  390. package/dist/providers/index.js +2 -0
  391. package/dist/resources/error-codes.js +1 -1
  392. package/dist/resources/errors.js +1 -1
  393. package/dist/resources/handlers/blob-handler.js +1 -1
  394. package/dist/resources/handlers/factory.js +1 -1
  395. package/dist/resources/handlers/filesystem-handler.js +1 -1
  396. package/dist/resources/index.js +1 -1
  397. package/dist/resources/internal-provider.js +1 -1
  398. package/dist/resources/manager.js +1 -1
  399. package/dist/resources/reference-parser.cjs +3 -3
  400. package/dist/resources/reference-parser.d.ts.map +1 -1
  401. package/dist/resources/reference-parser.js +4 -4
  402. package/dist/resources/schemas.js +1 -1
  403. package/dist/search/index.js +1 -1
  404. package/dist/search/search-service.js +1 -1
  405. package/dist/session/chat-session.cjs +169 -54
  406. package/dist/session/chat-session.d.ts +69 -29
  407. package/dist/session/chat-session.d.ts.map +1 -1
  408. package/dist/session/chat-session.js +171 -56
  409. package/dist/session/error-codes.js +1 -1
  410. package/dist/session/errors.js +1 -1
  411. package/dist/session/history/database.cjs +134 -21
  412. package/dist/session/history/database.d.ts +37 -8
  413. package/dist/session/history/database.d.ts.map +1 -1
  414. package/dist/session/history/database.js +135 -22
  415. package/dist/session/history/factory.js +1 -1
  416. package/dist/session/history/memory.cjs +18 -0
  417. package/dist/session/history/memory.d.ts +8 -0
  418. package/dist/session/history/memory.d.ts.map +1 -1
  419. package/dist/session/history/memory.js +19 -1
  420. package/dist/session/history/types.d.ts +13 -1
  421. package/dist/session/history/types.d.ts.map +1 -1
  422. package/dist/session/index.cjs +3 -0
  423. package/dist/session/index.d.ts +3 -0
  424. package/dist/session/index.d.ts.map +1 -1
  425. package/dist/session/index.js +3 -1
  426. package/dist/session/message-queue.cjs +201 -0
  427. package/dist/session/message-queue.d.ts +114 -0
  428. package/dist/session/message-queue.d.ts.map +1 -0
  429. package/dist/session/message-queue.js +178 -0
  430. package/dist/session/schemas.js +1 -1
  431. package/dist/session/session-manager.cjs +57 -7
  432. package/dist/session/session-manager.d.ts +18 -0
  433. package/dist/session/session-manager.d.ts.map +1 -1
  434. package/dist/session/session-manager.js +58 -8
  435. package/dist/session/title-generator.cjs +4 -8
  436. package/dist/session/title-generator.d.ts +1 -2
  437. package/dist/session/title-generator.d.ts.map +1 -1
  438. package/dist/session/title-generator.js +5 -9
  439. package/dist/session/types.cjs +16 -0
  440. package/dist/session/types.d.ts +14 -0
  441. package/dist/session/types.d.ts.map +1 -0
  442. package/dist/session/types.js +0 -0
  443. package/dist/storage/blob/factory.cjs +8 -11
  444. package/dist/storage/blob/factory.d.ts +32 -6
  445. package/dist/storage/blob/factory.d.ts.map +1 -1
  446. package/dist/storage/blob/factory.js +9 -12
  447. package/dist/storage/blob/index.cjs +56 -0
  448. package/dist/storage/blob/index.d.ts +45 -0
  449. package/dist/storage/blob/index.d.ts.map +1 -0
  450. package/dist/storage/blob/index.js +30 -0
  451. package/dist/storage/blob/local-blob-store.js +1 -1
  452. package/dist/storage/blob/memory-blob-store.js +1 -1
  453. package/dist/storage/blob/provider.cjs +16 -0
  454. package/dist/storage/blob/provider.d.ts +50 -0
  455. package/dist/storage/blob/provider.d.ts.map +1 -0
  456. package/dist/storage/blob/provider.js +0 -0
  457. package/dist/storage/blob/providers/index.cjs +31 -0
  458. package/dist/storage/blob/providers/index.d.ts +8 -0
  459. package/dist/storage/blob/providers/index.d.ts.map +1 -0
  460. package/dist/storage/blob/providers/index.js +7 -0
  461. package/dist/storage/blob/providers/local.cjs +39 -0
  462. package/dist/storage/blob/providers/local.d.ts +17 -0
  463. package/dist/storage/blob/providers/local.d.ts.map +1 -0
  464. package/dist/storage/blob/providers/local.js +16 -0
  465. package/dist/storage/blob/providers/memory.cjs +39 -0
  466. package/dist/storage/blob/providers/memory.d.ts +17 -0
  467. package/dist/storage/blob/providers/memory.d.ts.map +1 -0
  468. package/dist/storage/blob/providers/memory.js +16 -0
  469. package/dist/storage/blob/registry.cjs +50 -0
  470. package/dist/storage/blob/registry.d.ts +42 -0
  471. package/dist/storage/blob/registry.d.ts.map +1 -0
  472. package/dist/storage/blob/registry.js +26 -0
  473. package/dist/storage/blob/schemas.cjs +9 -12
  474. package/dist/storage/blob/schemas.d.ts +39 -34
  475. package/dist/storage/blob/schemas.d.ts.map +1 -1
  476. package/dist/storage/blob/schemas.js +7 -12
  477. package/dist/storage/cache/factory.cjs +8 -36
  478. package/dist/storage/cache/factory.d.ts +32 -7
  479. package/dist/storage/cache/factory.d.ts.map +1 -1
  480. package/dist/storage/cache/factory.js +9 -27
  481. package/dist/storage/cache/index.cjs +53 -0
  482. package/dist/storage/cache/index.d.ts +44 -0
  483. package/dist/storage/cache/index.d.ts.map +1 -0
  484. package/dist/storage/cache/index.js +28 -0
  485. package/dist/storage/cache/memory-cache-store.js +1 -1
  486. package/dist/storage/cache/provider.cjs +16 -0
  487. package/dist/storage/cache/provider.d.ts +56 -0
  488. package/dist/storage/cache/provider.d.ts.map +1 -0
  489. package/dist/storage/cache/provider.js +0 -0
  490. package/dist/storage/cache/providers/index.cjs +31 -0
  491. package/dist/storage/cache/providers/index.d.ts +8 -0
  492. package/dist/storage/cache/providers/index.d.ts.map +1 -0
  493. package/dist/storage/cache/providers/index.js +7 -0
  494. package/dist/storage/cache/providers/memory.cjs +40 -0
  495. package/dist/storage/cache/providers/memory.d.ts +17 -0
  496. package/dist/storage/cache/providers/memory.d.ts.map +1 -0
  497. package/dist/storage/cache/providers/memory.js +17 -0
  498. package/dist/storage/cache/providers/redis.cjs +66 -0
  499. package/dist/storage/cache/providers/redis.d.ts +20 -0
  500. package/dist/storage/cache/providers/redis.d.ts.map +1 -0
  501. package/dist/storage/cache/providers/redis.js +33 -0
  502. package/dist/storage/cache/redis-store.js +1 -1
  503. package/dist/{llm/tokenizer/google.cjs → storage/cache/registry.cjs} +23 -25
  504. package/dist/storage/cache/registry.d.ts +42 -0
  505. package/dist/storage/cache/registry.d.ts.map +1 -0
  506. package/dist/storage/cache/registry.js +26 -0
  507. package/dist/storage/cache/schemas.cjs +6 -2
  508. package/dist/storage/cache/schemas.d.ts +2 -3
  509. package/dist/storage/cache/schemas.d.ts.map +1 -1
  510. package/dist/storage/cache/schemas.js +4 -2
  511. package/dist/storage/database/factory.cjs +8 -47
  512. package/dist/storage/database/factory.d.ts +34 -8
  513. package/dist/storage/database/factory.d.ts.map +1 -1
  514. package/dist/storage/database/factory.js +9 -38
  515. package/dist/storage/database/index.cjs +58 -0
  516. package/dist/storage/database/index.d.ts +45 -0
  517. package/dist/storage/database/index.d.ts.map +1 -0
  518. package/dist/storage/database/index.js +37 -0
  519. package/dist/storage/database/memory-database-store.js +1 -1
  520. package/dist/storage/database/postgres-store.cjs +12 -0
  521. package/dist/storage/database/postgres-store.d.ts.map +1 -1
  522. package/dist/storage/database/postgres-store.js +13 -1
  523. package/dist/storage/database/provider.cjs +16 -0
  524. package/dist/storage/database/provider.d.ts +56 -0
  525. package/dist/storage/database/provider.d.ts.map +1 -0
  526. package/dist/storage/database/provider.js +0 -0
  527. package/dist/storage/database/providers/index.cjs +34 -0
  528. package/dist/storage/database/providers/index.d.ts +9 -0
  529. package/dist/storage/database/providers/index.d.ts.map +1 -0
  530. package/dist/storage/database/providers/index.js +9 -0
  531. package/dist/storage/database/providers/memory.cjs +40 -0
  532. package/dist/storage/database/providers/memory.d.ts +16 -0
  533. package/dist/storage/database/providers/memory.d.ts.map +1 -0
  534. package/dist/storage/database/providers/memory.js +17 -0
  535. package/dist/storage/database/providers/postgres.cjs +62 -0
  536. package/dist/storage/database/providers/postgres.d.ts +19 -0
  537. package/dist/storage/database/providers/postgres.d.ts.map +1 -0
  538. package/dist/storage/database/providers/postgres.js +29 -0
  539. package/dist/storage/database/providers/sqlite.cjs +66 -0
  540. package/dist/storage/database/providers/sqlite.d.ts +20 -0
  541. package/dist/storage/database/providers/sqlite.d.ts.map +1 -0
  542. package/dist/storage/database/providers/sqlite.js +33 -0
  543. package/dist/storage/database/registry.cjs +50 -0
  544. package/dist/storage/database/registry.d.ts +42 -0
  545. package/dist/storage/database/registry.d.ts.map +1 -0
  546. package/dist/storage/database/registry.js +26 -0
  547. package/dist/storage/database/schemas.cjs +8 -2
  548. package/dist/storage/database/schemas.d.ts +3 -4
  549. package/dist/storage/database/schemas.d.ts.map +1 -1
  550. package/dist/storage/database/schemas.js +5 -2
  551. package/dist/storage/database/sqlite-store.js +1 -1
  552. package/dist/storage/error-codes.cjs +6 -0
  553. package/dist/storage/error-codes.d.ts +7 -1
  554. package/dist/storage/error-codes.d.ts.map +1 -1
  555. package/dist/storage/error-codes.js +7 -1
  556. package/dist/storage/errors.cjs +80 -0
  557. package/dist/storage/errors.d.ts +24 -0
  558. package/dist/storage/errors.d.ts.map +1 -1
  559. package/dist/storage/errors.js +81 -1
  560. package/dist/storage/index.cjs +47 -4
  561. package/dist/storage/index.d.ts +34 -8
  562. package/dist/storage/index.d.ts.map +1 -1
  563. package/dist/storage/index.js +33 -4
  564. package/dist/storage/schemas.cjs +4 -0
  565. package/dist/storage/schemas.d.ts +17 -50
  566. package/dist/storage/schemas.d.ts.map +1 -1
  567. package/dist/storage/schemas.js +6 -2
  568. package/dist/storage/storage-manager.cjs +6 -6
  569. package/dist/storage/storage-manager.d.ts.map +1 -1
  570. package/dist/storage/storage-manager.js +4 -4
  571. package/dist/systemPrompt/contributors.js +1 -1
  572. package/dist/systemPrompt/error-codes.js +1 -1
  573. package/dist/systemPrompt/errors.js +1 -1
  574. package/dist/systemPrompt/in-built-prompts.cjs +7 -6
  575. package/dist/systemPrompt/in-built-prompts.d.ts +2 -2
  576. package/dist/systemPrompt/in-built-prompts.d.ts.map +1 -1
  577. package/dist/systemPrompt/in-built-prompts.js +7 -6
  578. package/dist/systemPrompt/index.js +1 -1
  579. package/dist/systemPrompt/manager.js +1 -1
  580. package/dist/systemPrompt/registry.cjs +2 -2
  581. package/dist/systemPrompt/registry.d.ts +1 -1
  582. package/dist/systemPrompt/registry.d.ts.map +1 -1
  583. package/dist/systemPrompt/registry.js +3 -3
  584. package/dist/systemPrompt/schemas.cjs +2 -2
  585. package/dist/systemPrompt/schemas.d.ts +18 -18
  586. package/dist/systemPrompt/schemas.js +3 -3
  587. package/dist/telemetry/decorators.js +1 -1
  588. package/dist/telemetry/error-codes.js +1 -1
  589. package/dist/telemetry/errors.js +1 -1
  590. package/dist/telemetry/exporters.js +1 -1
  591. package/dist/telemetry/index.js +1 -1
  592. package/dist/telemetry/schemas.js +1 -1
  593. package/dist/telemetry/telemetry.js +1 -1
  594. package/dist/telemetry/utils.js +1 -1
  595. package/dist/tools/bash-pattern-utils.cjs +91 -0
  596. package/dist/tools/bash-pattern-utils.d.ts +58 -0
  597. package/dist/tools/bash-pattern-utils.d.ts.map +1 -0
  598. package/dist/tools/bash-pattern-utils.js +64 -0
  599. package/dist/tools/confirmation/allowed-tools-provider/factory.js +1 -1
  600. package/dist/tools/confirmation/allowed-tools-provider/in-memory.js +1 -1
  601. package/dist/tools/confirmation/allowed-tools-provider/storage.js +1 -1
  602. package/dist/tools/custom-tool-registry.cjs +64 -0
  603. package/dist/tools/custom-tool-registry.d.ts +120 -0
  604. package/dist/tools/custom-tool-registry.d.ts.map +1 -0
  605. package/dist/tools/custom-tool-registry.js +40 -0
  606. package/dist/tools/custom-tool-schema-registry.cjs +164 -0
  607. package/dist/tools/custom-tool-schema-registry.d.ts +86 -0
  608. package/dist/tools/custom-tool-schema-registry.d.ts.map +1 -0
  609. package/dist/tools/custom-tool-schema-registry.js +140 -0
  610. package/dist/tools/display-types.cjs +60 -0
  611. package/dist/tools/display-types.d.ts +133 -0
  612. package/dist/tools/display-types.d.ts.map +1 -0
  613. package/dist/tools/display-types.js +32 -0
  614. package/dist/tools/error-codes.cjs +5 -0
  615. package/dist/tools/error-codes.d.ts +6 -1
  616. package/dist/tools/error-codes.d.ts.map +1 -1
  617. package/dist/tools/error-codes.js +6 -1
  618. package/dist/tools/errors.cjs +71 -0
  619. package/dist/tools/errors.d.ts +33 -0
  620. package/dist/tools/errors.d.ts.map +1 -1
  621. package/dist/tools/errors.js +72 -1
  622. package/dist/tools/index.cjs +15 -1
  623. package/dist/tools/index.d.ts +5 -0
  624. package/dist/tools/index.d.ts.map +1 -1
  625. package/dist/tools/index.js +13 -2
  626. package/dist/tools/internal-tools/constants.cjs +3 -9
  627. package/dist/tools/internal-tools/constants.d.ts +1 -1
  628. package/dist/tools/internal-tools/constants.d.ts.map +1 -1
  629. package/dist/tools/internal-tools/constants.js +4 -10
  630. package/dist/tools/internal-tools/implementations/ask-user-tool.cjs +1 -1
  631. package/dist/tools/internal-tools/implementations/ask-user-tool.js +2 -2
  632. package/dist/tools/internal-tools/implementations/delegate-to-url-tool.js +1 -1
  633. package/dist/tools/internal-tools/implementations/get-resource-tool.cjs +113 -0
  634. package/dist/tools/internal-tools/implementations/get-resource-tool.d.ts +30 -0
  635. package/dist/tools/internal-tools/implementations/get-resource-tool.d.ts.map +1 -0
  636. package/dist/tools/internal-tools/implementations/get-resource-tool.js +90 -0
  637. package/dist/tools/internal-tools/implementations/list-resources-tool.cjs +91 -0
  638. package/dist/tools/internal-tools/implementations/list-resources-tool.d.ts +24 -0
  639. package/dist/tools/internal-tools/implementations/list-resources-tool.d.ts.map +1 -0
  640. package/dist/tools/internal-tools/implementations/list-resources-tool.js +68 -0
  641. package/dist/tools/internal-tools/implementations/search-history-tool.js +1 -1
  642. package/dist/tools/internal-tools/provider.cjs +175 -31
  643. package/dist/tools/internal-tools/provider.d.ts +62 -14
  644. package/dist/tools/internal-tools/provider.d.ts.map +1 -1
  645. package/dist/tools/internal-tools/provider.js +176 -32
  646. package/dist/tools/internal-tools/registry.cjs +19 -43
  647. package/dist/tools/internal-tools/registry.d.ts +32 -11
  648. package/dist/tools/internal-tools/registry.d.ts.map +1 -1
  649. package/dist/tools/internal-tools/registry.js +20 -44
  650. package/dist/tools/schemas.cjs +36 -6
  651. package/dist/tools/schemas.d.ts +74 -5
  652. package/dist/tools/schemas.d.ts.map +1 -1
  653. package/dist/tools/schemas.js +30 -6
  654. package/dist/tools/tool-manager.cjs +279 -30
  655. package/dist/tools/tool-manager.d.ts +45 -4
  656. package/dist/tools/tool-manager.d.ts.map +1 -1
  657. package/dist/tools/tool-manager.js +284 -31
  658. package/dist/tools/types.d.ts +63 -0
  659. package/dist/tools/types.d.ts.map +1 -1
  660. package/dist/utils/api-key-resolver.cjs +19 -1
  661. package/dist/utils/api-key-resolver.d.ts.map +1 -1
  662. package/dist/utils/api-key-resolver.js +20 -2
  663. package/dist/utils/async-context.js +1 -1
  664. package/dist/utils/debug.js +1 -1
  665. package/dist/{llm/tokenizer/anthropic.cjs → utils/defer.cjs} +19 -20
  666. package/dist/utils/defer.d.ts +63 -0
  667. package/dist/utils/defer.d.ts.map +1 -0
  668. package/dist/utils/defer.js +19 -0
  669. package/dist/utils/error-conversion.js +1 -1
  670. package/dist/utils/execution-context.js +1 -1
  671. package/dist/utils/fs-walk.js +1 -1
  672. package/dist/utils/index.cjs +3 -3
  673. package/dist/utils/index.d.ts +1 -1
  674. package/dist/utils/index.d.ts.map +1 -1
  675. package/dist/utils/index.js +1 -1
  676. package/dist/utils/path.js +1 -1
  677. package/dist/utils/redactor.cjs +18 -3
  678. package/dist/utils/redactor.d.ts +0 -7
  679. package/dist/utils/redactor.d.ts.map +1 -1
  680. package/dist/utils/redactor.js +19 -4
  681. package/dist/utils/result.js +1 -1
  682. package/dist/utils/safe-stringify.js +1 -1
  683. package/dist/utils/schema-metadata.js +1 -1
  684. package/dist/utils/schema.js +1 -1
  685. package/dist/utils/service-initializer.cjs +15 -37
  686. package/dist/utils/service-initializer.d.ts.map +1 -1
  687. package/dist/utils/service-initializer.js +16 -38
  688. package/dist/utils/user-info.js +1 -1
  689. package/dist/utils/zod-schema-converter.js +1 -1
  690. package/package.json +10 -8
  691. package/dist/context/compression/middle-removal.cjs +0 -95
  692. package/dist/context/compression/middle-removal.d.ts +0 -47
  693. package/dist/context/compression/middle-removal.d.ts.map +0 -1
  694. package/dist/context/compression/middle-removal.js +0 -72
  695. package/dist/context/compression/oldest-removal.cjs +0 -83
  696. package/dist/context/compression/oldest-removal.d.ts +0 -42
  697. package/dist/context/compression/oldest-removal.d.ts.map +0 -1
  698. package/dist/context/compression/oldest-removal.js +0 -60
  699. package/dist/context/compression/types.d.ts +0 -18
  700. package/dist/context/compression/types.d.ts.map +0 -1
  701. package/dist/llm/formatters/anthropic.cjs +0 -257
  702. package/dist/llm/formatters/anthropic.d.ts +0 -46
  703. package/dist/llm/formatters/anthropic.d.ts.map +0 -1
  704. package/dist/llm/formatters/anthropic.js +0 -239
  705. package/dist/llm/formatters/factory.cjs +0 -50
  706. package/dist/llm/formatters/factory.d.ts +0 -10
  707. package/dist/llm/formatters/factory.d.ts.map +0 -1
  708. package/dist/llm/formatters/factory.js +0 -27
  709. package/dist/llm/formatters/openai.cjs +0 -203
  710. package/dist/llm/formatters/openai.d.ts +0 -39
  711. package/dist/llm/formatters/openai.d.ts.map +0 -1
  712. package/dist/llm/formatters/openai.js +0 -184
  713. package/dist/llm/formatters/types.d.ts +0 -41
  714. package/dist/llm/formatters/types.d.ts.map +0 -1
  715. package/dist/llm/services/anthropic.cjs +0 -511
  716. package/dist/llm/services/anthropic.d.ts +0 -48
  717. package/dist/llm/services/anthropic.d.ts.map +0 -1
  718. package/dist/llm/services/anthropic.js +0 -447
  719. package/dist/llm/services/openai.cjs +0 -611
  720. package/dist/llm/services/openai.d.ts +0 -48
  721. package/dist/llm/services/openai.d.ts.map +0 -1
  722. package/dist/llm/services/openai.js +0 -547
  723. package/dist/llm/tokenizer/anthropic.d.ts +0 -19
  724. package/dist/llm/tokenizer/anthropic.d.ts.map +0 -1
  725. package/dist/llm/tokenizer/anthropic.js +0 -20
  726. package/dist/llm/tokenizer/default.d.ts +0 -14
  727. package/dist/llm/tokenizer/default.d.ts.map +0 -1
  728. package/dist/llm/tokenizer/default.js +0 -18
  729. package/dist/llm/tokenizer/factory.d.ts +0 -12
  730. package/dist/llm/tokenizer/factory.d.ts.map +0 -1
  731. package/dist/llm/tokenizer/factory.js +0 -21
  732. package/dist/llm/tokenizer/google.d.ts +0 -29
  733. package/dist/llm/tokenizer/google.d.ts.map +0 -1
  734. package/dist/llm/tokenizer/google.js +0 -29
  735. package/dist/llm/tokenizer/openai.cjs +0 -115
  736. package/dist/llm/tokenizer/openai.d.ts +0 -41
  737. package/dist/llm/tokenizer/openai.d.ts.map +0 -1
  738. package/dist/llm/tokenizer/openai.js +0 -91
  739. package/dist/llm/tokenizer/types.d.ts +0 -18
  740. package/dist/llm/tokenizer/types.d.ts.map +0 -1
  741. package/dist/llm/tokenizer/types.js +0 -10
  742. package/dist/tools/internal-tools/implementations/bash-exec-tool.cjs +0 -106
  743. package/dist/tools/internal-tools/implementations/bash-exec-tool.d.ts +0 -13
  744. package/dist/tools/internal-tools/implementations/bash-exec-tool.d.ts.map +0 -1
  745. package/dist/tools/internal-tools/implementations/bash-exec-tool.js +0 -73
  746. package/dist/tools/internal-tools/implementations/bash-output-tool.cjs +0 -49
  747. package/dist/tools/internal-tools/implementations/bash-output-tool.d.ts +0 -12
  748. package/dist/tools/internal-tools/implementations/bash-output-tool.d.ts.map +0 -1
  749. package/dist/tools/internal-tools/implementations/bash-output-tool.js +0 -26
  750. package/dist/tools/internal-tools/implementations/edit-file-tool.cjs +0 -62
  751. package/dist/tools/internal-tools/implementations/edit-file-tool.d.ts +0 -12
  752. package/dist/tools/internal-tools/implementations/edit-file-tool.d.ts.map +0 -1
  753. package/dist/tools/internal-tools/implementations/edit-file-tool.js +0 -39
  754. package/dist/tools/internal-tools/implementations/glob-files-tool.cjs +0 -57
  755. package/dist/tools/internal-tools/implementations/glob-files-tool.d.ts +0 -12
  756. package/dist/tools/internal-tools/implementations/glob-files-tool.d.ts.map +0 -1
  757. package/dist/tools/internal-tools/implementations/glob-files-tool.js +0 -34
  758. package/dist/tools/internal-tools/implementations/grep-content-tool.cjs +0 -71
  759. package/dist/tools/internal-tools/implementations/grep-content-tool.d.ts +0 -12
  760. package/dist/tools/internal-tools/implementations/grep-content-tool.d.ts.map +0 -1
  761. package/dist/tools/internal-tools/implementations/grep-content-tool.js +0 -48
  762. package/dist/tools/internal-tools/implementations/kill-process-tool.cjs +0 -47
  763. package/dist/tools/internal-tools/implementations/kill-process-tool.d.ts +0 -12
  764. package/dist/tools/internal-tools/implementations/kill-process-tool.d.ts.map +0 -1
  765. package/dist/tools/internal-tools/implementations/kill-process-tool.js +0 -24
  766. package/dist/tools/internal-tools/implementations/read-file-tool.cjs +0 -55
  767. package/dist/tools/internal-tools/implementations/read-file-tool.d.ts +0 -12
  768. package/dist/tools/internal-tools/implementations/read-file-tool.d.ts.map +0 -1
  769. package/dist/tools/internal-tools/implementations/read-file-tool.js +0 -32
  770. package/dist/tools/internal-tools/implementations/write-file-tool.cjs +0 -56
  771. package/dist/tools/internal-tools/implementations/write-file-tool.d.ts +0 -12
  772. package/dist/tools/internal-tools/implementations/write-file-tool.d.ts.map +0 -1
  773. package/dist/tools/internal-tools/implementations/write-file-tool.js +0 -33
  774. package/dist/utils/env-file.cjs +0 -118
  775. package/dist/utils/env-file.d.ts +0 -5
  776. package/dist/utils/env-file.d.ts.map +0 -1
  777. package/dist/utils/env-file.js +0 -85
  778. /package/dist/context/{compression/types.js → compaction/provider.js} +0 -0
  779. /package/dist/context/{compression → compaction}/types.cjs +0 -0
  780. /package/dist/{llm/formatters → context/compaction}/types.js +0 -0
  781. /package/dist/{llm/formatters → image}/types.cjs +0 -0
@@ -28,9 +28,10 @@ var import_types = require("../errors/types.cjs");
28
28
  var import_error_codes = require("./error-codes.js");
29
29
  var import_schemas2 = require("./schemas.js");
30
30
  var import_registry = require("./registry.js");
31
+ var import_openrouter_model_registry = require("./providers/openrouter-model-registry.js");
31
32
  var import_api_key_resolver = require("../utils/api-key-resolver.cjs");
32
- function resolveAndValidateLLMConfig(previous, updates, logger) {
33
- const { candidate, warnings } = resolveLLMConfig(previous, updates, logger);
33
+ async function resolveAndValidateLLMConfig(previous, updates, logger) {
34
+ const { candidate, warnings } = await resolveLLMConfig(previous, updates, logger);
34
35
  if ((0, import_result.hasErrors)(warnings)) {
35
36
  const { errors } = (0, import_result.splitIssues)(warnings);
36
37
  return (0, import_result.fail)(errors);
@@ -38,7 +39,7 @@ function resolveAndValidateLLMConfig(previous, updates, logger) {
38
39
  const result = validateLLMConfig(candidate, warnings);
39
40
  return result;
40
41
  }
41
- function resolveLLMConfig(previous, updates, logger) {
42
+ async function resolveLLMConfig(previous, updates, logger) {
42
43
  const warnings = [];
43
44
  const provider = updates.provider ?? (updates.model ? (() => {
44
45
  try {
@@ -69,7 +70,7 @@ function resolveLLMConfig(previous, updates, logger) {
69
70
  });
70
71
  }
71
72
  let model = updates.model ?? previous.model;
72
- if (provider !== previous.provider && !(0, import_registry.acceptsAnyModel)(provider) && !(0, import_registry.isValidProviderModel)(provider, model)) {
73
+ if (provider !== previous.provider && !(0, import_registry.acceptsAnyModel)(provider) && !(0, import_registry.supportsCustomModels)(provider) && !(0, import_registry.isValidProviderModel)(provider, model)) {
73
74
  model = (0, import_registry.getDefaultModelForProvider)(provider) ?? previous.model;
74
75
  warnings.push({
75
76
  code: import_error_codes.LLMErrorCode.MODEL_INCOMPATIBLE,
@@ -80,42 +81,70 @@ function resolveLLMConfig(previous, updates, logger) {
80
81
  context: { provider, model }
81
82
  });
82
83
  }
83
- let router = updates.router;
84
- if (!router) {
85
- if (provider !== previous.provider && !(0, import_registry.isRouterSupportedForModel)(provider, model, previous.router)) {
86
- const supported = (0, import_registry.getSupportedRoutersForModel)(provider, model);
87
- if (supported.length === 0) {
88
- warnings.push({
89
- code: import_error_codes.LLMErrorCode.ROUTER_UNSUPPORTED,
90
- message: `No routers supported for model '${model}' (${provider})`,
91
- severity: "error",
92
- scope: import_types.ErrorScope.LLM,
93
- type: import_types.ErrorType.USER,
94
- context: router ? { provider, model, router } : { provider, model }
95
- });
96
- } else {
97
- router = supported.includes("vercel") ? "vercel" : supported[0];
98
- warnings.push({
99
- code: import_error_codes.LLMErrorCode.ROUTER_UNSUPPORTED,
100
- message: `Router changed to '${router}' for model '${model}' (${provider})`,
101
- severity: "warning",
102
- scope: import_types.ErrorScope.LLM,
103
- type: import_types.ErrorType.USER,
104
- context: { provider, model, router }
105
- });
84
+ const maxInputTokens = updates.maxInputTokens ?? (0, import_registry.getEffectiveMaxInputTokens)({ provider, model, apiKey: apiKey || previous.apiKey }, logger);
85
+ let baseURL;
86
+ if (updates.baseURL) {
87
+ baseURL = updates.baseURL;
88
+ } else if ((0, import_registry.supportsBaseURL)(provider)) {
89
+ baseURL = previous.baseURL;
90
+ } else {
91
+ baseURL = void 0;
92
+ }
93
+ if (provider === "vertex") {
94
+ const projectId = process.env.GOOGLE_VERTEX_PROJECT;
95
+ if (!projectId || !projectId.trim()) {
96
+ warnings.push({
97
+ code: import_error_codes.LLMErrorCode.CONFIG_MISSING,
98
+ message: "GOOGLE_VERTEX_PROJECT environment variable is required for Vertex AI. Set it to your GCP project ID and ensure ADC is configured via `gcloud auth application-default login`",
99
+ severity: "error",
100
+ scope: import_types.ErrorScope.LLM,
101
+ type: import_types.ErrorType.USER,
102
+ context: { provider, model }
103
+ });
104
+ }
105
+ }
106
+ if (provider === "bedrock") {
107
+ const region = process.env.AWS_REGION || process.env.AWS_DEFAULT_REGION;
108
+ if (!region || !region.trim()) {
109
+ warnings.push({
110
+ code: import_error_codes.LLMErrorCode.CONFIG_MISSING,
111
+ message: "AWS_REGION environment variable is required for Amazon Bedrock. Also set either AWS_BEARER_TOKEN_BEDROCK (API key) or AWS_ACCESS_KEY_ID + AWS_SECRET_ACCESS_KEY (IAM credentials).",
112
+ severity: "error",
113
+ scope: import_types.ErrorScope.LLM,
114
+ type: import_types.ErrorType.USER,
115
+ context: { provider, model }
116
+ });
117
+ }
118
+ }
119
+ if (provider === "openrouter") {
120
+ let lookupStatus = (0, import_openrouter_model_registry.lookupOpenRouterModel)(model);
121
+ if (lookupStatus === "unknown") {
122
+ try {
123
+ await (0, import_openrouter_model_registry.refreshOpenRouterModelCache)({ apiKey });
124
+ lookupStatus = (0, import_openrouter_model_registry.lookupOpenRouterModel)(model);
125
+ } catch {
126
+ logger.debug(
127
+ `OpenRouter model cache refresh failed, allowing model '${model}' without validation`
128
+ );
106
129
  }
107
- } else {
108
- router = previous.router;
130
+ }
131
+ if (lookupStatus === "invalid") {
132
+ warnings.push({
133
+ code: import_error_codes.LLMErrorCode.MODEL_INCOMPATIBLE,
134
+ message: `Model '${model}' not found in OpenRouter catalog. Check model ID at https://openrouter.ai/models`,
135
+ severity: "error",
136
+ scope: import_types.ErrorScope.LLM,
137
+ type: import_types.ErrorType.USER,
138
+ context: { provider, model }
139
+ });
109
140
  }
110
141
  }
111
- const maxInputTokens = updates.maxInputTokens ?? (0, import_registry.getEffectiveMaxInputTokens)({ provider, model, apiKey: apiKey || previous.apiKey }, logger);
112
142
  return {
113
143
  candidate: {
114
144
  provider,
115
145
  model,
116
146
  apiKey,
117
- router,
118
- baseURL: updates.baseURL ?? previous.baseURL,
147
+ baseURL,
119
148
  maxIterations: updates.maxIterations ?? previous.maxIterations,
120
149
  maxInputTokens,
121
150
  maxOutputTokens: updates.maxOutputTokens ?? previous.maxOutputTokens,
@@ -139,8 +168,7 @@ function validateLLMConfig(candidate, warnings) {
139
168
  type: import_types.ErrorType.USER,
140
169
  context: {
141
170
  provider: candidate.provider,
142
- model: candidate.model,
143
- ...candidate.router && { router: candidate.router }
171
+ model: candidate.model
144
172
  }
145
173
  });
146
174
  }
@@ -6,16 +6,16 @@ import type { IDextoLogger } from '../logger/v2/types.js';
6
6
  /**
7
7
  * Convenience function that combines resolveLLM and validateLLM
8
8
  */
9
- export declare function resolveAndValidateLLMConfig(previous: ValidatedLLMConfig, updates: LLMUpdates, logger: IDextoLogger): Result<ValidatedLLMConfig, LLMUpdateContext>;
9
+ export declare function resolveAndValidateLLMConfig(previous: ValidatedLLMConfig, updates: LLMUpdates, logger: IDextoLogger): Promise<Result<ValidatedLLMConfig, LLMUpdateContext>>;
10
10
  /**
11
11
  * Infers the LLM config from the provided updates
12
12
  * @param previous - The previous LLM config
13
13
  * @param updates - The updates to the LLM config
14
14
  * @returns The resolved LLM config
15
15
  */
16
- export declare function resolveLLMConfig(previous: ValidatedLLMConfig, updates: LLMUpdates, logger: IDextoLogger): {
16
+ export declare function resolveLLMConfig(previous: ValidatedLLMConfig, updates: LLMUpdates, logger: IDextoLogger): Promise<{
17
17
  candidate: LLMConfig;
18
18
  warnings: Issue<LLMUpdateContext>[];
19
- };
19
+ }>;
20
20
  export declare function validateLLMConfig(candidate: LLMConfig, warnings: Issue<LLMUpdateContext>[]): Result<ValidatedLLMConfig, LLMUpdateContext>;
21
21
  //# sourceMappingURL=resolver.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"resolver.d.ts","sourceRoot":"","sources":["../../src/llm/resolver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAiD,MAAM,oBAAoB,CAAC;AAC3F,OAAO,EAAE,KAAK,EAAyB,MAAM,uBAAuB,CAAC;AAGrE,OAAO,EAAE,KAAK,kBAAkB,EAAE,KAAK,UAAU,EAAE,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAWxF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEnD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAE7D;;GAEG;AACH,wBAAgB,2BAA2B,CACvC,QAAQ,EAAE,kBAAkB,EAC5B,OAAO,EAAE,UAAU,EACnB,MAAM,EAAE,YAAY,GACrB,MAAM,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CAU9C;AAED;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAC5B,QAAQ,EAAE,kBAAkB,EAC5B,OAAO,EAAE,UAAU,EACnB,MAAM,EAAE,YAAY,GACrB;IAAE,SAAS,EAAE,SAAS,CAAC;IAAC,QAAQ,EAAE,KAAK,CAAC,gBAAgB,CAAC,EAAE,CAAA;CAAE,CAsH/D;AAGD,wBAAgB,iBAAiB,CAC7B,SAAS,EAAE,SAAS,EACpB,QAAQ,EAAE,KAAK,CAAC,gBAAgB,CAAC,EAAE,GACpC,MAAM,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CA2B9C"}
1
+ {"version":3,"file":"resolver.d.ts","sourceRoot":"","sources":["../../src/llm/resolver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAiD,MAAM,oBAAoB,CAAC;AAC3F,OAAO,EAAE,KAAK,EAAyB,MAAM,uBAAuB,CAAC;AAGrE,OAAO,EAAE,KAAK,kBAAkB,EAAE,KAAK,UAAU,EAAE,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAexF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEnD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAM7D;;GAEG;AACH,wBAAsB,2BAA2B,CAC7C,QAAQ,EAAE,kBAAkB,EAC5B,OAAO,EAAE,UAAU,EACnB,MAAM,EAAE,YAAY,GACrB,OAAO,CAAC,MAAM,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CAAC,CAUvD;AAED;;;;;GAKG;AACH,wBAAsB,gBAAgB,CAClC,QAAQ,EAAE,kBAAkB,EAC5B,OAAO,EAAE,UAAU,EACnB,MAAM,EAAE,YAAY,GACrB,OAAO,CAAC;IAAE,SAAS,EAAE,SAAS,CAAC;IAAC,QAAQ,EAAE,KAAK,CAAC,gBAAgB,CAAC,EAAE,CAAA;CAAE,CAAC,CAkKxE;AAGD,wBAAgB,iBAAiB,CAC7B,SAAS,EAAE,SAAS,EACpB,QAAQ,EAAE,KAAK,CAAC,gBAAgB,CAAC,EAAE,GACpC,MAAM,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CA0B9C"}
@@ -1,4 +1,4 @@
1
- import "../chunk-C6A6W6XS.js";
1
+ import "../chunk-PTJYTZNU.js";
2
2
  import { hasErrors, splitIssues, ok, fail, zodToIssues } from "../utils/result.js";
3
3
  import { ErrorScope, ErrorType } from "../errors/types.js";
4
4
  import { LLMErrorCode } from "./error-codes.js";
@@ -6,15 +6,19 @@ import { LLMConfigSchema } from "./schemas.js";
6
6
  import {
7
7
  getDefaultModelForProvider,
8
8
  acceptsAnyModel,
9
- isRouterSupportedForModel,
10
- getSupportedRoutersForModel,
11
9
  getProviderFromModel,
12
10
  isValidProviderModel,
13
- getEffectiveMaxInputTokens
11
+ getEffectiveMaxInputTokens,
12
+ supportsBaseURL,
13
+ supportsCustomModels
14
14
  } from "./registry.js";
15
+ import {
16
+ lookupOpenRouterModel,
17
+ refreshOpenRouterModelCache
18
+ } from "./providers/openrouter-model-registry.js";
15
19
  import { resolveApiKeyForProvider } from "../utils/api-key-resolver.js";
16
- function resolveAndValidateLLMConfig(previous, updates, logger) {
17
- const { candidate, warnings } = resolveLLMConfig(previous, updates, logger);
20
+ async function resolveAndValidateLLMConfig(previous, updates, logger) {
21
+ const { candidate, warnings } = await resolveLLMConfig(previous, updates, logger);
18
22
  if (hasErrors(warnings)) {
19
23
  const { errors } = splitIssues(warnings);
20
24
  return fail(errors);
@@ -22,7 +26,7 @@ function resolveAndValidateLLMConfig(previous, updates, logger) {
22
26
  const result = validateLLMConfig(candidate, warnings);
23
27
  return result;
24
28
  }
25
- function resolveLLMConfig(previous, updates, logger) {
29
+ async function resolveLLMConfig(previous, updates, logger) {
26
30
  const warnings = [];
27
31
  const provider = updates.provider ?? (updates.model ? (() => {
28
32
  try {
@@ -53,7 +57,7 @@ function resolveLLMConfig(previous, updates, logger) {
53
57
  });
54
58
  }
55
59
  let model = updates.model ?? previous.model;
56
- if (provider !== previous.provider && !acceptsAnyModel(provider) && !isValidProviderModel(provider, model)) {
60
+ if (provider !== previous.provider && !acceptsAnyModel(provider) && !supportsCustomModels(provider) && !isValidProviderModel(provider, model)) {
57
61
  model = getDefaultModelForProvider(provider) ?? previous.model;
58
62
  warnings.push({
59
63
  code: LLMErrorCode.MODEL_INCOMPATIBLE,
@@ -64,42 +68,70 @@ function resolveLLMConfig(previous, updates, logger) {
64
68
  context: { provider, model }
65
69
  });
66
70
  }
67
- let router = updates.router;
68
- if (!router) {
69
- if (provider !== previous.provider && !isRouterSupportedForModel(provider, model, previous.router)) {
70
- const supported = getSupportedRoutersForModel(provider, model);
71
- if (supported.length === 0) {
72
- warnings.push({
73
- code: LLMErrorCode.ROUTER_UNSUPPORTED,
74
- message: `No routers supported for model '${model}' (${provider})`,
75
- severity: "error",
76
- scope: ErrorScope.LLM,
77
- type: ErrorType.USER,
78
- context: router ? { provider, model, router } : { provider, model }
79
- });
80
- } else {
81
- router = supported.includes("vercel") ? "vercel" : supported[0];
82
- warnings.push({
83
- code: LLMErrorCode.ROUTER_UNSUPPORTED,
84
- message: `Router changed to '${router}' for model '${model}' (${provider})`,
85
- severity: "warning",
86
- scope: ErrorScope.LLM,
87
- type: ErrorType.USER,
88
- context: { provider, model, router }
89
- });
71
+ const maxInputTokens = updates.maxInputTokens ?? getEffectiveMaxInputTokens({ provider, model, apiKey: apiKey || previous.apiKey }, logger);
72
+ let baseURL;
73
+ if (updates.baseURL) {
74
+ baseURL = updates.baseURL;
75
+ } else if (supportsBaseURL(provider)) {
76
+ baseURL = previous.baseURL;
77
+ } else {
78
+ baseURL = void 0;
79
+ }
80
+ if (provider === "vertex") {
81
+ const projectId = process.env.GOOGLE_VERTEX_PROJECT;
82
+ if (!projectId || !projectId.trim()) {
83
+ warnings.push({
84
+ code: LLMErrorCode.CONFIG_MISSING,
85
+ message: "GOOGLE_VERTEX_PROJECT environment variable is required for Vertex AI. Set it to your GCP project ID and ensure ADC is configured via `gcloud auth application-default login`",
86
+ severity: "error",
87
+ scope: ErrorScope.LLM,
88
+ type: ErrorType.USER,
89
+ context: { provider, model }
90
+ });
91
+ }
92
+ }
93
+ if (provider === "bedrock") {
94
+ const region = process.env.AWS_REGION || process.env.AWS_DEFAULT_REGION;
95
+ if (!region || !region.trim()) {
96
+ warnings.push({
97
+ code: LLMErrorCode.CONFIG_MISSING,
98
+ message: "AWS_REGION environment variable is required for Amazon Bedrock. Also set either AWS_BEARER_TOKEN_BEDROCK (API key) or AWS_ACCESS_KEY_ID + AWS_SECRET_ACCESS_KEY (IAM credentials).",
99
+ severity: "error",
100
+ scope: ErrorScope.LLM,
101
+ type: ErrorType.USER,
102
+ context: { provider, model }
103
+ });
104
+ }
105
+ }
106
+ if (provider === "openrouter") {
107
+ let lookupStatus = lookupOpenRouterModel(model);
108
+ if (lookupStatus === "unknown") {
109
+ try {
110
+ await refreshOpenRouterModelCache({ apiKey });
111
+ lookupStatus = lookupOpenRouterModel(model);
112
+ } catch {
113
+ logger.debug(
114
+ `OpenRouter model cache refresh failed, allowing model '${model}' without validation`
115
+ );
90
116
  }
91
- } else {
92
- router = previous.router;
117
+ }
118
+ if (lookupStatus === "invalid") {
119
+ warnings.push({
120
+ code: LLMErrorCode.MODEL_INCOMPATIBLE,
121
+ message: `Model '${model}' not found in OpenRouter catalog. Check model ID at https://openrouter.ai/models`,
122
+ severity: "error",
123
+ scope: ErrorScope.LLM,
124
+ type: ErrorType.USER,
125
+ context: { provider, model }
126
+ });
93
127
  }
94
128
  }
95
- const maxInputTokens = updates.maxInputTokens ?? getEffectiveMaxInputTokens({ provider, model, apiKey: apiKey || previous.apiKey }, logger);
96
129
  return {
97
130
  candidate: {
98
131
  provider,
99
132
  model,
100
133
  apiKey,
101
- router,
102
- baseURL: updates.baseURL ?? previous.baseURL,
134
+ baseURL,
103
135
  maxIterations: updates.maxIterations ?? previous.maxIterations,
104
136
  maxInputTokens,
105
137
  maxOutputTokens: updates.maxOutputTokens ?? previous.maxOutputTokens,
@@ -123,8 +155,7 @@ function validateLLMConfig(candidate, warnings) {
123
155
  type: ErrorType.USER,
124
156
  context: {
125
157
  provider: candidate.provider,
126
- model: candidate.model,
127
- ...candidate.router && { router: candidate.router }
158
+ model: candidate.model
128
159
  }
129
160
  });
130
161
  }
@@ -20,7 +20,9 @@ var schemas_exports = {};
20
20
  __export(schemas_exports, {
21
21
  LLMConfigBaseSchema: () => LLMConfigBaseSchema,
22
22
  LLMConfigSchema: () => LLMConfigSchema,
23
- LLMUpdatesSchema: () => LLMUpdatesSchema
23
+ LLMConfigSchemaRelaxed: () => LLMConfigSchemaRelaxed,
24
+ LLMUpdatesSchema: () => LLMUpdatesSchema,
25
+ createLLMConfigSchema: () => createLLMConfigSchema
24
26
  });
25
27
  module.exports = __toCommonJS(schemas_exports);
26
28
  var import_error_codes = require("./error-codes.js");
@@ -35,11 +37,9 @@ const LLMConfigFields = {
35
37
  provider: import_zod.z.enum(import_types2.LLM_PROVIDERS).describe("LLM provider (e.g., 'openai', 'anthropic', 'google', 'groq')"),
36
38
  model: import_result.NonEmptyTrimmed.describe("Specific model name for the selected provider"),
37
39
  // Expand $ENV refs and trim; final validation happens with provider context
38
- apiKey: (0, import_result.EnvExpandedString)().describe(
39
- "API key for provider; can be given directly or via $ENV reference"
40
- ),
40
+ // Optional for providers that don't need API keys (Ollama, vLLM, etc.)
41
+ apiKey: (0, import_result.EnvExpandedString)().optional().describe("API key for provider; can be given directly or via $ENV reference"),
41
42
  maxIterations: import_zod.z.coerce.number().int().positive().describe("Max iterations for agentic loops"),
42
- router: import_zod.z.enum(import_types2.LLM_ROUTERS).describe("Router to use (vercel | in-built)"),
43
43
  baseURL: import_result.OptionalURL.describe(
44
44
  "Base URL for provider (e.g., https://api.openai.com/v1). Only certain providers support this."
45
45
  ),
@@ -53,136 +53,129 @@ const LLMConfigFields = {
53
53
  const LLMConfigBaseSchema = import_zod.z.object({
54
54
  provider: LLMConfigFields.provider,
55
55
  model: LLMConfigFields.model,
56
+ // apiKey is optional at schema level - validated based on provider in superRefine
56
57
  apiKey: LLMConfigFields.apiKey,
57
58
  // Apply defaults only for complete config validation
58
59
  maxIterations: import_zod.z.coerce.number().int().positive().default(50),
59
- router: import_zod.z.enum(import_types2.LLM_ROUTERS).default("vercel"),
60
60
  baseURL: LLMConfigFields.baseURL,
61
61
  maxInputTokens: LLMConfigFields.maxInputTokens,
62
62
  maxOutputTokens: LLMConfigFields.maxOutputTokens,
63
63
  temperature: LLMConfigFields.temperature,
64
64
  allowedMediaTypes: LLMConfigFields.allowedMediaTypes
65
65
  }).strict();
66
- const LLMConfigSchema = LLMConfigBaseSchema.superRefine((data, ctx) => {
67
- const baseURLIsSet = data.baseURL != null && data.baseURL.trim() !== "";
68
- const maxInputTokensIsSet = data.maxInputTokens != null;
69
- if (!data.apiKey?.trim()) {
70
- const primaryVar = (0, import_api_key_resolver.getPrimaryApiKeyEnvVar)(data.provider);
71
- ctx.addIssue({
72
- code: import_zod.z.ZodIssueCode.custom,
73
- path: ["apiKey"],
74
- message: `Missing API key for provider '${data.provider}' \u2013 set $${primaryVar}`,
75
- params: {
76
- code: import_error_codes.LLMErrorCode.API_KEY_MISSING,
77
- scope: import_types.ErrorScope.LLM,
78
- type: import_types.ErrorType.USER,
79
- provider: data.provider,
80
- envVar: primaryVar
81
- }
82
- });
83
- }
84
- if (baseURLIsSet) {
85
- if (!(0, import_registry.supportsBaseURL)(data.provider)) {
66
+ function createLLMConfigSchema(options = {}) {
67
+ const { strict = true } = options;
68
+ return LLMConfigBaseSchema.superRefine((data, ctx) => {
69
+ const baseURLIsSet = data.baseURL != null && data.baseURL.trim() !== "";
70
+ const maxInputTokensIsSet = data.maxInputTokens != null;
71
+ if (strict && (0, import_registry.requiresApiKey)(data.provider) && !data.apiKey?.trim()) {
72
+ const primaryVar = (0, import_api_key_resolver.getPrimaryApiKeyEnvVar)(data.provider);
86
73
  ctx.addIssue({
87
74
  code: import_zod.z.ZodIssueCode.custom,
88
- path: ["provider"],
89
- message: `Provider '${data.provider}' does not support baseURL. Use an 'openai-compatible' provider if you need a custom base URL.`,
75
+ path: ["apiKey"],
76
+ message: `Missing API key for provider '${data.provider}' \u2013 set $${primaryVar}`,
90
77
  params: {
91
- code: import_error_codes.LLMErrorCode.BASE_URL_INVALID,
78
+ code: import_error_codes.LLMErrorCode.API_KEY_MISSING,
92
79
  scope: import_types.ErrorScope.LLM,
93
- type: import_types.ErrorType.USER
80
+ type: import_types.ErrorType.USER,
81
+ provider: data.provider,
82
+ envVar: primaryVar
94
83
  }
95
84
  });
96
85
  }
97
- } else if ((0, import_registry.requiresBaseURL)(data.provider)) {
98
- ctx.addIssue({
99
- code: import_zod.z.ZodIssueCode.custom,
100
- path: ["baseURL"],
101
- message: `Provider '${data.provider}' requires a 'baseURL'.`,
102
- params: {
103
- code: import_error_codes.LLMErrorCode.BASE_URL_MISSING,
104
- scope: import_types.ErrorScope.LLM,
105
- type: import_types.ErrorType.USER
106
- }
107
- });
108
- } else {
109
- if (!(0, import_registry.acceptsAnyModel)(data.provider)) {
110
- const supportedModelsList = (0, import_registry.getSupportedModels)(data.provider);
111
- if (!(0, import_registry.isValidProviderModel)(data.provider, data.model)) {
86
+ if (baseURLIsSet) {
87
+ if (!(0, import_registry.supportsBaseURL)(data.provider)) {
112
88
  ctx.addIssue({
113
89
  code: import_zod.z.ZodIssueCode.custom,
114
- path: ["model"],
115
- message: `Model '${data.model}' is not supported for provider '${data.provider}'. Supported: ${supportedModelsList.join(", ")}`,
90
+ path: ["provider"],
91
+ message: `Provider '${data.provider}' does not support baseURL. Use an 'openai-compatible' provider if you need a custom base URL.`,
116
92
  params: {
117
- code: import_error_codes.LLMErrorCode.MODEL_INCOMPATIBLE,
93
+ code: import_error_codes.LLMErrorCode.BASE_URL_INVALID,
118
94
  scope: import_types.ErrorScope.LLM,
119
95
  type: import_types.ErrorType.USER
120
96
  }
121
97
  });
122
98
  }
99
+ } else if (strict && (0, import_registry.requiresBaseURL)(data.provider)) {
100
+ ctx.addIssue({
101
+ code: import_zod.z.ZodIssueCode.custom,
102
+ path: ["baseURL"],
103
+ message: `Provider '${data.provider}' requires a 'baseURL'.`,
104
+ params: {
105
+ code: import_error_codes.LLMErrorCode.BASE_URL_MISSING,
106
+ scope: import_types.ErrorScope.LLM,
107
+ type: import_types.ErrorType.USER
108
+ }
109
+ });
123
110
  }
124
- if (maxInputTokensIsSet && !(0, import_registry.acceptsAnyModel)(data.provider)) {
125
- try {
126
- const cap = (0, import_registry.getMaxInputTokensForModel)(data.provider, data.model);
127
- if (data.maxInputTokens > cap) {
111
+ if (!baseURLIsSet || (0, import_registry.supportsBaseURL)(data.provider)) {
112
+ if (!(0, import_registry.acceptsAnyModel)(data.provider) && !(0, import_registry.supportsCustomModels)(data.provider)) {
113
+ const supportedModelsList = (0, import_registry.getSupportedModels)(data.provider);
114
+ if (!(0, import_registry.isValidProviderModel)(data.provider, data.model)) {
128
115
  ctx.addIssue({
129
116
  code: import_zod.z.ZodIssueCode.custom,
130
- path: ["maxInputTokens"],
131
- message: `Max input tokens for model '${data.model}' is ${cap}. You provided ${data.maxInputTokens}`,
117
+ path: ["model"],
118
+ message: `Model '${data.model}' is not supported for provider '${data.provider}'. Supported: ${supportedModelsList.join(", ")}`,
132
119
  params: {
133
- code: import_error_codes.LLMErrorCode.TOKENS_EXCEEDED,
120
+ code: import_error_codes.LLMErrorCode.MODEL_INCOMPATIBLE,
134
121
  scope: import_types.ErrorScope.LLM,
135
122
  type: import_types.ErrorType.USER
136
123
  }
137
124
  });
138
125
  }
139
- } catch (error) {
140
- if (error instanceof import_errors.DextoRuntimeError && error.code === import_error_codes.LLMErrorCode.MODEL_UNKNOWN) {
141
- ctx.addIssue({
142
- code: import_zod.z.ZodIssueCode.custom,
143
- path: ["model"],
144
- message: error.message,
145
- params: {
146
- code: error.code,
147
- scope: error.scope,
148
- type: error.type
149
- }
150
- });
151
- } else {
152
- const message = error instanceof Error ? error.message : "Unknown error occurred";
153
- ctx.addIssue({
154
- code: import_zod.z.ZodIssueCode.custom,
155
- path: ["model"],
156
- message,
157
- params: {
158
- code: import_error_codes.LLMErrorCode.REQUEST_INVALID_SCHEMA,
159
- scope: import_types.ErrorScope.LLM,
160
- type: import_types.ErrorType.SYSTEM
161
- }
162
- });
126
+ }
127
+ if (maxInputTokensIsSet && !(0, import_registry.acceptsAnyModel)(data.provider) && !(0, import_registry.supportsCustomModels)(data.provider)) {
128
+ try {
129
+ const cap = (0, import_registry.getMaxInputTokensForModel)(data.provider, data.model);
130
+ if (data.maxInputTokens > cap) {
131
+ ctx.addIssue({
132
+ code: import_zod.z.ZodIssueCode.custom,
133
+ path: ["maxInputTokens"],
134
+ message: `Max input tokens for model '${data.model}' is ${cap}. You provided ${data.maxInputTokens}`,
135
+ params: {
136
+ code: import_error_codes.LLMErrorCode.TOKENS_EXCEEDED,
137
+ scope: import_types.ErrorScope.LLM,
138
+ type: import_types.ErrorType.USER
139
+ }
140
+ });
141
+ }
142
+ } catch (error) {
143
+ if (error instanceof import_errors.DextoRuntimeError && error.code === import_error_codes.LLMErrorCode.MODEL_UNKNOWN) {
144
+ ctx.addIssue({
145
+ code: import_zod.z.ZodIssueCode.custom,
146
+ path: ["model"],
147
+ message: error.message,
148
+ params: {
149
+ code: error.code,
150
+ scope: error.scope,
151
+ type: error.type
152
+ }
153
+ });
154
+ } else {
155
+ const message = error instanceof Error ? error.message : "Unknown error occurred";
156
+ ctx.addIssue({
157
+ code: import_zod.z.ZodIssueCode.custom,
158
+ path: ["model"],
159
+ message,
160
+ params: {
161
+ code: import_error_codes.LLMErrorCode.REQUEST_INVALID_SCHEMA,
162
+ scope: import_types.ErrorScope.LLM,
163
+ type: import_types.ErrorType.SYSTEM
164
+ }
165
+ });
166
+ }
163
167
  }
164
168
  }
165
169
  }
166
- }
167
- if (!(0, import_registry.isRouterSupportedForModel)(data.provider, data.model, data.router)) {
168
- const supportedRouters = (0, import_registry.getSupportedRoutersForModel)(data.provider, data.model);
169
- ctx.addIssue({
170
- code: import_zod.z.ZodIssueCode.custom,
171
- path: ["router"],
172
- message: `Model '${data.model}' (${data.provider}) does not support router '${data.router}'. Supported: ${supportedRouters.join(", ")}`,
173
- params: {
174
- code: import_error_codes.LLMErrorCode.ROUTER_UNSUPPORTED,
175
- scope: import_types.ErrorScope.LLM,
176
- type: import_types.ErrorType.USER
177
- }
178
- });
179
- }
180
- }).brand();
170
+ }).brand();
171
+ }
172
+ const LLMConfigSchema = createLLMConfigSchema({ strict: true });
173
+ const LLMConfigSchemaRelaxed = createLLMConfigSchema({ strict: false });
181
174
  const LLMUpdatesSchema = import_zod.z.object({ ...LLMConfigFields }).partial().superRefine((data, ctx) => {
182
- if (!data.model && !data.provider && !data.router) {
175
+ if (!data.model && !data.provider) {
183
176
  ctx.addIssue({
184
177
  code: import_zod.z.ZodIssueCode.custom,
185
- message: "At least model, provider, or router must be specified for LLM switch",
178
+ message: "At least model or provider must be specified for LLM switch",
186
179
  path: []
187
180
  });
188
181
  }
@@ -191,5 +184,7 @@ const LLMUpdatesSchema = import_zod.z.object({ ...LLMConfigFields }).partial().s
191
184
  0 && (module.exports = {
192
185
  LLMConfigBaseSchema,
193
186
  LLMConfigSchema,
194
- LLMUpdatesSchema
187
+ LLMConfigSchemaRelaxed,
188
+ LLMUpdatesSchema,
189
+ createLLMConfigSchema
195
190
  });