@dexto/core 1.2.4 → 1.2.6

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 (551) hide show
  1. package/README.md +60 -0
  2. package/dist/agent/DextoAgent.cjs +579 -345
  3. package/dist/agent/DextoAgent.d.ts +131 -83
  4. package/dist/agent/DextoAgent.d.ts.map +1 -1
  5. package/dist/agent/DextoAgent.js +573 -336
  6. package/dist/agent/agentCard.cjs +4 -2
  7. package/dist/agent/agentCard.d.ts +0 -1
  8. package/dist/agent/agentCard.d.ts.map +1 -1
  9. package/dist/agent/agentCard.js +4 -2
  10. package/dist/agent/index.cjs +3 -7
  11. package/dist/agent/index.d.ts +3 -3
  12. package/dist/agent/index.d.ts.map +1 -1
  13. package/dist/agent/index.js +7 -6
  14. package/dist/agent/schemas.cjs +179 -75
  15. package/dist/agent/schemas.d.ts +2678 -586
  16. package/dist/agent/schemas.d.ts.map +1 -1
  17. package/dist/agent/schemas.js +172 -65
  18. package/dist/agent/state-manager.cjs +28 -23
  19. package/dist/agent/state-manager.d.ts +4 -1
  20. package/dist/agent/state-manager.d.ts.map +1 -1
  21. package/dist/agent/state-manager.js +28 -23
  22. package/dist/{preferences/constants.cjs → agent/types.cjs} +2 -14
  23. package/dist/agent/types.d.ts +54 -0
  24. package/dist/agent/types.d.ts.map +1 -0
  25. package/dist/agent/types.js +0 -0
  26. package/dist/approval/errors.cjs +89 -8
  27. package/dist/approval/errors.d.ts +5 -3
  28. package/dist/approval/errors.d.ts.map +1 -1
  29. package/dist/approval/errors.js +89 -8
  30. package/dist/approval/{providers/factory.d.ts → factory.d.ts} +2 -2
  31. package/dist/approval/factory.d.ts.map +1 -0
  32. package/dist/approval/{providers/factory.js → factory.js} +1 -1
  33. package/dist/approval/index.cjs +4 -6
  34. package/dist/approval/index.d.ts +3 -5
  35. package/dist/approval/index.d.ts.map +1 -1
  36. package/dist/approval/index.js +4 -5
  37. package/dist/approval/manager.cjs +140 -37
  38. package/dist/approval/manager.d.ts +56 -17
  39. package/dist/approval/manager.d.ts.map +1 -1
  40. package/dist/approval/manager.js +141 -38
  41. package/dist/approval/schemas.cjs +9 -1
  42. package/dist/approval/schemas.d.ts +120 -35
  43. package/dist/approval/schemas.d.ts.map +1 -1
  44. package/dist/approval/schemas.js +9 -2
  45. package/dist/approval/types.cjs +14 -2
  46. package/dist/approval/types.d.ts +64 -12
  47. package/dist/approval/types.d.ts.map +1 -1
  48. package/dist/approval/types.js +12 -1
  49. package/dist/context/compression/middle-removal.cjs +11 -11
  50. package/dist/context/compression/middle-removal.d.ts +3 -1
  51. package/dist/context/compression/middle-removal.d.ts.map +1 -1
  52. package/dist/context/compression/middle-removal.js +11 -11
  53. package/dist/context/compression/oldest-removal.cjs +18 -5
  54. package/dist/context/compression/oldest-removal.d.ts +3 -1
  55. package/dist/context/compression/oldest-removal.d.ts.map +1 -1
  56. package/dist/context/compression/oldest-removal.js +18 -5
  57. package/dist/context/manager.cjs +94 -67
  58. package/dist/context/manager.d.ts +13 -10
  59. package/dist/context/manager.d.ts.map +1 -1
  60. package/dist/context/manager.js +94 -67
  61. package/dist/context/utils.cjs +79 -65
  62. package/dist/context/utils.d.ts +15 -12
  63. package/dist/context/utils.d.ts.map +1 -1
  64. package/dist/context/utils.js +45 -31
  65. package/dist/errors/DextoRuntimeError.d.ts +5 -5
  66. package/dist/errors/DextoRuntimeError.d.ts.map +1 -1
  67. package/dist/errors/result-bridge.cjs +2 -3
  68. package/dist/errors/result-bridge.d.ts +5 -3
  69. package/dist/errors/result-bridge.d.ts.map +1 -1
  70. package/dist/errors/result-bridge.js +1 -2
  71. package/dist/errors/types.cjs +1 -2
  72. package/dist/errors/types.d.ts +5 -8
  73. package/dist/errors/types.d.ts.map +1 -1
  74. package/dist/errors/types.js +1 -2
  75. package/dist/events/index.cjs +125 -55
  76. package/dist/events/index.d.ts +204 -97
  77. package/dist/events/index.d.ts.map +1 -1
  78. package/dist/events/index.js +123 -55
  79. package/dist/filesystem/filesystem-service.cjs +40 -30
  80. package/dist/filesystem/filesystem-service.d.ts +9 -1
  81. package/dist/filesystem/filesystem-service.d.ts.map +1 -1
  82. package/dist/filesystem/filesystem-service.js +40 -30
  83. package/dist/filesystem/path-validator.cjs +4 -3
  84. package/dist/filesystem/path-validator.d.ts +3 -1
  85. package/dist/filesystem/path-validator.d.ts.map +1 -1
  86. package/dist/filesystem/path-validator.js +4 -3
  87. package/dist/filesystem/types.d.ts +3 -3
  88. package/dist/filesystem/types.d.ts.map +1 -1
  89. package/dist/index.browser.cjs +7 -0
  90. package/dist/index.browser.d.ts +2 -0
  91. package/dist/index.browser.d.ts.map +1 -1
  92. package/dist/index.browser.js +4 -0
  93. package/dist/index.cjs +0 -7
  94. package/dist/index.d.ts +12 -3
  95. package/dist/index.d.ts.map +1 -1
  96. package/dist/index.js +0 -4
  97. package/dist/llm/formatters/anthropic.cjs +32 -21
  98. package/dist/llm/formatters/anthropic.d.ts +3 -0
  99. package/dist/llm/formatters/anthropic.d.ts.map +1 -1
  100. package/dist/llm/formatters/anthropic.js +32 -21
  101. package/dist/llm/formatters/factory.cjs +6 -7
  102. package/dist/llm/formatters/factory.d.ts +2 -1
  103. package/dist/llm/formatters/factory.d.ts.map +1 -1
  104. package/dist/llm/formatters/factory.js +4 -5
  105. package/dist/llm/formatters/openai.cjs +38 -9
  106. package/dist/llm/formatters/openai.d.ts +3 -0
  107. package/dist/llm/formatters/openai.d.ts.map +1 -1
  108. package/dist/llm/formatters/openai.js +38 -9
  109. package/dist/llm/formatters/vercel.cjs +49 -8
  110. package/dist/llm/formatters/vercel.d.ts +3 -0
  111. package/dist/llm/formatters/vercel.d.ts.map +1 -1
  112. package/dist/llm/formatters/vercel.js +49 -8
  113. package/dist/llm/registry.cjs +153 -17
  114. package/dist/llm/registry.d.ts +5 -2
  115. package/dist/llm/registry.d.ts.map +1 -1
  116. package/dist/llm/registry.js +143 -7
  117. package/dist/llm/resolver.cjs +4 -4
  118. package/dist/llm/resolver.d.ts +3 -2
  119. package/dist/llm/resolver.d.ts.map +1 -1
  120. package/dist/llm/resolver.js +4 -4
  121. package/dist/llm/schemas.cjs +6 -3
  122. package/dist/llm/schemas.d.ts +51 -17
  123. package/dist/llm/schemas.d.ts.map +1 -1
  124. package/dist/llm/schemas.js +5 -3
  125. package/dist/llm/services/anthropic.cjs +216 -183
  126. package/dist/llm/services/anthropic.d.ts +3 -1
  127. package/dist/llm/services/anthropic.d.ts.map +1 -1
  128. package/dist/llm/services/anthropic.js +217 -184
  129. package/dist/llm/services/factory.cjs +15 -9
  130. package/dist/llm/services/factory.d.ts +2 -1
  131. package/dist/llm/services/factory.d.ts.map +1 -1
  132. package/dist/llm/services/factory.js +15 -9
  133. package/dist/llm/services/openai.cjs +262 -225
  134. package/dist/llm/services/openai.d.ts +3 -1
  135. package/dist/llm/services/openai.d.ts.map +1 -1
  136. package/dist/llm/services/openai.js +263 -226
  137. package/dist/llm/services/test-utils.integration.cjs +58 -12
  138. package/dist/llm/services/test-utils.integration.d.ts.map +1 -1
  139. package/dist/llm/services/test-utils.integration.js +58 -12
  140. package/dist/llm/services/types.d.ts +9 -0
  141. package/dist/llm/services/types.d.ts.map +1 -1
  142. package/dist/llm/services/vercel.cjs +163 -111
  143. package/dist/llm/services/vercel.d.ts +3 -1
  144. package/dist/llm/services/vercel.d.ts.map +1 -1
  145. package/dist/llm/services/vercel.js +157 -105
  146. package/dist/llm/tokenizer/factory.cjs +2 -2
  147. package/dist/llm/tokenizer/factory.d.ts +3 -1
  148. package/dist/llm/tokenizer/factory.d.ts.map +1 -1
  149. package/dist/llm/tokenizer/factory.js +2 -2
  150. package/dist/llm/tokenizer/openai.cjs +16 -9
  151. package/dist/llm/tokenizer/openai.d.ts +4 -1
  152. package/dist/llm/tokenizer/openai.d.ts.map +1 -1
  153. package/dist/llm/tokenizer/openai.js +16 -9
  154. package/dist/llm/validation.cjs +8 -9
  155. package/dist/llm/validation.d.ts +3 -1
  156. package/dist/llm/validation.d.ts.map +1 -1
  157. package/dist/llm/validation.js +5 -6
  158. package/dist/logger/factory.cjs +54 -0
  159. package/dist/logger/factory.d.ts +36 -0
  160. package/dist/logger/factory.d.ts.map +1 -0
  161. package/dist/logger/factory.js +31 -0
  162. package/dist/logger/index.cjs +42 -3
  163. package/dist/logger/index.d.ts +17 -1
  164. package/dist/logger/index.d.ts.map +1 -1
  165. package/dist/logger/index.js +26 -1
  166. package/dist/logger/logger.cjs +30 -17
  167. package/dist/logger/logger.d.ts.map +1 -1
  168. package/dist/logger/logger.js +30 -17
  169. package/dist/logger/v2/dexto-logger.cjs +141 -0
  170. package/dist/logger/v2/dexto-logger.d.ts +54 -0
  171. package/dist/logger/v2/dexto-logger.d.ts.map +1 -0
  172. package/dist/logger/v2/dexto-logger.js +118 -0
  173. package/dist/{preferences → logger/v2}/error-codes.cjs +11 -10
  174. package/dist/logger/v2/error-codes.d.ts +13 -0
  175. package/dist/logger/v2/error-codes.d.ts.map +1 -0
  176. package/dist/logger/v2/error-codes.js +13 -0
  177. package/dist/logger/v2/errors.cjs +107 -0
  178. package/dist/logger/v2/errors.d.ts +32 -0
  179. package/dist/logger/v2/errors.d.ts.map +1 -0
  180. package/dist/logger/v2/errors.js +84 -0
  181. package/dist/logger/v2/schemas.cjs +57 -0
  182. package/dist/logger/v2/schemas.d.ts +147 -0
  183. package/dist/logger/v2/schemas.d.ts.map +1 -0
  184. package/dist/logger/v2/schemas.js +33 -0
  185. package/dist/logger/v2/transport-factory.cjs +53 -0
  186. package/dist/logger/v2/transport-factory.d.ts +21 -0
  187. package/dist/logger/v2/transport-factory.d.ts.map +1 -0
  188. package/dist/logger/v2/transport-factory.js +29 -0
  189. package/dist/logger/v2/transports/console-transport.cjs +79 -0
  190. package/dist/logger/v2/transports/console-transport.d.ts +23 -0
  191. package/dist/logger/v2/transports/console-transport.d.ts.map +1 -0
  192. package/dist/logger/v2/transports/console-transport.js +46 -0
  193. package/dist/logger/v2/transports/file-transport.cjs +161 -0
  194. package/dist/logger/v2/transports/file-transport.d.ts +46 -0
  195. package/dist/logger/v2/transports/file-transport.d.ts.map +1 -0
  196. package/dist/logger/v2/transports/file-transport.js +128 -0
  197. package/dist/logger/v2/types.cjs +49 -0
  198. package/dist/logger/v2/types.d.ts +123 -0
  199. package/dist/logger/v2/types.d.ts.map +1 -0
  200. package/dist/logger/v2/types.js +26 -0
  201. package/dist/mcp/manager.cjs +88 -78
  202. package/dist/mcp/manager.d.ts +3 -1
  203. package/dist/mcp/manager.d.ts.map +1 -1
  204. package/dist/mcp/manager.js +88 -78
  205. package/dist/mcp/mcp-client.cjs +109 -79
  206. package/dist/mcp/mcp-client.d.ts +3 -0
  207. package/dist/mcp/mcp-client.d.ts.map +1 -1
  208. package/dist/mcp/mcp-client.js +102 -72
  209. package/dist/memory/index.cjs +2 -0
  210. package/dist/memory/index.d.ts +1 -1
  211. package/dist/memory/index.d.ts.map +1 -1
  212. package/dist/memory/index.js +3 -1
  213. package/dist/memory/manager.cjs +9 -7
  214. package/dist/memory/manager.d.ts +3 -1
  215. package/dist/memory/manager.d.ts.map +1 -1
  216. package/dist/memory/manager.js +9 -7
  217. package/dist/memory/schemas.cjs +10 -0
  218. package/dist/memory/schemas.d.ts +37 -8
  219. package/dist/memory/schemas.d.ts.map +1 -1
  220. package/dist/memory/schemas.js +9 -0
  221. package/dist/plugins/manager.cjs +21 -19
  222. package/dist/plugins/manager.d.ts +3 -1
  223. package/dist/plugins/manager.d.ts.map +1 -1
  224. package/dist/plugins/manager.js +21 -19
  225. package/dist/plugins/schemas.d.ts +9 -9
  226. package/dist/plugins/types.d.ts +2 -2
  227. package/dist/plugins/types.d.ts.map +1 -1
  228. package/dist/process/command-validator.cjs +30 -20
  229. package/dist/process/command-validator.d.ts +4 -1
  230. package/dist/process/command-validator.d.ts.map +1 -1
  231. package/dist/process/command-validator.js +30 -20
  232. package/dist/process/process-service.cjs +23 -21
  233. package/dist/process/process-service.d.ts +3 -1
  234. package/dist/process/process-service.d.ts.map +1 -1
  235. package/dist/process/process-service.js +23 -21
  236. package/dist/prompts/index.cjs +6 -8
  237. package/dist/prompts/index.d.ts +2 -4
  238. package/dist/prompts/index.d.ts.map +1 -1
  239. package/dist/prompts/index.js +4 -6
  240. package/dist/prompts/prompt-manager.cjs +25 -20
  241. package/dist/prompts/prompt-manager.d.ts +3 -1
  242. package/dist/prompts/prompt-manager.d.ts.map +1 -1
  243. package/dist/prompts/prompt-manager.js +25 -20
  244. package/dist/prompts/providers/config-prompt-provider.cjs +331 -0
  245. package/dist/prompts/providers/config-prompt-provider.d.ts +34 -0
  246. package/dist/prompts/providers/config-prompt-provider.d.ts.map +1 -0
  247. package/dist/prompts/providers/config-prompt-provider.js +308 -0
  248. package/dist/prompts/providers/custom-prompt-provider.cjs +11 -7
  249. package/dist/prompts/providers/custom-prompt-provider.d.ts +3 -1
  250. package/dist/prompts/providers/custom-prompt-provider.d.ts.map +1 -1
  251. package/dist/prompts/providers/custom-prompt-provider.js +11 -7
  252. package/dist/prompts/providers/mcp-prompt-provider.cjs +7 -6
  253. package/dist/prompts/providers/mcp-prompt-provider.d.ts +3 -1
  254. package/dist/prompts/providers/mcp-prompt-provider.d.ts.map +1 -1
  255. package/dist/prompts/providers/mcp-prompt-provider.js +7 -6
  256. package/dist/prompts/schemas.cjs +42 -23
  257. package/dist/prompts/schemas.d.ts +123 -14
  258. package/dist/prompts/schemas.d.ts.map +1 -1
  259. package/dist/prompts/schemas.js +39 -22
  260. package/dist/prompts/types.d.ts +1 -1
  261. package/dist/prompts/types.d.ts.map +1 -1
  262. package/dist/resources/handlers/blob-handler.cjs +15 -11
  263. package/dist/resources/handlers/blob-handler.d.ts +3 -1
  264. package/dist/resources/handlers/blob-handler.d.ts.map +1 -1
  265. package/dist/resources/handlers/blob-handler.js +15 -11
  266. package/dist/resources/handlers/factory.cjs +3 -3
  267. package/dist/resources/handlers/factory.d.ts +2 -1
  268. package/dist/resources/handlers/factory.d.ts.map +1 -1
  269. package/dist/resources/handlers/factory.js +3 -3
  270. package/dist/resources/handlers/filesystem-handler.cjs +10 -8
  271. package/dist/resources/handlers/filesystem-handler.d.ts +3 -1
  272. package/dist/resources/handlers/filesystem-handler.d.ts.map +1 -1
  273. package/dist/resources/handlers/filesystem-handler.js +10 -8
  274. package/dist/resources/internal-provider.cjs +28 -20
  275. package/dist/resources/internal-provider.d.ts +3 -1
  276. package/dist/resources/internal-provider.d.ts.map +1 -1
  277. package/dist/resources/internal-provider.js +28 -20
  278. package/dist/resources/manager.cjs +34 -25
  279. package/dist/resources/manager.d.ts +3 -1
  280. package/dist/resources/manager.d.ts.map +1 -1
  281. package/dist/resources/manager.js +34 -25
  282. package/dist/resources/schemas.d.ts +6 -6
  283. package/dist/search/search-service.cjs +8 -6
  284. package/dist/search/search-service.d.ts +3 -1
  285. package/dist/search/search-service.d.ts.map +1 -1
  286. package/dist/search/search-service.js +8 -6
  287. package/dist/session/chat-session.cjs +40 -27
  288. package/dist/session/chat-session.d.ts +10 -7
  289. package/dist/session/chat-session.d.ts.map +1 -1
  290. package/dist/session/chat-session.js +40 -27
  291. package/dist/session/history/database.cjs +18 -11
  292. package/dist/session/history/database.d.ts +3 -1
  293. package/dist/session/history/database.d.ts.map +1 -1
  294. package/dist/session/history/database.js +18 -11
  295. package/dist/session/history/factory.cjs +2 -2
  296. package/dist/session/history/factory.d.ts +5 -1
  297. package/dist/session/history/factory.d.ts.map +1 -1
  298. package/dist/session/history/factory.js +2 -2
  299. package/dist/session/session-manager.cjs +37 -53
  300. package/dist/session/session-manager.d.ts +3 -17
  301. package/dist/session/session-manager.d.ts.map +1 -1
  302. package/dist/session/session-manager.js +37 -53
  303. package/dist/session/title-generator.cjs +3 -2
  304. package/dist/session/title-generator.d.ts +2 -1
  305. package/dist/session/title-generator.d.ts.map +1 -1
  306. package/dist/session/title-generator.js +3 -2
  307. package/dist/storage/blob/factory.cjs +9 -18
  308. package/dist/storage/blob/factory.d.ts +5 -4
  309. package/dist/storage/blob/factory.d.ts.map +1 -1
  310. package/dist/storage/blob/factory.js +8 -17
  311. package/dist/storage/blob/local-blob-store.cjs +25 -32
  312. package/dist/storage/blob/local-blob-store.d.ts +3 -2
  313. package/dist/storage/blob/local-blob-store.d.ts.map +1 -1
  314. package/dist/storage/blob/local-blob-store.js +25 -32
  315. package/dist/storage/blob/memory-blob-store.cjs +326 -0
  316. package/dist/storage/blob/memory-blob-store.d.ts +66 -0
  317. package/dist/storage/blob/memory-blob-store.d.ts.map +1 -0
  318. package/dist/storage/blob/memory-blob-store.js +303 -0
  319. package/dist/storage/blob/schemas.cjs +3 -1
  320. package/dist/storage/blob/schemas.d.ts +6 -6
  321. package/dist/storage/blob/schemas.d.ts.map +1 -1
  322. package/dist/storage/blob/schemas.js +3 -1
  323. package/dist/storage/cache/factory.cjs +7 -8
  324. package/dist/storage/cache/factory.d.ts +4 -1
  325. package/dist/storage/cache/factory.d.ts.map +1 -1
  326. package/dist/storage/cache/factory.js +4 -5
  327. package/dist/storage/cache/redis-store.cjs +4 -1
  328. package/dist/storage/cache/redis-store.d.ts +3 -1
  329. package/dist/storage/cache/redis-store.d.ts.map +1 -1
  330. package/dist/storage/cache/redis-store.js +4 -1
  331. package/dist/storage/database/factory.cjs +13 -16
  332. package/dist/storage/database/factory.d.ts +5 -3
  333. package/dist/storage/database/factory.d.ts.map +1 -1
  334. package/dist/storage/database/factory.js +9 -12
  335. package/dist/storage/database/postgres-store.cjs +4 -1
  336. package/dist/storage/database/postgres-store.d.ts +3 -1
  337. package/dist/storage/database/postgres-store.d.ts.map +1 -1
  338. package/dist/storage/database/postgres-store.js +4 -1
  339. package/dist/storage/database/schemas.cjs +3 -4
  340. package/dist/storage/database/schemas.d.ts +8 -16
  341. package/dist/storage/database/schemas.d.ts.map +1 -1
  342. package/dist/storage/database/schemas.js +3 -4
  343. package/dist/storage/database/sqlite-store.cjs +17 -45
  344. package/dist/storage/database/sqlite-store.d.ts +3 -3
  345. package/dist/storage/database/sqlite-store.d.ts.map +1 -1
  346. package/dist/storage/database/sqlite-store.js +17 -45
  347. package/dist/storage/schemas.cjs +3 -1
  348. package/dist/storage/schemas.d.ts +16 -23
  349. package/dist/storage/schemas.d.ts.map +1 -1
  350. package/dist/storage/schemas.js +3 -1
  351. package/dist/storage/storage-manager.cjs +15 -15
  352. package/dist/storage/storage-manager.d.ts +6 -6
  353. package/dist/storage/storage-manager.d.ts.map +1 -1
  354. package/dist/storage/storage-manager.js +15 -15
  355. package/dist/systemPrompt/contributors.cjs +15 -15
  356. package/dist/systemPrompt/contributors.d.ts +5 -3
  357. package/dist/systemPrompt/contributors.d.ts.map +1 -1
  358. package/dist/systemPrompt/contributors.js +15 -15
  359. package/dist/systemPrompt/in-built-prompts.cjs +0 -5
  360. package/dist/systemPrompt/in-built-prompts.d.ts +1 -2
  361. package/dist/systemPrompt/in-built-prompts.d.ts.map +1 -1
  362. package/dist/systemPrompt/in-built-prompts.js +0 -4
  363. package/dist/systemPrompt/manager.cjs +31 -23
  364. package/dist/systemPrompt/manager.d.ts +5 -3
  365. package/dist/systemPrompt/manager.d.ts.map +1 -1
  366. package/dist/systemPrompt/manager.js +31 -23
  367. package/dist/systemPrompt/registry.cjs +1 -2
  368. package/dist/systemPrompt/registry.d.ts +1 -1
  369. package/dist/systemPrompt/registry.d.ts.map +1 -1
  370. package/dist/systemPrompt/registry.js +1 -2
  371. package/dist/systemPrompt/schemas.cjs +24 -18
  372. package/dist/systemPrompt/schemas.d.ts +46 -222
  373. package/dist/systemPrompt/schemas.d.ts.map +1 -1
  374. package/dist/systemPrompt/schemas.js +14 -18
  375. package/dist/telemetry/decorators.cjs +54 -15
  376. package/dist/telemetry/decorators.d.ts.map +1 -1
  377. package/dist/telemetry/decorators.js +54 -15
  378. package/dist/telemetry/utils.cjs +21 -14
  379. package/dist/telemetry/utils.d.ts +7 -3
  380. package/dist/telemetry/utils.d.ts.map +1 -1
  381. package/dist/telemetry/utils.js +21 -14
  382. package/dist/tools/confirmation/allowed-tools-provider/factory.cjs +2 -2
  383. package/dist/tools/confirmation/allowed-tools-provider/factory.d.ts +2 -1
  384. package/dist/tools/confirmation/allowed-tools-provider/factory.d.ts.map +1 -1
  385. package/dist/tools/confirmation/allowed-tools-provider/factory.js +2 -2
  386. package/dist/tools/confirmation/allowed-tools-provider/storage.cjs +7 -6
  387. package/dist/tools/confirmation/allowed-tools-provider/storage.d.ts +3 -1
  388. package/dist/tools/confirmation/allowed-tools-provider/storage.d.ts.map +1 -1
  389. package/dist/tools/confirmation/allowed-tools-provider/storage.js +7 -6
  390. package/dist/tools/errors.cjs +2 -1
  391. package/dist/tools/errors.d.ts.map +1 -1
  392. package/dist/tools/errors.js +2 -1
  393. package/dist/tools/internal-tools/constants.cjs +2 -1
  394. package/dist/tools/internal-tools/constants.d.ts +1 -1
  395. package/dist/tools/internal-tools/constants.d.ts.map +1 -1
  396. package/dist/tools/internal-tools/constants.js +2 -1
  397. package/dist/tools/internal-tools/implementations/bash-exec-tool.cjs +1 -1
  398. package/dist/tools/internal-tools/implementations/bash-exec-tool.js +1 -1
  399. package/dist/tools/internal-tools/implementations/delegate-to-url-tool.cjs +192 -0
  400. package/dist/tools/internal-tools/implementations/delegate-to-url-tool.d.ts +33 -0
  401. package/dist/tools/internal-tools/implementations/delegate-to-url-tool.d.ts.map +1 -0
  402. package/dist/tools/internal-tools/implementations/delegate-to-url-tool.js +169 -0
  403. package/dist/tools/internal-tools/provider.cjs +21 -17
  404. package/dist/tools/internal-tools/provider.d.ts +3 -1
  405. package/dist/tools/internal-tools/provider.d.ts.map +1 -1
  406. package/dist/tools/internal-tools/provider.js +21 -17
  407. package/dist/tools/internal-tools/registry.cjs +5 -0
  408. package/dist/tools/internal-tools/registry.d.ts.map +1 -1
  409. package/dist/tools/internal-tools/registry.js +5 -0
  410. package/dist/tools/schemas.cjs +16 -4
  411. package/dist/tools/schemas.d.ts +21 -9
  412. package/dist/tools/schemas.d.ts.map +1 -1
  413. package/dist/tools/schemas.js +15 -4
  414. package/dist/tools/tool-manager.cjs +64 -47
  415. package/dist/tools/tool-manager.d.ts +4 -2
  416. package/dist/tools/tool-manager.d.ts.map +1 -1
  417. package/dist/tools/tool-manager.js +61 -44
  418. package/dist/tools/types.d.ts +0 -4
  419. package/dist/tools/types.d.ts.map +1 -1
  420. package/dist/utils/env-file.cjs +118 -0
  421. package/dist/utils/env-file.d.ts +5 -0
  422. package/dist/utils/env-file.d.ts.map +1 -0
  423. package/dist/utils/env-file.js +85 -0
  424. package/dist/utils/error-conversion.cjs +23 -1
  425. package/dist/utils/error-conversion.d.ts +2 -1
  426. package/dist/utils/error-conversion.d.ts.map +1 -1
  427. package/dist/utils/error-conversion.js +23 -1
  428. package/dist/utils/execution-context.d.ts.map +1 -1
  429. package/dist/utils/fs-walk.d.ts.map +1 -1
  430. package/dist/utils/index.cjs +7 -9
  431. package/dist/utils/index.d.ts +3 -4
  432. package/dist/utils/index.d.ts.map +1 -1
  433. package/dist/utils/index.js +3 -4
  434. package/dist/utils/path.cjs +22 -57
  435. package/dist/utils/path.d.ts +8 -7
  436. package/dist/utils/path.d.ts.map +1 -1
  437. package/dist/utils/path.js +21 -54
  438. package/dist/utils/result.cjs +37 -14
  439. package/dist/utils/result.d.ts.map +1 -1
  440. package/dist/utils/result.js +37 -14
  441. package/dist/utils/schema.cjs +2 -3
  442. package/dist/utils/schema.d.ts +2 -1
  443. package/dist/utils/schema.d.ts.map +1 -1
  444. package/dist/utils/schema.js +1 -2
  445. package/dist/utils/service-initializer.cjs +88 -61
  446. package/dist/utils/service-initializer.d.ts +4 -2
  447. package/dist/utils/service-initializer.d.ts.map +1 -1
  448. package/dist/utils/service-initializer.js +70 -43
  449. package/package.json +7 -3
  450. package/dist/Dexto.cjs +0 -251
  451. package/dist/Dexto.d.ts +0 -191
  452. package/dist/Dexto.d.ts.map +0 -1
  453. package/dist/Dexto.js +0 -228
  454. package/dist/agent/registry/error-codes.cjs +0 -44
  455. package/dist/agent/registry/error-codes.d.ts +0 -21
  456. package/dist/agent/registry/error-codes.d.ts.map +0 -1
  457. package/dist/agent/registry/error-codes.js +0 -21
  458. package/dist/agent/registry/errors.cjs +0 -188
  459. package/dist/agent/registry/errors.d.ts +0 -63
  460. package/dist/agent/registry/errors.d.ts.map +0 -1
  461. package/dist/agent/registry/errors.js +0 -165
  462. package/dist/agent/registry/registry.cjs +0 -479
  463. package/dist/agent/registry/registry.d.ts +0 -130
  464. package/dist/agent/registry/registry.d.ts.map +0 -1
  465. package/dist/agent/registry/registry.js +0 -453
  466. package/dist/agent/registry/types.cjs +0 -74
  467. package/dist/agent/registry/types.d.ts +0 -142
  468. package/dist/agent/registry/types.d.ts.map +0 -1
  469. package/dist/agent/registry/types.js +0 -48
  470. package/dist/agent/registry/user-registry.cjs +0 -140
  471. package/dist/agent/registry/user-registry.d.ts +0 -34
  472. package/dist/agent/registry/user-registry.d.ts.map +0 -1
  473. package/dist/agent/registry/user-registry.js +0 -105
  474. package/dist/approval/providers/event-based-approval-provider.cjs +0 -156
  475. package/dist/approval/providers/event-based-approval-provider.d.ts +0 -39
  476. package/dist/approval/providers/event-based-approval-provider.d.ts.map +0 -1
  477. package/dist/approval/providers/event-based-approval-provider.js +0 -133
  478. package/dist/approval/providers/factory.d.ts.map +0 -1
  479. package/dist/approval/providers/noop-approval-provider.cjs +0 -54
  480. package/dist/approval/providers/noop-approval-provider.d.ts +0 -18
  481. package/dist/approval/providers/noop-approval-provider.d.ts.map +0 -1
  482. package/dist/approval/providers/noop-approval-provider.js +0 -31
  483. package/dist/config/agent-resolver.cjs +0 -153
  484. package/dist/config/agent-resolver.d.ts +0 -14
  485. package/dist/config/agent-resolver.d.ts.map +0 -1
  486. package/dist/config/agent-resolver.js +0 -123
  487. package/dist/config/error-codes.cjs +0 -39
  488. package/dist/config/error-codes.d.ts +0 -16
  489. package/dist/config/error-codes.d.ts.map +0 -1
  490. package/dist/config/error-codes.js +0 -16
  491. package/dist/config/errors.cjs +0 -126
  492. package/dist/config/errors.d.ts +0 -34
  493. package/dist/config/errors.d.ts.map +0 -1
  494. package/dist/config/errors.js +0 -103
  495. package/dist/config/index.cjs +0 -26
  496. package/dist/config/index.d.ts +0 -4
  497. package/dist/config/index.d.ts.map +0 -1
  498. package/dist/config/index.js +0 -3
  499. package/dist/config/loader.cjs +0 -119
  500. package/dist/config/loader.d.ts +0 -16
  501. package/dist/config/loader.d.ts.map +0 -1
  502. package/dist/config/loader.js +0 -86
  503. package/dist/config/writer.cjs +0 -182
  504. package/dist/config/writer.d.ts +0 -35
  505. package/dist/config/writer.d.ts.map +0 -1
  506. package/dist/config/writer.js +0 -147
  507. package/dist/preferences/constants.d.ts +0 -2
  508. package/dist/preferences/constants.d.ts.map +0 -1
  509. package/dist/preferences/constants.js +0 -5
  510. package/dist/preferences/error-codes.d.ts +0 -8
  511. package/dist/preferences/error-codes.d.ts.map +0 -1
  512. package/dist/preferences/error-codes.js +0 -12
  513. package/dist/preferences/errors.cjs +0 -75
  514. package/dist/preferences/errors.d.ts +0 -18
  515. package/dist/preferences/errors.d.ts.map +0 -1
  516. package/dist/preferences/errors.js +0 -51
  517. package/dist/preferences/index.cjs +0 -55
  518. package/dist/preferences/index.d.ts +0 -6
  519. package/dist/preferences/index.d.ts.map +0 -1
  520. package/dist/preferences/index.js +0 -32
  521. package/dist/preferences/loader.cjs +0 -138
  522. package/dist/preferences/loader.d.ts +0 -51
  523. package/dist/preferences/loader.d.ts.map +0 -1
  524. package/dist/preferences/loader.js +0 -110
  525. package/dist/preferences/schemas.cjs +0 -75
  526. package/dist/preferences/schemas.d.ts +0 -110
  527. package/dist/preferences/schemas.d.ts.map +0 -1
  528. package/dist/preferences/schemas.js +0 -49
  529. package/dist/prompts/providers/file-prompt-provider.cjs +0 -399
  530. package/dist/prompts/providers/file-prompt-provider.d.ts +0 -47
  531. package/dist/prompts/providers/file-prompt-provider.d.ts.map +0 -1
  532. package/dist/prompts/providers/file-prompt-provider.js +0 -376
  533. package/dist/prompts/providers/starter-prompt-provider.cjs +0 -170
  534. package/dist/prompts/providers/starter-prompt-provider.d.ts +0 -45
  535. package/dist/prompts/providers/starter-prompt-provider.d.ts.map +0 -1
  536. package/dist/prompts/providers/starter-prompt-provider.js +0 -147
  537. package/dist/utils/api-key-store.cjs +0 -56
  538. package/dist/utils/api-key-store.d.ts +0 -24
  539. package/dist/utils/api-key-store.d.ts.map +0 -1
  540. package/dist/utils/api-key-store.js +0 -31
  541. package/dist/utils/env.cjs +0 -154
  542. package/dist/utils/env.d.ts +0 -28
  543. package/dist/utils/env.d.ts.map +0 -1
  544. package/dist/utils/env.js +0 -119
  545. package/dist/utils/port-utils.cjs +0 -37
  546. package/dist/utils/port-utils.d.ts +0 -10
  547. package/dist/utils/port-utils.d.ts.map +0 -1
  548. package/dist/utils/port-utils.js +0 -14
  549. package/dist/utils/port-utils.spec.cjs +0 -26
  550. package/dist/utils/port-utils.spec.js +0 -25
  551. /package/dist/approval/{providers/factory.cjs → factory.cjs} +0 -0
