@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,195 @@
1
+ import { z } from 'zod';
2
+
3
+ // ==================== Schema 定义 ====================
4
+
5
+ // 节点依赖配置
6
+ export const DependsOnSchema = z.array(z.string());
7
+ export type DependsOn = z.infer<typeof DependsOnSchema>;
8
+
9
+ // 重试配置
10
+ export const RetryConfigSchema = z.object({
11
+ max_attempts: z.number().min(1).default(1),
12
+ backoff: z.enum(['fixed', 'exponential']).default('exponential'),
13
+ initial_delay: z.number().min(0).default(1000),
14
+ });
15
+ export type RetryConfig = z.infer<typeof RetryConfigSchema>;
16
+
17
+ // 节点定义 Schema
18
+ export const NodeDefinitionSchema = z.object({
19
+ id: z.string().min(1, 'Node ID is required'),
20
+ type: z.string().min(1, 'Node type is required'),
21
+ name: z.string().optional(),
22
+ config: z.record(z.string(), z.unknown()).optional().default({}),
23
+ depends_on: z.array(z.string()).optional(),
24
+ condition: z.string().optional(),
25
+ retry: RetryConfigSchema.optional(),
26
+ timeout: z.number().optional(),
27
+ });
28
+
29
+ export type NodeDefinition = z.infer<typeof NodeDefinitionSchema>;
30
+
31
+ // ==================== Node Interface ====================
32
+
33
+ /**
34
+ * Node interface - base interface for all workflow nodes
35
+ */
36
+ export interface Node {
37
+ /** Node type identifier */
38
+ readonly type: string;
39
+ /** Node unique identifier */
40
+ readonly id: string;
41
+ /** Execute the node with the given context */
42
+ execute(context: NodeExecutionContext): Promise<NodeExecutionResult>;
43
+ }
44
+
45
+ // Import types needed for Node interface (avoid circular dependency by using inline types)
46
+ // These will be resolved at runtime via NodeExecutionContext import
47
+ import type { NodeExecutionContext, NodeExecutionResult } from './run';
48
+
49
+ // Workflow 配置
50
+ export const WorkflowConfigSchema = z.object({
51
+ parallel_limit: z.number().nullable().optional(),
52
+ timeout: z.number().nullable().optional(),
53
+ retry: RetryConfigSchema.optional(),
54
+ debug: z.boolean().optional(),
55
+ });
56
+ export type WorkflowConfig = z.infer<typeof WorkflowConfigSchema>;
57
+
58
+ // 输出定义
59
+ export const OutputDefinitionSchema = z.object({
60
+ name: z.string(),
61
+ source: z.string(),
62
+ path: z.string(),
63
+ });
64
+ export type OutputDefinition = z.infer<typeof OutputDefinitionSchema>;
65
+
66
+ // Workflow 元数据
67
+ export const WorkflowMetadataSchema = z.object({
68
+ author: z.string().optional(),
69
+ taskId: z.number().optional(), // 新增:关联的任务 ID
70
+ tags: z.array(z.string()).optional().default([]),
71
+ created_at: z.string().optional(),
72
+ updated_at: z.string().optional(),
73
+ });
74
+ export type WorkflowMetadata = z.infer<typeof WorkflowMetadataSchema>;
75
+
76
+ // ==================== Workflow 定义 ====================
77
+
78
+ export const WorkflowDefinitionSchema = z.object({
79
+ name: z.string().min(1, 'Workflow name is required'),
80
+ version: z.string().default('1.0'),
81
+ description: z.string().optional(),
82
+ config: WorkflowConfigSchema.optional().default({}),
83
+ nodes: z.array(NodeDefinitionSchema).min(1, 'At least one node is required'),
84
+ entry: z.union([z.string(), z.array(z.string())]).default('__default_entry__'),
85
+ outputs: z.array(OutputDefinitionSchema).optional().default([]),
86
+ metadata: WorkflowMetadataSchema.optional().default({}),
87
+ });
88
+
89
+ export type WorkflowDefinition = z.infer<typeof WorkflowDefinitionSchema>;
90
+
91
+ // 扩展 Workflow 定义,自动计算入口节点
92
+ export interface WorkflowDefinitionExtended extends WorkflowDefinition {
93
+ // 自动计算的入口节点列表
94
+ computedEntry: string[];
95
+ // 节点映射
96
+ nodeMap: Map<string, NodeDefinition>;
97
+ // 拓扑排序结果
98
+ topologicalOrder: string[];
99
+ }
100
+
101
+ // ==================== Workflow 实体 ====================
102
+
103
+ export interface Workflow {
104
+ id: string;
105
+ name: string;
106
+ version: string;
107
+ description?: string;
108
+ definition: WorkflowDefinition;
109
+ config: WorkflowConfig;
110
+ metadata: WorkflowMetadata;
111
+ tags: string[];
112
+ createdAt: Date;
113
+ updatedAt: Date;
114
+ }
115
+
116
+ // ==================== YAML/JSON 解析辅助 ====================
117
+
118
+ export interface ParsedWorkflow {
119
+ format: 'yaml' | 'json';
120
+ definition: WorkflowDefinition;
121
+ }
122
+
123
+ // YAML parser placeholder - will be implemented with yaml package
124
+ let yamlParser: typeof import('yaml') | null = null;
125
+
126
+ async function getYamlParser() {
127
+ if (!yamlParser) {
128
+ yamlParser = await import('yaml');
129
+ }
130
+ return yamlParser;
131
+ }
132
+
133
+ /**
134
+ * 解析 Workflow 文件
135
+ * @param content 文件内容
136
+ * @param filename 文件名,用于自动检测格式
137
+ */
138
+ export async function parseWorkflowFile(content: string, filename: string): Promise<ParsedWorkflow> {
139
+ const isYaml = filename.endsWith('.yaml') || filename.endsWith('.yml');
140
+ const isJson = filename.endsWith('.json');
141
+
142
+ let definition: WorkflowDefinition;
143
+
144
+ if (isYaml) {
145
+ const yaml = await getYamlParser();
146
+ definition = WorkflowDefinitionSchema.parse(yaml.parse(content));
147
+ } else if (isJson) {
148
+ definition = WorkflowDefinitionSchema.parse(JSON.parse(content));
149
+ } else {
150
+ // 尝试自动检测
151
+ try {
152
+ definition = WorkflowDefinitionSchema.parse(JSON.parse(content));
153
+ } catch {
154
+ const yaml = await getYamlParser();
155
+ definition = WorkflowDefinitionSchema.parse(yaml.parse(content));
156
+ }
157
+ }
158
+
159
+ return {
160
+ format: isYaml ? 'yaml' : 'json',
161
+ definition
162
+ };
163
+ }
164
+
165
+ /**
166
+ * Synchronous version of parseWorkflowFile
167
+ * Uses JSON parsing only for auto-detection
168
+ */
169
+ export function parseWorkflowFileSync(content: string, filename: string): ParsedWorkflow {
170
+ const isYaml = filename.endsWith('.yaml') || filename.endsWith('.yml');
171
+ const isJson = filename.endsWith('.json');
172
+
173
+ let definition: WorkflowDefinition;
174
+
175
+ if (isJson) {
176
+ definition = WorkflowDefinitionSchema.parse(JSON.parse(content));
177
+ } else if (isYaml) {
178
+ // For sync YAML parsing, we need the yaml package synchronously
179
+ // This will throw if yaml is not imported, but that's acceptable
180
+ // for production use where async parsing is preferred
181
+ throw new Error('Synchronous YAML parsing not supported. Use parseWorkflowFile() instead.');
182
+ } else {
183
+ // 尝试自动检测 JSON
184
+ try {
185
+ definition = WorkflowDefinitionSchema.parse(JSON.parse(content));
186
+ } catch {
187
+ throw new Error('Cannot auto-detect format. Please use .yaml, .yml, or .json extension.');
188
+ }
189
+ }
190
+
191
+ return {
192
+ format: isJson ? 'json' : 'yaml',
193
+ definition
194
+ };
195
+ }
@@ -0,0 +1,51 @@
1
+ /**
2
+ * @fileoverview Workflow types compatibility layer
3
+ * Re-exports all types from types/index.ts for backward compatibility
4
+ */
5
+
6
+ // Re-export from types/index.ts
7
+ export type {
8
+ // Workflow types
9
+ Workflow,
10
+ WorkflowDefinition,
11
+ WorkflowDefinitionExtended,
12
+ WorkflowConfig,
13
+ WorkflowMetadata,
14
+ RetryConfig,
15
+ Node,
16
+ NodeDefinition,
17
+ NodeDefinitionSchema,
18
+ DependsOn,
19
+ DependsOnSchema,
20
+ OutputDefinition,
21
+ TemplateResolver,
22
+ ParsedWorkflow,
23
+ } from './types';
24
+
25
+ export {
26
+ WorkflowDefinitionSchema,
27
+ RetryConfigSchema,
28
+ WorkflowConfigSchema,
29
+ WorkflowMetadataSchema,
30
+ parseWorkflowFile,
31
+ parseWorkflowFileSync,
32
+ } from './types/workflow';
33
+
34
+ export { OutputDefinitionSchema } from './types/workflow';
35
+
36
+ // Run types
37
+ export type {
38
+ RunStatus,
39
+ RunOptions,
40
+ RunResult,
41
+ WorkflowRun,
42
+ NodeRun,
43
+ NodeStatus,
44
+ NodeExecutionContext,
45
+ NodeExecutionResult,
46
+ } from './types';
47
+
48
+ export { createNodeExecutionContext } from './types';
49
+
50
+ // Other types
51
+ export type { AgentSessionInfo } from './types';
@@ -0,0 +1,47 @@
1
+ /**
2
+ * 便捷函数:createWorkflowFromClass
3
+ */
4
+
5
+ import { WorkflowConverter } from '../extractor/workflow-converter';
6
+ import type { ConvertedWorkflowDefinition } from '../types/decorators-types';
7
+
8
+ /**
9
+ * 从装饰器类创建 WorkflowDefinition
10
+ *
11
+ * 这是最常用的便捷函数,自动处理实例创建和转换
12
+ *
13
+ * @param targetClass - 使用 @Workflow 装饰的类
14
+ * @param options - 可选配置
15
+ * @returns WorkflowDefinition
16
+ *
17
+ * @example
18
+ * ```typescript
19
+ * @Workflow({ name: 'my-workflow', entry: 'start' })
20
+ * class MyWorkflow {
21
+ * @NodeAs({ nodeId: 'start' })
22
+ * async start() { return { done: true }; }
23
+ * }
24
+ *
25
+ * // 方式一:自动创建实例
26
+ * const workflow = createWorkflowFromClass(MyWorkflow);
27
+ *
28
+ * // 方式二:传入自定义实例
29
+ * const myInstance = new MyWorkflow(customDep);
30
+ * const workflow = createWorkflowFromClass(MyWorkflow, { instance: myInstance });
31
+ * ```
32
+ */
33
+ export function createWorkflowFromClass(
34
+ targetClass: new (...args: any[]) => any,
35
+ options?: {
36
+ /** 自定义实例,不传则自动创建 */
37
+ instance?: any;
38
+ /** 构造函数参数 */
39
+ constructorArgs?: any[];
40
+ }
41
+ ): ConvertedWorkflowDefinition {
42
+ // 创建或使用提供的实例
43
+ const instance = options?.instance ?? new targetClass(...(options?.constructorArgs ?? []));
44
+
45
+ // 转换
46
+ return WorkflowConverter.fromClass(targetClass, instance);
47
+ }
@@ -0,0 +1,245 @@
1
+ /**
2
+ * Execution State Builder
3
+ *
4
+ * Builds execution state from session messages and workflow definition.
5
+ */
6
+
7
+ import { TracedAs } from '../../log-trace/decorator';
8
+ import { WorkflowDefinition } from '../types';
9
+ import { SessionMessage } from '../../session/types';
10
+ import type { ExecutionState } from './validation-rules';
11
+
12
+ /**
13
+ * Builder for constructing ExecutionState from session data
14
+ */
15
+ export class ExecutionStateBuilder {
16
+
17
+ @TracedAs("recovery.builder.build", { recordParams: true, recordResult: true, log: true })
18
+ build(messages: SessionMessage[], definition: WorkflowDefinition): ExecutionState {
19
+ const state: ExecutionState = {
20
+ completedNodes: new Set<string>(),
21
+ inProgressNodes: new Set<string>(),
22
+ pendingNodes: new Set<string>(),
23
+ nodeOutputs: new Map<string, unknown>(),
24
+ nodeInputs: new Map<string, unknown>(),
25
+ variables: new Map<string, unknown>(),
26
+ loopCounts: new Map<string, number>(),
27
+ };
28
+
29
+ // Parse messages to build state
30
+ this.parseMessages(messages, state);
31
+
32
+ // Build DAG from definition to determine pending nodes
33
+ this.buildPendingNodes(definition, state);
34
+
35
+ return state;
36
+ }
37
+
38
+ /**
39
+ * Parse session messages to extract node states and outputs
40
+ */
41
+ @TracedAs("recovery.builder.parseMessages", { recordParams: true, recordResult: true, log: true })
42
+ private parseMessages(messages: SessionMessage[], state: ExecutionState): void {
43
+ let lastCallNodeId: string | null = null;
44
+ let lastCallInput: unknown = null;
45
+
46
+ for (const msg of messages) {
47
+ const metadata = msg.metadata as Record<string, unknown> | undefined;
48
+ const msgType = metadata?.type as string | undefined;
49
+
50
+ switch (msgType) {
51
+ case 'workflow.node.call': {
52
+ const nodeId = metadata?.workflowNodeId as string | undefined;
53
+ if (nodeId) {
54
+ lastCallNodeId = nodeId;
55
+ lastCallInput = this.extractInput(msg);
56
+
57
+ // Mark as in-progress (might be completed later)
58
+ state.inProgressNodes.add(nodeId);
59
+ state.nodeInputs.set(nodeId, lastCallInput);
60
+ }
61
+ break;
62
+ }
63
+
64
+ case 'workflow.node.result': {
65
+ if (lastCallNodeId) {
66
+ // Node completed successfully
67
+ state.inProgressNodes.delete(lastCallNodeId);
68
+ state.completedNodes.add(lastCallNodeId);
69
+
70
+ // Extract output
71
+ const output = this.extractOutput(msg);
72
+ state.nodeOutputs.set(lastCallNodeId, output);
73
+
74
+ // Extract variables from output
75
+ this.extractVariables(output, state);
76
+
77
+ lastCallNodeId = null;
78
+ lastCallInput = null;
79
+ }
80
+ break;
81
+ }
82
+
83
+ case 'workflow.node.interrupt': {
84
+ if (lastCallNodeId) {
85
+ // Node interrupted - still in progress
86
+ state.inProgressNodes.add(lastCallNodeId);
87
+ }
88
+ break;
89
+ }
90
+
91
+ case 'workflow.node.resume': {
92
+ // User resumed after interrupt
93
+ if (lastCallNodeId) {
94
+ state.inProgressNodes.add(lastCallNodeId);
95
+ }
96
+ break;
97
+ }
98
+ }
99
+ }
100
+
101
+ // If there's still a lastCallNodeId in progress without result, keep it as in-progress
102
+ // This means the workflow was interrupted mid-execution
103
+ }
104
+
105
+ /**
106
+ * Build pending nodes from workflow definition
107
+ */
108
+ @TracedAs("recovery.builder.buildPendingNodes", { recordParams: true, recordResult: true, log: true })
109
+ private buildPendingNodes(definition: WorkflowDefinition, state: ExecutionState): void {
110
+ const nodeIds = new Set((definition.nodes || []).map(n => n.id));
111
+ const allNodeIds = Array.from(nodeIds);
112
+
113
+ // Determine entry nodes
114
+ const entryNodes = this.getEntryNodes(definition);
115
+
116
+ // For each entry node, traverse the DAG and mark nodes as pending
117
+ // if they are reachable from an in-progress node and not completed
118
+ for (const entryNode of entryNodes) {
119
+ if (!state.completedNodes.has(entryNode)) {
120
+ this.markPendingFromNode(entryNode, definition, state);
121
+ }
122
+ }
123
+
124
+ // Also check if any completed node has unexecuted children
125
+ for (const completedId of state.completedNodes) {
126
+ const children = this.getDirectChildren(completedId, definition);
127
+ for (const childId of children) {
128
+ if (!state.completedNodes.has(childId) && !state.inProgressNodes.has(childId)) {
129
+ state.pendingNodes.add(childId);
130
+ }
131
+ }
132
+ }
133
+ }
134
+
135
+ /**
136
+ * Get entry nodes from workflow definition
137
+ */
138
+ private getEntryNodes(definition: WorkflowDefinition): string[] {
139
+ const entry = definition.entry;
140
+ if (!entry) {
141
+ return [];
142
+ }
143
+
144
+ if (Array.isArray(entry)) {
145
+ return entry;
146
+ }
147
+
148
+ return [entry];
149
+ }
150
+
151
+ /**
152
+ * Mark all nodes as pending starting from a given node
153
+ */
154
+ private markPendingFromNode(
155
+ startNodeId: string,
156
+ definition: WorkflowDefinition,
157
+ state: ExecutionState
158
+ ): void {
159
+ const visited = new Set<string>();
160
+ const queue: string[] = [startNodeId];
161
+
162
+ while (queue.length > 0) {
163
+ const nodeId = queue.shift()!;
164
+
165
+ if (visited.has(nodeId)) {
166
+ continue;
167
+ }
168
+ visited.add(nodeId);
169
+
170
+ // Only add to pending if not completed
171
+ if (!state.completedNodes.has(nodeId)) {
172
+ state.pendingNodes.add(nodeId);
173
+ }
174
+
175
+ // Queue children
176
+ const children = this.getDirectChildren(nodeId, definition);
177
+ for (const childId of children) {
178
+ if (!visited.has(childId)) {
179
+ queue.push(childId);
180
+ }
181
+ }
182
+ }
183
+ }
184
+
185
+ /**
186
+ * Get direct children of a node
187
+ */
188
+ private getDirectChildren(nodeId: string, definition: WorkflowDefinition): string[] {
189
+ // Note: In the actual definition, edges might use 'source' and 'target'
190
+ // but for now we need to check both possible formats
191
+ const edges = (definition as any).edges || (definition as any).connections || [];
192
+
193
+ return edges
194
+ .filter((edge: any) => edge.source === nodeId || edge.from === nodeId)
195
+ .map((edge: any) => edge.target || edge.to);
196
+ }
197
+
198
+ /**
199
+ * Extract input from a workflow.node.call message
200
+ */
201
+ private extractInput(msg: SessionMessage): unknown {
202
+ try {
203
+ // Try parsing as JSON
204
+ return JSON.parse(msg.content);
205
+ } catch {
206
+ return msg.content;
207
+ }
208
+ }
209
+
210
+ /**
211
+ * Extract output from a workflow.node.result message
212
+ */
213
+ private extractOutput(msg: SessionMessage): unknown {
214
+ try {
215
+ // Try parsing as JSON
216
+ return JSON.parse(msg.content);
217
+ } catch {
218
+ return msg.content;
219
+ }
220
+ }
221
+
222
+ /**
223
+ * Extract variables from node output and add to state
224
+ */
225
+ private extractVariables(output: unknown, state: ExecutionState): void {
226
+ if (!output || typeof output !== 'object') {
227
+ return;
228
+ }
229
+
230
+ const outputObj = output as Record<string, unknown>;
231
+
232
+ // Add each top-level property as a potential variable
233
+ for (const [key, value] of Object.entries(outputObj)) {
234
+ // Skip internal properties
235
+ if (key.startsWith('_') || key.startsWith('$')) {
236
+ continue;
237
+ }
238
+
239
+ // Add to variables if not already set
240
+ if (!state.variables.has(key)) {
241
+ state.variables.set(key, value);
242
+ }
243
+ }
244
+ }
245
+ }
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Workflow Utilities
3
+ */
4
+
5
+ export { TemplateResolver, resolveTemplates, resolveTemplateString } from './template-resolver';
6
+ export type { TemplateResolverOptions, ResolvedValue } from './template-resolver';
7
+
8
+ // Recovery utilities
9
+ export { RecoveryValidator } from './recovery-validator';
10
+ export { ExecutionStateBuilder } from './execution-state';
11
+ export {
12
+ ValidationError,
13
+ ValidationResult,
14
+ RecoveryPlan,
15
+ ValidationErrorType,
16
+ SuggestedAction,
17
+ ExecutionState,
18
+ } from './validation-rules';
@@ -0,0 +1,58 @@
1
+ /**
2
+ * NodeRegistry 集成辅助
3
+ *
4
+ * 提供函数来帮助将 decorator 节点类型注册到 NodeRegistry
5
+ */
6
+
7
+ import type { NodeRegistry } from '../engine/node-registry';
8
+ import { DecoratorNode } from '../decorators/decorator-node';
9
+ import { ConditionNode } from '../nodes/condition-node';
10
+ import { MergeNode } from '../nodes/merge-node';
11
+
12
+ /**
13
+ * 将所有内置节点类型注册到 NodeRegistry
14
+ *
15
+ * @param registry - NodeRegistry 实例
16
+ *
17
+ * @example
18
+ * ```typescript
19
+ * import { registerDecoratorNodeType } from '@roy-agent/workflow-decorators';
20
+ *
21
+ * // 在 WorkflowComponent 初始化时调用
22
+ * registerDecoratorNodeType(registry);
23
+ * ```
24
+ */
25
+ export function registerDecoratorNodeType(registry: NodeRegistry): void {
26
+ // 注册 decorator 节点类型
27
+ registry.register('decorator', (definition) => {
28
+ return new DecoratorNode(definition);
29
+ });
30
+
31
+ // 注册 condition 节点类型
32
+ registry.register('condition', (definition) => {
33
+ return new ConditionNode(definition);
34
+ });
35
+
36
+ // 注册 merge 节点类型
37
+ registry.register('merge', (definition) => {
38
+ return new MergeNode(definition);
39
+ });
40
+ }
41
+
42
+ /**
43
+ * 检查 WorkflowDefinition 是否包含 decorator 类型的节点
44
+ */
45
+ export function hasDecoratorNodes(
46
+ nodes: Array<{ type: string }>
47
+ ): boolean {
48
+ return nodes.some(node => node.type === 'decorator');
49
+ }
50
+
51
+ /**
52
+ * 从 WorkflowDefinition 中提取所有 decorator 类型的节点
53
+ */
54
+ export function getDecoratorNodes(
55
+ nodes: Array<{ type: string; id: string }>
56
+ ): Array<{ type: string; id: string }> {
57
+ return nodes.filter(node => node.type === 'decorator');
58
+ }