@ai-setting/roy-agent-core 1.3.10 → 1.3.14

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 (379) hide show
  1. package/dist/config/index.js +1647 -0
  2. package/dist/index.js +12579 -89691
  3. package/package.json +19 -56
  4. package/src/config/config-component.test.ts +0 -627
  5. package/src/config/config-component.ts +0 -906
  6. package/src/config/config-parser.test.ts +0 -319
  7. package/src/config/config-parser.ts +0 -203
  8. package/src/config/decentralized-config.test.ts +0 -740
  9. package/src/config/env-key.ts +0 -210
  10. package/src/config/env-source.test.ts +0 -252
  11. package/src/config/env-source.ts +0 -301
  12. package/src/config/file-source.test.ts +0 -357
  13. package/src/config/file-source.ts +0 -421
  14. package/src/config/index.ts +0 -24
  15. package/src/config/protocol-resolver.test.ts +0 -217
  16. package/src/config/protocol-resolver.ts +0 -228
  17. package/src/env/agent/agent-component.abort.test.ts +0 -511
  18. package/src/env/agent/agent-component.record-session.test.ts +0 -349
  19. package/src/env/agent/agent-component.test.ts +0 -1389
  20. package/src/env/agent/agent-component.tool-error.test.ts +0 -327
  21. package/src/env/agent/agent-component.ts +0 -1711
  22. package/src/env/agent/agent-config-registration.test.ts +0 -226
  23. package/src/env/agent/agent-config-registration.ts +0 -46
  24. package/src/env/agent/agent-reminder-plugin.integration.test.ts +0 -243
  25. package/src/env/agent/index.ts +0 -10
  26. package/src/env/agent/summary-agent.parse-hint.test.ts +0 -360
  27. package/src/env/agent/summary-agent.ts +0 -508
  28. package/src/env/agent/types.ts +0 -536
  29. package/src/env/commands/commands-component.test.ts +0 -364
  30. package/src/env/commands/commands-component.ts +0 -604
  31. package/src/env/commands/commands-config-registration.test.ts +0 -198
  32. package/src/env/commands/commands-config-registration.ts +0 -38
  33. package/src/env/commands/index.ts +0 -21
  34. package/src/env/commands/parser.test.ts +0 -203
  35. package/src/env/commands/parser.ts +0 -115
  36. package/src/env/commands/types.ts +0 -184
  37. package/src/env/commands-prompt-integration.test.ts +0 -243
  38. package/src/env/component-env.test.ts +0 -119
  39. package/src/env/component.ts +0 -335
  40. package/src/env/constants.test.ts +0 -72
  41. package/src/env/constants.ts +0 -123
  42. package/src/env/debug/debug-component.test.ts +0 -114
  43. package/src/env/debug/debug-component.ts +0 -547
  44. package/src/env/debug/formatters/index.ts +0 -9
  45. package/src/env/debug/formatters/repl-formatter.test.ts +0 -139
  46. package/src/env/debug/formatters/repl-formatter.ts +0 -358
  47. package/src/env/debug/formatters/trace-formatter.test.ts +0 -119
  48. package/src/env/debug/formatters/trace-formatter.ts +0 -191
  49. package/src/env/debug/formatters/tree-formatter.test.ts +0 -107
  50. package/src/env/debug/formatters/tree-formatter.ts +0 -325
  51. package/src/env/debug/index.ts +0 -38
  52. package/src/env/debug/parser/regex-parser.test.ts +0 -201
  53. package/src/env/debug/parser/regex-parser.ts +0 -196
  54. package/src/env/debug/parser/span-builder.test.ts +0 -241
  55. package/src/env/debug/parser/span-builder.ts +0 -386
  56. package/src/env/debug/reader/log-reader.test.ts +0 -170
  57. package/src/env/debug/reader/log-reader.ts +0 -186
  58. package/src/env/debug/reader/span-db-reader.test.ts +0 -118
  59. package/src/env/debug/reader/span-db-reader.ts +0 -201
  60. package/src/env/debug/types.test.ts +0 -187
  61. package/src/env/debug/types.ts +0 -171
  62. package/src/env/environment-init.test.ts +0 -183
  63. package/src/env/environment-lifecycle.test.ts +0 -516
  64. package/src/env/environment-service.test.ts +0 -332
  65. package/src/env/environment.handle-query.test.ts +0 -96
  66. package/src/env/environment.test.ts +0 -232
  67. package/src/env/environment.ts +0 -708
  68. package/src/env/errors.test.ts +0 -165
  69. package/src/env/errors.ts +0 -157
  70. package/src/env/event-source/event-source-agent-handler.test.ts +0 -193
  71. package/src/env/event-source/event-source-agent-handler.ts +0 -111
  72. package/src/env/event-source/event-source-component.process-cleanup.test.ts +0 -236
  73. package/src/env/event-source/event-source-component.stop.test.ts +0 -346
  74. package/src/env/event-source/event-source-component.test.ts +0 -1207
  75. package/src/env/event-source/event-source-component.ts +0 -1379
  76. package/src/env/event-source/event-source-config-registration.test.ts +0 -242
  77. package/src/env/event-source/event-source-config-registration.ts +0 -37
  78. package/src/env/event-source/event-source-integration.test.ts +0 -320
  79. package/src/env/event-source/event-source-platform.test.ts +0 -630
  80. package/src/env/event-source/types.ts +0 -298
  81. package/src/env/hook/global-hook-manager.ts +0 -162
  82. package/src/env/hook/hook-manager.test.ts +0 -374
  83. package/src/env/hook/hook-manager.ts +0 -309
  84. package/src/env/hook/index.ts +0 -38
  85. package/src/env/hook/types.ts +0 -138
  86. package/src/env/index.ts +0 -144
  87. package/src/env/interface.ts +0 -203
  88. package/src/env/llm/hooks.test.ts +0 -293
  89. package/src/env/llm/hooks.ts +0 -316
  90. package/src/env/llm/index.ts +0 -61
  91. package/src/env/llm/invoke-threshold-check.test.ts +0 -88
  92. package/src/env/llm/invoke-timeout.test.ts +0 -54
  93. package/src/env/llm/invoke.test.ts +0 -71
  94. package/src/env/llm/invoke.ts +0 -1039
  95. package/src/env/llm/llm-config.test.ts +0 -523
  96. package/src/env/llm/llm.test.ts +0 -233
  97. package/src/env/llm/llm.ts +0 -568
  98. package/src/env/llm/provider.test.ts +0 -182
  99. package/src/env/llm/provider.ts +0 -108
  100. package/src/env/llm/transform.test.ts +0 -251
  101. package/src/env/llm/transform.ts +0 -286
  102. package/src/env/llm/types.test.ts +0 -580
  103. package/src/env/llm/types.ts +0 -424
  104. package/src/env/log-trace/decorator-otel.test.ts +0 -182
  105. package/src/env/log-trace/decorator.ts +0 -230
  106. package/src/env/log-trace/index.ts +0 -79
  107. package/src/env/log-trace/log-trace-component.test.ts +0 -242
  108. package/src/env/log-trace/log-trace-component.ts +0 -497
  109. package/src/env/log-trace/log-trace-config-registration.test.ts +0 -348
  110. package/src/env/log-trace/log-trace-config-registration.ts +0 -45
  111. package/src/env/log-trace/logger.test.ts +0 -149
  112. package/src/env/log-trace/logger.ts +0 -522
  113. package/src/env/log-trace/opentelemetry/cli-propagation.test.ts +0 -147
  114. package/src/env/log-trace/opentelemetry/cli-propagation.ts +0 -194
  115. package/src/env/log-trace/opentelemetry/integration.test.ts +0 -668
  116. package/src/env/log-trace/opentelemetry/mod.ts +0 -25
  117. package/src/env/log-trace/opentelemetry/propagation-env.test.ts +0 -181
  118. package/src/env/log-trace/opentelemetry/propagation-env.ts +0 -136
  119. package/src/env/log-trace/opentelemetry/propagation.test.ts +0 -259
  120. package/src/env/log-trace/opentelemetry/propagation.ts +0 -215
  121. package/src/env/log-trace/opentelemetry/tracer-provider-context.test.ts +0 -166
  122. package/src/env/log-trace/opentelemetry/tracer-provider.test.ts +0 -379
  123. package/src/env/log-trace/opentelemetry/tracer-provider.ts +0 -612
  124. package/src/env/log-trace/span-storage.test.ts +0 -145
  125. package/src/env/log-trace/span-storage.ts +0 -230
  126. package/src/env/log-trace/trace-context.test.ts +0 -187
  127. package/src/env/log-trace/trace-context.ts +0 -162
  128. package/src/env/log-trace/types.test.ts +0 -63
  129. package/src/env/log-trace/types.ts +0 -172
  130. package/src/env/mcp/README.md +0 -244
  131. package/src/env/mcp/__integration__/mcp-component.integration.test.ts +0 -373
  132. package/src/env/mcp/config.test.ts +0 -74
  133. package/src/env/mcp/config.ts +0 -116
  134. package/src/env/mcp/index.ts +0 -41
  135. package/src/env/mcp/loader.test.ts +0 -161
  136. package/src/env/mcp/loader.ts +0 -209
  137. package/src/env/mcp/mcp-component.test.ts +0 -111
  138. package/src/env/mcp/mcp-component.ts +0 -358
  139. package/src/env/mcp/mcp-config-registration.test.ts +0 -304
  140. package/src/env/mcp/mcp-config-registration.ts +0 -50
  141. package/src/env/mcp/scanner.test.ts +0 -170
  142. package/src/env/mcp/scanner.ts +0 -246
  143. package/src/env/mcp/tool/adapter.test.ts +0 -520
  144. package/src/env/mcp/tool/adapter.ts +0 -521
  145. package/src/env/mcp/tool/index.ts +0 -5
  146. package/src/env/mcp/types.test.ts +0 -171
  147. package/src/env/mcp/types.ts +0 -79
  148. package/src/env/memory/README.md +0 -177
  149. package/src/env/memory/built-in/index.ts +0 -59
  150. package/src/env/memory/built-in/recall-memory.ts +0 -103
  151. package/src/env/memory/built-in/record-memory.ts +0 -148
  152. package/src/env/memory/index.ts +0 -20
  153. package/src/env/memory/memory-component.test.ts +0 -239
  154. package/src/env/memory/memory-component.ts +0 -503
  155. package/src/env/memory/memory-config-registration.test.ts +0 -67
  156. package/src/env/memory/memory-config-registration.ts +0 -48
  157. package/src/env/memory/memory-config.ts +0 -45
  158. package/src/env/memory/memory-file.test.ts +0 -268
  159. package/src/env/memory/plugin/index.ts +0 -48
  160. package/src/env/memory/plugin/memory-agent.test.ts +0 -249
  161. package/src/env/memory/plugin/memory-agent.ts +0 -365
  162. package/src/env/memory/plugin/memory-manager.ts +0 -198
  163. package/src/env/memory/plugin/memory-plugin-agent.test.ts +0 -145
  164. package/src/env/memory/plugin/memory-plugin.ts +0 -210
  165. package/src/env/memory/plugin/plugin-simplified.test.ts +0 -51
  166. package/src/env/memory/plugin/recall-memory.test.ts +0 -106
  167. package/src/env/memory/plugin/recall-memory.ts +0 -53
  168. package/src/env/memory/plugin/types.ts +0 -101
  169. package/src/env/memory/tools/memory-agent-tools.ts +0 -228
  170. package/src/env/memory/types.ts +0 -85
  171. package/src/env/paths.ts +0 -118
  172. package/src/env/prompt/index.ts +0 -18
  173. package/src/env/prompt/memory-prompts.test.ts +0 -91
  174. package/src/env/prompt/prompt-component.test.ts +0 -491
  175. package/src/env/prompt/prompt-component.ts +0 -619
  176. package/src/env/prompt/prompt-config-registration.test.ts +0 -213
  177. package/src/env/prompt/prompt-config-registration.ts +0 -39
  178. package/src/env/prompt/prompts-index.ts +0 -504
  179. package/src/env/prompt/renderer.ts +0 -67
  180. package/src/env/prompt/types.ts +0 -136
  181. package/src/env/session/hooks.ts +0 -18
  182. package/src/env/session/index.ts +0 -37
  183. package/src/env/session/search-query-parser.test.ts +0 -425
  184. package/src/env/session/search-query-parser.ts +0 -171
  185. package/src/env/session/session-checkpoint.test.ts +0 -523
  186. package/src/env/session/session-component.extract-recent-messages.test.ts +0 -209
  187. package/src/env/session/session-component.test.ts +0 -132
  188. package/src/env/session/session-component.ts +0 -1249
  189. package/src/env/session/session-config-registration.test.ts +0 -138
  190. package/src/env/session/session-config-registration.ts +0 -52
  191. package/src/env/session/session-message-converter.test.ts +0 -763
  192. package/src/env/session/session-message-converter.ts +0 -415
  193. package/src/env/session/session-message-e2e.test.ts +0 -448
  194. package/src/env/session/session-search.test.ts +0 -391
  195. package/src/env/session/session-store.test.ts +0 -362
  196. package/src/env/session/session-store.ts +0 -141
  197. package/src/env/session/storage/index.ts +0 -6
  198. package/src/env/session/storage/memory.ts +0 -502
  199. package/src/env/session/storage/sqlite.ts +0 -794
  200. package/src/env/session/types.ts +0 -742
  201. package/src/env/skill/config.ts +0 -39
  202. package/src/env/skill/index.ts +0 -6
  203. package/src/env/skill/parser.test.ts +0 -116
  204. package/src/env/skill/parser.ts +0 -77
  205. package/src/env/skill/scanner.test.ts +0 -211
  206. package/src/env/skill/scanner.ts +0 -119
  207. package/src/env/skill/skill-component.test.ts +0 -234
  208. package/src/env/skill/skill-component.ts +0 -352
  209. package/src/env/skill/skill-config-registration.test.ts +0 -60
  210. package/src/env/skill/skill-config-registration.ts +0 -43
  211. package/src/env/skill/tool/index.ts +0 -1
  212. package/src/env/skill/tool/skill-tool.test.ts +0 -100
  213. package/src/env/skill/tool/skill-tool.ts +0 -72
  214. package/src/env/skill/types.ts +0 -64
  215. package/src/env/task/delegate/delegate-tool.test.ts +0 -498
  216. package/src/env/task/delegate/delegate-tool.ts +0 -1014
  217. package/src/env/task/delegate/index.ts +0 -18
  218. package/src/env/task/delegate/stop-tool.test.ts +0 -140
  219. package/src/env/task/delegate/stop-tool.ts +0 -119
  220. package/src/env/task/delegate/task-events.test.ts +0 -178
  221. package/src/env/task/delegate/task-events.ts +0 -143
  222. package/src/env/task/hooks/contexts.test.ts +0 -92
  223. package/src/env/task/hooks/contexts.ts +0 -192
  224. package/src/env/task/hooks/index.ts +0 -23
  225. package/src/env/task/hooks/task-hook-points.test.ts +0 -32
  226. package/src/env/task/hooks/task-hook-points.ts +0 -54
  227. package/src/env/task/index.ts +0 -7
  228. package/src/env/task/plugins/index.ts +0 -13
  229. package/src/env/task/plugins/task-plugin.test.ts +0 -74
  230. package/src/env/task/plugins/task-plugin.ts +0 -89
  231. package/src/env/task/plugins/task-tag-plugin.test.ts +0 -377
  232. package/src/env/task/plugins/task-tag-plugin.ts +0 -319
  233. package/src/env/task/plugins/task-workflow-extractor.integration.test.ts +0 -226
  234. package/src/env/task/plugins/workflow-extractor-agent.test.ts +0 -107
  235. package/src/env/task/plugins/workflow-extractor-agent.ts +0 -225
  236. package/src/env/task/storage/index.ts +0 -6
  237. package/src/env/task/storage/sqlite-task-store.test.ts +0 -283
  238. package/src/env/task/storage/sqlite-task-store.ts +0 -903
  239. package/src/env/task/storage/task-search.test.ts +0 -291
  240. package/src/env/task/tag-service.test.ts +0 -198
  241. package/src/env/task/tag-service.ts +0 -264
  242. package/src/env/task/task-component.test.ts +0 -193
  243. package/src/env/task/task-component.ts +0 -658
  244. package/src/env/task/task-config-registration.test.ts +0 -57
  245. package/src/env/task/task-config-registration.ts +0 -37
  246. package/src/env/task/task-types.test.ts +0 -137
  247. package/src/env/task/tools/complete-tool.ts +0 -44
  248. package/src/env/task/tools/create-tool.ts +0 -49
  249. package/src/env/task/tools/delete-tool.ts +0 -43
  250. package/src/env/task/tools/get-tool.ts +0 -59
  251. package/src/env/task/tools/index.ts +0 -10
  252. package/src/env/task/tools/list-tool.ts +0 -40
  253. package/src/env/task/tools/operation/create-tool.ts +0 -48
  254. package/src/env/task/tools/operation/delete-tool.ts +0 -43
  255. package/src/env/task/tools/operation/get-tool.ts +0 -43
  256. package/src/env/task/tools/operation/index.ts +0 -9
  257. package/src/env/task/tools/operation/list-tool.ts +0 -40
  258. package/src/env/task/tools/operation/operation-tools.test.ts +0 -274
  259. package/src/env/task/tools/operation/operation-types.ts +0 -75
  260. package/src/env/task/tools/operation/update-tool.ts +0 -47
  261. package/src/env/task/tools/task-tools.test.ts +0 -203
  262. package/src/env/task/tools/task-types.test.ts +0 -75
  263. package/src/env/task/tools/task-types.ts +0 -68
  264. package/src/env/task/tools/update-tool.ts +0 -70
  265. package/src/env/task/types.ts +0 -160
  266. package/src/env/tool/built-in/bash.ts +0 -201
  267. package/src/env/tool/built-in/echo.ts +0 -29
  268. package/src/env/tool/built-in/edit-file.test.ts +0 -136
  269. package/src/env/tool/built-in/edit-file.ts +0 -92
  270. package/src/env/tool/built-in/glob.test.ts +0 -94
  271. package/src/env/tool/built-in/glob.ts +0 -65
  272. package/src/env/tool/built-in/grep.test.ts +0 -122
  273. package/src/env/tool/built-in/grep.ts +0 -108
  274. package/src/env/tool/built-in/index.ts +0 -44
  275. package/src/env/tool/built-in/read-file.test.ts +0 -84
  276. package/src/env/tool/built-in/read-file.ts +0 -75
  277. package/src/env/tool/built-in/write-file.test.ts +0 -119
  278. package/src/env/tool/built-in/write-file.ts +0 -68
  279. package/src/env/tool/index.ts +0 -24
  280. package/src/env/tool/registry.test.ts +0 -257
  281. package/src/env/tool/registry.ts +0 -167
  282. package/src/env/tool/tool-component.test.ts +0 -559
  283. package/src/env/tool/tool-component.ts +0 -563
  284. package/src/env/tool/tool-config-registration.test.ts +0 -249
  285. package/src/env/tool/tool-config-registration.ts +0 -46
  286. package/src/env/tool/types.ts +0 -267
  287. package/src/env/tool/validator.test.ts +0 -143
  288. package/src/env/tool/validator.ts +0 -44
  289. package/src/env/types.ts +0 -180
  290. package/src/env/workflow/ask-user-tool-registration.test.ts +0 -216
  291. package/src/env/workflow/complex-workflow.integration.test.ts +0 -1900
  292. package/src/env/workflow/decorators/decorator-node.ts +0 -229
  293. package/src/env/workflow/decorators/decorator.test.ts +0 -196
  294. package/src/env/workflow/decorators/edge.ts +0 -82
  295. package/src/env/workflow/decorators/index.ts +0 -31
  296. package/src/env/workflow/decorators/node-as.ts +0 -98
  297. package/src/env/workflow/decorators/workflow.ts +0 -54
  298. package/src/env/workflow/engine/dag-manager.test.ts +0 -570
  299. package/src/env/workflow/engine/dag-manager.ts +0 -594
  300. package/src/env/workflow/engine/engine.ts +0 -1422
  301. package/src/env/workflow/engine/event-bus.test.ts +0 -359
  302. package/src/env/workflow/engine/event-bus.ts +0 -156
  303. package/src/env/workflow/engine/executor-agent-session.test.ts +0 -84
  304. package/src/env/workflow/engine/executor.test.ts +0 -619
  305. package/src/env/workflow/engine/executor.ts +0 -593
  306. package/src/env/workflow/engine/index.ts +0 -24
  307. package/src/env/workflow/engine/node-registry.test.ts +0 -560
  308. package/src/env/workflow/engine/node-registry.ts +0 -289
  309. package/src/env/workflow/engine/resume-removed.test.ts +0 -22
  310. package/src/env/workflow/engine/scheduler.test.ts +0 -715
  311. package/src/env/workflow/engine/scheduler.ts +0 -318
  312. package/src/env/workflow/engine/workflow-engine.test.ts +0 -815
  313. package/src/env/workflow/extractor/workflow-converter.ts +0 -306
  314. package/src/env/workflow/fixtures.ts +0 -380
  315. package/src/env/workflow/index.ts +0 -38
  316. package/src/env/workflow/integration/run-resume-unified.test.ts +0 -186
  317. package/src/env/workflow/integration/service-integration.test.ts +0 -267
  318. package/src/env/workflow/metadata/keys.ts +0 -12
  319. package/src/env/workflow/nodes/agent-component-adapter.test.ts +0 -318
  320. package/src/env/workflow/nodes/agent-component-adapter.ts +0 -448
  321. package/src/env/workflow/nodes/agent-node.test.ts +0 -371
  322. package/src/env/workflow/nodes/agent-node.ts +0 -598
  323. package/src/env/workflow/nodes/ask-user-node.ts +0 -113
  324. package/src/env/workflow/nodes/condition-node.ts +0 -200
  325. package/src/env/workflow/nodes/index.ts +0 -9
  326. package/src/env/workflow/nodes/merge-node.ts +0 -141
  327. package/src/env/workflow/nodes/skill-node.test.ts +0 -253
  328. package/src/env/workflow/nodes/skill-node.ts +0 -393
  329. package/src/env/workflow/nodes/tool-node.test.ts +0 -251
  330. package/src/env/workflow/nodes/tool-node.ts +0 -493
  331. package/src/env/workflow/nodes/workflow-llm-history.test.ts +0 -455
  332. package/src/env/workflow/nodes/workflow-node.test.ts +0 -315
  333. package/src/env/workflow/nodes/workflow-node.ts +0 -311
  334. package/src/env/workflow/service/index.ts +0 -27
  335. package/src/env/workflow/service/registry.test.ts +0 -133
  336. package/src/env/workflow/service/registry.ts +0 -71
  337. package/src/env/workflow/service/workflow-service.test.ts +0 -310
  338. package/src/env/workflow/service/workflow-service.ts +0 -393
  339. package/src/env/workflow/storage/index.ts +0 -28
  340. package/src/env/workflow/storage/mock-repositories.ts +0 -385
  341. package/src/env/workflow/storage/sqlite.test.ts +0 -179
  342. package/src/env/workflow/storage/sqlite.ts +0 -163
  343. package/src/env/workflow/storage/workflow-repo.test.ts +0 -780
  344. package/src/env/workflow/storage/workflow-repo.ts +0 -342
  345. package/src/env/workflow/tools/ask-user-tool.ts +0 -82
  346. package/src/env/workflow/tools/index.ts +0 -26
  347. package/src/env/workflow/tools/run-workflow.test.ts +0 -352
  348. package/src/env/workflow/tools/run-workflow.ts +0 -214
  349. package/src/env/workflow/types/context.ts +0 -18
  350. package/src/env/workflow/types/decorators-types.ts +0 -198
  351. package/src/env/workflow/types/event.test.ts +0 -515
  352. package/src/env/workflow/types/event.ts +0 -193
  353. package/src/env/workflow/types/index.ts +0 -49
  354. package/src/env/workflow/types/run.test.ts +0 -437
  355. package/src/env/workflow/types/run.ts +0 -173
  356. package/src/env/workflow/types/workflow-hil.ts +0 -114
  357. package/src/env/workflow/types/workflow-message.test.ts +0 -138
  358. package/src/env/workflow/types/workflow-message.ts +0 -196
  359. package/src/env/workflow/types/workflow-session.test.ts +0 -95
  360. package/src/env/workflow/types/workflow-session.ts +0 -59
  361. package/src/env/workflow/types/workflow.test.ts +0 -495
  362. package/src/env/workflow/types/workflow.ts +0 -195
  363. package/src/env/workflow/types_compat.ts +0 -51
  364. package/src/env/workflow/utils/create-workflow.ts +0 -47
  365. package/src/env/workflow/utils/execution-state.ts +0 -245
  366. package/src/env/workflow/utils/index.ts +0 -18
  367. package/src/env/workflow/utils/node-registry-helper.ts +0 -58
  368. package/src/env/workflow/utils/recovery-validator.test.ts +0 -460
  369. package/src/env/workflow/utils/recovery-validator.ts +0 -377
  370. package/src/env/workflow/utils/session-parser.test.ts +0 -111
  371. package/src/env/workflow/utils/session-parser.ts +0 -94
  372. package/src/env/workflow/utils/session-recovery.test.ts +0 -334
  373. package/src/env/workflow/utils/session-recovery.ts +0 -188
  374. package/src/env/workflow/utils/template-resolver.test.ts +0 -258
  375. package/src/env/workflow/utils/template-resolver.ts +0 -436
  376. package/src/env/workflow/utils/validation-rules.ts +0 -149
  377. package/src/env/workflow/workflow-component.ts +0 -544
  378. package/src/index.ts +0 -422
  379. package/src/utils/id.ts +0 -21
