@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,306 @@
1
+ /**
2
+ * WorkflowConverter - 将装饰器类转换为 WorkflowDefinition
3
+ */
4
+
5
+ import 'reflect-metadata';
6
+ import { getWorkflowMetadata } from '../decorators/workflow';
7
+ import { getNodeMetadatas } from '../decorators/node-as';
8
+ import { getEdgeMetadatas } from '../decorators/edge';
9
+ import type {
10
+ WorkflowMetadata,
11
+ NodeMetadata,
12
+ EdgeMetadata,
13
+ ValidationResult,
14
+ ConvertedWorkflowDefinition,
15
+ ConvertedNodeDefinition,
16
+ } from '../types/decorators-types';
17
+
18
+ // Note: createWorkflowFromClass is exported from ./utils/create-workflow
19
+ // and re-exported from workflow-component.ts to avoid circular dependencies
20
+
21
+ /**
22
+ * Workflow 转换器
23
+ *
24
+ * 负责将使用装饰器定义的类转换为标准的 WorkflowDefinition
25
+ */
26
+ export class WorkflowConverter {
27
+
28
+ /**
29
+ * 从装饰器类提取 Workflow 元数据
30
+ */
31
+ static extractWorkflowMetadata(targetClass: Function): WorkflowMetadata | undefined {
32
+ return getWorkflowMetadata(targetClass);
33
+ }
34
+
35
+ /**
36
+ * 从装饰器类提取所有 Node 元数据
37
+ */
38
+ static extractNodeMetadatas(targetClass: Function): NodeMetadata[] {
39
+ // 获取原型上的元数据(方法装饰器存储在原型上)
40
+ return getNodeMetadatas(targetClass.prototype);
41
+ }
42
+
43
+ /**
44
+ * 从装饰器类提取所有 Edge 元数据
45
+ */
46
+ static extractEdgeMetadatas(targetClass: Function): EdgeMetadata[] {
47
+ return getEdgeMetadatas(targetClass);
48
+ }
49
+
50
+ /**
51
+ * 将装饰器类转换为 WorkflowDefinition
52
+ */
53
+ static fromClass(
54
+ targetClass: new (...args: any[]) => any,
55
+ instance: any
56
+ ): ConvertedWorkflowDefinition {
57
+ // 1. 获取 Workflow 元数据
58
+ const workflowMeta = this.extractWorkflowMetadata(targetClass);
59
+ if (!workflowMeta) {
60
+ throw new Error('Class must be decorated with @Workflow');
61
+ }
62
+
63
+ // 2. 获取所有 Node 元数据
64
+ const nodeMetadatas = this.extractNodeMetadatas(targetClass);
65
+ if (nodeMetadatas.length === 0) {
66
+ throw new Error('At least one method must be decorated with @NodeAs');
67
+ }
68
+
69
+ // 3. 获取所有 Edge 元数据
70
+ const edgeMetadatas = this.extractEdgeMetadatas(targetClass);
71
+
72
+ // 4. 合并 Edge 到 Node 的 dependsOn
73
+ const nodeMap = this.buildNodeMap(nodeMetadatas, edgeMetadatas);
74
+
75
+ // 5. 转换为 NodeDefinition[]
76
+ const nodes: ConvertedNodeDefinition[] = Array.from(nodeMap.values()).map(meta => ({
77
+ id: meta.nodeId,
78
+ type: meta.nodeType,
79
+ name: meta.name,
80
+ config: {
81
+ ...meta.config,
82
+ _methodName: meta.methodName, // 存储方法名用于执行
83
+ _instance: instance, // 存储实例引用用于执行
84
+ },
85
+ depends_on: meta.dependsOn,
86
+ condition: meta.condition,
87
+ retry: meta.retry,
88
+ timeout: meta.timeout,
89
+ }));
90
+
91
+ // 6. 确定入口节点
92
+ const entry = workflowMeta.entry || nodeMetadatas[0]?.nodeId || 'unknown';
93
+
94
+ // 7. 构建 WorkflowDefinition
95
+ return {
96
+ name: workflowMeta.name,
97
+ version: workflowMeta.version || '1.0',
98
+ description: workflowMeta.description,
99
+ config: workflowMeta.config || {},
100
+ nodes,
101
+ entry,
102
+ outputs: [],
103
+ metadata: {
104
+ tags: workflowMeta.tags || [],
105
+ author: workflowMeta.author,
106
+ },
107
+ };
108
+ }
109
+
110
+ /**
111
+ * 构建节点映射,并合并边依赖
112
+ */
113
+ private static buildNodeMap(
114
+ nodeMetadatas: NodeMetadata[],
115
+ edgeMetadatas: EdgeMetadata[]
116
+ ): Map<string, NodeMetadata> {
117
+ const nodeMap = new Map<string, NodeMetadata>();
118
+
119
+ // 初始化节点映射
120
+ for (const nodeMeta of nodeMetadatas) {
121
+ nodeMap.set(nodeMeta.nodeId, { ...nodeMeta });
122
+ }
123
+
124
+ // 从 Edge 元数据添加依赖和条件
125
+ for (const edge of edgeMetadatas) {
126
+ const targetNode = nodeMap.get(edge.to);
127
+ if (targetNode) {
128
+ // 添加依赖(如果不存在)
129
+ if (!targetNode.dependsOn.includes(edge.from)) {
130
+ targetNode.dependsOn = [...targetNode.dependsOn, edge.from];
131
+ }
132
+
133
+ // 合并条件边:如果 @Edge 有 condition,将其与节点的 condition 合并
134
+ // 条件格式:${nodeId.field} 表示从哪个节点的输出获取条件值
135
+ if (edge.condition) {
136
+ // 如果节点已有条件,合并为 AND 关系
137
+ if (targetNode.condition) {
138
+ targetNode.condition = `(${targetNode.condition}) AND (${edge.condition})`;
139
+ } else {
140
+ targetNode.condition = edge.condition;
141
+ }
142
+ }
143
+ }
144
+ }
145
+
146
+ return nodeMap;
147
+ }
148
+
149
+ /**
150
+ * 验证装饰器类的有效性
151
+ */
152
+ static validateWorkflowClass(targetClass: Function): ValidationResult {
153
+ const errors: string[] = [];
154
+ const warnings: string[] = [];
155
+
156
+ // 1. 检查 @Workflow 装饰器
157
+ const workflowMeta = this.extractWorkflowMetadata(targetClass);
158
+ if (!workflowMeta) {
159
+ errors.push('Class must be decorated with @Workflow');
160
+ return { valid: false, errors, warnings };
161
+ }
162
+
163
+ // 2. 检查至少有一个 @NodeAs 节点
164
+ const nodeMetadatas = this.extractNodeMetadatas(targetClass);
165
+ if (nodeMetadatas.length === 0) {
166
+ errors.push('At least one method must be decorated with @NodeAs');
167
+ return { valid: false, errors, warnings };
168
+ }
169
+
170
+ // 3. 检查入口节点存在
171
+ const entry = workflowMeta.entry;
172
+ if (entry) {
173
+ const entries = Array.isArray(entry) ? entry : [entry];
174
+ for (const e of entries) {
175
+ if (!nodeMetadatas.find(n => n.nodeId === e)) {
176
+ errors.push(`Entry node '${e}' not found`);
177
+ }
178
+ }
179
+ }
180
+
181
+ // 4. 检查依赖节点存在
182
+ for (const node of nodeMetadatas) {
183
+ for (const dep of node.dependsOn) {
184
+ if (!nodeMetadatas.find(n => n.nodeId === dep)) {
185
+ errors.push(`Node '${node.nodeId}' depends on non-existent node '${dep}'`);
186
+ }
187
+ }
188
+ }
189
+
190
+ // 5. 检查循环依赖
191
+ if (this.hasCycle(nodeMetadatas)) {
192
+ errors.push('Workflow contains a cycle');
193
+ }
194
+
195
+ return {
196
+ valid: errors.length === 0,
197
+ errors,
198
+ warnings,
199
+ };
200
+ }
201
+
202
+ /**
203
+ * 检测是否存在循环依赖
204
+ *
205
+ * dependsOn 语义:A 依赖 B 表示 A.dependsOn = [B]
206
+ * 这意味着 B 执行完成后才能执行 A,所以边是 B → A
207
+ *
208
+ * 检测方法:构建反向邻接表(谁依赖我),然后 DFS 检测环
209
+ */
210
+ private static hasCycle(nodeMetadatas: NodeMetadata[]): boolean {
211
+ const visited = new Set<string>();
212
+ const recStack = new Set<string>();
213
+
214
+ // 构建反向邻接表:nodeId -> 依赖此 node 的节点列表
215
+ // 即:谁在我之后执行
216
+ const adjList = new Map<string, string[]>();
217
+ for (const node of nodeMetadatas) {
218
+ adjList.set(node.nodeId, []);
219
+ }
220
+ for (const node of nodeMetadatas) {
221
+ for (const dep of node.dependsOn) {
222
+ const deps = adjList.get(dep);
223
+ if (deps) {
224
+ deps.push(node.nodeId);
225
+ }
226
+ }
227
+ }
228
+
229
+ // DFS 检测环:从任意节点出发,如果能回到已在递归栈中的节点,则存在环
230
+ const dfs = (nodeId: string): boolean => {
231
+ visited.add(nodeId);
232
+ recStack.add(nodeId);
233
+
234
+ const neighbors = adjList.get(nodeId) || [];
235
+ for (const neighbor of neighbors) {
236
+ if (!visited.has(neighbor)) {
237
+ if (dfs(neighbor)) {
238
+ return true;
239
+ }
240
+ } else if (recStack.has(neighbor)) {
241
+ // 发现环:neighbor 已在递归栈中
242
+ return true;
243
+ }
244
+ }
245
+
246
+ recStack.delete(nodeId);
247
+ return false;
248
+ };
249
+
250
+ // 检查所有节点
251
+ for (const node of nodeMetadatas) {
252
+ if (!visited.has(node.nodeId)) {
253
+ if (dfs(node.nodeId)) {
254
+ return true;
255
+ }
256
+ }
257
+ }
258
+
259
+ return false;
260
+ }
261
+
262
+ /**
263
+ * 执行装饰器方法(用于 WorkflowEngine 调用)
264
+ */
265
+ static async executeNode(
266
+ nodeDef: ConvertedNodeDefinition,
267
+ context: {
268
+ input: any;
269
+ previousOutputs: Map<string, any>;
270
+ }
271
+ ): Promise<{ output: any; error?: Error }> {
272
+ const instance = nodeDef.config._instance;
273
+ const methodName = nodeDef.config._methodName;
274
+
275
+ if (!instance || !methodName) {
276
+ return { output: undefined, error: new Error('Missing method information') };
277
+ }
278
+
279
+ const method = (instance as any)[methodName as string];
280
+ if (typeof method !== 'function') {
281
+ return { output: undefined, error: new Error(`Method ${methodName} is not a function`) };
282
+ }
283
+
284
+ // 准备输入参数
285
+ const deps = nodeDef.depends_on || [];
286
+ let input = context.input;
287
+
288
+ if (deps.length > 0) {
289
+ // 从依赖节点输出构建输入
290
+ input = {};
291
+ for (const depId of deps) {
292
+ input[depId] = context.previousOutputs.get(depId);
293
+ }
294
+ }
295
+
296
+ try {
297
+ const result = await method.call(instance, input);
298
+ return { output: result };
299
+ } catch (error) {
300
+ return {
301
+ output: undefined,
302
+ error: error instanceof Error ? error : new Error(String(error))
303
+ };
304
+ }
305
+ }
306
+ }
@@ -0,0 +1,380 @@
1
+ /**
2
+ * Test Fixtures - Workflow Definitions for Integration Tests
3
+ */
4
+
5
+ import type { WorkflowDefinition } from './types';
6
+
7
+ // Helper to create workflow fixtures without strict type checking
8
+ function createWorkflow<T extends object>(def: T): T {
9
+ return def;
10
+ }
11
+
12
+ /**
13
+ * Simple single-node workflow for basic testing
14
+ */
15
+ export const singleNodeWorkflow = createWorkflow({
16
+ name: 'single-node-test',
17
+ version: '1.0.0',
18
+ description: 'A simple single-node workflow for testing',
19
+ nodes: [
20
+ {
21
+ id: 'node-1',
22
+ type: 'tool',
23
+ config: {
24
+ tool_name: 'echo',
25
+ tool_args: {
26
+ message: 'Hello from single-node workflow'
27
+ }
28
+ }
29
+ }
30
+ ],
31
+ entry: 'node-1'
32
+ });
33
+
34
+ /**
35
+ * Sequential workflow with three steps
36
+ */
37
+ export const sequentialWorkflow = createWorkflow({
38
+ name: 'sequential-test',
39
+ version: '1.0.0',
40
+ description: 'Three-step sequential workflow',
41
+ nodes: [
42
+ {
43
+ id: 'step-1',
44
+ type: 'tool',
45
+ config: {
46
+ tool_name: 'echo',
47
+ tool_args: {
48
+ message: 'Step 1'
49
+ }
50
+ }
51
+ },
52
+ {
53
+ id: 'step-2',
54
+ type: 'tool',
55
+ config: {
56
+ tool_name: 'echo',
57
+ tool_args: {
58
+ message: 'Step 2'
59
+ }
60
+ },
61
+ depends_on: ['step-1']
62
+ },
63
+ {
64
+ id: 'step-3',
65
+ type: 'tool',
66
+ config: {
67
+ tool_name: 'echo',
68
+ tool_args: {
69
+ message: 'Step 3'
70
+ }
71
+ },
72
+ depends_on: ['step-2']
73
+ }
74
+ ],
75
+ entry: 'step-1'
76
+ });
77
+
78
+ /**
79
+ * Parallel workflow with two branches
80
+ */
81
+ export const parallelWorkflow = createWorkflow({
82
+ name: 'parallel-test',
83
+ version: '1.0.0',
84
+ description: 'Parallel execution workflow with two branches',
85
+ nodes: [
86
+ {
87
+ id: 'start',
88
+ type: 'tool',
89
+ config: {
90
+ tool_name: 'echo',
91
+ tool_args: {
92
+ message: 'Start'
93
+ }
94
+ }
95
+ },
96
+ {
97
+ id: 'branch-a',
98
+ type: 'tool',
99
+ config: {
100
+ tool_name: 'echo',
101
+ tool_args: {
102
+ message: 'Branch A'
103
+ }
104
+ },
105
+ depends_on: ['start']
106
+ },
107
+ {
108
+ id: 'branch-b',
109
+ type: 'tool',
110
+ config: {
111
+ tool_name: 'echo',
112
+ tool_args: {
113
+ message: 'Branch B'
114
+ }
115
+ },
116
+ depends_on: ['start']
117
+ },
118
+ {
119
+ id: 'merge',
120
+ type: 'tool',
121
+ config: {
122
+ tool_name: 'echo',
123
+ tool_args: {
124
+ message: 'Merge'
125
+ }
126
+ },
127
+ depends_on: ['branch-a', 'branch-b']
128
+ }
129
+ ],
130
+ entry: 'start'
131
+ });
132
+
133
+ /**
134
+ * Diamond workflow - classic DAG pattern
135
+ * start
136
+ * / \
137
+ * left right
138
+ * \ /
139
+ * merge
140
+ * |
141
+ * end
142
+ */
143
+ export const diamondWorkflow = createWorkflow({
144
+ name: 'diamond-test',
145
+ version: '1.0.0',
146
+ description: 'Diamond pattern workflow',
147
+ nodes: [
148
+ {
149
+ id: 'start',
150
+ type: 'tool',
151
+ config: {
152
+ tool_name: 'echo',
153
+ tool_args: {
154
+ message: 'Diamond Start'
155
+ }
156
+ }
157
+ },
158
+ {
159
+ id: 'left',
160
+ type: 'tool',
161
+ config: {
162
+ tool_name: 'echo',
163
+ tool_args: {
164
+ message: 'Left Branch'
165
+ }
166
+ },
167
+ depends_on: ['start']
168
+ },
169
+ {
170
+ id: 'right',
171
+ type: 'tool',
172
+ config: {
173
+ tool_name: 'echo',
174
+ tool_args: {
175
+ message: 'Right Branch'
176
+ }
177
+ },
178
+ depends_on: ['start']
179
+ },
180
+ {
181
+ id: 'merge',
182
+ type: 'tool',
183
+ config: {
184
+ tool_name: 'echo',
185
+ tool_args: {
186
+ message: 'Merge'
187
+ }
188
+ },
189
+ depends_on: ['left', 'right']
190
+ },
191
+ {
192
+ id: 'end',
193
+ type: 'tool',
194
+ config: {
195
+ tool_name: 'echo',
196
+ tool_args: {
197
+ message: 'Diamond End'
198
+ }
199
+ },
200
+ depends_on: ['merge']
201
+ }
202
+ ],
203
+ entry: 'start'
204
+ });
205
+
206
+ /**
207
+ * Workflow with conditional execution
208
+ */
209
+ export const conditionalWorkflow = createWorkflow({
210
+ name: 'conditional-test',
211
+ version: '1.0.0',
212
+ description: 'Workflow with conditional branching',
213
+ nodes: [
214
+ {
215
+ id: 'input',
216
+ type: 'tool',
217
+ config: {
218
+ tool_name: 'echo',
219
+ tool_args: {
220
+ message: 'input'
221
+ }
222
+ }
223
+ },
224
+ {
225
+ id: 'check',
226
+ type: 'tool',
227
+ config: {
228
+ tool_name: 'echo',
229
+ tool_args: {
230
+ message: 'Check'
231
+ }
232
+ },
233
+ depends_on: ['input']
234
+ },
235
+ {
236
+ id: 'action-a',
237
+ type: 'tool',
238
+ config: {
239
+ tool_name: 'echo',
240
+ tool_args: {
241
+ message: 'Action A'
242
+ }
243
+ },
244
+ depends_on: ['check']
245
+ },
246
+ {
247
+ id: 'action-b',
248
+ type: 'tool',
249
+ config: {
250
+ tool_name: 'echo',
251
+ tool_args: {
252
+ message: 'Action B'
253
+ }
254
+ },
255
+ depends_on: ['check']
256
+ }
257
+ ],
258
+ entry: 'input'
259
+ });
260
+
261
+ /**
262
+ * Complex multi-level workflow
263
+ */
264
+ export const complexWorkflow = createWorkflow({
265
+ name: 'complex-test',
266
+ version: '1.0.0',
267
+ description: 'Complex multi-level workflow',
268
+ nodes: [
269
+ {
270
+ id: 'level1-a',
271
+ type: 'tool',
272
+ config: {
273
+ tool_name: 'echo',
274
+ tool_args: {
275
+ message: 'Level 1 A'
276
+ }
277
+ }
278
+ },
279
+ {
280
+ id: 'level1-b',
281
+ type: 'tool',
282
+ config: {
283
+ tool_name: 'echo',
284
+ tool_args: {
285
+ message: 'Level 1 B'
286
+ }
287
+ }
288
+ },
289
+ {
290
+ id: 'level2-a',
291
+ type: 'tool',
292
+ config: {
293
+ tool_name: 'echo',
294
+ tool_args: {
295
+ message: 'Level 2 A'
296
+ }
297
+ },
298
+ depends_on: ['level1-a']
299
+ },
300
+ {
301
+ id: 'level2-b',
302
+ type: 'tool',
303
+ config: {
304
+ tool_name: 'echo',
305
+ tool_args: {
306
+ message: 'Level 2 B'
307
+ }
308
+ },
309
+ depends_on: ['level1-a', 'level1-b']
310
+ },
311
+ {
312
+ id: 'level3',
313
+ type: 'tool',
314
+ config: {
315
+ tool_name: 'echo',
316
+ tool_args: {
317
+ message: 'Level 3'
318
+ }
319
+ },
320
+ depends_on: ['level2-a', 'level2-b']
321
+ }
322
+ ],
323
+ entry: ['level1-a', 'level1-b']
324
+ });
325
+
326
+ /**
327
+ * Workflow that should fail (tool error)
328
+ */
329
+ export const failingWorkflow = createWorkflow({
330
+ name: 'failing-test',
331
+ version: '1.0.0',
332
+ description: 'Workflow that intentionally fails',
333
+ nodes: [
334
+ {
335
+ id: 'fail-node',
336
+ type: 'tool',
337
+ config: {
338
+ tool_name: 'nonexistent-tool',
339
+ tool_args: {}
340
+ }
341
+ }
342
+ ],
343
+ entry: 'fail-node'
344
+ });
345
+
346
+ /**
347
+ * Workflow with timeout (long running)
348
+ */
349
+ export const longRunningWorkflow = createWorkflow({
350
+ name: 'long-running-test',
351
+ version: '1.0.0',
352
+ description: 'Workflow with long running node',
353
+ nodes: [
354
+ {
355
+ id: 'sleep-node',
356
+ type: 'tool',
357
+ config: {
358
+ tool_name: 'bash',
359
+ tool_args: {
360
+ command: 'sleep 5 && echo "done"'
361
+ }
362
+ }
363
+ }
364
+ ],
365
+ entry: 'sleep-node'
366
+ });
367
+
368
+ /**
369
+ * All test workflows collection
370
+ */
371
+ export const testWorkflows = {
372
+ singleNode: singleNodeWorkflow,
373
+ sequential: sequentialWorkflow,
374
+ parallel: parallelWorkflow,
375
+ diamond: diamondWorkflow,
376
+ conditional: conditionalWorkflow,
377
+ complex: complexWorkflow,
378
+ failing: failingWorkflow,
379
+ longRunning: longRunningWorkflow
380
+ };
@@ -0,0 +1,38 @@
1
+ /**
2
+ * Workflow Module
3
+ *
4
+ * 提供基于装饰器的 Workflow 定义和执行能力
5
+ *
6
+ * @example
7
+ * ```typescript
8
+ * import { Workflow, NodeAs, createWorkflowFromClass } from '@ai-setting/roy-agent-core';
9
+ *
10
+ * @Workflow({ name: 'my-workflow', entry: 'step1' })
11
+ * @WorkflowEdges([{ from: 'step1', to: 'step2' }])
12
+ * class MyWorkflow {
13
+ * @NodeAs({ nodeId: 'step1', nodeType: 'tool' })
14
+ * async step1() { return { result: 'done' }; }
15
+ *
16
+ * @NodeAs({ nodeId: 'step2', dependsOn: 'step1' })
17
+ * async step2() { return { result: 'processed' }; }
18
+ * }
19
+ *
20
+ * const workflow = createWorkflowFromClass(MyWorkflow);
21
+ * ```
22
+ */
23
+
24
+ // Decorators
25
+ export { Workflow } from './decorators/workflow';
26
+ export { NodeAs } from './decorators/node-as';
27
+ export { Edge, WorkflowEdges } from './decorators/edge';
28
+ export { DecoratorNode } from './decorators/decorator-node';
29
+
30
+ // Converter
31
+ export { WorkflowConverter } from './extractor/workflow-converter';
32
+ export { createWorkflowFromClass } from './utils/create-workflow';
33
+
34
+ // Component
35
+ export { WorkflowComponent } from './workflow-component';
36
+
37
+ // Types - re-export from types/index
38
+ export * from './types/index';