@ai-setting/roy-agent-core 1.0.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 (378) hide show
  1. package/dist/index.js +99145 -0
  2. package/package.json +114 -0
  3. package/src/config/config-component.test.ts +627 -0
  4. package/src/config/config-component.ts +906 -0
  5. package/src/config/config-parser.test.ts +319 -0
  6. package/src/config/config-parser.ts +203 -0
  7. package/src/config/decentralized-config.test.ts +740 -0
  8. package/src/config/env-key.ts +210 -0
  9. package/src/config/env-source.test.ts +252 -0
  10. package/src/config/env-source.ts +301 -0
  11. package/src/config/file-source.test.ts +357 -0
  12. package/src/config/file-source.ts +421 -0
  13. package/src/config/index.ts +24 -0
  14. package/src/config/protocol-resolver.test.ts +217 -0
  15. package/src/config/protocol-resolver.ts +228 -0
  16. package/src/env/agent/agent-component.abort.test.ts +511 -0
  17. package/src/env/agent/agent-component.record-session.test.ts +349 -0
  18. package/src/env/agent/agent-component.test.ts +1389 -0
  19. package/src/env/agent/agent-component.tool-error.test.ts +327 -0
  20. package/src/env/agent/agent-component.ts +1711 -0
  21. package/src/env/agent/agent-config-registration.test.ts +226 -0
  22. package/src/env/agent/agent-config-registration.ts +46 -0
  23. package/src/env/agent/agent-reminder-plugin.integration.test.ts +243 -0
  24. package/src/env/agent/index.ts +10 -0
  25. package/src/env/agent/summary-agent.parse-hint.test.ts +360 -0
  26. package/src/env/agent/summary-agent.ts +508 -0
  27. package/src/env/agent/types.ts +536 -0
  28. package/src/env/commands/commands-component.test.ts +364 -0
  29. package/src/env/commands/commands-component.ts +604 -0
  30. package/src/env/commands/commands-config-registration.test.ts +198 -0
  31. package/src/env/commands/commands-config-registration.ts +38 -0
  32. package/src/env/commands/index.ts +21 -0
  33. package/src/env/commands/parser.test.ts +203 -0
  34. package/src/env/commands/parser.ts +115 -0
  35. package/src/env/commands/types.ts +184 -0
  36. package/src/env/commands-prompt-integration.test.ts +243 -0
  37. package/src/env/component-env.test.ts +119 -0
  38. package/src/env/component.ts +335 -0
  39. package/src/env/constants.test.ts +72 -0
  40. package/src/env/constants.ts +123 -0
  41. package/src/env/debug/debug-component.test.ts +114 -0
  42. package/src/env/debug/debug-component.ts +547 -0
  43. package/src/env/debug/formatters/index.ts +9 -0
  44. package/src/env/debug/formatters/repl-formatter.test.ts +139 -0
  45. package/src/env/debug/formatters/repl-formatter.ts +358 -0
  46. package/src/env/debug/formatters/trace-formatter.test.ts +119 -0
  47. package/src/env/debug/formatters/trace-formatter.ts +191 -0
  48. package/src/env/debug/formatters/tree-formatter.test.ts +107 -0
  49. package/src/env/debug/formatters/tree-formatter.ts +325 -0
  50. package/src/env/debug/index.ts +38 -0
  51. package/src/env/debug/parser/regex-parser.test.ts +201 -0
  52. package/src/env/debug/parser/regex-parser.ts +196 -0
  53. package/src/env/debug/parser/span-builder.test.ts +241 -0
  54. package/src/env/debug/parser/span-builder.ts +386 -0
  55. package/src/env/debug/reader/log-reader.test.ts +170 -0
  56. package/src/env/debug/reader/log-reader.ts +186 -0
  57. package/src/env/debug/reader/span-db-reader.test.ts +118 -0
  58. package/src/env/debug/reader/span-db-reader.ts +201 -0
  59. package/src/env/debug/types.test.ts +187 -0
  60. package/src/env/debug/types.ts +171 -0
  61. package/src/env/environment-init.test.ts +183 -0
  62. package/src/env/environment-lifecycle.test.ts +516 -0
  63. package/src/env/environment-service.test.ts +332 -0
  64. package/src/env/environment.handle-query.test.ts +96 -0
  65. package/src/env/environment.test.ts +232 -0
  66. package/src/env/environment.ts +708 -0
  67. package/src/env/errors.test.ts +165 -0
  68. package/src/env/errors.ts +157 -0
  69. package/src/env/event-source/event-source-agent-handler.test.ts +193 -0
  70. package/src/env/event-source/event-source-agent-handler.ts +111 -0
  71. package/src/env/event-source/event-source-component.process-cleanup.test.ts +236 -0
  72. package/src/env/event-source/event-source-component.stop.test.ts +346 -0
  73. package/src/env/event-source/event-source-component.test.ts +1207 -0
  74. package/src/env/event-source/event-source-component.ts +1379 -0
  75. package/src/env/event-source/event-source-config-registration.test.ts +242 -0
  76. package/src/env/event-source/event-source-config-registration.ts +37 -0
  77. package/src/env/event-source/event-source-integration.test.ts +320 -0
  78. package/src/env/event-source/event-source-platform.test.ts +630 -0
  79. package/src/env/event-source/types.ts +298 -0
  80. package/src/env/hook/global-hook-manager.ts +162 -0
  81. package/src/env/hook/hook-manager.test.ts +374 -0
  82. package/src/env/hook/hook-manager.ts +309 -0
  83. package/src/env/hook/index.ts +38 -0
  84. package/src/env/hook/types.ts +138 -0
  85. package/src/env/index.ts +144 -0
  86. package/src/env/interface.ts +203 -0
  87. package/src/env/llm/hooks.test.ts +293 -0
  88. package/src/env/llm/hooks.ts +316 -0
  89. package/src/env/llm/index.ts +61 -0
  90. package/src/env/llm/invoke-threshold-check.test.ts +88 -0
  91. package/src/env/llm/invoke-timeout.test.ts +54 -0
  92. package/src/env/llm/invoke.test.ts +71 -0
  93. package/src/env/llm/invoke.ts +1039 -0
  94. package/src/env/llm/llm-config.test.ts +523 -0
  95. package/src/env/llm/llm.test.ts +233 -0
  96. package/src/env/llm/llm.ts +568 -0
  97. package/src/env/llm/provider.test.ts +182 -0
  98. package/src/env/llm/provider.ts +108 -0
  99. package/src/env/llm/transform.test.ts +251 -0
  100. package/src/env/llm/transform.ts +286 -0
  101. package/src/env/llm/types.test.ts +580 -0
  102. package/src/env/llm/types.ts +424 -0
  103. package/src/env/log-trace/decorator-otel.test.ts +182 -0
  104. package/src/env/log-trace/decorator.ts +230 -0
  105. package/src/env/log-trace/index.ts +79 -0
  106. package/src/env/log-trace/log-trace-component.test.ts +242 -0
  107. package/src/env/log-trace/log-trace-component.ts +497 -0
  108. package/src/env/log-trace/log-trace-config-registration.test.ts +348 -0
  109. package/src/env/log-trace/log-trace-config-registration.ts +45 -0
  110. package/src/env/log-trace/logger.test.ts +149 -0
  111. package/src/env/log-trace/logger.ts +522 -0
  112. package/src/env/log-trace/opentelemetry/cli-propagation.test.ts +147 -0
  113. package/src/env/log-trace/opentelemetry/cli-propagation.ts +194 -0
  114. package/src/env/log-trace/opentelemetry/integration.test.ts +668 -0
  115. package/src/env/log-trace/opentelemetry/mod.ts +25 -0
  116. package/src/env/log-trace/opentelemetry/propagation-env.test.ts +181 -0
  117. package/src/env/log-trace/opentelemetry/propagation-env.ts +136 -0
  118. package/src/env/log-trace/opentelemetry/propagation.test.ts +259 -0
  119. package/src/env/log-trace/opentelemetry/propagation.ts +215 -0
  120. package/src/env/log-trace/opentelemetry/tracer-provider-context.test.ts +166 -0
  121. package/src/env/log-trace/opentelemetry/tracer-provider.test.ts +379 -0
  122. package/src/env/log-trace/opentelemetry/tracer-provider.ts +612 -0
  123. package/src/env/log-trace/span-storage.test.ts +145 -0
  124. package/src/env/log-trace/span-storage.ts +230 -0
  125. package/src/env/log-trace/trace-context.test.ts +187 -0
  126. package/src/env/log-trace/trace-context.ts +162 -0
  127. package/src/env/log-trace/types.test.ts +63 -0
  128. package/src/env/log-trace/types.ts +172 -0
  129. package/src/env/mcp/README.md +244 -0
  130. package/src/env/mcp/__integration__/mcp-component.integration.test.ts +373 -0
  131. package/src/env/mcp/config.test.ts +74 -0
  132. package/src/env/mcp/config.ts +116 -0
  133. package/src/env/mcp/index.ts +41 -0
  134. package/src/env/mcp/loader.test.ts +161 -0
  135. package/src/env/mcp/loader.ts +209 -0
  136. package/src/env/mcp/mcp-component.test.ts +111 -0
  137. package/src/env/mcp/mcp-component.ts +358 -0
  138. package/src/env/mcp/mcp-config-registration.test.ts +304 -0
  139. package/src/env/mcp/mcp-config-registration.ts +50 -0
  140. package/src/env/mcp/scanner.test.ts +170 -0
  141. package/src/env/mcp/scanner.ts +246 -0
  142. package/src/env/mcp/tool/adapter.test.ts +520 -0
  143. package/src/env/mcp/tool/adapter.ts +521 -0
  144. package/src/env/mcp/tool/index.ts +5 -0
  145. package/src/env/mcp/types.test.ts +171 -0
  146. package/src/env/mcp/types.ts +79 -0
  147. package/src/env/memory/README.md +177 -0
  148. package/src/env/memory/built-in/index.ts +59 -0
  149. package/src/env/memory/built-in/recall-memory.ts +103 -0
  150. package/src/env/memory/built-in/record-memory.ts +148 -0
  151. package/src/env/memory/index.ts +20 -0
  152. package/src/env/memory/memory-component.test.ts +239 -0
  153. package/src/env/memory/memory-component.ts +503 -0
  154. package/src/env/memory/memory-config-registration.test.ts +67 -0
  155. package/src/env/memory/memory-config-registration.ts +48 -0
  156. package/src/env/memory/memory-config.ts +45 -0
  157. package/src/env/memory/memory-file.test.ts +268 -0
  158. package/src/env/memory/plugin/index.ts +48 -0
  159. package/src/env/memory/plugin/memory-agent.test.ts +249 -0
  160. package/src/env/memory/plugin/memory-agent.ts +365 -0
  161. package/src/env/memory/plugin/memory-manager.ts +198 -0
  162. package/src/env/memory/plugin/memory-plugin-agent.test.ts +145 -0
  163. package/src/env/memory/plugin/memory-plugin.ts +210 -0
  164. package/src/env/memory/plugin/plugin-simplified.test.ts +51 -0
  165. package/src/env/memory/plugin/recall-memory.test.ts +106 -0
  166. package/src/env/memory/plugin/recall-memory.ts +53 -0
  167. package/src/env/memory/plugin/types.ts +101 -0
  168. package/src/env/memory/tools/memory-agent-tools.ts +228 -0
  169. package/src/env/memory/types.ts +85 -0
  170. package/src/env/paths.ts +118 -0
  171. package/src/env/prompt/index.ts +18 -0
  172. package/src/env/prompt/memory-prompts.test.ts +91 -0
  173. package/src/env/prompt/prompt-component.test.ts +491 -0
  174. package/src/env/prompt/prompt-component.ts +619 -0
  175. package/src/env/prompt/prompt-config-registration.test.ts +213 -0
  176. package/src/env/prompt/prompt-config-registration.ts +39 -0
  177. package/src/env/prompt/prompts-index.ts +504 -0
  178. package/src/env/prompt/renderer.ts +67 -0
  179. package/src/env/prompt/types.ts +136 -0
  180. package/src/env/session/hooks.ts +18 -0
  181. package/src/env/session/index.ts +37 -0
  182. package/src/env/session/search-query-parser.test.ts +425 -0
  183. package/src/env/session/search-query-parser.ts +171 -0
  184. package/src/env/session/session-checkpoint.test.ts +523 -0
  185. package/src/env/session/session-component.extract-recent-messages.test.ts +209 -0
  186. package/src/env/session/session-component.test.ts +132 -0
  187. package/src/env/session/session-component.ts +1249 -0
  188. package/src/env/session/session-config-registration.test.ts +138 -0
  189. package/src/env/session/session-config-registration.ts +52 -0
  190. package/src/env/session/session-message-converter.test.ts +763 -0
  191. package/src/env/session/session-message-converter.ts +415 -0
  192. package/src/env/session/session-message-e2e.test.ts +448 -0
  193. package/src/env/session/session-search.test.ts +391 -0
  194. package/src/env/session/session-store.test.ts +362 -0
  195. package/src/env/session/session-store.ts +141 -0
  196. package/src/env/session/storage/index.ts +6 -0
  197. package/src/env/session/storage/memory.ts +502 -0
  198. package/src/env/session/storage/sqlite.ts +794 -0
  199. package/src/env/session/types.ts +742 -0
  200. package/src/env/skill/config.ts +39 -0
  201. package/src/env/skill/index.ts +6 -0
  202. package/src/env/skill/parser.test.ts +116 -0
  203. package/src/env/skill/parser.ts +77 -0
  204. package/src/env/skill/scanner.test.ts +211 -0
  205. package/src/env/skill/scanner.ts +119 -0
  206. package/src/env/skill/skill-component.test.ts +234 -0
  207. package/src/env/skill/skill-component.ts +352 -0
  208. package/src/env/skill/skill-config-registration.test.ts +60 -0
  209. package/src/env/skill/skill-config-registration.ts +43 -0
  210. package/src/env/skill/tool/index.ts +1 -0
  211. package/src/env/skill/tool/skill-tool.test.ts +100 -0
  212. package/src/env/skill/tool/skill-tool.ts +72 -0
  213. package/src/env/skill/types.ts +64 -0
  214. package/src/env/task/delegate/delegate-tool.test.ts +498 -0
  215. package/src/env/task/delegate/delegate-tool.ts +1014 -0
  216. package/src/env/task/delegate/index.ts +18 -0
  217. package/src/env/task/delegate/stop-tool.test.ts +140 -0
  218. package/src/env/task/delegate/stop-tool.ts +119 -0
  219. package/src/env/task/delegate/task-events.test.ts +178 -0
  220. package/src/env/task/delegate/task-events.ts +143 -0
  221. package/src/env/task/hooks/contexts.test.ts +92 -0
  222. package/src/env/task/hooks/contexts.ts +192 -0
  223. package/src/env/task/hooks/index.ts +23 -0
  224. package/src/env/task/hooks/task-hook-points.test.ts +32 -0
  225. package/src/env/task/hooks/task-hook-points.ts +54 -0
  226. package/src/env/task/index.ts +7 -0
  227. package/src/env/task/plugins/index.ts +13 -0
  228. package/src/env/task/plugins/task-plugin.test.ts +74 -0
  229. package/src/env/task/plugins/task-plugin.ts +89 -0
  230. package/src/env/task/plugins/task-tag-plugin.test.ts +377 -0
  231. package/src/env/task/plugins/task-tag-plugin.ts +319 -0
  232. package/src/env/task/plugins/task-workflow-extractor.integration.test.ts +226 -0
  233. package/src/env/task/plugins/workflow-extractor-agent.test.ts +107 -0
  234. package/src/env/task/plugins/workflow-extractor-agent.ts +225 -0
  235. package/src/env/task/storage/index.ts +6 -0
  236. package/src/env/task/storage/sqlite-task-store.test.ts +283 -0
  237. package/src/env/task/storage/sqlite-task-store.ts +903 -0
  238. package/src/env/task/storage/task-search.test.ts +291 -0
  239. package/src/env/task/tag-service.test.ts +198 -0
  240. package/src/env/task/tag-service.ts +264 -0
  241. package/src/env/task/task-component.test.ts +193 -0
  242. package/src/env/task/task-component.ts +658 -0
  243. package/src/env/task/task-config-registration.test.ts +57 -0
  244. package/src/env/task/task-config-registration.ts +37 -0
  245. package/src/env/task/task-types.test.ts +137 -0
  246. package/src/env/task/tools/complete-tool.ts +44 -0
  247. package/src/env/task/tools/create-tool.ts +49 -0
  248. package/src/env/task/tools/delete-tool.ts +43 -0
  249. package/src/env/task/tools/get-tool.ts +59 -0
  250. package/src/env/task/tools/index.ts +10 -0
  251. package/src/env/task/tools/list-tool.ts +40 -0
  252. package/src/env/task/tools/operation/create-tool.ts +48 -0
  253. package/src/env/task/tools/operation/delete-tool.ts +43 -0
  254. package/src/env/task/tools/operation/get-tool.ts +43 -0
  255. package/src/env/task/tools/operation/index.ts +9 -0
  256. package/src/env/task/tools/operation/list-tool.ts +40 -0
  257. package/src/env/task/tools/operation/operation-tools.test.ts +274 -0
  258. package/src/env/task/tools/operation/operation-types.ts +75 -0
  259. package/src/env/task/tools/operation/update-tool.ts +47 -0
  260. package/src/env/task/tools/task-tools.test.ts +203 -0
  261. package/src/env/task/tools/task-types.test.ts +75 -0
  262. package/src/env/task/tools/task-types.ts +68 -0
  263. package/src/env/task/tools/update-tool.ts +70 -0
  264. package/src/env/task/types.ts +160 -0
  265. package/src/env/tool/built-in/bash.ts +201 -0
  266. package/src/env/tool/built-in/echo.ts +29 -0
  267. package/src/env/tool/built-in/edit-file.test.ts +136 -0
  268. package/src/env/tool/built-in/edit-file.ts +92 -0
  269. package/src/env/tool/built-in/glob.test.ts +94 -0
  270. package/src/env/tool/built-in/glob.ts +65 -0
  271. package/src/env/tool/built-in/grep.test.ts +122 -0
  272. package/src/env/tool/built-in/grep.ts +108 -0
  273. package/src/env/tool/built-in/index.ts +44 -0
  274. package/src/env/tool/built-in/read-file.test.ts +84 -0
  275. package/src/env/tool/built-in/read-file.ts +75 -0
  276. package/src/env/tool/built-in/write-file.test.ts +119 -0
  277. package/src/env/tool/built-in/write-file.ts +68 -0
  278. package/src/env/tool/index.ts +24 -0
  279. package/src/env/tool/registry.test.ts +257 -0
  280. package/src/env/tool/registry.ts +167 -0
  281. package/src/env/tool/tool-component.test.ts +559 -0
  282. package/src/env/tool/tool-component.ts +563 -0
  283. package/src/env/tool/tool-config-registration.test.ts +249 -0
  284. package/src/env/tool/tool-config-registration.ts +46 -0
  285. package/src/env/tool/types.ts +267 -0
  286. package/src/env/tool/validator.test.ts +143 -0
  287. package/src/env/tool/validator.ts +44 -0
  288. package/src/env/types.ts +180 -0
  289. package/src/env/workflow/ask-user-tool-registration.test.ts +216 -0
  290. package/src/env/workflow/complex-workflow.integration.test.ts +1900 -0
  291. package/src/env/workflow/decorators/decorator-node.ts +229 -0
  292. package/src/env/workflow/decorators/decorator.test.ts +196 -0
  293. package/src/env/workflow/decorators/edge.ts +82 -0
  294. package/src/env/workflow/decorators/index.ts +31 -0
  295. package/src/env/workflow/decorators/node-as.ts +98 -0
  296. package/src/env/workflow/decorators/workflow.ts +54 -0
  297. package/src/env/workflow/engine/dag-manager.test.ts +570 -0
  298. package/src/env/workflow/engine/dag-manager.ts +594 -0
  299. package/src/env/workflow/engine/engine.ts +1422 -0
  300. package/src/env/workflow/engine/event-bus.test.ts +359 -0
  301. package/src/env/workflow/engine/event-bus.ts +156 -0
  302. package/src/env/workflow/engine/executor-agent-session.test.ts +84 -0
  303. package/src/env/workflow/engine/executor.test.ts +619 -0
  304. package/src/env/workflow/engine/executor.ts +593 -0
  305. package/src/env/workflow/engine/index.ts +24 -0
  306. package/src/env/workflow/engine/node-registry.test.ts +560 -0
  307. package/src/env/workflow/engine/node-registry.ts +289 -0
  308. package/src/env/workflow/engine/resume-removed.test.ts +22 -0
  309. package/src/env/workflow/engine/scheduler.test.ts +715 -0
  310. package/src/env/workflow/engine/scheduler.ts +318 -0
  311. package/src/env/workflow/engine/workflow-engine.test.ts +815 -0
  312. package/src/env/workflow/extractor/workflow-converter.ts +306 -0
  313. package/src/env/workflow/fixtures.ts +380 -0
  314. package/src/env/workflow/index.ts +38 -0
  315. package/src/env/workflow/integration/run-resume-unified.test.ts +186 -0
  316. package/src/env/workflow/integration/service-integration.test.ts +267 -0
  317. package/src/env/workflow/metadata/keys.ts +12 -0
  318. package/src/env/workflow/nodes/agent-component-adapter.test.ts +318 -0
  319. package/src/env/workflow/nodes/agent-component-adapter.ts +448 -0
  320. package/src/env/workflow/nodes/agent-node.test.ts +371 -0
  321. package/src/env/workflow/nodes/agent-node.ts +598 -0
  322. package/src/env/workflow/nodes/ask-user-node.ts +113 -0
  323. package/src/env/workflow/nodes/condition-node.ts +200 -0
  324. package/src/env/workflow/nodes/index.ts +9 -0
  325. package/src/env/workflow/nodes/merge-node.ts +141 -0
  326. package/src/env/workflow/nodes/skill-node.test.ts +253 -0
  327. package/src/env/workflow/nodes/skill-node.ts +393 -0
  328. package/src/env/workflow/nodes/tool-node.test.ts +251 -0
  329. package/src/env/workflow/nodes/tool-node.ts +493 -0
  330. package/src/env/workflow/nodes/workflow-llm-history.test.ts +455 -0
  331. package/src/env/workflow/nodes/workflow-node.test.ts +315 -0
  332. package/src/env/workflow/nodes/workflow-node.ts +311 -0
  333. package/src/env/workflow/service/index.ts +27 -0
  334. package/src/env/workflow/service/registry.test.ts +133 -0
  335. package/src/env/workflow/service/registry.ts +71 -0
  336. package/src/env/workflow/service/workflow-service.test.ts +310 -0
  337. package/src/env/workflow/service/workflow-service.ts +393 -0
  338. package/src/env/workflow/storage/index.ts +28 -0
  339. package/src/env/workflow/storage/mock-repositories.ts +385 -0
  340. package/src/env/workflow/storage/sqlite.test.ts +179 -0
  341. package/src/env/workflow/storage/sqlite.ts +163 -0
  342. package/src/env/workflow/storage/workflow-repo.test.ts +780 -0
  343. package/src/env/workflow/storage/workflow-repo.ts +342 -0
  344. package/src/env/workflow/tools/ask-user-tool.ts +82 -0
  345. package/src/env/workflow/tools/index.ts +26 -0
  346. package/src/env/workflow/tools/run-workflow.test.ts +352 -0
  347. package/src/env/workflow/tools/run-workflow.ts +214 -0
  348. package/src/env/workflow/types/context.ts +18 -0
  349. package/src/env/workflow/types/decorators-types.ts +198 -0
  350. package/src/env/workflow/types/event.test.ts +515 -0
  351. package/src/env/workflow/types/event.ts +193 -0
  352. package/src/env/workflow/types/index.ts +49 -0
  353. package/src/env/workflow/types/run.test.ts +437 -0
  354. package/src/env/workflow/types/run.ts +173 -0
  355. package/src/env/workflow/types/workflow-hil.ts +114 -0
  356. package/src/env/workflow/types/workflow-message.test.ts +138 -0
  357. package/src/env/workflow/types/workflow-message.ts +196 -0
  358. package/src/env/workflow/types/workflow-session.test.ts +95 -0
  359. package/src/env/workflow/types/workflow-session.ts +59 -0
  360. package/src/env/workflow/types/workflow.test.ts +495 -0
  361. package/src/env/workflow/types/workflow.ts +195 -0
  362. package/src/env/workflow/types_compat.ts +51 -0
  363. package/src/env/workflow/utils/create-workflow.ts +47 -0
  364. package/src/env/workflow/utils/execution-state.ts +245 -0
  365. package/src/env/workflow/utils/index.ts +18 -0
  366. package/src/env/workflow/utils/node-registry-helper.ts +58 -0
  367. package/src/env/workflow/utils/recovery-validator.test.ts +460 -0
  368. package/src/env/workflow/utils/recovery-validator.ts +377 -0
  369. package/src/env/workflow/utils/session-parser.test.ts +111 -0
  370. package/src/env/workflow/utils/session-parser.ts +94 -0
  371. package/src/env/workflow/utils/session-recovery.test.ts +334 -0
  372. package/src/env/workflow/utils/session-recovery.ts +188 -0
  373. package/src/env/workflow/utils/template-resolver.test.ts +258 -0
  374. package/src/env/workflow/utils/template-resolver.ts +436 -0
  375. package/src/env/workflow/utils/validation-rules.ts +149 -0
  376. package/src/env/workflow/workflow-component.ts +544 -0
  377. package/src/index.ts +422 -0
  378. package/src/utils/id.ts +21 -0
@@ -0,0 +1,742 @@
1
+ /**
2
+ * @fileoverview Session Component Types
3
+ */
4
+
5
+ import { z } from "zod";
6
+
7
+ // ============================================================================
8
+ // Config Schema
9
+ // ============================================================================
10
+
11
+ /**
12
+ * Session Component configuration schema
13
+ */
14
+ export const SessionConfigSchema = z.object({
15
+ /** Default working directory */
16
+ defaultDirectory: z.string().default("/tmp"),
17
+
18
+ /** Default title template */
19
+ defaultTitleTemplate: z.string().default("Session - {date}"),
20
+
21
+ /** Maximum number of messages per session */
22
+ maxMessages: z.number().default(100),
23
+
24
+ /** Context compaction threshold (percentage) */
25
+ compactionThreshold: z.number().default(80),
26
+
27
+ /** Enable auto compaction */
28
+ autoCompact: z.boolean().default(true),
29
+
30
+ /** Storage configuration */
31
+ storage: z.object({
32
+ type: z.enum(["memory", "sqlite"]).default("sqlite"),
33
+ dbPath: z.string().optional(),
34
+ }).default({}),
35
+ }).transform((config) => ({
36
+ ...config,
37
+ // Set defaultDirectory to cwd if not provided and equals default
38
+ defaultDirectory: config.defaultDirectory === "/tmp" ? (typeof process !== 'undefined' ? process.cwd() : "/tmp") : config.defaultDirectory,
39
+ }));
40
+
41
+ export type SessionConfig = z.infer<typeof SessionConfigSchema>;
42
+
43
+ // ============================================================================
44
+ // Checkpoint Types (new)
45
+ // ============================================================================
46
+
47
+ /**
48
+ * Checkpoint type
49
+ */
50
+ export type CheckpointType = "compact" | "manual";
51
+
52
+ /**
53
+ * Checkpoint metadata (stored in Session.metadata)
54
+ */
55
+ export interface CheckpointMeta {
56
+ id: string;
57
+ messageIndex: number;
58
+ title: string;
59
+ createdAt: number;
60
+ type: CheckpointType;
61
+ }
62
+
63
+ /**
64
+ * User Intent type - represents a user's intent extracted from conversation
65
+ */
66
+ export type UserIntent = string;
67
+
68
+ /**
69
+ * Recent message for checkpoint
70
+ *
71
+ * Stores a simplified version of a message for context preservation
72
+ */
73
+ export interface RecentMessage {
74
+ role: string;
75
+ content: string;
76
+ }
77
+
78
+ /**
79
+ * Complete checkpoint information (includes generated content)
80
+ */
81
+ export interface SessionCheckpoint extends CheckpointMeta {
82
+ summary: string;
83
+ processKeyPoints: string[];
84
+ currentState: string;
85
+ nextSteps: string[];
86
+ messageCountBefore: number;
87
+ metadata?: Record<string, unknown>;
88
+
89
+ /** User intents extracted from the conversation */
90
+ userIntents: UserIntent[];
91
+
92
+ /**
93
+ * Recent messages preserved from the compacted conversation
94
+ *
95
+ * Contains the last N turns of user query + assistant text response
96
+ * (excluding tool calls and tool results).
97
+ * This allows the checkpoint to serve as a fresh history context.
98
+ *
99
+ * Format: [user, assistant, user, assistant, ...] from most recent
100
+ */
101
+ recentMessages?: RecentMessage[];
102
+ }
103
+
104
+ /**
105
+ * Checkpoints metadata in session
106
+ */
107
+ export interface SessionCheckpointsMeta {
108
+ latestCheckpointId?: string;
109
+ checkpoints: CheckpointMeta[];
110
+ }
111
+
112
+ /**
113
+ * Checkpoint message metadata (stored in message metadata)
114
+ */
115
+ export interface CheckpointMessageMeta {
116
+ isCheckpoint: boolean;
117
+ checkpointId: string;
118
+ checkpointMeta: SessionCheckpoint;
119
+ }
120
+
121
+ // ============================================================================
122
+ // Session Entity
123
+ // ============================================================================
124
+
125
+ /**
126
+ * Session entity
127
+ */
128
+ export interface Session {
129
+ id: string;
130
+ title: string;
131
+ directory: string;
132
+ parentID?: string;
133
+ createdAt: number;
134
+ updatedAt: number;
135
+ messageCount: number;
136
+ metadata?: SessionMetadata;
137
+ }
138
+
139
+ /**
140
+ * Session metadata
141
+ */
142
+ export interface SessionMetadata extends Record<string, unknown> {
143
+ /** Total number of messages in the session */
144
+ messageCount?: number;
145
+ checkpoints?: SessionCheckpointsMeta;
146
+ checkpointDetails?: Record<string, SessionCheckpoint>;
147
+ }
148
+
149
+ // ============================================================================
150
+ // Workflow Session Types (new)
151
+ // ============================================================================
152
+
153
+ /**
154
+ * Agent Sub-session reference
155
+ */
156
+ export interface AgentSessionRef {
157
+ nodeId: string;
158
+ sessionId: string;
159
+ status: 'active' | 'paused' | 'completed';
160
+ }
161
+
162
+ /**
163
+ * Workflow Session metadata
164
+ * Extends SessionMetadata with workflow-specific fields
165
+ */
166
+ export interface WorkflowSessionMetadata extends SessionMetadata {
167
+ type: 'workflow';
168
+ workflowId?: string;
169
+ workflowName: string;
170
+ workflowVersion?: string;
171
+ status: 'running' | 'paused' | 'completed' | 'failed';
172
+ input?: unknown;
173
+ rootNodeId?: string;
174
+ agentSessions?: AgentSessionRef[];
175
+ }
176
+
177
+ /**
178
+ * Session message
179
+ */
180
+ export interface SessionMessage {
181
+ id: string;
182
+ sessionID: string;
183
+ role: Role;
184
+ content: string;
185
+ timestamp: number;
186
+ parts?: MessagePart[];
187
+
188
+ /** Whether the message has been archived (compacted) */
189
+ isArchived?: boolean;
190
+
191
+ /** Timestamp when the message was archived */
192
+ archivedAt?: number;
193
+
194
+ /** Checkpoint ID this message belongs to */
195
+ checkpointId?: string;
196
+
197
+ /** Message metadata (includes checkpoint info if this is a checkpoint message) */
198
+ metadata?: MessageMetadata;
199
+ }
200
+
201
+ /**
202
+ * Message metadata
203
+ */
204
+ export interface MessageMetadata extends Record<string, unknown> {
205
+ /** 消息类型标识,用于过滤和分类 */
206
+ type?: "tool_call" | "tool_result" | "checkpoint" | "user_intent"
207
+ | "workflow.node.call" // Workflow node execution started
208
+ | "workflow.node.interrupt" // Workflow node waiting for user input
209
+ | "workflow.node.result" // Workflow node execution result
210
+ | "workflow.node.resume"; // Workflow node resumed after user response
211
+ isCheckpoint?: boolean;
212
+ checkpointId?: string;
213
+ checkpointMeta?: SessionCheckpoint;
214
+
215
+ // Workflow-specific metadata fields
216
+ /** Workflow node ID (for workflow.node.* messages) */
217
+ workflowNodeId?: string;
218
+ /** Workflow node type (for workflow.node.* messages) */
219
+ workflowNodeType?: string;
220
+ /** Agent session ID (for agent nodes in workflow) */
221
+ agentSessionId?: string;
222
+ /** User response (for workflow.node.resume messages) */
223
+ response?: string;
224
+ /** Success flag (for workflow.node.result messages) */
225
+ success?: boolean;
226
+ }
227
+
228
+ /**
229
+ * Message role
230
+ */
231
+ export type Role = "user" | "assistant" | "system" | "tool"
232
+ | "workflow.node.call" // Workflow node execution started
233
+ | "workflow.node.interrupt" // Workflow node waiting for user input
234
+ | "workflow.node.result" // Workflow node execution result
235
+ | "workflow.node.resume"; // Workflow node resumed after user response
236
+
237
+ /**
238
+ * Message part
239
+ */
240
+ export type MessagePart = SessionPart;
241
+
242
+ // ============================================================================
243
+ // New Session Part Types (AI SDK v6 compatible)
244
+ // ============================================================================
245
+
246
+ /**
247
+ * Text part - plain text content
248
+ */
249
+ export interface TextPart {
250
+ type: "text";
251
+ content: string;
252
+ /** If true, this part was generated by the system (e.g., auto-summary) */
253
+ synthetic?: boolean;
254
+ /** If true, this part should be ignored (e.g., replaced by reasoning) */
255
+ ignored?: boolean;
256
+ }
257
+
258
+ /**
259
+ * Tool call part - represents a tool invocation
260
+ */
261
+ export interface ToolCallPart {
262
+ type: "tool-call";
263
+ /** AI SDK standard field name */
264
+ toolCallId: string;
265
+ toolName: string;
266
+ /** Tool arguments - can be string (JSON) or object */
267
+ arguments: string | Record<string, unknown>;
268
+ state: "pending" | "running";
269
+ }
270
+
271
+ /**
272
+ * Tool result part - represents the result of a tool execution
273
+ */
274
+ export interface ToolResultPart {
275
+ type: "tool-result";
276
+ toolCallId: string;
277
+ toolName: string;
278
+ output: string;
279
+ error?: string;
280
+ state: "completed" | "error";
281
+ }
282
+
283
+ /**
284
+ * Reasoning part - AI thinking/thought content
285
+ */
286
+ export interface ReasoningPart {
287
+ type: "reasoning";
288
+ /** Reasoning content */
289
+ content: string;
290
+ /** Reasoning type (for different models) */
291
+ reasoningType?: "core" | "effort" | "summary";
292
+ /** State */
293
+ state?: "thinking" | "completed";
294
+ /** Whether to collapse by default (like AI SDK default) */
295
+ isCollapsed?: boolean;
296
+ /** Metadata */
297
+ metadata?: {
298
+ tokenCount?: number;
299
+ time?: { start: number; end?: number };
300
+ };
301
+ }
302
+
303
+ /**
304
+ * File part - file attachment
305
+ */
306
+ export interface FilePart {
307
+ type: "file";
308
+ mime: string;
309
+ url: string;
310
+ filename?: string;
311
+ }
312
+
313
+ /**
314
+ * Checkpoint part - compaction checkpoint marker
315
+ *
316
+ * Represents a checkpoint message in the conversation history.
317
+ * This is stored as a user role message with markdown content summarizing
318
+ * the compacted conversation segment.
319
+ */
320
+ export interface CheckpointPart {
321
+ type: "checkpoint";
322
+ /** Checkpoint ID reference */
323
+ checkpointId: string;
324
+ /** Markdown content summarizing the checkpoint */
325
+ content: string;
326
+ /** Title of the checkpoint */
327
+ title?: string;
328
+ /** Process key points */
329
+ processKeyPoints?: string[];
330
+ /** Current state description */
331
+ currentState?: string;
332
+ /** Next steps */
333
+ nextSteps?: string[];
334
+ /** Number of messages that were compacted */
335
+ messageCountBefore?: number;
336
+ /** Creation timestamp */
337
+ createdAt?: number;
338
+ }
339
+
340
+ /**
341
+ * Union type for all Session Part types
342
+ */
343
+ export type SessionPart =
344
+ | TextPart
345
+ | ToolCallPart
346
+ | ToolResultPart
347
+ | ReasoningPart
348
+ | FilePart
349
+ | CheckpointPart
350
+ // Workflow-specific parts
351
+ | WorkflowNodeCallPart
352
+ | WorkflowNodeInterruptPart
353
+ | WorkflowNodeResultPart
354
+ | WorkflowNodeResumePart;
355
+
356
+ /**
357
+ * workflow.node.call 消息 part (for workflow sessions)
358
+ */
359
+ export interface WorkflowNodeCallPart {
360
+ type: 'workflow-node-call';
361
+ nodeId: string;
362
+ nodeType: string;
363
+ input?: unknown;
364
+ startTime: number;
365
+ /** Agent session ID (only for agent nodes) */
366
+ agentSessionId?: string;
367
+ }
368
+
369
+ /**
370
+ * workflow.node.interrupt 消息 part (for workflow sessions)
371
+ */
372
+ export interface WorkflowNodeInterruptPart {
373
+ type: 'workflow-node-interrupt';
374
+ nodeId: string;
375
+ nodeType: string;
376
+ query: string;
377
+ options?: string[];
378
+ timestamp: number;
379
+ /** Agent session ID (only for agent nodes) */
380
+ agentSessionId?: string;
381
+ }
382
+
383
+ /**
384
+ * workflow.node.result 消息 part (for workflow sessions)
385
+ */
386
+ export interface WorkflowNodeResultPart {
387
+ type: 'workflow-node-result';
388
+ nodeId: string;
389
+ nodeType: string;
390
+ output?: unknown;
391
+ error?: string;
392
+ durationMs: number;
393
+ }
394
+
395
+ /**
396
+ * workflow.node.resume 消息 part (for workflow sessions)
397
+ */
398
+ export interface WorkflowNodeResumePart {
399
+ type: 'workflow-node-resume';
400
+ response: string;
401
+ timestamp: number;
402
+ }
403
+
404
+ /**
405
+ * Context usage statistics
406
+ */
407
+ export interface ContextUsage {
408
+ inputTokens: number;
409
+ outputTokens: number;
410
+ totalTokens: number;
411
+ contextWindow?: number;
412
+ usagePercent?: number;
413
+ requestCount: number;
414
+ lastUpdated: number;
415
+ }
416
+
417
+ // ============================================================================
418
+ // Options
419
+ // ============================================================================
420
+
421
+ /**
422
+ * Options for creating a session
423
+ */
424
+ export interface CreateSessionOptions {
425
+ /** Custom session ID (optional, will be generated if not provided) */
426
+ id?: string;
427
+ title?: string;
428
+ directory?: string;
429
+ parentID?: string;
430
+ metadata?: Record<string, unknown>;
431
+ hooks?: SessionHooksConfig;
432
+ }
433
+
434
+ /**
435
+ * Options for updating a session
436
+ */
437
+ export interface UpdateSessionOptions {
438
+ title?: string;
439
+ metadata?: Record<string, unknown>;
440
+ }
441
+
442
+ /**
443
+ * Options for listing sessions
444
+ */
445
+ export interface ListSessionsOptions {
446
+ filter?: {
447
+ metadata?: Record<string, unknown>;
448
+ startTime?: number;
449
+ endTime?: number;
450
+ };
451
+ sort?: {
452
+ field: "updatedAt" | "createdAt" | "title";
453
+ order: "asc" | "desc";
454
+ };
455
+ offset?: number;
456
+ limit?: number;
457
+ }
458
+
459
+ /**
460
+ * Options for adding a message
461
+ */
462
+ export interface AddMessageOptions {
463
+ role: Role;
464
+ content: string;
465
+ parts?: MessagePart[];
466
+ metadata?: MessageMetadata;
467
+ }
468
+
469
+ // ============================================================================
470
+ // Compact Options & Result (new)
471
+ // ============================================================================
472
+
473
+ /**
474
+ * Options for compact operation
475
+ */
476
+ export interface CompactOptions {
477
+ /** User-provided summary hint for checkpoint generation */
478
+ summary?: string;
479
+
480
+ /** User-provided process key points hint */
481
+ processKeyPoints?: string[];
482
+
483
+ /** User-provided current state hint */
484
+ currentState?: string;
485
+
486
+ /** User-provided next steps hint */
487
+ nextSteps?: string[];
488
+
489
+ /** Whether this is auto-triggered compact */
490
+ auto?: boolean;
491
+
492
+ /**
493
+ * Scenario hint for guiding checkpoint generation
494
+ *
495
+ * A natural language description that provides context about the current scenario.
496
+ * This helps the SummaryAgent generate more relevant checkpoints based on the specific
497
+ * situation. Examples:
498
+ * - "Task execution in progress: implementing feature X, current working directory is /path/to/project"
499
+ * - "Bug investigation: analyzing crash dump, current hypothesis is memory corruption"
500
+ * - "Code review session: reviewing PR #123, focus on security implications"
501
+ *
502
+ * When provided, this will be prepended to the system prompt to guide the checkpoint
503
+ * generation with scenario-specific emphasis.
504
+ */
505
+ scenarioHint?: string;
506
+ }
507
+
508
+ /**
509
+ * Result of compact operation
510
+ */
511
+ export interface CompactResult {
512
+ checkpoint: SessionCheckpoint;
513
+ deletedMessageCount: number;
514
+ remainingMessageCount: number;
515
+ checkpointCount: number;
516
+ }
517
+
518
+ /**
519
+ * Preview of compact operation
520
+ */
521
+ export interface CompactPreview {
522
+ messageCountToCompact: number;
523
+ estimatedCheckpointTokens: number;
524
+ wouldTrigger: boolean;
525
+ }
526
+
527
+ // ============================================================================
528
+ // Context Reading Options (new)
529
+ // ============================================================================
530
+
531
+ /**
532
+ * Options for getting session context
533
+ */
534
+ export interface GetContextOptions {
535
+ /** Start from specified checkpoint */
536
+ fromCheckpoint?: string;
537
+
538
+ /** Start from latest checkpoint (default: true) */
539
+ fromLatestCheckpoint?: boolean;
540
+
541
+ /** Read full history (ignore checkpoints) */
542
+ fullHistory?: boolean;
543
+
544
+ /** Message limit */
545
+ messageLimit?: number;
546
+
547
+ /** Minimum user messages to include (ensures starting from user message boundary) */
548
+ minUserMessages?: number;
549
+
550
+ /** Include checkpoint details */
551
+ includeCheckpoints?: boolean;
552
+ }
553
+
554
+ /**
555
+ * Result of getting session context
556
+ */
557
+ export interface GetContextResult {
558
+ session: Session;
559
+ checkpoints: SessionCheckpoint[];
560
+ startCheckpoint?: SessionCheckpoint;
561
+ messages: SessionMessage[];
562
+ totalMessageCount: number;
563
+ activeMessageCount: number;
564
+ archivedMessageCount: number;
565
+ estimatedTokens: number;
566
+ }
567
+
568
+ // ============================================================================
569
+ // Get Messages Options (new)
570
+ // ============================================================================
571
+
572
+ /**
573
+ * Options for getting messages
574
+ */
575
+ export interface GetMessagesOptions {
576
+ /** Include archived messages */
577
+ includeArchived?: boolean;
578
+
579
+ /** From checkpoint ID */
580
+ fromCheckpointId?: string;
581
+
582
+ /** Reverse order */
583
+ reverse?: boolean;
584
+ }
585
+
586
+ // ============================================================================
587
+ // Hooks
588
+ // ============================================================================
589
+
590
+ /**
591
+ * Session hook type
592
+ */
593
+ export type SessionHookType =
594
+ | "before.session.create"
595
+ | "after.session.create"
596
+ | "before.session.get"
597
+ | "after.session.get"
598
+ | "before.session.list"
599
+ | "after.session.list"
600
+ | "before.session.update"
601
+ | "after.session.update"
602
+ | "before.session.delete"
603
+ | "after.session.delete"
604
+ | "before.session.compact" // (new)
605
+ | "after.session.compact" // (new)
606
+ | "before.session.createCheckpoint" // (new)
607
+ | "after.session.createCheckpoint" // (new)
608
+ | "before.session.deleteCheckpoint" // (new)
609
+ | "after.session.deleteCheckpoint"; // (new)
610
+
611
+ /**
612
+ * Session hook context
613
+ */
614
+ export interface SessionHookContext {
615
+ session?: Session;
616
+ id?: string;
617
+ options?: CreateSessionOptions | UpdateSessionOptions;
618
+ checkpoint?: SessionCheckpoint; // [new] For checkpoint hooks
619
+ }
620
+
621
+ /**
622
+ * Session hook callback
623
+ */
624
+ export type SessionHookCallback = (context?: any) => Promise<void>;
625
+
626
+ /**
627
+ * Session hook definition
628
+ */
629
+ export interface SessionHook {
630
+ name: string;
631
+ before?: SessionHookCallback;
632
+ after?: SessionHookCallback;
633
+ }
634
+
635
+ /**
636
+ * Session hooks configuration
637
+ */
638
+ export interface SessionHooksConfig {
639
+ [key: string]: SessionHook[];
640
+ }
641
+
642
+ // ============================================================================
643
+ // Search Types (new)
644
+ // ============================================================================
645
+
646
+ /**
647
+ * Options for searching messages
648
+ */
649
+ export interface SearchMessagesOptions {
650
+ /** Search query (supports AND/OR/NOT syntax) */
651
+ query: string;
652
+
653
+ /** Limit search to specific session ID */
654
+ sessionId?: string;
655
+
656
+ /** Maximum number of results per session */
657
+ limit?: number;
658
+
659
+ /** Maximum total results */
660
+ maxResults?: number;
661
+
662
+ /** Only search messages before this timestamp */
663
+ beforeTime?: number;
664
+
665
+ /** Only search messages after this timestamp */
666
+ afterTime?: number;
667
+
668
+ /** Include archived messages */
669
+ includeArchived?: boolean;
670
+
671
+ /** Include context (messages before/after matches) */
672
+ includeContext?: boolean;
673
+
674
+ /** Number of context lines before/after */
675
+ contextLines?: number;
676
+ }
677
+
678
+ /**
679
+ * A single message match
680
+ */
681
+ export interface MessageMatch {
682
+ /** Message ID */
683
+ messageId: string;
684
+
685
+ /** Session ID */
686
+ sessionId: string;
687
+
688
+ /** Message role */
689
+ role: Role;
690
+
691
+ /** Message content */
692
+ content: string;
693
+
694
+ /** Message timestamp */
695
+ timestamp: number;
696
+
697
+ /** Context before the match (if enabled) */
698
+ contextBefore?: string;
699
+
700
+ /** Context after the match (if enabled) */
701
+ contextAfter?: string;
702
+
703
+ /** Match score (relevance) */
704
+ score?: number;
705
+ }
706
+
707
+ /**
708
+ * Search result aggregated by session
709
+ */
710
+ export interface SearchResult {
711
+ /** Session ID */
712
+ sessionId: string;
713
+
714
+ /** Session title */
715
+ sessionTitle: string;
716
+
717
+ /** Session directory */
718
+ sessionDirectory: string;
719
+
720
+ /** Session update timestamp */
721
+ updatedAt: number;
722
+
723
+ /** Total message count in session */
724
+ messageCount: number;
725
+
726
+ /** Matching messages in this session */
727
+ matches: MessageMatch[];
728
+ }
729
+
730
+ /**
731
+ * Search result with metadata
732
+ */
733
+ export interface SearchResultWithMeta {
734
+ /** Total number of matching messages */
735
+ totalMatches: number;
736
+
737
+ /** Number of sessions with matches */
738
+ sessionCount: number;
739
+
740
+ /** Results grouped by session */
741
+ results: SearchResult[];
742
+ }