@@ -1,44 +0,0 @@
1
- import { ZodError } from "zod";
2
- import type { Tool, ValidationResult } from "./types";
3
-
4
- /**
5
- * 工具参数验证器
6
- */
7
- export class ToolValidator {
8
- /**
9
- * 验证参数
10
- */
11
- async validate(tool: Tool, args: Record<string, unknown>): Promise<ValidationResult> {
12
- try {
13
- // 使用 Zod 验证参数
14
- const parsed = await tool.parameters.parseAsync(args);
15
- return {
16
- success: true,
17
- data: parsed as Record<string, unknown>,
18
- };
19
- } catch (error) {
20
- if (error instanceof ZodError) {
21
- const errorMessage = tool.formatValidationError
22
- ? tool.formatValidationError(error)
23
- : this.formatError(error);
24
- return {
25
- success: false,
26
- error: `Invalid arguments for tool '${tool.name}': ${errorMessage}`,
27
- };
28
- }
29
- return {
30
- success: false,
31
- error: `Validation error: ${error}`,
32
- };
33
- }
34
- }
35
-
36
- /**
37
- * 格式化 Zod 错误
38
- */
39
- private formatError(error: ZodError): string {
40
- return error.errors
41
- .map((e) => `${e.path.join(".")}: ${e.message}`)
42
- .join("; ");
43
- }
44
- }
package/src/env/types.ts DELETED
@@ -1,180 +0,0 @@
1
- /**
2
- * @fileoverview Environment types and interfaces
3
- *
4
- * 定义 Environment 的核心类型,包括:
5
- * - Environment 配置
6
- * - EnvEvent 事件类型
7
- */
8
-
9
- // ============================================================================
10
- // Environment Types
11
- // ============================================================================
12
-
13
- /**
14
- * Environment Config
15
- */
16
- export interface EnvironmentConfig {
17
- /** 环境名称 */
18
- name: string;
19
- /** 环境版本 */
20
- version: string;
21
- /** 是否启用 */
22
- enabled: boolean;
23
- }
24
-
25
- /**
26
- * BaseEnvironment 配置
27
- */
28
- export interface BaseEnvironmentConfig {
29
- /** 环境名称 */
30
- name?: string;
31
- /** 环境版本 */
32
- version?: string;
33
- /** 是否启用 */
34
- enabled?: boolean;
35
- }
36
-
37
- // ============================================================================
38
- // EnvEvent Types
39
- // ============================================================================
40
-
41
- /**
42
- * EnvEvent 元信息
43
- */
44
- export interface EnvEventMetadata {
45
- /** 触发事件的 session ID */
46
- trigger_session_id?: string;
47
- /** 触发事件的 agent ID */
48
- trigger_agent_id?: string;
49
- /** Agent 名称 */
50
- trigger_agent_name?: string;
51
- /** 环境名称 */
52
- env_name?: string;
53
- /** 事件来源 */
54
- source?: string;
55
- /** 其他元数据 */
56
- [key: string]: unknown;
57
- }
58
-
59
- /**
60
- * EnvEvent
61
- *
62
- * 统一的事件机制,用于:
63
- * - Stream 事件(stream.start, stream.text, stream.completed 等)
64
- * - 工具调用事件(tool.call, tool.result 等)
65
- * - 会话事件(session.created, session.updated 等)
66
- * - Agent 事件(agent.thinking, agent.acting 等)
67
- */
68
- export interface EnvEvent<T = unknown> {
69
- /** 事件 ID */
70
- id: string;
71
- /** 事件类型 */
72
- type: string;
73
- /** 时间戳 */
74
- timestamp: number;
75
- /** 元信息 */
76
- metadata: EnvEventMetadata;
77
- /** 事件负载 */
78
- payload: T;
79
- }
80
-
81
- /**
82
- * EnvEvent Handler
83
- */
84
- export type EnvEventHandler = (event: EnvEvent) => void | Promise<void>;
85
-
86
- /**
87
- * EnvEvent 创建参数(部分属性,可选)
88
- *
89
- * 用于 pushEnvEvent 方法,允许传入部分属性,自动补全必填字段
90
- */
91
- export interface EnvEventInput {
92
- /** 事件类型(必填) */
93
- type: string;
94
- /** 事件 ID(可选,自动生成) */
95
- id?: string;
96
- /** 时间戳(可选,自动生成) */
97
- timestamp?: number;
98
- /** 元信息(可选,自动创建) */
99
- metadata?: EnvEventMetadata;
100
- /** 事件负载(可选) */
101
- payload?: unknown;
102
- }
103
-
104
- // ============================================================================
105
- // Context Types
106
- // ============================================================================
107
-
108
- /**
109
- * Action 类型
110
- */
111
- export interface Action {
112
- /** Action 类型 */
113
- type: string;
114
- /** Action 参数 */
115
- params?: Record<string, unknown>;
116
- }
117
-
118
- /**
119
- * Tool Result
120
- */
121
- export interface ToolResult {
122
- /** 是否成功 */
123
- success: boolean;
124
- /** 输出内容 */
125
- output: string | Record<string, unknown>;
126
- /** 错误信息 */
127
- error?: string;
128
- }
129
-
130
- /**
131
- * Context
132
- */
133
- export interface Context {
134
- /** 会话 ID */
135
- sessionId?: string;
136
- /** 用户 ID */
137
- userId?: string;
138
- /** 工作目录 */
139
- workdir?: string;
140
- /** 中断信号 */
141
- abort?: AbortSignal;
142
- /** 元数据 */
143
- metadata?: Record<string, unknown>;
144
- }
145
-
146
- // ============================================================================
147
- // Hook Context Types
148
- // ============================================================================
149
-
150
- /**
151
- * Session Hook 上下文
152
- */
153
- export interface SessionHookContext {
154
- /** Session 对象 */
155
- session?: {
156
- id: string;
157
- title?: string;
158
- metadata?: Record<string, unknown>;
159
- };
160
- /** 操作选项 */
161
- options?: Record<string, unknown>;
162
- }
163
-
164
- /**
165
- * Log Context(日志上下文)
166
- */
167
- export interface LogContext {
168
- /** 日志级别 */
169
- level: string;
170
- /** 日志类别 */
171
- category: string;
172
- /** 日志消息 */
173
- message: string;
174
- /** 时间戳 */
175
- timestamp: number;
176
- /** 调用位置 */
177
- callerLocation?: string;
178
- /** 其他元数据 */
179
- [key: string]: unknown;
180
- }
@@ -1,216 +0,0 @@
1
- /**
2
- * @fileoverview AskUserTool Registration Tests
3
- *
4
- * Tests to verify that ask_user tool is only registered in Workflow AgentNode context,
5
- * NOT in default agent or sub agent (delegate task) contexts.
6
- *
7
- * Design:
8
- * - ask_user tool should NOT be available to default agent
9
- * - ask_user tool should NOT be available to sub agent (delegate task)
10
- * - ask_user tool should ONLY be available in Workflow AgentNode when workflow is running
11
- */
12
-
13
- import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
14
- import { z } from 'zod';
15
-
16
- // Mock the ask_user tool
17
- const mockAskUserTool = {
18
- name: 'ask_user',
19
- description: 'Ask user for input',
20
- parameters: z.object({
21
- query: z.string().describe('The question to ask'),
22
- options: z.array(z.string()).optional(),
23
- }),
24
- execute: vi.fn().mockImplementation(() => {
25
- throw new Error('AskUserError - should not be called in this test');
26
- }),
27
- metadata: { category: 'workflow', tags: ['human-in-loop'] },
28
- };
29
-
30
- describe('AskUserTool Registration', () => {
31
- describe('ToolComponent registration behavior', () => {
32
- it('should NOT register ask_user tool by default', () => {
33
- // The ask_user tool should NOT be pre-registered to ToolComponent
34
- // This test documents the expected behavior
35
-
36
- // Setup: Create a mock ToolComponent
37
- const registeredTools = new Map<string, any>();
38
- const mockToolComponent = {
39
- register: vi.fn((tool: any) => {
40
- registeredTools.set(tool.name, tool);
41
- }),
42
- registerMany: vi.fn((tools: any[]) => {
43
- tools.forEach((tool: any) => {
44
- registeredTools.set(tool.name, tool);
45
- });
46
- }),
47
- getTool: vi.fn((name: string) => registeredTools.get(name)),
48
- listTools: vi.fn(() => Array.from(registeredTools.keys())),
49
- };
50
-
51
- // Verify: ask_user is NOT registered by default
52
- expect(mockToolComponent.getTool('ask_user')).toBeUndefined();
53
- });
54
-
55
- it('should document that ask_user is workflow-only', () => {
56
- // This test documents the design:
57
- // - ask_user tool is only available in Workflow AgentNode context
58
- // - It should NOT be available to default agent
59
- // - It should NOT be available to sub agent (delegate task)
60
-
61
- const toolScope = {
62
- availableIn: {
63
- defaultAgent: false,
64
- subAgent: false,
65
- workflowAgentNode: true, // Only when workflow is running
66
- },
67
- registrationPoint: 'AgentNode options (not init time)',
68
- };
69
-
70
- expect(toolScope.availableIn.defaultAgent).toBe(false);
71
- expect(toolScope.availableIn.subAgent).toBe(false);
72
- expect(toolScope.availableIn.workflowAgentNode).toBe(true);
73
- });
74
- });
75
-
76
- describe('AgentNode with ask_user in allowedTools', () => {
77
- it('should include ask_user in allowedTools when running workflow agent', () => {
78
- // Test that when Workflow AgentNode runs, it should have ask_user in allowedTools
79
- // This is set in the AgentNode.execute() method when building AgentConfig
80
-
81
- const agentConfig = {
82
- type: 'general',
83
- prompt: 'Test prompt',
84
- // ask_user should be explicitly allowed for workflow agents
85
- options: {
86
- allowedTools: ['ask_user'],
87
- },
88
- };
89
-
90
- expect(agentConfig.options.allowedTools).toContain('ask_user');
91
- });
92
-
93
- it('should NOT include ask_user for non-workflow agents', () => {
94
- // Test that regular agents (default agent, sub agent) should NOT have ask_user
95
-
96
- // Default agent - no allowedTools in options
97
- const defaultAgentConfig = {
98
- type: 'general',
99
- prompt: 'Test prompt',
100
- // No options.allowedTools - uses default tool list
101
- };
102
-
103
- // Sub agent (delegate task) - should not have ask_user
104
- const subAgentConfig = {
105
- type: 'delegate',
106
- prompt: 'Delegate task',
107
- // No options.allowedTools
108
- };
109
-
110
- // These configs should NOT have ask_user in their allowed tools
111
- expect(defaultAgentConfig.options?.allowedTools).toBeUndefined();
112
- expect(subAgentConfig.options?.allowedTools).toBeUndefined();
113
- });
114
- });
115
-
116
- describe('WorkflowComponent initialization', () => {
117
- it('should NOT register ask_user tool during init', () => {
118
- // WorkflowComponent.init() should NOT call registerAskUserTool()
119
- // This documents the expected behavior after refactoring
120
-
121
- // The registerAskUserTool method exists but should NOT be called during init
122
- // It has been removed from the init() and initSqliteService() methods
123
- const shouldNotRegisterDuringInit = true; // This is the expected behavior
124
-
125
- expect(shouldNotRegisterDuringInit).toBe(true);
126
- });
127
-
128
- it('should register ask_user only via AgentNode options', () => {
129
- // The new design:
130
- // - ask_user is not registered globally
131
- // - AgentNode adds allowedTools: ['ask_user'] to its options when building AgentConfig
132
- // - AgentComponentAdapter passes this to AgentContext
133
- // - AgentComponent uses AgentContext.allowedTools to filter tools
134
-
135
- const registrationPoints = {
136
- duringInit: false,
137
- viaAgentNodeOptions: true,
138
- };
139
-
140
- expect(registrationPoints.duringInit).toBe(false);
141
- expect(registrationPoints.viaAgentNodeOptions).toBe(true);
142
- });
143
- });
144
-
145
- describe('AgentContext.allowedTools propagation', () => {
146
- it('should pass allowedTools from AgentNode to AgentContext', () => {
147
- // Test the data flow:
148
- // AgentNode (options.allowedTools: ['ask_user'])
149
- // -> AgentComponentAdapter passes to context.allowedTools
150
- // -> AgentContext (allowedTools: ['ask_user'])
151
- // -> AgentComponent.run()
152
-
153
- const agentNodeOptions = {
154
- timeout: 60000,
155
- model: 'gpt-4',
156
- allowedTools: ['ask_user'],
157
- };
158
-
159
- // AgentComponentAdapter builds AgentContext
160
- const agentContext = {
161
- sessionId: 'test-session',
162
- allowedTools: agentNodeOptions.allowedTools, // Pass through from options
163
- deniedTools: agentNodeOptions.deniedTools,
164
- };
165
-
166
- expect(agentContext.allowedTools).toEqual(['ask_user']);
167
- expect(agentContext.allowedTools).toBe(agentNodeOptions.allowedTools);
168
- });
169
-
170
- it('should NOT pass allowedTools for non-workflow agents', () => {
171
- // Default agent and sub agent should NOT have allowedTools set in context
172
-
173
- const defaultAgentContext = {
174
- sessionId: 'default-session',
175
- // No allowedTools - uses default tool list
176
- };
177
-
178
- const subAgentContext = {
179
- sessionId: 'sub-agent-session',
180
- // No allowedTools - uses default tool list
181
- };
182
-
183
- expect(defaultAgentContext.allowedTools).toBeUndefined();
184
- expect(subAgentContext.allowedTools).toBeUndefined();
185
- });
186
- });
187
- });
188
-
189
- describe('AskUserTool Scope Enforcement', () => {
190
- it('should enforce ask_user scope: workflow-only', () => {
191
- // Document the scope rules:
192
- // 1. Default Agent - NO access to ask_user
193
- // 2. Sub Agent (delegate task) - NO access to ask_user
194
- // 3. Workflow AgentNode - ONLY access when workflow is running
195
-
196
- const toolScopeMatrix = {
197
- defaultAgent: {
198
- canAccess: false,
199
- reason: 'ask_user is workflow-specific functionality',
200
- },
201
- subAgent: {
202
- canAccess: false,
203
- reason: 'delegate task is for autonomous execution, no human interruption',
204
- },
205
- workflowAgentNode: {
206
- canAccess: true,
207
- condition: 'only when workflow is running',
208
- reason: 'enables human-in-loop for workflow pause/resume',
209
- },
210
- };
211
-
212
- expect(toolScopeMatrix.defaultAgent.canAccess).toBe(false);
213
- expect(toolScopeMatrix.subAgent.canAccess).toBe(false);
214
- expect(toolScopeMatrix.workflowAgentNode.canAccess).toBe(true);
215
- });
216
- });