@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,335 @@
1
+ import { z, ZodType, ZodTypeDef } from "zod";
2
+
3
+ // 前向声明 Environment(避免循环依赖)
4
+ import type { Environment } from "./interface";
5
+
6
+ // 导入 Hook 系统
7
+ import { HookManager, createHook, createPriorityHook } from "./hook";
8
+ import type { Hook, HookContext, HookPhase, HookMeta, HookFn, HookManagerOptions } from "./hook";
9
+
10
+ // 导出 Hook 系统
11
+ export type { Hook, HookContext, HookPhase, HookMeta, HookFn, HookManagerOptions };
12
+ export { HookManager, createHook, createPriorityHook };
13
+
14
+ /**
15
+ * Component 状态
16
+ */
17
+ export type ComponentStatus =
18
+ | "created"
19
+ | "initializing"
20
+ | "running"
21
+ | "stopping"
22
+ | "stopped"
23
+ | "error";
24
+
25
+ /**
26
+ * Component 配置
27
+ */
28
+ export interface ComponentConfig {
29
+ name: string;
30
+ version: string;
31
+ enabled: boolean;
32
+ options?: Record<string, unknown>;
33
+ /**
34
+ * Environment 实例(可选)
35
+ *
36
+ * 推荐在 init 时接收 env 实例,以便:
37
+ * - 通过 env.getComponent() 获取其他组件
38
+ * - 通过 env.pushEnvEvent() 发布事件
39
+ * - 通过 env.handle_query() 处理查询
40
+ *
41
+ * 如果未提供,部分 Component 仍可正常工作(如测试场景)
42
+ *
43
+ * @example
44
+ * ```typescript
45
+ * async onInit(): Promise<void> {
46
+ * if (this.env) {
47
+ * const configComp = this.env.getComponent("config");
48
+ * }
49
+ * }
50
+ * ```
51
+ */
52
+ env?: Environment;
53
+ }
54
+
55
+ /**
56
+ * Component 路径声明
57
+ */
58
+ export interface ComponentPaths {
59
+ base: "config" | "state" | "data" | "cache";
60
+ subPath: string;
61
+ isDirectory: boolean;
62
+ }
63
+
64
+ /**
65
+ * Component Schema(注册配置)
66
+ */
67
+ export interface ComponentSchema {
68
+ /** Component 名称 */
69
+ name: string;
70
+
71
+ /** 配置 Schema(Zod) */
72
+ schema: ZodType<unknown, ZodTypeDef, unknown>;
73
+
74
+ /** 默认值(从 Schema 提取) */
75
+ defaults: Record<string, unknown>;
76
+
77
+ /** 路径声明 */
78
+ paths?: Record<string, ComponentPaths>;
79
+
80
+ /** 元信息 */
81
+ metadata?: {
82
+ description?: string;
83
+ version?: string;
84
+ author?: string;
85
+ };
86
+ }
87
+
88
+ /**
89
+ * Component 配置变更事件
90
+ */
91
+ export interface ComponentConfigChangeEvent {
92
+ /** Component 名称 */
93
+ component: string;
94
+
95
+ /** 变更的配置键 */
96
+ key: string;
97
+
98
+ /** 旧值 */
99
+ oldValue: unknown;
100
+
101
+ /** 新值 */
102
+ newValue: unknown;
103
+
104
+ /** 是否持久化 */
105
+ persisted: boolean;
106
+
107
+ /** 时间戳 */
108
+ timestamp: number;
109
+ }
110
+
111
+ /**
112
+ * Component 配置监听回调
113
+ */
114
+ export type ComponentWatchCallback = (
115
+ event: ComponentConfigChangeEvent
116
+ ) => void | Promise<void>;
117
+
118
+ /**
119
+ * Component 基类接口
120
+ */
121
+ export interface Component {
122
+ /** Component 名称 */
123
+ readonly name: string;
124
+
125
+ /** Component 版本 */
126
+ readonly version: string;
127
+
128
+ /** 获取状态 */
129
+ getStatus(): ComponentStatus;
130
+
131
+ /** 获取配置 */
132
+ getConfig(): ComponentConfig;
133
+
134
+ /** 初始化 */
135
+ init(config: ComponentConfig): Promise<void>;
136
+
137
+ /** 启动 */
138
+ start(): Promise<void>;
139
+
140
+ /** 停止 */
141
+ stop(): Promise<void>;
142
+ }
143
+
144
+ /**
145
+ * Component 基类实现
146
+ */
147
+ export abstract class BaseComponent implements Component {
148
+ abstract readonly name: string;
149
+ abstract readonly version: string;
150
+
151
+ protected _status: ComponentStatus = "created";
152
+ protected _enabled: boolean = true;
153
+ protected env!: Environment; // 非可选,使用 definite assignment assertion
154
+
155
+ /** Hook 管理器 - 子类初始化时由构造函数设置 */
156
+ public readonly hookManager: HookManager;
157
+
158
+ constructor() {
159
+ // 创建 HookManager,稍后在 init 中更新组件信息
160
+ this.hookManager = new HookManager();
161
+ }
162
+
163
+ getStatus(): ComponentStatus {
164
+ return this._status;
165
+ }
166
+
167
+ getConfig(): ComponentConfig {
168
+ return {
169
+ name: this.name,
170
+ version: this.version,
171
+ enabled: this._enabled,
172
+ env: this.env,
173
+ };
174
+ }
175
+
176
+ /**
177
+ * 检查 Environment 是否已初始化
178
+ */
179
+ protected isEnvInitialized(): boolean {
180
+ return this._status !== "created";
181
+ }
182
+
183
+ protected setStatus(status: ComponentStatus): void {
184
+ this._status = status;
185
+ }
186
+
187
+ /**
188
+ * 获取 Environment 实例
189
+ */
190
+ protected getEnv(): Environment {
191
+ return this.env;
192
+ }
193
+
194
+ async init(config?: ComponentConfig): Promise<void> {
195
+ // 如果提供了 env,则注入
196
+ if (config?.env) {
197
+ this.env = config.env;
198
+ }
199
+
200
+ this.setStatus("initializing");
201
+
202
+ // 只有当 name/version 未在子类中定义时才从 config 注入
203
+ // 注意:如果子类已定义这些属性,Object.defineProperty 会失败
204
+ try {
205
+ if (config?.name) Object.defineProperty(this, "name", { value: config.name, writable: false });
206
+ if (config?.version) Object.defineProperty(this, "version", { value: config.version, writable: false });
207
+ } catch {
208
+ // 忽略错误(属性可能已在子类中定义)
209
+ }
210
+ if (config?.enabled !== undefined) this._enabled = config.enabled;
211
+
212
+ // 更新 HookManager 的组件信息
213
+ this.hookManager.setComponentInfo(this.name, this.version);
214
+
215
+ await this.onInit();
216
+ this.setStatus("running");
217
+ }
218
+
219
+ async start(): Promise<void> {
220
+ // 使用内部标志跟踪 start() 是否已调用
221
+ // 这是必要的,因为 init() 会将状态设为 "running",但组件的 start() 仍需被调用
222
+ if ((this as any)._started) return;
223
+ (this as any)._started = true;
224
+
225
+ await this.onStart();
226
+ this.setStatus("running");
227
+ }
228
+
229
+ async stop(): Promise<void> {
230
+ this.setStatus("stopping");
231
+
232
+ // 清理 Hooks
233
+ this.hookManager.clear();
234
+
235
+ await this.onStop();
236
+ this.setStatus("stopped");
237
+ }
238
+
239
+ /**
240
+ * 子类可覆盖的钩子方法
241
+ */
242
+ protected async onInit(): Promise<void> {}
243
+ protected async onStart(): Promise<void> {}
244
+ protected async onStop(): Promise<void> {}
245
+
246
+ // ========================================================================
247
+ // Hook 便捷方法
248
+ // ========================================================================
249
+
250
+ /**
251
+ * 注册 Hook
252
+ *
253
+ * @param hookPoint Hook 点名称
254
+ * @param hook Hook 实例
255
+ */
256
+ protected registerHook<T = unknown>(hookPoint: string, hook: Hook<T>): void {
257
+ this.hookManager.register(hookPoint, hook);
258
+ }
259
+
260
+ /**
261
+ * 便捷方法:快速注册 Hook
262
+ */
263
+ protected addHook<T = unknown>(
264
+ hookPoint: string,
265
+ name: string,
266
+ fn: HookFn<T>,
267
+ priority?: number
268
+ ): void {
269
+ this.hookManager.register(
270
+ hookPoint,
271
+ createHook({ name, priority }, fn)
272
+ );
273
+ }
274
+
275
+ /**
276
+ * 便捷方法:按名称取消注册 Hook
277
+ */
278
+ protected removeHook(hookPoint: string, name: string): boolean {
279
+ return this.hookManager.unregister(hookPoint, name);
280
+ }
281
+
282
+ /**
283
+ * 执行 Hook
284
+ */
285
+ protected async executeHooks<T = unknown>(
286
+ hookPoint: string,
287
+ data: T,
288
+ metadata?: Record<string, unknown>
289
+ ): Promise<void> {
290
+ await this.hookManager.execute(hookPoint, data, metadata);
291
+ }
292
+
293
+ // ========================================================================
294
+ // 配置统一管理方法
295
+ // ========================================================================
296
+
297
+ /**
298
+ * 获取 ConfigComponent 实例
299
+ *
300
+ * 子类可使用此方法获取配置组件,支持热更新
301
+ */
302
+ protected getConfigComponent(): { get(key: string): unknown } | undefined {
303
+ return this.env?.getComponent("config") as unknown as { get(key: string): unknown } | undefined;
304
+ }
305
+
306
+ /**
307
+ * 动态获取运行时配置值
308
+ *
309
+ * 优先从 ConfigComponent 获取(支持热更新),否则返回默认值
310
+ * 适用于运行时可能变化的配置(如 API Keys、模型参数)
311
+ *
312
+ * @param key 配置键(支持点号分隔的路径,如 "llm.temperature")
313
+ * @param defaultValue 默认值
314
+ * @returns 配置值或默认值
315
+ *
316
+ * @example
317
+ * ```typescript
318
+ * // 获取 LLM 温度配置(可能支持热更新)
319
+ * const temperature = this.getRuntimeConfig("llm.temperature", 0.7);
320
+ *
321
+ * // 获取 API Key
322
+ * const apiKey = this.getRuntimeConfig<string>("llm.providers.openai.apiKey");
323
+ * ```
324
+ */
325
+ protected getRuntimeConfig<T>(key: string, defaultValue: T): T {
326
+ const configComponent = this.getConfigComponent();
327
+ if (configComponent) {
328
+ const value = configComponent.get(key);
329
+ if (value !== undefined) {
330
+ return value as T;
331
+ }
332
+ }
333
+ return defaultValue;
334
+ }
335
+ }
@@ -0,0 +1,72 @@
1
+ import { describe, test, expect } from "bun:test";
2
+ import {
3
+ AgentEvents,
4
+ AgentErrorMessages,
5
+ ToolEvents,
6
+ ToolErrorMessages,
7
+ LLMErrorMessages,
8
+ ComponentEvents,
9
+ isAgentEvent,
10
+ isToolEvent,
11
+ } from "./constants";
12
+
13
+ describe("常量定义", () => {
14
+
15
+ describe("AgentEvents", () => {
16
+ test("应该定义正确的事件名称", () => {
17
+ expect(AgentEvents.RUN_START).toBe("agent.run.start");
18
+ expect(AgentEvents.RUN_COMPLETE).toBe("agent.run.complete");
19
+ expect(AgentEvents.RUN_ERROR).toBe("agent.run.error");
20
+ expect(AgentEvents.TOOL_CALLED).toBe("agent.tool.called");
21
+ expect(AgentEvents.TOOL_RESULT).toBe("agent.tool.result");
22
+ expect(AgentEvents.LLM_REQUEST).toBe("agent.llm.request");
23
+ expect(AgentEvents.LLM_RESPONSE).toBe("agent.llm.response");
24
+ });
25
+ });
26
+
27
+ describe("ToolEvents", () => {
28
+ test("应该定义正确的事件名称", () => {
29
+ expect(ToolEvents.EXECUTE_START).toBe("tool.execute.start");
30
+ expect(ToolEvents.EXECUTE_COMPLETE).toBe("tool.execute.complete");
31
+ expect(ToolEvents.EXECUTE_ERROR).toBe("tool.execute.error");
32
+ expect(ToolEvents.REGISTERED).toBe("tool.registered");
33
+ });
34
+ });
35
+
36
+ describe("ComponentEvents", () => {
37
+ test("应该定义正确的事件名称", () => {
38
+ expect(ComponentEvents.INIT_START).toBe("component.init.start");
39
+ expect(ComponentEvents.INIT_COMPLETE).toBe("component.init.complete");
40
+ expect(ComponentEvents.STOP).toBe("component.stop");
41
+ });
42
+ });
43
+
44
+ describe("错误消息函数", () => {
45
+ test("AgentErrorMessages 应该生成正确的消息", () => {
46
+ expect(AgentErrorMessages.notFound("my-agent")).toBe("Agent not found: my-agent");
47
+ expect(AgentErrorMessages.alreadyRunning("my-agent")).toBe("Agent my-agent is already running");
48
+ });
49
+
50
+ test("ToolErrorMessages 应该生成正确的消息", () => {
51
+ expect(ToolErrorMessages.notFound("readFile")).toBe("Tool not found: readFile");
52
+ expect(ToolErrorMessages.disabled("writeFile")).toBe("Tool writeFile is disabled");
53
+ });
54
+
55
+ test("LLMErrorMessages 应该生成正确的消息", () => {
56
+ expect(LLMErrorMessages.providerNotFound("openai")).toBe("LLM provider not found: openai");
57
+ expect(LLMErrorMessages.apiKeyMissing("anthropic")).toBe("API key missing for provider: anthropic");
58
+ });
59
+ });
60
+
61
+ describe("类型守卫", () => {
62
+ test("isAgentEvent 应该正确识别 Agent 事件", () => {
63
+ expect(isAgentEvent("agent.run.start")).toBe(true);
64
+ expect(isAgentEvent("tool.execute.start")).toBe(false);
65
+ });
66
+
67
+ test("isToolEvent 应该正确识别 Tool 事件", () => {
68
+ expect(isToolEvent("tool.execute.start")).toBe(true);
69
+ expect(isToolEvent("agent.run.start")).toBe(false);
70
+ });
71
+ });
72
+ });
@@ -0,0 +1,123 @@
1
+ /**
2
+ * @fileoverview 统一常量定义
3
+ *
4
+ * 定义事件名称和错误消息常量,避免硬编码字符串
5
+ */
6
+
7
+ /**
8
+ * Agent 相关事件名称
9
+ */
10
+ export const AgentEvents = {
11
+ RUN_START: "agent.run.start",
12
+ RUN_COMPLETE: "agent.run.complete",
13
+ RUN_ERROR: "agent.run.error",
14
+ TOOL_CALLED: "agent.tool.called",
15
+ TOOL_RESULT: "agent.tool.result",
16
+ LLM_REQUEST: "agent.llm.request",
17
+ LLM_RESPONSE: "agent.llm.response",
18
+ ITERATION_START: "agent.iteration.start",
19
+ ITERATION_COMPLETE: "agent.iteration.complete",
20
+ } as const;
21
+
22
+ /**
23
+ * Tool 相关事件名称
24
+ */
25
+ export const ToolEvents = {
26
+ EXECUTE_START: "tool.execute.start",
27
+ EXECUTE_COMPLETE: "tool.execute.complete",
28
+ EXECUTE_ERROR: "tool.execute.error",
29
+ REGISTERED: "tool.registered",
30
+ UNREGISTERED: "tool.unregistered",
31
+ } as const;
32
+
33
+ /**
34
+ * Component 生命周期事件名称
35
+ */
36
+ export const ComponentEvents = {
37
+ INIT_START: "component.init.start",
38
+ INIT_COMPLETE: "component.init.complete",
39
+ START: "component.start",
40
+ STOP: "component.stop",
41
+ } as const;
42
+
43
+ /**
44
+ * Session 相关事件名称
45
+ */
46
+ export const SessionEvents = {
47
+ CREATED: "session.created",
48
+ DELETED: "session.deleted",
49
+ MESSAGE_ADDED: "session.message.added",
50
+ } as const;
51
+
52
+ /**
53
+ * Agent 错误消息
54
+ */
55
+ export const AgentErrorMessages = {
56
+ notFound: (name: string) => `Agent not found: ${name}`,
57
+ alreadyRunning: (name: string) => `Agent ${name} is already running`,
58
+ notRunning: (name: string) => `Agent ${name} is not running`,
59
+ runFailed: (name: string, reason?: string) =>
60
+ reason ? `Agent ${name} run failed: ${reason}` : `Agent ${name} run failed`,
61
+ } as const;
62
+
63
+ /**
64
+ * Tool 错误消息
65
+ */
66
+ export const ToolErrorMessages = {
67
+ notFound: (name: string) => `Tool not found: ${name}`,
68
+ disabled: (name: string) => `Tool ${name} is disabled`,
69
+ executionFailed: (name: string, reason?: string) =>
70
+ reason ? `Tool ${name} execution failed: ${reason}` : `Tool ${name} execution failed`,
71
+ validationFailed: (name: string, reason?: string) =>
72
+ reason ? `Tool ${name} validation failed: ${reason}` : `Tool ${name} validation failed`,
73
+ } as const;
74
+
75
+ /**
76
+ * LLM 错误消息
77
+ */
78
+ export const LLMErrorMessages = {
79
+ providerNotFound: (provider: string) => `LLM provider not found: ${provider}`,
80
+ apiKeyMissing: (provider: string) => `API key missing for provider: ${provider}`,
81
+ invocationFailed: (provider: string, reason?: string) =>
82
+ reason ? `LLM ${provider} invocation failed: ${reason}` : `LLM ${provider} invocation failed`,
83
+ timeout: (provider: string) => `LLM ${provider} invocation timeout`,
84
+ } as const;
85
+
86
+ /**
87
+ * Component 错误消息
88
+ */
89
+ export const ComponentErrorMessages = {
90
+ notFound: (name: string) => `Component not found: ${name}`,
91
+ notRegistered: (name: string) => `Component ${name} is not registered`,
92
+ notRunning: (name: string) => `Component ${name} is not running`,
93
+ initFailed: (name: string, reason?: string) =>
94
+ reason ? `Component ${name} init failed: ${reason}` : `Component ${name} init failed`,
95
+ } as const;
96
+
97
+ /**
98
+ * 检查是否是 Agent 事件
99
+ */
100
+ export function isAgentEvent(event: string): event is typeof AgentEvents[keyof typeof AgentEvents] {
101
+ return event.startsWith("agent.");
102
+ }
103
+
104
+ /**
105
+ * 检查是否是 Tool 事件
106
+ */
107
+ export function isToolEvent(event: string): event is typeof ToolEvents[keyof typeof ToolEvents] {
108
+ return event.startsWith("tool.");
109
+ }
110
+
111
+ /**
112
+ * 检查是否是 Component 事件
113
+ */
114
+ export function isComponentEvent(event: string): event is typeof ComponentEvents[keyof typeof ComponentEvents] {
115
+ return event.startsWith("component.");
116
+ }
117
+
118
+ /**
119
+ * 检查是否是 Session 事件
120
+ */
121
+ export function isSessionEvent(event: string): event is typeof SessionEvents[keyof typeof SessionEvents] {
122
+ return event.startsWith("session.");
123
+ }
@@ -0,0 +1,114 @@
1
+ import { describe, expect, test, beforeEach } from 'bun:test';
2
+ import { DebugComponent } from './debug-component';
3
+ import type { TraceEntry, TraceTreeNode, ParserOptions } from './types';
4
+
5
+ describe('DebugComponent', () => {
6
+ let component: DebugComponent;
7
+
8
+ beforeEach(() => {
9
+ component = new DebugComponent();
10
+ });
11
+
12
+ describe('initialization', () => {
13
+ test('should have correct name and version', () => {
14
+ expect(component.name).toBe('debug');
15
+ expect(component.version).toBe('1.0.0');
16
+ });
17
+
18
+ test('should initialize with running status', async () => {
19
+ await component.init();
20
+ expect(component.getStatus()).toBe('running');
21
+ });
22
+ });
23
+
24
+ describe('getTraces', () => {
25
+ test('should return traces from log file', async () => {
26
+ await component.init();
27
+
28
+ // Note: Without proper file mocking, we test the structure
29
+ const traces = await component.getTraces({
30
+ logFile: '/nonexistent/app.log',
31
+ });
32
+
33
+ expect(Array.isArray(traces)).toBe(true);
34
+ // Non-existent file returns empty array
35
+ expect(traces).toEqual([]);
36
+ });
37
+
38
+ test('should filter by function name', async () => {
39
+ await component.init();
40
+
41
+ const traces = await component.getTraces({
42
+ logFile: '/real/app.log',
43
+ function: 'llm.invoke',
44
+ });
45
+
46
+ expect(traces.every(t => t.function.includes('llm'))).toBe(true);
47
+ });
48
+
49
+ test('should return empty array for non-existent file', async () => {
50
+ await component.init();
51
+
52
+ const traces = await component.getTraces({
53
+ logFile: '/nonexistent/file.log',
54
+ });
55
+
56
+ expect(traces).toEqual([]);
57
+ });
58
+ });
59
+
60
+ describe('listTraceIds', () => {
61
+ test('should return trace ID list', async () => {
62
+ await component.init();
63
+
64
+ const result = await component.listTraceIds({
65
+ logFile: '/real/app.log',
66
+ });
67
+
68
+ expect(result).toHaveProperty('traceIds');
69
+ expect(result).toHaveProperty('count');
70
+ expect(Array.isArray(result.traceIds)).toBe(true);
71
+ });
72
+
73
+ test('should respect limit parameter', async () => {
74
+ await component.init();
75
+
76
+ const result = await component.listTraceIds({
77
+ logFile: '/real/app.log',
78
+ limit: 5,
79
+ });
80
+
81
+ expect(result.traceIds.length).toBeLessThanOrEqual(5);
82
+ });
83
+ });
84
+
85
+ describe('getCallTree', () => {
86
+ test('should return call tree for trace', async () => {
87
+ await component.init();
88
+
89
+ const tree = await component.getCallTree({
90
+ logFile: '/real/app.log',
91
+ traceId: 'req_123',
92
+ });
93
+
94
+ if (tree) {
95
+ expect(tree).toHaveProperty('traceId');
96
+ expect(tree).toHaveProperty('function');
97
+ expect(tree).toHaveProperty('children');
98
+ expect(Array.isArray(tree.children)).toBe(true);
99
+ }
100
+ });
101
+
102
+ test('should return null for non-existent trace', async () => {
103
+ await component.init();
104
+
105
+ const tree = await component.getCallTree({
106
+ logFile: '/real/app.log',
107
+ traceId: 'nonexistent',
108
+ });
109
+
110
+ // May return null or empty tree depending on implementation
111
+ expect(tree === null || tree.traceId !== 'nonexistent').toBe(true);
112
+ });
113
+ });
114
+ });