@@ -5,7 +5,7 @@ import {
5
5
  SessionEventBus,
6
6
  SessionEventNames
7
7
  } from "../events/index.js";
8
- import { logger } from "../logger/index.js";
8
+ import { DextoLogComponent } from "../logger/v2/types.js";
9
9
  import { DextoRuntimeError, ErrorScope, ErrorType } from "../errors/index.js";
10
10
  import { PluginErrorCode } from "../plugins/error-codes.js";
11
11
  class ChatSession {
@@ -19,13 +19,15 @@ class ChatSession {
19
19
  *
20
20
  * @param services - The shared services from the agent (state manager, prompt, client managers, etc.)
21
21
  * @param id - Unique identifier for this session
22
+ * @param logger - Logger instance for dependency injection
22
23
  */
23
- constructor(services, id) {
24
+ constructor(services, id, logger) {
24
25
  this.services = services;
25
26
  this.id = id;
27
+ this.logger = logger.createChild(DextoLogComponent.SESSION);
26
28
  this.eventBus = new SessionEventBus();
27
29
  this.setupEventForwarding();
28
- logger.debug(`ChatSession ${this.id}: Created, awaiting initialization`);
30
+ this.logger.debug(`ChatSession ${this.id}: Created, awaiting initialization`);
29
31
  }
30
32
  /**
31
33
  * Session-scoped event emitter for handling conversation events.
@@ -34,9 +36,9 @@ class ChatSession {
34
36
  * to the global agent event bus.
35
37
  *
36
38
  * Events emitted include:
37
- * - `llmservice:thinking` - AI model is processing
38
- * - `llmservice:toolCall` - Tool execution requested
39
- * - `llmservice:response` - Final response generated
39
+ * - `llm:thinking` - AI model is processing
40
+ * - `llm:tool-call` - Tool execution requested
41
+ * - `llm:response` - Final response generated
40
42
  */
41
43
  eventBus;
42
44
  /**
@@ -61,6 +63,7 @@ class ChatSession {
61
63
  * Calling cancel() aborts the in-flight LLM request and tool execution checks.
62
64
  */
63
65
  currentRunController = null;
66
+ logger;
64
67
  /**
65
68
  * Initialize the session services asynchronously.
66
69
  * This must be called after construction to set up the storage-backed services.
@@ -80,14 +83,14 @@ class ChatSession {
80
83
  SessionEventNames.forEach((eventName) => {
81
84
  const forwarder = (payload) => {
82
85
  const payloadWithSession = payload && typeof payload === "object" ? { ...payload, sessionId: this.id } : { sessionId: this.id };
83
- logger.silly(
84
- `Forwarding session event ${eventName} to agent bus with session context: ${JSON.stringify(payloadWithSession, null, 2)}`
85
- );
86
86
  this.services.agentEventBus.emit(eventName, payloadWithSession);
87
87
  };
88
88
  this.forwarders.set(eventName, forwarder);
89
89
  this.eventBus.on(eventName, forwarder);
90
90
  });
91
+ this.logger.debug(
92
+ `[setupEventForwarding] Event forwarding setup complete for session=${this.id}`
93
+ );
91
94
  }
92
95
  /**
93
96
  * Initializes session-specific services.
@@ -96,7 +99,8 @@ class ChatSession {
96
99
  const llmConfig = this.services.stateManager.getLLMConfig(this.id);
97
100
  this.historyProvider = createDatabaseHistoryProvider(
98
101
  this.services.storageManager.getDatabase(),
99
- this.id
102
+ this.id,
103
+ this.logger
100
104
  );
101
105
  this.llmService = createLLMService(
102
106
  llmConfig,
@@ -108,10 +112,12 @@ class ChatSession {
108
112
  this.eventBus,
109
113
  // Use session event bus
110
114
  this.id,
111
- this.services.resourceManager
115
+ this.services.resourceManager,
112
116
  // Pass ResourceManager for blob storage
117
+ this.logger
118
+ // Pass logger for dependency injection
113
119
  );
114
- logger.debug(`ChatSession ${this.id}: Services initialized with storage`);
120
+ this.logger.debug(`ChatSession ${this.id}: Services initialized with storage`);
115
121
  }
116
122
  /**
117
123
  * Saves a blocked interaction to history when a plugin blocks execution.
@@ -137,7 +143,7 @@ class ChatSession {
137
143
  await this.historyProvider.saveMessage(userMessage);
138
144
  await this.historyProvider.saveMessage(assistantMessage);
139
145
  const llmConfig = this.services.stateManager.getLLMConfig(this.id);
140
- this.eventBus.emit("llmservice:response", {
146
+ this.eventBus.emit("llm:response", {
141
147
  content: errorContent,
142
148
  provider: llmConfig.provider,
143
149
  model: llmConfig.model,
@@ -168,7 +174,7 @@ class ChatSession {
168
174
  * ```
169
175
  */
170
176
  async run(input, imageDataInput, fileDataInput, stream) {
171
- logger.debug(
177
+ this.logger.debug(
172
178
  `Running session ${this.id} | input.len=${input?.length ?? 0} | image=${imageDataInput ? imageDataInput.mimeType : "none"} | file=${fileDataInput ? `${fileDataInput.mimeType}:${fileDataInput.filename ?? "unknown"}` : "none"}`
173
179
  );
174
180
  this.currentRunController = new AbortController();
@@ -226,7 +232,7 @@ class ChatSession {
226
232
  } catch (error) {
227
233
  const aborted = error instanceof Error && error.name === "AbortError" || typeof error === "object" && error !== null && error.aborted === true;
228
234
  if (aborted) {
229
- this.eventBus.emit("llmservice:error", {
235
+ this.eventBus.emit("llm:error", {
230
236
  error: new Error("Run cancelled"),
231
237
  context: "user_cancelled",
232
238
  recoverable: true
@@ -241,14 +247,20 @@ class ChatSession {
241
247
  imageDataInput,
242
248
  fileDataInput
243
249
  );
244
- logger.debug(`ChatSession ${this.id}: Saved blocked interaction to history`);
250
+ this.logger.debug(
251
+ `ChatSession ${this.id}: Saved blocked interaction to history`
252
+ );
245
253
  } catch (saveError) {
246
- logger.warn(
254
+ this.logger.warn(
247
255
  `Failed to save blocked interaction to history: ${saveError instanceof Error ? saveError.message : String(saveError)}`
248
256
  );
249
257
  }
250
258
  return error.message;
251
259
  }
260
+ const errortype = error instanceof Error ? "object" : "string";
261
+ this.logger.error(
262
+ `Error in ChatSession.run: errortype=${errortype}: ${error instanceof Error ? error.message : String(error)}`
263
+ );
252
264
  throw error;
253
265
  } finally {
254
266
  this.currentRunController = null;
@@ -284,7 +296,7 @@ class ChatSession {
284
296
  * This method:
285
297
  * 1. Clears all messages from the session's conversation history
286
298
  * 2. Removes persisted history from the storage provider
287
- * 3. Emits a `dexto:conversationReset` event with session context
299
+ * 3. Emits a `session:reset` event with session context
288
300
  *
289
301
  * The system prompt and session configuration remain unchanged.
290
302
  * Only the conversation messages are cleared.
@@ -301,7 +313,7 @@ class ChatSession {
301
313
  */
302
314
  async reset() {
303
315
  await this.historyProvider.clearHistory();
304
- this.services.agentEventBus.emit("dexto:conversationReset", {
316
+ this.services.agentEventBus.emit("session:reset", {
305
317
  sessionId: this.id
306
318
  });
307
319
  }
@@ -354,19 +366,20 @@ class ChatSession {
354
366
  this.eventBus,
355
367
  // Use session event bus
356
368
  this.id,
357
- this.services.resourceManager
369
+ this.services.resourceManager,
370
+ this.logger
358
371
  );
359
372
  this.llmService = newLLMService;
360
- logger.info(
373
+ this.logger.info(
361
374
  `ChatSession ${this.id}: LLM switched to ${newLLMConfig.provider}/${newLLMConfig.model}`
362
375
  );
363
- this.eventBus.emit("llmservice:switched", {
376
+ this.eventBus.emit("llm:switched", {
364
377
  newConfig: newLLMConfig,
365
378
  router,
366
379
  historyRetained: true
367
380
  });
368
381
  } catch (error) {
369
- logger.error(
382
+ this.logger.error(
370
383
  `Error during ChatSession.switchLLM for session ${this.id}: ${error instanceof Error ? error.message : String(error)}`
371
384
  );
372
385
  throw error;
@@ -380,11 +393,11 @@ class ChatSession {
380
393
  async cleanup() {
381
394
  try {
382
395
  this.dispose();
383
- logger.debug(
396
+ this.logger.debug(
384
397
  `ChatSession ${this.id}: Memory cleanup completed (chat history preserved)`
385
398
  );
386
399
  } catch (error) {
387
- logger.error(
400
+ this.logger.error(
388
401
  `Error during ChatSession cleanup for session ${this.id}: ${error instanceof Error ? error.message : String(error)}`
389
402
  );
390
403
  throw error;
@@ -398,12 +411,12 @@ class ChatSession {
398
411
  * Without this cleanup, sessions would remain in memory due to listener references.
399
412
  */
400
413
  dispose() {
401
- logger.debug(`Disposing session ${this.id} - cleaning up event listeners`);
414
+ this.logger.debug(`Disposing session ${this.id} - cleaning up event listeners`);
402
415
  this.forwarders.forEach((forwarder, eventName) => {
403
416
  this.eventBus.off(eventName, forwarder);
404
417
  });
405
418
  this.forwarders.clear();
406
- logger.debug(`Session ${this.id} disposed successfully`);
419
+ this.logger.debug(`Session ${this.id} disposed successfully`);
407
420
  }
408
421
  /**
409
422
  * Cancel the currently running turn for this session, if any.
@@ -21,23 +21,25 @@ __export(database_exports, {
21
21
  DatabaseHistoryProvider: () => DatabaseHistoryProvider
22
22
  });
23
23
  module.exports = __toCommonJS(database_exports);
24
- var import_logger = require("../../logger/index.cjs");
24
+ var import_types = require("../../logger/v2/types.cjs");
25
25
  var import_errors = require("../errors.js");
26
26
  class DatabaseHistoryProvider {
27
- constructor(sessionId, database) {
27
+ constructor(sessionId, database, logger) {
28
28
  this.sessionId = sessionId;
29
29
  this.database = database;
30
+ this.logger = logger.createChild(import_types.DextoLogComponent.SESSION);
30
31
  }
32
+ logger;
31
33
  async getHistory() {
32
34
  const key = this.getMessagesKey();
33
35
  try {
34
36
  const messages = await this.database.getRange(key, 0, 1e3);
35
- import_logger.logger.debug(
37
+ this.logger.debug(
36
38
  `DatabaseHistoryProvider: Retrieved ${messages.length} messages for session ${this.sessionId}`
37
39
  );
38
40
  return messages;
39
41
  } catch (error) {
40
- import_logger.logger.error(
42
+ this.logger.error(
41
43
  `DatabaseHistoryProvider: Error retrieving messages for session ${this.sessionId}: ${error instanceof Error ? error.message : String(error)}`
42
44
  );
43
45
  return [];
@@ -55,12 +57,15 @@ class DatabaseHistoryProvider {
55
57
  contentPreview = `[${message.content.length} parts]`;
56
58
  }
57
59
  }
58
- import_logger.logger.debug(`DatabaseHistoryProvider: Saved message for session ${this.sessionId}`, {
59
- role: message.role,
60
- content: contentPreview
61
- });
60
+ this.logger.debug(
61
+ `DatabaseHistoryProvider: Saved message for session ${this.sessionId}`,
62
+ {
63
+ role: message.role,
64
+ content: contentPreview
65
+ }
66
+ );
62
67
  } catch (error) {
63
- import_logger.logger.error(
68
+ this.logger.error(
64
69
  `DatabaseHistoryProvider: Error saving message for session ${this.sessionId}: ${error instanceof Error ? error.message : String(error)}`
65
70
  );
66
71
  throw import_errors.SessionError.storageFailed(
@@ -74,9 +79,11 @@ class DatabaseHistoryProvider {
74
79
  const key = this.getMessagesKey();
75
80
  try {
76
81
  await this.database.delete(key);
77
- import_logger.logger.debug(`DatabaseHistoryProvider: Cleared history for session ${this.sessionId}`);
82
+ this.logger.debug(
83
+ `DatabaseHistoryProvider: Cleared history for session ${this.sessionId}`
84
+ );
78
85
  } catch (error) {
79
- import_logger.logger.error(
86
+ this.logger.error(
80
87
  `DatabaseHistoryProvider: Error clearing session ${this.sessionId}: ${error instanceof Error ? error.message : String(error)}`
81
88
  );
82
89
  throw import_errors.SessionError.resetFailed(
@@ -1,3 +1,4 @@
1
+ import type { IDextoLogger } from '../../logger/v2/types.js';
1
2
  import type { Database } from '../../storage/types.js';
2
3
  import type { InternalMessage } from '../../context/types.js';
3
4
  import type { IConversationHistoryProvider } from './types.js';
@@ -16,7 +17,8 @@ import type { IConversationHistoryProvider } from './types.js';
16
17
  export declare class DatabaseHistoryProvider implements IConversationHistoryProvider {
17
18
  private sessionId;
18
19
  private database;
19
- constructor(sessionId: string, database: Database);
20
+ private logger;
21
+ constructor(sessionId: string, database: Database, logger: IDextoLogger);
20
22
  getHistory(): Promise<InternalMessage[]>;
21
23
  saveMessage(message: InternalMessage): Promise<void>;
22
24
  clearHistory(): Promise<void>;
@@ -1 +1 @@
1
- {"version":3,"file":"database.d.ts","sourceRoot":"","sources":["../../../src/session/history/database.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAEvD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,YAAY,CAAC;AAE/D;;;;;;;;;;;GAWG;AACH,qBAAa,uBAAwB,YAAW,4BAA4B;IAEpE,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,QAAQ;gBADR,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,QAAQ;IAGxB,UAAU,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;IAmBxC,WAAW,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAkCpD,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAgBnC,OAAO,CAAC,cAAc;CAGzB"}
1
+ {"version":3,"file":"database.d.ts","sourceRoot":"","sources":["../../../src/session/history/database.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAE7D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAEvD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,YAAY,CAAC;AAE/D;;;;;;;;;;;GAWG;AACH,qBAAa,uBAAwB,YAAW,4BAA4B;IAIpE,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,QAAQ;IAJpB,OAAO,CAAC,MAAM,CAAe;gBAGjB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,QAAQ,EAC1B,MAAM,EAAE,YAAY;IAKlB,UAAU,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;IAmBxC,WAAW,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAqCpD,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAkBnC,OAAO,CAAC,cAAc;CAGzB"}
@@ -1,21 +1,23 @@
1
1
  import "../../chunk-C6A6W6XS.js";
2
- import { logger } from "../../logger/index.js";
2
+ import { DextoLogComponent } from "../../logger/v2/types.js";
3
3
  import { SessionError } from "../errors.js";
4
4
  class DatabaseHistoryProvider {
5
- constructor(sessionId, database) {
5
+ constructor(sessionId, database, logger) {
6
6
  this.sessionId = sessionId;
7
7
  this.database = database;
8
+ this.logger = logger.createChild(DextoLogComponent.SESSION);
8
9
  }
10
+ logger;
9
11
  async getHistory() {
10
12
  const key = this.getMessagesKey();
11
13
  try {
12
14
  const messages = await this.database.getRange(key, 0, 1e3);
13
- logger.debug(
15
+ this.logger.debug(
14
16
  `DatabaseHistoryProvider: Retrieved ${messages.length} messages for session ${this.sessionId}`
15
17
  );
16
18
  return messages;
17
19
  } catch (error) {
18
- logger.error(
20
+ this.logger.error(
19
21
  `DatabaseHistoryProvider: Error retrieving messages for session ${this.sessionId}: ${error instanceof Error ? error.message : String(error)}`
20
22
  );
21
23
  return [];
@@ -33,12 +35,15 @@ class DatabaseHistoryProvider {
33
35
  contentPreview = `[${message.content.length} parts]`;
34
36
  }
35
37
  }
36
- logger.debug(`DatabaseHistoryProvider: Saved message for session ${this.sessionId}`, {
37
- role: message.role,
38
- content: contentPreview
39
- });
38
+ this.logger.debug(
39
+ `DatabaseHistoryProvider: Saved message for session ${this.sessionId}`,
40
+ {
41
+ role: message.role,
42
+ content: contentPreview
43
+ }
44
+ );
40
45
  } catch (error) {
41
- logger.error(
46
+ this.logger.error(
42
47
  `DatabaseHistoryProvider: Error saving message for session ${this.sessionId}: ${error instanceof Error ? error.message : String(error)}`
43
48
  );
44
49
  throw SessionError.storageFailed(
@@ -52,9 +57,11 @@ class DatabaseHistoryProvider {
52
57
  const key = this.getMessagesKey();
53
58
  try {
54
59
  await this.database.delete(key);
55
- logger.debug(`DatabaseHistoryProvider: Cleared history for session ${this.sessionId}`);
60
+ this.logger.debug(
61
+ `DatabaseHistoryProvider: Cleared history for session ${this.sessionId}`
62
+ );
56
63
  } catch (error) {
57
- logger.error(
64
+ this.logger.error(
58
65
  `DatabaseHistoryProvider: Error clearing session ${this.sessionId}: ${error instanceof Error ? error.message : String(error)}`
59
66
  );
60
67
  throw SessionError.resetFailed(
@@ -22,8 +22,8 @@ __export(factory_exports, {
22
22
  });
23
23
  module.exports = __toCommonJS(factory_exports);
24
24
  var import_database = require("./database.js");
25
- function createDatabaseHistoryProvider(database, sessionId) {
26
- return new import_database.DatabaseHistoryProvider(sessionId, database);
25
+ function createDatabaseHistoryProvider(database, sessionId, logger) {
26
+ return new import_database.DatabaseHistoryProvider(sessionId, database, logger);
27
27
  }
28
28
  // Annotate the CommonJS export names for ESM import in node:
29
29
  0 && (module.exports = {
@@ -1,7 +1,11 @@
1
1
  import type { IConversationHistoryProvider } from './types.js';
2
2
  import type { Database } from '../../storage/types.js';
3
+ import type { IDextoLogger } from '../../logger/v2/types.js';
3
4
  /**
4
5
  * Create a history provider directly with database backend
6
+ * @param database Database instance
7
+ * @param sessionId Session ID
8
+ * @param logger Logger instance for logging
5
9
  */
6
- export declare function createDatabaseHistoryProvider(database: Database, sessionId: string): IConversationHistoryProvider;
10
+ export declare function createDatabaseHistoryProvider(database: Database, sessionId: string, logger: IDextoLogger): IConversationHistoryProvider;
7
11
  //# sourceMappingURL=factory.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../src/session/history/factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,YAAY,CAAC;AAC/D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAGvD;;GAEG;AACH,wBAAgB,6BAA6B,CACzC,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,MAAM,GAClB,4BAA4B,CAE9B"}
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../src/session/history/factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,YAAY,CAAC;AAC/D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAG7D;;;;;GAKG;AACH,wBAAgB,6BAA6B,CACzC,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,YAAY,GACrB,4BAA4B,CAE9B"}
@@ -1,7 +1,7 @@
1
1
  import "../../chunk-C6A6W6XS.js";
2
2
  import { DatabaseHistoryProvider } from "./database.js";
3
- function createDatabaseHistoryProvider(database, sessionId) {
4
- return new DatabaseHistoryProvider(sessionId, database);
3
+ function createDatabaseHistoryProvider(database, sessionId, logger) {
4
+ return new DatabaseHistoryProvider(sessionId, database, logger);
5
5
  }
6
6
  export {
7
7
  createDatabaseHistoryProvider
@@ -23,13 +23,14 @@ __export(session_manager_exports, {
23
23
  module.exports = __toCommonJS(session_manager_exports);
24
24
  var import_crypto = require("crypto");
25
25
  var import_chat_session = require("./chat-session.js");
26
- var import_logger = require("../logger/index.js");
26
+ var import_types = require("../logger/v2/types.js");
27
27
  var import_errors = require("./errors.js");
28
28
  class SessionManager {
29
- constructor(services, config = {}) {
29
+ constructor(services, config = {}, logger) {
30
30
  this.services = services;
31
31
  this.maxSessions = config.maxSessions ?? 100;
32
32
  this.sessionTTL = config.sessionTTL ?? 36e5;
33
+ this.logger = logger.createChild(import_types.DextoLogComponent.SESSION);
33
34
  }
34
35
  sessions = /* @__PURE__ */ new Map();
35
36
  maxSessions;
@@ -39,6 +40,7 @@ class SessionManager {
39
40
  initializationPromise;
40
41
  // Add a Map to track ongoing session creation operations to prevent race conditions
41
42
  pendingCreations = /* @__PURE__ */ new Map();
43
+ logger;
42
44
  /**
43
45
  * Initialize the SessionManager with persistent storage.
44
46
  * This must be called before using any session operations.
@@ -51,12 +53,12 @@ class SessionManager {
51
53
  const cleanupIntervalMs = Math.min(this.sessionTTL / 4, 15 * 60 * 1e3);
52
54
  this.cleanupInterval = setInterval(
53
55
  () => this.cleanupExpiredSessions().catch(
54
- (err) => import_logger.logger.error(`Periodic session cleanup failed: ${err}`)
56
+ (err) => this.logger.error(`Periodic session cleanup failed: ${err}`)
55
57
  ),
56
58
  cleanupIntervalMs
57
59
  );
58
60
  this.initialized = true;
59
- import_logger.logger.debug(
61
+ this.logger.debug(
60
62
  `SessionManager initialized with periodic cleanup every ${Math.round(cleanupIntervalMs / 1e3 / 60)} minutes`
61
63
  );
62
64
  }
@@ -67,7 +69,7 @@ class SessionManager {
67
69
  async restoreSessionsFromStorage() {
68
70
  try {
69
71
  const sessionKeys = await this.services.storageManager.getDatabase().list("session:");
70
- import_logger.logger.debug(`Found ${sessionKeys.length} persisted sessions to restore`);
72
+ this.logger.debug(`Found ${sessionKeys.length} persisted sessions to restore`);
71
73
  for (const sessionKey of sessionKeys) {
72
74
  const sessionId = sessionKey.replace("session:", "");
73
75
  const sessionData = await this.services.storageManager.getDatabase().get(sessionKey);
@@ -75,15 +77,15 @@ class SessionManager {
75
77
  const now = Date.now();
76
78
  const lastActivity = sessionData.lastActivity;
77
79
  if (now - lastActivity <= this.sessionTTL) {
78
- import_logger.logger.debug(`Session ${sessionId} restored from storage`);
80
+ this.logger.debug(`Session ${sessionId} restored from storage`);
79
81
  } else {
80
82
  await this.services.storageManager.getDatabase().delete(sessionKey);
81
- import_logger.logger.debug(`Expired session ${sessionId} cleaned up during restore`);
83
+ this.logger.debug(`Expired session ${sessionId} cleaned up during restore`);
82
84
  }
83
85
  }
84
86
  }
85
87
  } catch (error) {
86
- import_logger.logger.error(
88
+ this.logger.error(
87
89
  `Failed to restore sessions from storage: ${error instanceof Error ? error.message : String(error)}`
88
90
  );
89
91
  }
@@ -135,10 +137,14 @@ class SessionManager {
135
137
  const existingMetadata = await this.services.storageManager.getDatabase().get(sessionKey);
136
138
  if (existingMetadata) {
137
139
  await this.updateSessionActivity(id);
138
- const session2 = new import_chat_session.ChatSession({ ...this.services, sessionManager: this }, id);
140
+ const session2 = new import_chat_session.ChatSession(
141
+ { ...this.services, sessionManager: this },
142
+ id,
143
+ this.logger
144
+ );
139
145
  await session2.init();
140
146
  this.sessions.set(id, session2);
141
- import_logger.logger.info(`Restored session from storage: ${id}`, null, "cyan");
147
+ this.logger.info(`Restored session from storage: ${id}`);
142
148
  return session2;
143
149
  }
144
150
  const activeSessionKeys = await this.services.storageManager.getDatabase().list("session:");
@@ -154,19 +160,21 @@ class SessionManager {
154
160
  try {
155
161
  await this.services.storageManager.getDatabase().set(sessionKey, sessionData);
156
162
  } catch (error) {
157
- import_logger.logger.error(`Failed to store session metadata for ${id}:`, error);
163
+ this.logger.error(`Failed to store session metadata for ${id}:`, {
164
+ error: error instanceof Error ? error.message : String(error)
165
+ });
158
166
  throw error;
159
167
  }
160
168
  let session;
161
169
  try {
162
- session = new import_chat_session.ChatSession({ ...this.services, sessionManager: this }, id);
170
+ session = new import_chat_session.ChatSession({ ...this.services, sessionManager: this }, id, this.logger);
163
171
  await session.init();
164
172
  this.sessions.set(id, session);
165
173
  await this.services.storageManager.getCache().set(sessionKey, sessionData, this.sessionTTL / 1e3);
166
- import_logger.logger.info(`Created new session: ${id}`, null, "green");
174
+ this.logger.info(`Created new session: ${id}`);
167
175
  return session;
168
176
  } catch (error) {
169
- import_logger.logger.error(
177
+ this.logger.error(
170
178
  `Failed to initialize session ${id}: ${error instanceof Error ? error.message : String(error)}`
171
179
  );
172
180
  await this.services.storageManager.getDatabase().delete(sessionKey);
@@ -175,16 +183,6 @@ class SessionManager {
175
183
  throw import_errors.SessionError.initializationFailed(id, reason);
176
184
  }
177
185
  }
178
- /**
179
- * Gets or creates the default session.
180
- * This is used for backward compatibility with single-session operations.
181
- *
182
- * @returns The default ChatSession (creates one if it doesn't exist)
183
- */
184
- async getDefaultSession() {
185
- const defaultSessionId = "default";
186
- return await this.createSession(defaultSessionId);
187
- }
188
186
  /**
189
187
  * Retrieves an existing session by ID.
190
188
  *
@@ -206,7 +204,8 @@ class SessionManager {
206
204
  if (sessionData) {
207
205
  const session = new import_chat_session.ChatSession(
208
206
  { ...this.services, sessionManager: this },
209
- sessionId
207
+ sessionId,
208
+ this.logger
210
209
  );
211
210
  await session.init();
212
211
  this.sessions.set(sessionId, session);
@@ -230,7 +229,9 @@ class SessionManager {
230
229
  }
231
230
  const sessionKey = `session:${sessionId}`;
232
231
  await this.services.storageManager.getCache().delete(sessionKey);
233
- import_logger.logger.debug(`Ended session (removed from memory, chat history preserved): ${sessionId}`);
232
+ this.logger.debug(
233
+ `Ended session (removed from memory, chat history preserved): ${sessionId}`
234
+ );
234
235
  }
235
236
  /**
236
237
  * Deletes a session and its conversation history, removing everything from memory and storage.
@@ -249,7 +250,7 @@ class SessionManager {
249
250
  const sessionKey = `session:${sessionId}`;
250
251
  await this.services.storageManager.getDatabase().delete(sessionKey);
251
252
  await this.services.storageManager.getCache().delete(sessionKey);
252
- import_logger.logger.debug(`Deleted session and conversation history: ${sessionId}`);
253
+ this.logger.debug(`Deleted session and conversation history: ${sessionId}`);
253
254
  }
254
255
  /**
255
256
  * Resets the conversation history for a session while keeping the session alive.
@@ -272,7 +273,7 @@ class SessionManager {
272
273
  await this.services.storageManager.getDatabase().set(sessionKey, sessionData);
273
274
  await this.services.storageManager.getCache().set(sessionKey, sessionData, this.sessionTTL / 1e3);
274
275
  }
275
- import_logger.logger.debug(`Reset session conversation: ${sessionId}`);
276
+ this.logger.debug(`Reset session conversation: ${sessionId}`);
276
277
  }
277
278
  /**
278
279
  * Lists all active session IDs.
@@ -385,13 +386,13 @@ class SessionManager {
385
386
  if (session) {
386
387
  session.dispose();
387
388
  this.sessions.delete(sessionId);
388
- import_logger.logger.debug(
389
+ this.logger.debug(
389
390
  `Removed expired session from memory: ${sessionId} (chat history preserved)`
390
391
  );
391
392
  }
392
393
  }
393
394
  if (expiredSessions.length > 0) {
394
- import_logger.logger.debug(
395
+ this.logger.debug(
395
396
  `Memory cleanup: removed ${expiredSessions.length} inactive sessions, chat history preserved`
396
397
  );
397
398
  }
@@ -413,13 +414,13 @@ class SessionManager {
413
414
  await session.switchLLM(newLLMConfig);
414
415
  } catch (error) {
415
416
  failedSessions.push(sId);
416
- import_logger.logger.warn(
417
+ this.logger.warn(
417
418
  `Error switching LLM for session ${sId}: ${error instanceof Error ? error.message : String(error)}`
418
419
  );
419
420
  }
420
421
  }
421
422
  }
422
- this.services.agentEventBus.emit("dexto:llmSwitched", {
423
+ this.services.agentEventBus.emit("llm:switched", {
423
424
  newConfig: newLLMConfig,
424
425
  router: newLLMConfig.router,
425
426
  historyRetained: true,
@@ -441,7 +442,7 @@ class SessionManager {
441
442
  throw import_errors.SessionError.notFound(sessionId);
442
443
  }
443
444
  await session.switchLLM(newLLMConfig);
444
- this.services.agentEventBus.emit("dexto:llmSwitched", {
445
+ this.services.agentEventBus.emit("llm:switched", {
445
446
  newConfig: newLLMConfig,
446
447
  router: newLLMConfig.router,
447
448
  historyRetained: true,
@@ -450,23 +451,6 @@ class SessionManager {
450
451
  const message = `Successfully switched to ${newLLMConfig.provider}/${newLLMConfig.model} using ${newLLMConfig.router} router for session ${sessionId}`;
451
452
  return { message, warnings: [] };
452
453
  }
453
- /**
454
- * Switch LLM for the default session.
455
- * @param newLLMConfig The new LLM configuration to apply
456
- * @returns Result object with success message and any warnings
457
- */
458
- async switchLLMForDefaultSession(newLLMConfig) {
459
- const defaultSession = await this.getDefaultSession();
460
- await defaultSession.switchLLM(newLLMConfig);
461
- this.services.agentEventBus.emit("dexto:llmSwitched", {
462
- newConfig: newLLMConfig,
463
- router: newLLMConfig.router,
464
- historyRetained: true,
465
- sessionIds: [defaultSession.id]
466
- });
467
- const message = `Successfully switched to ${newLLMConfig.provider}/${newLLMConfig.model} using ${newLLMConfig.router} router`;
468
- return { message, warnings: [] };
469
- }
470
454
  /**
471
455
  * Get session statistics for monitoring and debugging.
472
456
  */
@@ -492,21 +476,21 @@ class SessionManager {
492
476
  if (this.cleanupInterval) {
493
477
  clearInterval(this.cleanupInterval);
494
478
  delete this.cleanupInterval;
495
- import_logger.logger.debug("Periodic session cleanup stopped");
479
+ this.logger.debug("Periodic session cleanup stopped");
496
480
  }
497
481
  const sessionIds = Array.from(this.sessions.keys());
498
482
  for (const sessionId of sessionIds) {
499
483
  try {
500
484
  await this.endSession(sessionId);
501
485
  } catch (error) {
502
- import_logger.logger.error(
486
+ this.logger.error(
503
487
  `Failed to cleanup session ${sessionId}: ${error instanceof Error ? error.message : String(error)}`
504
488
  );
505
489
  }
506
490
  }
507
491
  this.sessions.clear();
508
492
  this.initialized = false;
509
- import_logger.logger.debug("SessionManager cleanup completed");
493
+ this.logger.debug("SessionManager cleanup completed");
510
494
  }
511
495
  }
512
496
  // Annotate the CommonJS export names for ESM import in node: