pulseed 0.6.1 → 0.6.3

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 (963) hide show
  1. package/README.md +1 -1
  2. package/dist/adapters/agents/claude-api.d.ts +2 -2
  3. package/dist/adapters/agents/claude-api.d.ts.map +1 -1
  4. package/dist/adapters/agents/claude-api.js +3 -2
  5. package/dist/adapters/agents/claude-api.js.map +1 -1
  6. package/dist/adapters/agents/openai-codex.d.ts +3 -0
  7. package/dist/adapters/agents/openai-codex.d.ts.map +1 -1
  8. package/dist/adapters/agents/openai-codex.js +5 -0
  9. package/dist/adapters/agents/openai-codex.js.map +1 -1
  10. package/dist/adapters/datasources/artifact-metric-datasource.d.ts +3 -0
  11. package/dist/adapters/datasources/artifact-metric-datasource.d.ts.map +1 -1
  12. package/dist/adapters/datasources/artifact-metric-datasource.js +20 -1
  13. package/dist/adapters/datasources/artifact-metric-datasource.js.map +1 -1
  14. package/dist/adapters/types/a2a.d.ts +24 -24
  15. package/dist/base/config/global-config.d.ts +4 -4
  16. package/dist/base/llm/codex-llm-client.d.ts +3 -0
  17. package/dist/base/llm/codex-llm-client.d.ts.map +1 -1
  18. package/dist/base/llm/codex-llm-client.js +71 -7
  19. package/dist/base/llm/codex-llm-client.js.map +1 -1
  20. package/dist/base/llm/llm-client.d.ts +2 -0
  21. package/dist/base/llm/llm-client.d.ts.map +1 -1
  22. package/dist/base/llm/llm-client.js +2 -2
  23. package/dist/base/llm/llm-client.js.map +1 -1
  24. package/dist/base/llm/ollama-client.d.ts.map +1 -1
  25. package/dist/base/llm/ollama-client.js +12 -0
  26. package/dist/base/llm/ollama-client.js.map +1 -1
  27. package/dist/base/llm/openai-client.d.ts +4 -0
  28. package/dist/base/llm/openai-client.d.ts.map +1 -1
  29. package/dist/base/llm/openai-client.js +29 -15
  30. package/dist/base/llm/openai-client.js.map +1 -1
  31. package/dist/base/llm/provider-config.d.ts +12 -2
  32. package/dist/base/llm/provider-config.d.ts.map +1 -1
  33. package/dist/base/llm/provider-config.js +46 -5
  34. package/dist/base/llm/provider-config.js.map +1 -1
  35. package/dist/base/llm/provider-factory.d.ts +1 -1
  36. package/dist/base/llm/provider-factory.d.ts.map +1 -1
  37. package/dist/base/llm/provider-factory.js +7 -2
  38. package/dist/base/llm/provider-factory.js.map +1 -1
  39. package/dist/base/state/state-manager-goal-write.d.ts +1 -1
  40. package/dist/base/state/state-manager-goal-write.d.ts.map +1 -1
  41. package/dist/base/state/state-manager.d.ts +2 -6
  42. package/dist/base/state/state-manager.d.ts.map +1 -1
  43. package/dist/base/state/state-manager.js.map +1 -1
  44. package/dist/base/state/state-write-fence.d.ts +7 -0
  45. package/dist/base/state/state-write-fence.d.ts.map +1 -0
  46. package/dist/base/state/state-write-fence.js +2 -0
  47. package/dist/base/state/state-write-fence.js.map +1 -0
  48. package/dist/base/types/companion.d.ts +2 -0
  49. package/dist/base/types/companion.d.ts.map +1 -0
  50. package/dist/base/types/companion.js +2 -0
  51. package/dist/base/types/companion.js.map +1 -0
  52. package/dist/base/types/core.d.ts +1 -1
  53. package/dist/base/types/core.d.ts.map +1 -1
  54. package/dist/base/types/core.js +1 -0
  55. package/dist/base/types/core.js.map +1 -1
  56. package/dist/base/types/index.d.ts +1 -0
  57. package/dist/base/types/index.d.ts.map +1 -1
  58. package/dist/base/types/index.js +1 -0
  59. package/dist/base/types/index.js.map +1 -1
  60. package/dist/base/utils/execFileNoThrow.d.ts +4 -0
  61. package/dist/base/utils/execFileNoThrow.d.ts.map +1 -1
  62. package/dist/base/utils/execFileNoThrow.js +81 -2
  63. package/dist/base/utils/execFileNoThrow.js.map +1 -1
  64. package/dist/index.d.ts +4 -2
  65. package/dist/index.d.ts.map +1 -1
  66. package/dist/index.js +2 -1
  67. package/dist/index.js.map +1 -1
  68. package/dist/interface/chat/chat-event-state.d.ts +2 -0
  69. package/dist/interface/chat/chat-event-state.d.ts.map +1 -1
  70. package/dist/interface/chat/chat-event-state.js +28 -11
  71. package/dist/interface/chat/chat-event-state.js.map +1 -1
  72. package/dist/interface/chat/chat-events.d.ts +9 -1
  73. package/dist/interface/chat/chat-events.d.ts.map +1 -1
  74. package/dist/interface/chat/chat-history.d.ts +4739 -1
  75. package/dist/interface/chat/chat-history.d.ts.map +1 -1
  76. package/dist/interface/chat/chat-history.js +40 -2
  77. package/dist/interface/chat/chat-history.js.map +1 -1
  78. package/dist/interface/chat/chat-runner-command-helpers.d.ts +1 -0
  79. package/dist/interface/chat/chat-runner-command-helpers.d.ts.map +1 -1
  80. package/dist/interface/chat/chat-runner-command-helpers.js +1 -0
  81. package/dist/interface/chat/chat-runner-command-helpers.js.map +1 -1
  82. package/dist/interface/chat/chat-runner-commands.d.ts +4 -32
  83. package/dist/interface/chat/chat-runner-commands.d.ts.map +1 -1
  84. package/dist/interface/chat/chat-runner-commands.js +156 -7
  85. package/dist/interface/chat/chat-runner-commands.js.map +1 -1
  86. package/dist/interface/chat/chat-runner-contracts.d.ts +153 -0
  87. package/dist/interface/chat/chat-runner-contracts.d.ts.map +1 -0
  88. package/dist/interface/chat/chat-runner-contracts.js +2 -0
  89. package/dist/interface/chat/chat-runner-contracts.js.map +1 -0
  90. package/dist/interface/chat/chat-runner-event-bridge.d.ts +8 -2
  91. package/dist/interface/chat/chat-runner-event-bridge.d.ts.map +1 -1
  92. package/dist/interface/chat/chat-runner-event-bridge.js +76 -11
  93. package/dist/interface/chat/chat-runner-event-bridge.js.map +1 -1
  94. package/dist/interface/chat/chat-runner-routes.d.ts +66 -12
  95. package/dist/interface/chat/chat-runner-routes.d.ts.map +1 -1
  96. package/dist/interface/chat/chat-runner-routes.js +322 -30
  97. package/dist/interface/chat/chat-runner-routes.js.map +1 -1
  98. package/dist/interface/chat/chat-runner-runtime.d.ts +1 -1
  99. package/dist/interface/chat/chat-runner-runtime.d.ts.map +1 -1
  100. package/dist/interface/chat/chat-runner-runtime.js +4 -0
  101. package/dist/interface/chat/chat-runner-runtime.js.map +1 -1
  102. package/dist/interface/chat/chat-runner.d.ts +11 -71
  103. package/dist/interface/chat/chat-runner.d.ts.map +1 -1
  104. package/dist/interface/chat/chat-runner.js +440 -58
  105. package/dist/interface/chat/chat-runner.js.map +1 -1
  106. package/dist/interface/chat/chat-session-store.d.ts +2 -0
  107. package/dist/interface/chat/chat-session-store.d.ts.map +1 -1
  108. package/dist/interface/chat/chat-session-store.js +3 -6
  109. package/dist/interface/chat/chat-session-store.js.map +1 -1
  110. package/dist/interface/chat/chat-state-service.d.ts +1 -0
  111. package/dist/interface/chat/chat-state-service.d.ts.map +1 -1
  112. package/dist/interface/chat/chat-state-service.js +1 -0
  113. package/dist/interface/chat/chat-state-service.js.map +1 -1
  114. package/dist/interface/chat/cross-platform-session-global.d.ts +2 -1
  115. package/dist/interface/chat/cross-platform-session-global.d.ts.map +1 -1
  116. package/dist/interface/chat/cross-platform-session-global.js +4 -10
  117. package/dist/interface/chat/cross-platform-session-global.js.map +1 -1
  118. package/dist/interface/chat/cross-platform-session.d.ts +30 -1
  119. package/dist/interface/chat/cross-platform-session.d.ts.map +1 -1
  120. package/dist/interface/chat/cross-platform-session.js +413 -52
  121. package/dist/interface/chat/cross-platform-session.js.map +1 -1
  122. package/dist/interface/chat/event-subscriber.js +2 -2
  123. package/dist/interface/chat/event-subscriber.js.map +1 -1
  124. package/dist/interface/chat/failure-recovery.js +1 -1
  125. package/dist/interface/chat/failure-recovery.js.map +1 -1
  126. package/dist/interface/chat/freeform-route-classifier.d.ts +5 -5
  127. package/dist/interface/chat/freeform-route-classifier.js +3 -2
  128. package/dist/interface/chat/freeform-route-classifier.js.map +1 -1
  129. package/dist/interface/chat/gateway-setup-status.d.ts +33 -0
  130. package/dist/interface/chat/gateway-setup-status.d.ts.map +1 -0
  131. package/dist/interface/chat/gateway-setup-status.js +44 -0
  132. package/dist/interface/chat/gateway-setup-status.js.map +1 -0
  133. package/dist/interface/chat/ingress-router.d.ts +22 -0
  134. package/dist/interface/chat/ingress-router.d.ts.map +1 -1
  135. package/dist/interface/chat/ingress-router.js +148 -11
  136. package/dist/interface/chat/ingress-router.js.map +1 -1
  137. package/dist/interface/chat/operation-progress.d.ts +17 -0
  138. package/dist/interface/chat/operation-progress.d.ts.map +1 -0
  139. package/dist/interface/chat/operation-progress.js +29 -0
  140. package/dist/interface/chat/operation-progress.js.map +1 -0
  141. package/dist/interface/chat/setup-config-write.d.ts +27 -0
  142. package/dist/interface/chat/setup-config-write.d.ts.map +1 -0
  143. package/dist/interface/chat/setup-config-write.js +79 -0
  144. package/dist/interface/chat/setup-config-write.js.map +1 -0
  145. package/dist/interface/chat/setup-dialogue.d.ts +199 -0
  146. package/dist/interface/chat/setup-dialogue.d.ts.map +1 -0
  147. package/dist/interface/chat/setup-dialogue.js +97 -0
  148. package/dist/interface/chat/setup-dialogue.js.map +1 -0
  149. package/dist/interface/chat/setup-secret-intake.d.ts +68 -0
  150. package/dist/interface/chat/setup-secret-intake.d.ts.map +1 -0
  151. package/dist/interface/chat/setup-secret-intake.js +84 -0
  152. package/dist/interface/chat/setup-secret-intake.js.map +1 -0
  153. package/dist/interface/chat/turn-language.d.ts +23 -0
  154. package/dist/interface/chat/turn-language.d.ts.map +1 -0
  155. package/dist/interface/chat/turn-language.js +46 -0
  156. package/dist/interface/chat/turn-language.js.map +1 -0
  157. package/dist/interface/cli/cli-command-registry.d.ts +1 -1
  158. package/dist/interface/cli/cli-command-registry.d.ts.map +1 -1
  159. package/dist/interface/cli/cli-runner.js +1 -1
  160. package/dist/interface/cli/cli-runner.js.map +1 -1
  161. package/dist/interface/cli/commands/config.d.ts.map +1 -1
  162. package/dist/interface/cli/commands/config.js +12 -1
  163. package/dist/interface/cli/commands/config.js.map +1 -1
  164. package/dist/interface/cli/commands/daemon.d.ts.map +1 -1
  165. package/dist/interface/cli/commands/daemon.js +62 -1
  166. package/dist/interface/cli/commands/daemon.js.map +1 -1
  167. package/dist/interface/cli/commands/doctor.d.ts +1 -0
  168. package/dist/interface/cli/commands/doctor.d.ts.map +1 -1
  169. package/dist/interface/cli/commands/doctor.js +69 -0
  170. package/dist/interface/cli/commands/doctor.js.map +1 -1
  171. package/dist/interface/cli/commands/goal-dispatch.d.ts.map +1 -1
  172. package/dist/interface/cli/commands/goal-dispatch.js +9 -1
  173. package/dist/interface/cli/commands/goal-dispatch.js.map +1 -1
  174. package/dist/interface/cli/commands/goal-raw.d.ts +1 -0
  175. package/dist/interface/cli/commands/goal-raw.d.ts.map +1 -1
  176. package/dist/interface/cli/commands/goal-raw.js +34 -2
  177. package/dist/interface/cli/commands/goal-raw.js.map +1 -1
  178. package/dist/interface/cli/commands/operator-binding-status.d.ts +59 -0
  179. package/dist/interface/cli/commands/operator-binding-status.d.ts.map +1 -0
  180. package/dist/interface/cli/commands/operator-binding-status.js +257 -0
  181. package/dist/interface/cli/commands/operator-binding-status.js.map +1 -0
  182. package/dist/interface/cli/commands/run.d.ts +2 -2
  183. package/dist/interface/cli/commands/run.d.ts.map +1 -1
  184. package/dist/interface/cli/commands/run.js.map +1 -1
  185. package/dist/interface/cli/commands/runtime.d.ts.map +1 -1
  186. package/dist/interface/cli/commands/runtime.js +8 -1
  187. package/dist/interface/cli/commands/runtime.js.map +1 -1
  188. package/dist/interface/cli/commands/setup/import/flow.d.ts.map +1 -1
  189. package/dist/interface/cli/commands/setup/import/flow.js +2 -0
  190. package/dist/interface/cli/commands/setup/import/flow.js.map +1 -1
  191. package/dist/interface/cli/commands/setup/import/provider.d.ts.map +1 -1
  192. package/dist/interface/cli/commands/setup/import/provider.js +5 -1
  193. package/dist/interface/cli/commands/setup/import/provider.js.map +1 -1
  194. package/dist/interface/cli/commands/setup/import/types.d.ts +1 -0
  195. package/dist/interface/cli/commands/setup/import/types.d.ts.map +1 -1
  196. package/dist/interface/cli/commands/setup/steps-gateway.js +14 -3
  197. package/dist/interface/cli/commands/setup/steps-gateway.js.map +1 -1
  198. package/dist/interface/cli/commands/setup-shared.d.ts +2 -0
  199. package/dist/interface/cli/commands/setup-shared.d.ts.map +1 -1
  200. package/dist/interface/cli/commands/setup-shared.js +4 -1
  201. package/dist/interface/cli/commands/setup-shared.js.map +1 -1
  202. package/dist/interface/cli/commands/setup-wizard.d.ts +33 -0
  203. package/dist/interface/cli/commands/setup-wizard.d.ts.map +1 -1
  204. package/dist/interface/cli/commands/setup-wizard.js +124 -4
  205. package/dist/interface/cli/commands/setup-wizard.js.map +1 -1
  206. package/dist/interface/cli/commands/setup.d.ts.map +1 -1
  207. package/dist/interface/cli/commands/setup.js +13 -1
  208. package/dist/interface/cli/commands/setup.js.map +1 -1
  209. package/dist/interface/cli/commands/telegram.d.ts.map +1 -1
  210. package/dist/interface/cli/commands/telegram.js +27 -3
  211. package/dist/interface/cli/commands/telegram.js.map +1 -1
  212. package/dist/interface/cli/setup.d.ts +3 -3
  213. package/dist/interface/cli/setup.d.ts.map +1 -1
  214. package/dist/interface/cli/setup.js +3 -2
  215. package/dist/interface/cli/setup.js.map +1 -1
  216. package/dist/interface/cli/utils/loop-runner.d.ts +1 -1
  217. package/dist/interface/cli/utils/loop-runner.d.ts.map +1 -1
  218. package/dist/interface/cli/utils.js +1 -1
  219. package/dist/interface/tui/actions.d.ts.map +1 -1
  220. package/dist/interface/tui/actions.js +14 -6
  221. package/dist/interface/tui/actions.js.map +1 -1
  222. package/dist/interface/tui/app.d.ts +1 -7
  223. package/dist/interface/tui/app.d.ts.map +1 -1
  224. package/dist/interface/tui/app.js +71 -120
  225. package/dist/interface/tui/app.js.map +1 -1
  226. package/dist/interface/tui/chat/suggestions.js +1 -1
  227. package/dist/interface/tui/chat/suggestions.js.map +1 -1
  228. package/dist/interface/tui/chat-surface.d.ts +1 -0
  229. package/dist/interface/tui/chat-surface.d.ts.map +1 -1
  230. package/dist/interface/tui/chat-surface.js +15 -0
  231. package/dist/interface/tui/chat-surface.js.map +1 -1
  232. package/dist/interface/tui/entry-approval.js +2 -2
  233. package/dist/interface/tui/entry-approval.js.map +1 -1
  234. package/dist/interface/tui/entry-deps.d.ts +1 -1
  235. package/dist/interface/tui/entry-deps.d.ts.map +1 -1
  236. package/dist/interface/tui/entry-deps.js +54 -8
  237. package/dist/interface/tui/entry-deps.js.map +1 -1
  238. package/dist/interface/tui/input-action.d.ts +49 -0
  239. package/dist/interface/tui/input-action.d.ts.map +1 -0
  240. package/dist/interface/tui/input-action.js +46 -0
  241. package/dist/interface/tui/input-action.js.map +1 -0
  242. package/dist/interface/tui/markdown-renderer.d.ts.map +1 -1
  243. package/dist/interface/tui/markdown-renderer.js +4 -1
  244. package/dist/interface/tui/markdown-renderer.js.map +1 -1
  245. package/dist/interface/tui/use-loop.d.ts +1 -1
  246. package/dist/interface/tui/use-loop.d.ts.map +1 -1
  247. package/dist/orchestrator/execution/adapter-layer.d.ts +1 -1
  248. package/dist/orchestrator/execution/adapter-layer.d.ts.map +1 -1
  249. package/dist/orchestrator/execution/agent-loop/agent-loop-context-assembler.d.ts.map +1 -1
  250. package/dist/orchestrator/execution/agent-loop/agent-loop-context-assembler.js +12 -1
  251. package/dist/orchestrator/execution/agent-loop/agent-loop-context-assembler.js.map +1 -1
  252. package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.d.ts +1 -1
  253. package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.d.ts.map +1 -1
  254. package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.js +18 -1
  255. package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.js.map +1 -1
  256. package/dist/orchestrator/execution/agent-loop/agent-loop-events.d.ts +3 -0
  257. package/dist/orchestrator/execution/agent-loop/agent-loop-events.d.ts.map +1 -1
  258. package/dist/orchestrator/execution/agent-loop/agent-loop-events.js.map +1 -1
  259. package/dist/orchestrator/execution/agent-loop/agent-loop-model-client.d.ts.map +1 -1
  260. package/dist/orchestrator/execution/agent-loop/agent-loop-model-client.js +1 -0
  261. package/dist/orchestrator/execution/agent-loop/agent-loop-model-client.js.map +1 -1
  262. package/dist/orchestrator/execution/agent-loop/agent-loop-model.d.ts +2 -1
  263. package/dist/orchestrator/execution/agent-loop/agent-loop-model.d.ts.map +1 -1
  264. package/dist/orchestrator/execution/agent-loop/agent-loop-model.js.map +1 -1
  265. package/dist/orchestrator/execution/agent-loop/agent-loop-result.d.ts +17 -0
  266. package/dist/orchestrator/execution/agent-loop/agent-loop-result.d.ts.map +1 -1
  267. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-output.d.ts +3 -0
  268. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-output.d.ts.map +1 -1
  269. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.d.ts +1 -0
  270. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.d.ts.map +1 -1
  271. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.js +20 -3
  272. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.js.map +1 -1
  273. package/dist/orchestrator/execution/agent-loop/agent-loop-trace-store.d.ts.map +1 -1
  274. package/dist/orchestrator/execution/agent-loop/agent-loop-trace-store.js +5 -3
  275. package/dist/orchestrator/execution/agent-loop/agent-loop-trace-store.js.map +1 -1
  276. package/dist/orchestrator/execution/agent-loop/agent-timeline.d.ts +3 -1
  277. package/dist/orchestrator/execution/agent-loop/agent-timeline.d.ts.map +1 -1
  278. package/dist/orchestrator/execution/agent-loop/agent-timeline.js +8 -20
  279. package/dist/orchestrator/execution/agent-loop/agent-timeline.js.map +1 -1
  280. package/dist/orchestrator/execution/agent-loop/anthropic-messages-agent-loop-model-client.d.ts.map +1 -1
  281. package/dist/orchestrator/execution/agent-loop/anthropic-messages-agent-loop-model-client.js +5 -2
  282. package/dist/orchestrator/execution/agent-loop/anthropic-messages-agent-loop-model-client.js.map +1 -1
  283. package/dist/orchestrator/execution/agent-loop/bounded-agent-loop-runner.d.ts.map +1 -1
  284. package/dist/orchestrator/execution/agent-loop/bounded-agent-loop-runner.js +43 -25
  285. package/dist/orchestrator/execution/agent-loop/bounded-agent-loop-runner.js.map +1 -1
  286. package/dist/orchestrator/execution/agent-loop/chat-agent-loop-runner.d.ts.map +1 -1
  287. package/dist/orchestrator/execution/agent-loop/chat-agent-loop-runner.js +20 -4
  288. package/dist/orchestrator/execution/agent-loop/chat-agent-loop-runner.js.map +1 -1
  289. package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.d.ts +1 -51
  290. package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.d.ts.map +1 -1
  291. package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.js +3 -239
  292. package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.js.map +1 -1
  293. package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.d.ts +60 -0
  294. package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.d.ts.map +1 -0
  295. package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.js +244 -0
  296. package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.js.map +1 -0
  297. package/dist/orchestrator/execution/agent-loop/index.d.ts +1 -1
  298. package/dist/orchestrator/execution/agent-loop/index.d.ts.map +1 -1
  299. package/dist/orchestrator/execution/agent-loop/index.js +1 -1
  300. package/dist/orchestrator/execution/agent-loop/index.js.map +1 -1
  301. package/dist/orchestrator/execution/agent-loop/openai-responses-agent-loop-model-client.d.ts.map +1 -1
  302. package/dist/orchestrator/execution/agent-loop/openai-responses-agent-loop-model-client.js +5 -2
  303. package/dist/orchestrator/execution/agent-loop/openai-responses-agent-loop-model-client.js.map +1 -1
  304. package/dist/orchestrator/execution/agent-loop/task-agent-loop-result.d.ts.map +1 -1
  305. package/dist/orchestrator/execution/agent-loop/task-agent-loop-result.js +2 -1
  306. package/dist/orchestrator/execution/agent-loop/task-agent-loop-result.js.map +1 -1
  307. package/dist/orchestrator/execution/task/task-generation.d.ts +50 -2
  308. package/dist/orchestrator/execution/task/task-generation.d.ts.map +1 -1
  309. package/dist/orchestrator/execution/task/task-generation.js +19 -1
  310. package/dist/orchestrator/execution/task/task-generation.js.map +1 -1
  311. package/dist/orchestrator/execution/task/task-lifecycle-runner.d.ts +2 -1
  312. package/dist/orchestrator/execution/task/task-lifecycle-runner.d.ts.map +1 -1
  313. package/dist/orchestrator/execution/task/task-lifecycle-runner.js +1 -1
  314. package/dist/orchestrator/execution/task/task-lifecycle-runner.js.map +1 -1
  315. package/dist/orchestrator/execution/task/task-lifecycle.d.ts +2 -1
  316. package/dist/orchestrator/execution/task/task-lifecycle.d.ts.map +1 -1
  317. package/dist/orchestrator/execution/task/task-lifecycle.js +20 -14
  318. package/dist/orchestrator/execution/task/task-lifecycle.js.map +1 -1
  319. package/dist/orchestrator/execution/task/task-prompt-builder.d.ts.map +1 -1
  320. package/dist/orchestrator/execution/task/task-prompt-builder.js +9 -0
  321. package/dist/orchestrator/execution/task/task-prompt-builder.js.map +1 -1
  322. package/dist/orchestrator/execution/task/task-verifier-rules.d.ts +3 -1
  323. package/dist/orchestrator/execution/task/task-verifier-rules.d.ts.map +1 -1
  324. package/dist/orchestrator/execution/task/task-verifier-rules.js +37 -33
  325. package/dist/orchestrator/execution/task/task-verifier-rules.js.map +1 -1
  326. package/dist/orchestrator/execution/task/task-verifier.d.ts.map +1 -1
  327. package/dist/orchestrator/execution/task/task-verifier.js +10 -2
  328. package/dist/orchestrator/execution/task/task-verifier.js.map +1 -1
  329. package/dist/orchestrator/execution/task/task-workspace.d.ts +8 -0
  330. package/dist/orchestrator/execution/task/task-workspace.d.ts.map +1 -0
  331. package/dist/orchestrator/execution/task/task-workspace.js +22 -0
  332. package/dist/orchestrator/execution/task/task-workspace.js.map +1 -0
  333. package/dist/orchestrator/execution/types/task-group.d.ts +73 -9
  334. package/dist/orchestrator/execution/types/task-group.d.ts.map +1 -1
  335. package/dist/orchestrator/execution/types/task.d.ts +103 -5
  336. package/dist/orchestrator/execution/types/task.d.ts.map +1 -1
  337. package/dist/orchestrator/execution/types/task.js +10 -0
  338. package/dist/orchestrator/execution/types/task.js.map +1 -1
  339. package/dist/orchestrator/goal/goal-decomposer.d.ts.map +1 -1
  340. package/dist/orchestrator/goal/goal-decomposer.js +2 -1
  341. package/dist/orchestrator/goal/goal-decomposer.js.map +1 -1
  342. package/dist/orchestrator/goal/goal-negotiator.d.ts.map +1 -1
  343. package/dist/orchestrator/goal/goal-negotiator.js +5 -2
  344. package/dist/orchestrator/goal/goal-negotiator.js.map +1 -1
  345. package/dist/orchestrator/goal/goal-suggest.d.ts +6 -6
  346. package/dist/orchestrator/goal/goal-validation.d.ts +4 -5
  347. package/dist/orchestrator/goal/goal-validation.d.ts.map +1 -1
  348. package/dist/orchestrator/goal/goal-validation.js +11 -17
  349. package/dist/orchestrator/goal/goal-validation.js.map +1 -1
  350. package/dist/orchestrator/goal/negotiator-prompts.d.ts.map +1 -1
  351. package/dist/orchestrator/goal/negotiator-prompts.js +8 -4
  352. package/dist/orchestrator/goal/negotiator-prompts.js.map +1 -1
  353. package/dist/orchestrator/goal/negotiator-steps.d.ts.map +1 -1
  354. package/dist/orchestrator/goal/negotiator-steps.js +7 -11
  355. package/dist/orchestrator/goal/negotiator-steps.js.map +1 -1
  356. package/dist/orchestrator/goal/types/goal-refiner.d.ts +6 -6
  357. package/dist/orchestrator/goal/types/goal.d.ts +167 -6
  358. package/dist/orchestrator/goal/types/goal.d.ts.map +1 -1
  359. package/dist/orchestrator/goal/types/goal.js +8 -0
  360. package/dist/orchestrator/goal/types/goal.js.map +1 -1
  361. package/dist/orchestrator/goal/types/negotiation.d.ts +120 -6
  362. package/dist/orchestrator/goal/types/negotiation.d.ts.map +1 -1
  363. package/dist/orchestrator/goal/types/negotiation.js +3 -0
  364. package/dist/orchestrator/goal/types/negotiation.js.map +1 -1
  365. package/dist/orchestrator/goal/types/suggest.d.ts +6 -6
  366. package/dist/orchestrator/loop/checkpoint-manager-loop.d.ts +1 -1
  367. package/dist/orchestrator/loop/checkpoint-manager-loop.d.ts.map +1 -1
  368. package/dist/orchestrator/loop/core-loop/capability.d.ts +1 -21
  369. package/dist/orchestrator/loop/core-loop/capability.d.ts.map +1 -1
  370. package/dist/orchestrator/loop/core-loop/capability.js +1 -150
  371. package/dist/orchestrator/loop/core-loop/capability.js.map +1 -1
  372. package/dist/orchestrator/loop/core-loop/contracts.d.ts +1 -318
  373. package/dist/orchestrator/loop/core-loop/contracts.d.ts.map +1 -1
  374. package/dist/orchestrator/loop/core-loop/contracts.js +1 -39
  375. package/dist/orchestrator/loop/core-loop/contracts.js.map +1 -1
  376. package/dist/orchestrator/loop/core-loop/control.d.ts +1 -26
  377. package/dist/orchestrator/loop/core-loop/control.d.ts.map +1 -1
  378. package/dist/orchestrator/loop/core-loop/control.js +1 -71
  379. package/dist/orchestrator/loop/core-loop/control.js.map +1 -1
  380. package/dist/orchestrator/loop/core-loop/decision-engine.d.ts +1 -78
  381. package/dist/orchestrator/loop/core-loop/decision-engine.d.ts.map +1 -1
  382. package/dist/orchestrator/loop/core-loop/decision-engine.js +1 -144
  383. package/dist/orchestrator/loop/core-loop/decision-engine.js.map +1 -1
  384. package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.d.ts +1 -47
  385. package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.d.ts.map +1 -1
  386. package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.js +1 -385
  387. package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.js.map +1 -1
  388. package/dist/orchestrator/loop/core-loop/evidence-ledger.d.ts +1 -21
  389. package/dist/orchestrator/loop/core-loop/evidence-ledger.d.ts.map +1 -1
  390. package/dist/orchestrator/loop/core-loop/evidence-ledger.js +1 -35
  391. package/dist/orchestrator/loop/core-loop/evidence-ledger.js.map +1 -1
  392. package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.d.ts +1 -6
  393. package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.d.ts.map +1 -1
  394. package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.js +1 -42
  395. package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.js.map +1 -1
  396. package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.d.ts +1 -13
  397. package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.d.ts.map +1 -1
  398. package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.js +1 -40
  399. package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.js.map +1 -1
  400. package/dist/orchestrator/loop/core-loop/iteration-kernel.d.ts +1 -36
  401. package/dist/orchestrator/loop/core-loop/iteration-kernel.d.ts.map +1 -1
  402. package/dist/orchestrator/loop/core-loop/iteration-kernel.js +1 -834
  403. package/dist/orchestrator/loop/core-loop/iteration-kernel.js.map +1 -1
  404. package/dist/orchestrator/loop/core-loop/learning.d.ts +1 -30
  405. package/dist/orchestrator/loop/core-loop/learning.d.ts.map +1 -1
  406. package/dist/orchestrator/loop/core-loop/learning.js +1 -91
  407. package/dist/orchestrator/loop/core-loop/learning.js.map +1 -1
  408. package/dist/orchestrator/loop/core-loop/phase-policy.d.ts +1 -19
  409. package/dist/orchestrator/loop/core-loop/phase-policy.d.ts.map +1 -1
  410. package/dist/orchestrator/loop/core-loop/phase-policy.js +1 -157
  411. package/dist/orchestrator/loop/core-loop/phase-policy.js.map +1 -1
  412. package/dist/orchestrator/loop/core-loop/phase-runtime.d.ts +1 -30
  413. package/dist/orchestrator/loop/core-loop/phase-runtime.d.ts.map +1 -1
  414. package/dist/orchestrator/loop/core-loop/phase-runtime.js +1 -102
  415. package/dist/orchestrator/loop/core-loop/phase-runtime.js.map +1 -1
  416. package/dist/orchestrator/loop/core-loop/phase-specs.d.ts +1 -1268
  417. package/dist/orchestrator/loop/core-loop/phase-specs.d.ts.map +1 -1
  418. package/dist/orchestrator/loop/core-loop/phase-specs.js +1 -348
  419. package/dist/orchestrator/loop/core-loop/phase-specs.js.map +1 -1
  420. package/dist/orchestrator/loop/core-loop/preparation.d.ts +1 -58
  421. package/dist/orchestrator/loop/core-loop/preparation.d.ts.map +1 -1
  422. package/dist/orchestrator/loop/core-loop/preparation.js +1 -367
  423. package/dist/orchestrator/loop/core-loop/preparation.js.map +1 -1
  424. package/dist/orchestrator/loop/core-loop/public-research.d.ts +1 -31
  425. package/dist/orchestrator/loop/core-loop/public-research.d.ts.map +1 -1
  426. package/dist/orchestrator/loop/core-loop/public-research.js +1 -111
  427. package/dist/orchestrator/loop/core-loop/public-research.js.map +1 -1
  428. package/dist/orchestrator/loop/core-loop/task-cycle-stall.d.ts +1 -8
  429. package/dist/orchestrator/loop/core-loop/task-cycle-stall.d.ts.map +1 -1
  430. package/dist/orchestrator/loop/core-loop/task-cycle-stall.js +1 -432
  431. package/dist/orchestrator/loop/core-loop/task-cycle-stall.js.map +1 -1
  432. package/dist/orchestrator/loop/core-loop/task-cycle-wait.d.ts +1 -10
  433. package/dist/orchestrator/loop/core-loop/task-cycle-wait.d.ts.map +1 -1
  434. package/dist/orchestrator/loop/core-loop/task-cycle-wait.js +1 -175
  435. package/dist/orchestrator/loop/core-loop/task-cycle-wait.js.map +1 -1
  436. package/dist/orchestrator/loop/core-loop/task-cycle.d.ts +1 -40
  437. package/dist/orchestrator/loop/core-loop/task-cycle.d.ts.map +1 -1
  438. package/dist/orchestrator/loop/core-loop/task-cycle.js +1 -429
  439. package/dist/orchestrator/loop/core-loop/task-cycle.js.map +1 -1
  440. package/dist/orchestrator/loop/core-loop.d.ts +1 -85
  441. package/dist/orchestrator/loop/core-loop.d.ts.map +1 -1
  442. package/dist/orchestrator/loop/core-loop.js +3 -625
  443. package/dist/orchestrator/loop/core-loop.js.map +1 -1
  444. package/dist/orchestrator/loop/durable-loop/capability.d.ts +22 -0
  445. package/dist/orchestrator/loop/durable-loop/capability.d.ts.map +1 -0
  446. package/dist/orchestrator/loop/durable-loop/capability.js +151 -0
  447. package/dist/orchestrator/loop/durable-loop/capability.js.map +1 -0
  448. package/dist/orchestrator/loop/durable-loop/contracts.d.ts +319 -0
  449. package/dist/orchestrator/loop/durable-loop/contracts.d.ts.map +1 -0
  450. package/dist/orchestrator/loop/durable-loop/contracts.js +40 -0
  451. package/dist/orchestrator/loop/durable-loop/contracts.js.map +1 -0
  452. package/dist/orchestrator/loop/durable-loop/control.d.ts +27 -0
  453. package/dist/orchestrator/loop/durable-loop/control.d.ts.map +1 -0
  454. package/dist/orchestrator/loop/durable-loop/control.js +72 -0
  455. package/dist/orchestrator/loop/durable-loop/control.js.map +1 -0
  456. package/dist/orchestrator/loop/durable-loop/decision-engine.d.ts +79 -0
  457. package/dist/orchestrator/loop/durable-loop/decision-engine.d.ts.map +1 -0
  458. package/dist/orchestrator/loop/durable-loop/decision-engine.js +145 -0
  459. package/dist/orchestrator/loop/durable-loop/decision-engine.js.map +1 -0
  460. package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.d.ts +48 -0
  461. package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.d.ts.map +1 -0
  462. package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.js +386 -0
  463. package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.js.map +1 -0
  464. package/dist/orchestrator/loop/durable-loop/evidence-ledger.d.ts +22 -0
  465. package/dist/orchestrator/loop/durable-loop/evidence-ledger.d.ts.map +1 -0
  466. package/dist/orchestrator/loop/durable-loop/evidence-ledger.js +36 -0
  467. package/dist/orchestrator/loop/durable-loop/evidence-ledger.js.map +1 -0
  468. package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.d.ts +7 -0
  469. package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.d.ts.map +1 -0
  470. package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.js +43 -0
  471. package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.js.map +1 -0
  472. package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.d.ts +14 -0
  473. package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.d.ts.map +1 -0
  474. package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.js +41 -0
  475. package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.js.map +1 -0
  476. package/dist/orchestrator/loop/durable-loop/iteration-kernel.d.ts +38 -0
  477. package/dist/orchestrator/loop/durable-loop/iteration-kernel.d.ts.map +1 -0
  478. package/dist/orchestrator/loop/durable-loop/iteration-kernel.js +835 -0
  479. package/dist/orchestrator/loop/durable-loop/iteration-kernel.js.map +1 -0
  480. package/dist/orchestrator/loop/durable-loop/learning.d.ts +31 -0
  481. package/dist/orchestrator/loop/durable-loop/learning.d.ts.map +1 -0
  482. package/dist/orchestrator/loop/durable-loop/learning.js +92 -0
  483. package/dist/orchestrator/loop/durable-loop/learning.js.map +1 -0
  484. package/dist/orchestrator/loop/durable-loop/phase-policy.d.ts +20 -0
  485. package/dist/orchestrator/loop/durable-loop/phase-policy.d.ts.map +1 -0
  486. package/dist/orchestrator/loop/durable-loop/phase-policy.js +158 -0
  487. package/dist/orchestrator/loop/durable-loop/phase-policy.js.map +1 -0
  488. package/dist/orchestrator/loop/durable-loop/phase-runtime.d.ts +31 -0
  489. package/dist/orchestrator/loop/durable-loop/phase-runtime.d.ts.map +1 -0
  490. package/dist/orchestrator/loop/durable-loop/phase-runtime.js +103 -0
  491. package/dist/orchestrator/loop/durable-loop/phase-runtime.js.map +1 -0
  492. package/dist/orchestrator/loop/durable-loop/phase-specs.d.ts +1269 -0
  493. package/dist/orchestrator/loop/durable-loop/phase-specs.d.ts.map +1 -0
  494. package/dist/orchestrator/loop/durable-loop/phase-specs.js +349 -0
  495. package/dist/orchestrator/loop/durable-loop/phase-specs.js.map +1 -0
  496. package/dist/orchestrator/loop/durable-loop/preparation.d.ts +59 -0
  497. package/dist/orchestrator/loop/durable-loop/preparation.d.ts.map +1 -0
  498. package/dist/orchestrator/loop/durable-loop/preparation.js +368 -0
  499. package/dist/orchestrator/loop/durable-loop/preparation.js.map +1 -0
  500. package/dist/orchestrator/loop/durable-loop/public-research.d.ts +32 -0
  501. package/dist/orchestrator/loop/durable-loop/public-research.d.ts.map +1 -0
  502. package/dist/orchestrator/loop/durable-loop/public-research.js +112 -0
  503. package/dist/orchestrator/loop/durable-loop/public-research.js.map +1 -0
  504. package/dist/orchestrator/loop/durable-loop/task-cycle-stall.d.ts +9 -0
  505. package/dist/orchestrator/loop/durable-loop/task-cycle-stall.d.ts.map +1 -0
  506. package/dist/orchestrator/loop/durable-loop/task-cycle-stall.js +464 -0
  507. package/dist/orchestrator/loop/durable-loop/task-cycle-stall.js.map +1 -0
  508. package/dist/orchestrator/loop/durable-loop/task-cycle-wait.d.ts +11 -0
  509. package/dist/orchestrator/loop/durable-loop/task-cycle-wait.d.ts.map +1 -0
  510. package/dist/orchestrator/loop/durable-loop/task-cycle-wait.js +176 -0
  511. package/dist/orchestrator/loop/durable-loop/task-cycle-wait.js.map +1 -0
  512. package/dist/orchestrator/loop/durable-loop/task-cycle.d.ts +42 -0
  513. package/dist/orchestrator/loop/durable-loop/task-cycle.d.ts.map +1 -0
  514. package/dist/orchestrator/loop/durable-loop/task-cycle.js +430 -0
  515. package/dist/orchestrator/loop/durable-loop/task-cycle.js.map +1 -0
  516. package/dist/orchestrator/loop/durable-loop.d.ts +93 -0
  517. package/dist/orchestrator/loop/durable-loop.d.ts.map +1 -0
  518. package/dist/orchestrator/loop/durable-loop.js +651 -0
  519. package/dist/orchestrator/loop/durable-loop.js.map +1 -0
  520. package/dist/orchestrator/loop/loop-report-helper.d.ts +1 -1
  521. package/dist/orchestrator/loop/loop-report-helper.d.ts.map +1 -1
  522. package/dist/orchestrator/loop/loop-result-types.d.ts +1 -1
  523. package/dist/orchestrator/loop/loop-result-types.d.ts.map +1 -1
  524. package/dist/orchestrator/loop/parallel-dispatch.d.ts +2 -2
  525. package/dist/orchestrator/loop/parallel-dispatch.d.ts.map +1 -1
  526. package/dist/orchestrator/loop/post-loop-hooks.d.ts +1 -1
  527. package/dist/orchestrator/loop/post-loop-hooks.d.ts.map +1 -1
  528. package/dist/orchestrator/loop/run-policy.d.ts +1 -1
  529. package/dist/orchestrator/loop/run-policy.d.ts.map +1 -1
  530. package/dist/orchestrator/loop/tree-loop-runner.d.ts +1 -1
  531. package/dist/orchestrator/loop/tree-loop-runner.d.ts.map +1 -1
  532. package/dist/orchestrator/loop/tree-loop-runner.js +1 -1
  533. package/dist/orchestrator/loop/tree-loop-runner.js.map +1 -1
  534. package/dist/orchestrator/strategy/divergent-exploration.d.ts +2 -1
  535. package/dist/orchestrator/strategy/divergent-exploration.d.ts.map +1 -1
  536. package/dist/orchestrator/strategy/divergent-exploration.js +119 -36
  537. package/dist/orchestrator/strategy/divergent-exploration.js.map +1 -1
  538. package/dist/orchestrator/strategy/strategy-helpers.d.ts +86 -4
  539. package/dist/orchestrator/strategy/strategy-helpers.d.ts.map +1 -1
  540. package/dist/orchestrator/strategy/strategy-manager-base.d.ts +6 -2
  541. package/dist/orchestrator/strategy/strategy-manager-base.d.ts.map +1 -1
  542. package/dist/orchestrator/strategy/strategy-manager-base.js +71 -18
  543. package/dist/orchestrator/strategy/strategy-manager-base.js.map +1 -1
  544. package/dist/orchestrator/strategy/types/strategy.d.ts +450 -14
  545. package/dist/orchestrator/strategy/types/strategy.d.ts.map +1 -1
  546. package/dist/orchestrator/strategy/types/strategy.js +30 -0
  547. package/dist/orchestrator/strategy/types/strategy.js.map +1 -1
  548. package/dist/platform/code-search/contracts.d.ts +3 -0
  549. package/dist/platform/code-search/contracts.d.ts.map +1 -1
  550. package/dist/platform/code-search/contracts.js.map +1 -1
  551. package/dist/platform/code-search/indexes/indexer.d.ts.map +1 -1
  552. package/dist/platform/code-search/indexes/indexer.js +3 -0
  553. package/dist/platform/code-search/indexes/indexer.js.map +1 -1
  554. package/dist/platform/code-search/indexes/semantic-index.d.ts.map +1 -1
  555. package/dist/platform/code-search/indexes/semantic-index.js +3 -0
  556. package/dist/platform/code-search/indexes/semantic-index.js.map +1 -1
  557. package/dist/platform/code-search/orchestrator.d.ts.map +1 -1
  558. package/dist/platform/code-search/orchestrator.js +14 -3
  559. package/dist/platform/code-search/orchestrator.js.map +1 -1
  560. package/dist/platform/code-search/query-planner.d.ts.map +1 -1
  561. package/dist/platform/code-search/query-planner.js +1 -17
  562. package/dist/platform/code-search/query-planner.js.map +1 -1
  563. package/dist/platform/code-search/reranker.d.ts +5 -1
  564. package/dist/platform/code-search/reranker.d.ts.map +1 -1
  565. package/dist/platform/code-search/reranker.js +9 -5
  566. package/dist/platform/code-search/reranker.js.map +1 -1
  567. package/dist/platform/corrections/memory-correction-ledger.d.ts +30 -30
  568. package/dist/platform/dream/dream-activation.d.ts +161 -1
  569. package/dist/platform/dream/dream-activation.d.ts.map +1 -1
  570. package/dist/platform/dream/dream-activation.js +63 -14
  571. package/dist/platform/dream/dream-activation.js.map +1 -1
  572. package/dist/platform/dream/dream-event-workflows.d.ts +2 -2
  573. package/dist/platform/dream/dream-types.d.ts +52 -52
  574. package/dist/platform/dream/playbook-memory.d.ts +3 -3
  575. package/dist/platform/drive/stall-detector/repetitive.d.ts.map +1 -1
  576. package/dist/platform/drive/stall-detector/repetitive.js +50 -5
  577. package/dist/platform/drive/stall-detector/repetitive.js.map +1 -1
  578. package/dist/platform/drive/stall-detector.d.ts +19 -0
  579. package/dist/platform/drive/stall-detector.d.ts.map +1 -1
  580. package/dist/platform/drive/stall-detector.js.map +1 -1
  581. package/dist/platform/drive/types/stall.d.ts +1 -1
  582. package/dist/platform/knowledge/memory/memory-selection.d.ts.map +1 -1
  583. package/dist/platform/knowledge/memory/memory-selection.js +24 -18
  584. package/dist/platform/knowledge/memory/memory-selection.js.map +1 -1
  585. package/dist/platform/knowledge/transfer/knowledge-transfer-apply.d.ts.map +1 -1
  586. package/dist/platform/knowledge/transfer/knowledge-transfer-apply.js +7 -3
  587. package/dist/platform/knowledge/transfer/knowledge-transfer-apply.js.map +1 -1
  588. package/dist/platform/knowledge/types/agent-memory.d.ts +46 -46
  589. package/dist/platform/knowledge/types/embedding.d.ts +4 -4
  590. package/dist/platform/knowledge/types/knowledge.d.ts +53 -0
  591. package/dist/platform/knowledge/types/knowledge.d.ts.map +1 -1
  592. package/dist/platform/knowledge/types/knowledge.js +15 -0
  593. package/dist/platform/knowledge/types/knowledge.js.map +1 -1
  594. package/dist/platform/knowledge/types/memory-lifecycle.d.ts +2 -2
  595. package/dist/platform/observation/capability-detector/types.d.ts +4 -4
  596. package/dist/platform/observation/context-provider/collector.d.ts +2 -0
  597. package/dist/platform/observation/context-provider/collector.d.ts.map +1 -1
  598. package/dist/platform/observation/context-provider/collector.js +27 -2
  599. package/dist/platform/observation/context-provider/collector.js.map +1 -1
  600. package/dist/platform/observation/context-provider.d.ts +4 -0
  601. package/dist/platform/observation/context-provider.d.ts.map +1 -1
  602. package/dist/platform/observation/context-provider.js.map +1 -1
  603. package/dist/platform/observation/engine/observe-datasource-stage.d.ts +3 -2
  604. package/dist/platform/observation/engine/observe-datasource-stage.d.ts.map +1 -1
  605. package/dist/platform/observation/engine/observe-datasource-stage.js +2 -2
  606. package/dist/platform/observation/engine/observe-datasource-stage.js.map +1 -1
  607. package/dist/platform/observation/observation-apply.d.ts +1 -1
  608. package/dist/platform/observation/observation-apply.d.ts.map +1 -1
  609. package/dist/platform/observation/observation-apply.js +3 -3
  610. package/dist/platform/observation/observation-apply.js.map +1 -1
  611. package/dist/platform/observation/observation-datasource.d.ts +2 -2
  612. package/dist/platform/observation/observation-datasource.d.ts.map +1 -1
  613. package/dist/platform/observation/observation-datasource.js +13 -7
  614. package/dist/platform/observation/observation-datasource.js.map +1 -1
  615. package/dist/platform/observation/observation-engine.d.ts +1 -1
  616. package/dist/platform/observation/observation-engine.d.ts.map +1 -1
  617. package/dist/platform/observation/observation-engine.js +48 -7
  618. package/dist/platform/observation/observation-engine.js.map +1 -1
  619. package/dist/platform/observation/types/capability.d.ts +16 -16
  620. package/dist/platform/observation/types/data-source.d.ts +12 -0
  621. package/dist/platform/observation/types/data-source.d.ts.map +1 -1
  622. package/dist/platform/observation/types/data-source.js +1 -0
  623. package/dist/platform/observation/types/data-source.js.map +1 -1
  624. package/dist/platform/observation/workspace-context.d.ts +8 -1
  625. package/dist/platform/observation/workspace-context.d.ts.map +1 -1
  626. package/dist/platform/observation/workspace-context.js +35 -14
  627. package/dist/platform/observation/workspace-context.js.map +1 -1
  628. package/dist/platform/profile/profile-change-proposal.d.ts +20 -20
  629. package/dist/platform/profile/relationship-profile.d.ts +6 -6
  630. package/dist/platform/profile/user-md-profile-import.d.ts +2 -2
  631. package/dist/platform/soil/contracts.d.ts +98 -98
  632. package/dist/platform/soil/types.d.ts +8 -8
  633. package/dist/platform/traits/curiosity-engine.d.ts +2 -5
  634. package/dist/platform/traits/curiosity-engine.d.ts.map +1 -1
  635. package/dist/platform/traits/curiosity-engine.js.map +1 -1
  636. package/dist/platform/traits/curiosity-proposals.d.ts +2 -0
  637. package/dist/platform/traits/curiosity-proposals.d.ts.map +1 -1
  638. package/dist/platform/traits/curiosity-proposals.js +36 -17
  639. package/dist/platform/traits/curiosity-proposals.js.map +1 -1
  640. package/dist/platform/traits/curiosity-transfer.d.ts +9 -5
  641. package/dist/platform/traits/curiosity-transfer.d.ts.map +1 -1
  642. package/dist/platform/traits/curiosity-transfer.js +4 -1
  643. package/dist/platform/traits/curiosity-transfer.js.map +1 -1
  644. package/dist/platform/traits/ethics-gate.d.ts +16 -17
  645. package/dist/platform/traits/ethics-gate.d.ts.map +1 -1
  646. package/dist/platform/traits/ethics-gate.js +83 -47
  647. package/dist/platform/traits/ethics-gate.js.map +1 -1
  648. package/dist/platform/traits/ethics-rules.d.ts +4 -6
  649. package/dist/platform/traits/ethics-rules.d.ts.map +1 -1
  650. package/dist/platform/traits/ethics-rules.js +19 -261
  651. package/dist/platform/traits/ethics-rules.js.map +1 -1
  652. package/dist/platform/traits/types/curiosity.d.ts +157 -10
  653. package/dist/platform/traits/types/curiosity.d.ts.map +1 -1
  654. package/dist/platform/traits/types/curiosity.js +10 -0
  655. package/dist/platform/traits/types/curiosity.js.map +1 -1
  656. package/dist/platform/traits/types/guardrail.d.ts +6 -6
  657. package/dist/prompt/purposes/curiosity.d.ts +4 -4
  658. package/dist/runtime/approval-broker.d.ts +33 -0
  659. package/dist/runtime/approval-broker.d.ts.map +1 -1
  660. package/dist/runtime/approval-broker.js +155 -17
  661. package/dist/runtime/approval-broker.js.map +1 -1
  662. package/dist/runtime/companion-policy.d.ts +27 -0
  663. package/dist/runtime/companion-policy.d.ts.map +1 -0
  664. package/dist/runtime/companion-policy.js +135 -0
  665. package/dist/runtime/companion-policy.js.map +1 -0
  666. package/dist/runtime/confirmation-decision.d.ts +2 -2
  667. package/dist/runtime/control/daemon-runtime-control-executor.d.ts +0 -6
  668. package/dist/runtime/control/daemon-runtime-control-executor.d.ts.map +1 -1
  669. package/dist/runtime/control/daemon-runtime-control-executor.js +1 -1
  670. package/dist/runtime/control/daemon-runtime-control-executor.js.map +1 -1
  671. package/dist/runtime/control/index.d.ts +6 -3
  672. package/dist/runtime/control/index.d.ts.map +1 -1
  673. package/dist/runtime/control/index.js +2 -1
  674. package/dist/runtime/control/index.js.map +1 -1
  675. package/dist/runtime/control/runtime-control-intent.d.ts +16 -1
  676. package/dist/runtime/control/runtime-control-intent.d.ts.map +1 -1
  677. package/dist/runtime/control/runtime-control-intent.js +26 -13
  678. package/dist/runtime/control/runtime-control-intent.js.map +1 -1
  679. package/dist/runtime/control/runtime-control-service.d.ts +1 -1
  680. package/dist/runtime/control/runtime-control-service.d.ts.map +1 -1
  681. package/dist/runtime/control/runtime-control-service.js +29 -64
  682. package/dist/runtime/control/runtime-control-service.js.map +1 -1
  683. package/dist/runtime/control/runtime-target-resolver.d.ts +39 -0
  684. package/dist/runtime/control/runtime-target-resolver.d.ts.map +1 -0
  685. package/dist/runtime/control/runtime-target-resolver.js +112 -0
  686. package/dist/runtime/control/runtime-target-resolver.js.map +1 -0
  687. package/dist/runtime/conversational-approval-decision.d.ts +29 -0
  688. package/dist/runtime/conversational-approval-decision.d.ts.map +1 -0
  689. package/dist/runtime/conversational-approval-decision.js +92 -0
  690. package/dist/runtime/conversational-approval-decision.js.map +1 -0
  691. package/dist/runtime/daemon/client.d.ts +1 -4
  692. package/dist/runtime/daemon/client.d.ts.map +1 -1
  693. package/dist/runtime/daemon/client.js +0 -3
  694. package/dist/runtime/daemon/client.js.map +1 -1
  695. package/dist/runtime/daemon/control-contracts.d.ts +7 -0
  696. package/dist/runtime/daemon/control-contracts.d.ts.map +1 -0
  697. package/dist/runtime/daemon/control-contracts.js +2 -0
  698. package/dist/runtime/daemon/control-contracts.js.map +1 -0
  699. package/dist/runtime/daemon/runner-startup.js +1 -1
  700. package/dist/runtime/daemon/runner-startup.js.map +1 -1
  701. package/dist/runtime/daemon/runner.d.ts +1 -1
  702. package/dist/runtime/daemon/runner.d.ts.map +1 -1
  703. package/dist/runtime/executor/goal-worker.d.ts +9 -4
  704. package/dist/runtime/executor/goal-worker.d.ts.map +1 -1
  705. package/dist/runtime/executor/goal-worker.js +18 -1
  706. package/dist/runtime/executor/goal-worker.js.map +1 -1
  707. package/dist/runtime/executor/loop-supervisor.d.ts +3 -2
  708. package/dist/runtime/executor/loop-supervisor.d.ts.map +1 -1
  709. package/dist/runtime/executor/loop-supervisor.js +60 -8
  710. package/dist/runtime/executor/loop-supervisor.js.map +1 -1
  711. package/dist/runtime/gateway/channel-adapter.d.ts +19 -0
  712. package/dist/runtime/gateway/channel-adapter.d.ts.map +1 -1
  713. package/dist/runtime/gateway/channel-policy.d.ts +1 -0
  714. package/dist/runtime/gateway/channel-policy.d.ts.map +1 -1
  715. package/dist/runtime/gateway/channel-policy.js +6 -4
  716. package/dist/runtime/gateway/channel-policy.js.map +1 -1
  717. package/dist/runtime/gateway/chat-event-rendering.d.ts +34 -0
  718. package/dist/runtime/gateway/chat-event-rendering.d.ts.map +1 -0
  719. package/dist/runtime/gateway/chat-event-rendering.js +61 -0
  720. package/dist/runtime/gateway/chat-event-rendering.js.map +1 -0
  721. package/dist/runtime/gateway/chat-session-dispatch.d.ts +2 -13
  722. package/dist/runtime/gateway/chat-session-dispatch.d.ts.map +1 -1
  723. package/dist/runtime/gateway/chat-session-dispatch.js +6 -3
  724. package/dist/runtime/gateway/chat-session-dispatch.js.map +1 -1
  725. package/dist/runtime/gateway/chat-session-port.d.ts +25 -0
  726. package/dist/runtime/gateway/chat-session-port.d.ts.map +1 -0
  727. package/dist/runtime/gateway/chat-session-port.js +20 -0
  728. package/dist/runtime/gateway/chat-session-port.js.map +1 -0
  729. package/dist/runtime/gateway/discord-gateway-adapter.d.ts +3 -1
  730. package/dist/runtime/gateway/discord-gateway-adapter.d.ts.map +1 -1
  731. package/dist/runtime/gateway/discord-gateway-adapter.js +34 -2
  732. package/dist/runtime/gateway/discord-gateway-adapter.js.map +1 -1
  733. package/dist/runtime/gateway/index.d.ts +2 -0
  734. package/dist/runtime/gateway/index.d.ts.map +1 -1
  735. package/dist/runtime/gateway/index.js +1 -0
  736. package/dist/runtime/gateway/index.js.map +1 -1
  737. package/dist/runtime/gateway/ingress-gateway.d.ts.map +1 -1
  738. package/dist/runtime/gateway/ingress-gateway.js +1 -0
  739. package/dist/runtime/gateway/ingress-gateway.js.map +1 -1
  740. package/dist/runtime/gateway/signal-gateway-adapter.d.ts +2 -1
  741. package/dist/runtime/gateway/signal-gateway-adapter.d.ts.map +1 -1
  742. package/dist/runtime/gateway/signal-gateway-adapter.js +13 -3
  743. package/dist/runtime/gateway/signal-gateway-adapter.js.map +1 -1
  744. package/dist/runtime/gateway/slack-channel-adapter.d.ts +2 -1
  745. package/dist/runtime/gateway/slack-channel-adapter.d.ts.map +1 -1
  746. package/dist/runtime/gateway/slack-channel-adapter.js +6 -2
  747. package/dist/runtime/gateway/slack-channel-adapter.js.map +1 -1
  748. package/dist/runtime/gateway/telegram-gateway-adapter.d.ts +9 -2
  749. package/dist/runtime/gateway/telegram-gateway-adapter.d.ts.map +1 -1
  750. package/dist/runtime/gateway/telegram-gateway-adapter.js +141 -13
  751. package/dist/runtime/gateway/telegram-gateway-adapter.js.map +1 -1
  752. package/dist/runtime/gateway/typing-indicator.d.ts +11 -0
  753. package/dist/runtime/gateway/typing-indicator.d.ts.map +1 -0
  754. package/dist/runtime/gateway/typing-indicator.js +68 -0
  755. package/dist/runtime/gateway/typing-indicator.js.map +1 -0
  756. package/dist/runtime/gateway/whatsapp-gateway-adapter.d.ts +2 -1
  757. package/dist/runtime/gateway/whatsapp-gateway-adapter.d.ts.map +1 -1
  758. package/dist/runtime/gateway/whatsapp-gateway-adapter.js +22 -8
  759. package/dist/runtime/gateway/whatsapp-gateway-adapter.js.map +1 -1
  760. package/dist/runtime/gateway/ws-channel-adapter.d.ts.map +1 -1
  761. package/dist/runtime/gateway/ws-channel-adapter.js +1 -0
  762. package/dist/runtime/gateway/ws-channel-adapter.js.map +1 -1
  763. package/dist/runtime/interactive-automation/failure-classifier.d.ts +0 -1
  764. package/dist/runtime/interactive-automation/failure-classifier.d.ts.map +1 -1
  765. package/dist/runtime/interactive-automation/failure-classifier.js +0 -19
  766. package/dist/runtime/interactive-automation/failure-classifier.js.map +1 -1
  767. package/dist/runtime/interactive-automation/providers/manus-browser.d.ts.map +1 -1
  768. package/dist/runtime/interactive-automation/providers/manus-browser.js +30 -1
  769. package/dist/runtime/interactive-automation/providers/manus-browser.js.map +1 -1
  770. package/dist/runtime/logger.d.ts.map +1 -1
  771. package/dist/runtime/logger.js +5 -2
  772. package/dist/runtime/logger.js.map +1 -1
  773. package/dist/runtime/plugin-loader.js +2 -2
  774. package/dist/runtime/plugin-loader.js.map +1 -1
  775. package/dist/runtime/run-spec/derive.d.ts +24 -24
  776. package/dist/runtime/run-spec/derive.d.ts.map +1 -1
  777. package/dist/runtime/run-spec/derive.js +6 -0
  778. package/dist/runtime/run-spec/derive.js.map +1 -1
  779. package/dist/runtime/run-spec/handoff.d.ts +74 -0
  780. package/dist/runtime/run-spec/handoff.d.ts.map +1 -0
  781. package/dist/runtime/run-spec/handoff.js +496 -0
  782. package/dist/runtime/run-spec/handoff.js.map +1 -0
  783. package/dist/runtime/run-spec/index.d.ts +2 -0
  784. package/dist/runtime/run-spec/index.d.ts.map +1 -1
  785. package/dist/runtime/run-spec/index.js +2 -0
  786. package/dist/runtime/run-spec/index.js.map +1 -1
  787. package/dist/runtime/run-spec/pending-dialogue-arbiter.d.ts +25 -0
  788. package/dist/runtime/run-spec/pending-dialogue-arbiter.d.ts.map +1 -0
  789. package/dist/runtime/run-spec/pending-dialogue-arbiter.js +81 -0
  790. package/dist/runtime/run-spec/pending-dialogue-arbiter.js.map +1 -0
  791. package/dist/runtime/run-spec/types.d.ts +91 -42
  792. package/dist/runtime/run-spec/types.d.ts.map +1 -1
  793. package/dist/runtime/run-spec/types.js +7 -0
  794. package/dist/runtime/run-spec/types.js.map +1 -1
  795. package/dist/runtime/schedule/engine-execution.js +2 -35
  796. package/dist/runtime/schedule/engine-execution.js.map +1 -1
  797. package/dist/runtime/schedule/history.d.ts +2 -2
  798. package/dist/runtime/schedule/presets.d.ts +4 -4
  799. package/dist/runtime/schedule/source.d.ts +1 -1
  800. package/dist/runtime/session-registry/registry.d.ts.map +1 -1
  801. package/dist/runtime/session-registry/registry.js +27 -2
  802. package/dist/runtime/session-registry/registry.js.map +1 -1
  803. package/dist/runtime/session-registry/types.d.ts +120 -112
  804. package/dist/runtime/session-registry/types.d.ts.map +1 -1
  805. package/dist/runtime/session-registry/types.js +1 -0
  806. package/dist/runtime/session-registry/types.js.map +1 -1
  807. package/dist/runtime/store/artifact-retention.d.ts +11 -6
  808. package/dist/runtime/store/artifact-retention.d.ts.map +1 -1
  809. package/dist/runtime/store/artifact-retention.js +0 -13
  810. package/dist/runtime/store/artifact-retention.js.map +1 -1
  811. package/dist/runtime/store/background-run-store.d.ts +1 -0
  812. package/dist/runtime/store/background-run-store.d.ts.map +1 -1
  813. package/dist/runtime/store/background-run-store.js +1 -0
  814. package/dist/runtime/store/background-run-store.js.map +1 -1
  815. package/dist/runtime/store/budget-store.d.ts +8 -8
  816. package/dist/runtime/store/dream-checkpoints.d.ts +1 -1
  817. package/dist/runtime/store/dream-checkpoints.d.ts.map +1 -1
  818. package/dist/runtime/store/evaluator-results.d.ts +1 -1
  819. package/dist/runtime/store/evaluator-results.d.ts.map +1 -1
  820. package/dist/runtime/store/evidence-ledger.d.ts +39 -6377
  821. package/dist/runtime/store/evidence-ledger.d.ts.map +1 -1
  822. package/dist/runtime/store/evidence-ledger.js +415 -501
  823. package/dist/runtime/store/evidence-ledger.js.map +1 -1
  824. package/dist/runtime/store/evidence-types.d.ts +6378 -0
  825. package/dist/runtime/store/evidence-types.d.ts.map +1 -0
  826. package/dist/runtime/store/evidence-types.js +459 -0
  827. package/dist/runtime/store/evidence-types.js.map +1 -0
  828. package/dist/runtime/store/experiment-queue-store.d.ts +109 -109
  829. package/dist/runtime/store/experiment-queue-store.d.ts.map +1 -1
  830. package/dist/runtime/store/experiment-queue-store.js +1 -1
  831. package/dist/runtime/store/experiment-queue-store.js.map +1 -1
  832. package/dist/runtime/store/index.d.ts +4 -4
  833. package/dist/runtime/store/index.d.ts.map +1 -1
  834. package/dist/runtime/store/index.js +2 -2
  835. package/dist/runtime/store/index.js.map +1 -1
  836. package/dist/runtime/store/metric-history.d.ts +1 -1
  837. package/dist/runtime/store/metric-history.d.ts.map +1 -1
  838. package/dist/runtime/store/operator-handoff-store.d.ts +12 -12
  839. package/dist/runtime/store/postmortem-report.d.ts +40 -40
  840. package/dist/runtime/store/postmortem-report.js.map +1 -1
  841. package/dist/runtime/store/proactive-intervention-store.d.ts +8 -8
  842. package/dist/runtime/store/reproducibility-manifest.d.ts +27 -27
  843. package/dist/runtime/store/reproducibility-manifest.d.ts.map +1 -1
  844. package/dist/runtime/store/reproducibility-manifest.js.map +1 -1
  845. package/dist/runtime/store/research-evidence.d.ts +1 -1
  846. package/dist/runtime/store/research-evidence.d.ts.map +1 -1
  847. package/dist/runtime/store/runtime-operation-schemas.d.ts +46 -46
  848. package/dist/runtime/store/runtime-schemas.d.ts +73 -12
  849. package/dist/runtime/store/runtime-schemas.d.ts.map +1 -1
  850. package/dist/runtime/store/runtime-schemas.js +9 -0
  851. package/dist/runtime/store/runtime-schemas.js.map +1 -1
  852. package/dist/runtime/types/companion.d.ts +394 -0
  853. package/dist/runtime/types/companion.d.ts.map +1 -0
  854. package/dist/runtime/types/companion.js +87 -0
  855. package/dist/runtime/types/companion.js.map +1 -0
  856. package/dist/runtime/types/daemon.d.ts +3 -3
  857. package/dist/runtime/types/hook.d.ts +12 -12
  858. package/dist/runtime/types/schedule.d.ts +32 -32
  859. package/dist/tools/builtin/exports.d.ts +2 -0
  860. package/dist/tools/builtin/exports.d.ts.map +1 -1
  861. package/dist/tools/builtin/exports.js +2 -0
  862. package/dist/tools/builtin/exports.js.map +1 -1
  863. package/dist/tools/builtin/factory.d.ts +10 -1
  864. package/dist/tools/builtin/factory.d.ts.map +1 -1
  865. package/dist/tools/builtin/factory.js +18 -1
  866. package/dist/tools/builtin/factory.js.map +1 -1
  867. package/dist/tools/executor.d.ts.map +1 -1
  868. package/dist/tools/executor.js +8 -6
  869. package/dist/tools/executor.js.map +1 -1
  870. package/dist/tools/fs/ApplyPatchTool/ApplyPatchTool.d.ts.map +1 -1
  871. package/dist/tools/fs/ApplyPatchTool/ApplyPatchTool.js +1 -0
  872. package/dist/tools/fs/ApplyPatchTool/ApplyPatchTool.js.map +1 -1
  873. package/dist/tools/fs/FileEditTool/FileEditTool.d.ts.map +1 -1
  874. package/dist/tools/fs/FileEditTool/FileEditTool.js +1 -0
  875. package/dist/tools/fs/FileEditTool/FileEditTool.js.map +1 -1
  876. package/dist/tools/fs/FileWriteTool/FileWriteTool.d.ts.map +1 -1
  877. package/dist/tools/fs/FileWriteTool/FileWriteTool.js +1 -0
  878. package/dist/tools/fs/FileWriteTool/FileWriteTool.js.map +1 -1
  879. package/dist/tools/fs/GlobTool/GlobTool.d.ts.map +1 -1
  880. package/dist/tools/fs/GlobTool/GlobTool.js +1 -0
  881. package/dist/tools/fs/GlobTool/GlobTool.js.map +1 -1
  882. package/dist/tools/fs/GrepTool/GrepTool.d.ts.map +1 -1
  883. package/dist/tools/fs/GrepTool/GrepTool.js +1 -0
  884. package/dist/tools/fs/GrepTool/GrepTool.js.map +1 -1
  885. package/dist/tools/fs/JsonQueryTool/JsonQueryTool.d.ts.map +1 -1
  886. package/dist/tools/fs/JsonQueryTool/JsonQueryTool.js +1 -0
  887. package/dist/tools/fs/JsonQueryTool/JsonQueryTool.js.map +1 -1
  888. package/dist/tools/fs/ListDirTool/ListDirTool.d.ts.map +1 -1
  889. package/dist/tools/fs/ListDirTool/ListDirTool.js +1 -0
  890. package/dist/tools/fs/ListDirTool/ListDirTool.js.map +1 -1
  891. package/dist/tools/fs/ReadTool/ReadTool.d.ts.map +1 -1
  892. package/dist/tools/fs/ReadTool/ReadTool.js +1 -0
  893. package/dist/tools/fs/ReadTool/ReadTool.js.map +1 -1
  894. package/dist/tools/kaggle/KaggleSubmissionTools.d.ts +4 -4
  895. package/dist/tools/kaggle/metrics.d.ts +4 -4
  896. package/dist/tools/mutation/TaskCreateTool/TaskCreateTool.d.ts +4 -4
  897. package/dist/tools/mutation/TaskUpdateTool/TaskUpdateTool.d.ts +10 -10
  898. package/dist/tools/network/GitHubCliTool/GitHubCliTool.d.ts +8 -8
  899. package/dist/tools/network/HttpFetchTool/HttpFetchTool.d.ts.map +1 -1
  900. package/dist/tools/network/HttpFetchTool/HttpFetchTool.js +1 -0
  901. package/dist/tools/network/HttpFetchTool/HttpFetchTool.js.map +1 -1
  902. package/dist/tools/network/WebSearchTool/WebSearchTool.d.ts.map +1 -1
  903. package/dist/tools/network/WebSearchTool/WebSearchTool.js +1 -0
  904. package/dist/tools/network/WebSearchTool/WebSearchTool.js.map +1 -1
  905. package/dist/tools/query/ArchitectureTool/ArchitectureTool.js +3 -3
  906. package/dist/tools/query/ArchitectureTool/ArchitectureTool.js.map +1 -1
  907. package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.d.ts +20 -20
  908. package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.d.ts.map +1 -1
  909. package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.js +1 -0
  910. package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.js.map +1 -1
  911. package/dist/tools/query/CodeSearchRepairTool/CodeSearchRepairTool.d.ts.map +1 -1
  912. package/dist/tools/query/CodeSearchRepairTool/CodeSearchRepairTool.js +1 -0
  913. package/dist/tools/query/CodeSearchRepairTool/CodeSearchRepairTool.js.map +1 -1
  914. package/dist/tools/query/CodeSearchTool/CodeSearchTool.d.ts.map +1 -1
  915. package/dist/tools/query/CodeSearchTool/CodeSearchTool.js +1 -0
  916. package/dist/tools/query/CodeSearchTool/CodeSearchTool.js.map +1 -1
  917. package/dist/tools/query/ConfigTool/ConfigTool.d.ts.map +1 -1
  918. package/dist/tools/query/ConfigTool/ConfigTool.js +1 -0
  919. package/dist/tools/query/ConfigTool/ConfigTool.js.map +1 -1
  920. package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.d.ts.map +1 -1
  921. package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.js +1 -0
  922. package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.js.map +1 -1
  923. package/dist/tools/query/SkillSearchTool/SkillSearchTool.d.ts.map +1 -1
  924. package/dist/tools/query/SkillSearchTool/SkillSearchTool.js +1 -0
  925. package/dist/tools/query/SkillSearchTool/SkillSearchTool.js.map +1 -1
  926. package/dist/tools/query/ToolSearchTool/ToolSearchTool.d.ts.map +1 -1
  927. package/dist/tools/query/ToolSearchTool/ToolSearchTool.js +1 -0
  928. package/dist/tools/query/ToolSearchTool/ToolSearchTool.js.map +1 -1
  929. package/dist/tools/runtime/LongRunningRuntimeTools.d.ts +32 -32
  930. package/dist/tools/runtime/RunSpecHandoffTools.d.ts +12 -0
  931. package/dist/tools/runtime/RunSpecHandoffTools.d.ts.map +1 -0
  932. package/dist/tools/runtime/RunSpecHandoffTools.js +224 -0
  933. package/dist/tools/runtime/RunSpecHandoffTools.js.map +1 -0
  934. package/dist/tools/runtime/SetupRuntimeControlTools.d.ts +11 -0
  935. package/dist/tools/runtime/SetupRuntimeControlTools.d.ts.map +1 -0
  936. package/dist/tools/runtime/SetupRuntimeControlTools.js +463 -0
  937. package/dist/tools/runtime/SetupRuntimeControlTools.js.map +1 -0
  938. package/dist/tools/schedule/CreateScheduleTool/CreateScheduleTool.d.ts +28 -28
  939. package/dist/tools/schedule/UpdateScheduleTool/UpdateScheduleTool.d.ts +32 -32
  940. package/dist/tools/system/GitDiffTool/GitDiffTool.d.ts.map +1 -1
  941. package/dist/tools/system/GitDiffTool/GitDiffTool.js +1 -0
  942. package/dist/tools/system/GitDiffTool/GitDiffTool.js.map +1 -1
  943. package/dist/tools/system/GitLogTool/GitLogTool.d.ts.map +1 -1
  944. package/dist/tools/system/GitLogTool/GitLogTool.js +1 -0
  945. package/dist/tools/system/GitLogTool/GitLogTool.js.map +1 -1
  946. package/dist/tools/system/ShellTool/ShellTool.d.ts.map +1 -1
  947. package/dist/tools/system/ShellTool/ShellTool.js +2 -1
  948. package/dist/tools/system/ShellTool/ShellTool.js.map +1 -1
  949. package/dist/tools/system/TestRunnerTool/TestRunnerTool.d.ts.map +1 -1
  950. package/dist/tools/system/TestRunnerTool/TestRunnerTool.js +2 -1
  951. package/dist/tools/system/TestRunnerTool/TestRunnerTool.js.map +1 -1
  952. package/dist/tools/system/UpdatePlanTool/UpdatePlanTool.d.ts.map +1 -1
  953. package/dist/tools/system/UpdatePlanTool/UpdatePlanTool.js +1 -0
  954. package/dist/tools/system/UpdatePlanTool/UpdatePlanTool.js.map +1 -1
  955. package/dist/tools/types.d.ts +62 -2
  956. package/dist/tools/types.d.ts.map +1 -1
  957. package/dist/tools/types.js +25 -0
  958. package/dist/tools/types.js.map +1 -1
  959. package/package.json +1 -1
  960. package/dist/interface/tui/approval-overlay.d.ts +0 -8
  961. package/dist/interface/tui/approval-overlay.d.ts.map +0 -1
  962. package/dist/interface/tui/approval-overlay.js +0 -21
  963. package/dist/interface/tui/approval-overlay.js.map +0 -1
@@ -2,8 +2,10 @@ import { randomUUID } from "node:crypto";
2
2
  import * as path from "node:path";
3
3
  import { ChatRunner } from "./chat-runner.js";
4
4
  import { createIngressRouter, } from "./ingress-router.js";
5
- import { recognizeRuntimeControlIntent } from "../../runtime/control/index.js";
5
+ import { classifyRuntimeControlIntent } from "../../runtime/control/index.js";
6
6
  import { classifyFreeformRouteIntent } from "./freeform-route-classifier.js";
7
+ import { deriveRunSpecFromText } from "../../runtime/run-spec/index.js";
8
+ import { intakeSetupSecrets } from "./setup-secret-intake.js";
7
9
  import { StateManager } from "../../base/state/state-manager.js";
8
10
  import { buildAdapterRegistry, buildLLMClient } from "../../base/llm/provider-factory.js";
9
11
  import { loadProviderConfig } from "../../base/llm/provider-config.js";
@@ -20,7 +22,11 @@ import { buildCliDataSourceRegistry } from "../cli/data-source-bootstrap.js";
20
22
  import { ConcurrencyController, createBuiltinTools, ToolExecutor, ToolPermissionManager, ToolRegistry, } from "../../tools/index.js";
21
23
  import { createNativeChatAgentLoopRunner, createNativeReviewAgentLoopRunner, shouldUseNativeTaskAgentLoop, } from "../../orchestrator/execution/agent-loop/index.js";
22
24
  import { RuntimeControlService, createDaemonRuntimeControlExecutor, } from "../../runtime/control/index.js";
25
+ import { ApprovalBroker } from "../../runtime/approval-broker.js";
26
+ import { ApprovalStore, createRuntimeStorePaths } from "../../runtime/store/index.js";
27
+ import { classifyConversationalApprovalDecision } from "../../runtime/conversational-approval-decision.js";
23
28
  import { registerGlobalCrossPlatformChatSessionManager } from "./cross-platform-session-global.js";
29
+ import { buildCompanionRuntimeContract, evaluateCompanionOutputPolicy, } from "../../runtime/companion-policy.js";
24
30
  function normalizeIdentity(value) {
25
31
  const trimmed = value?.trim();
26
32
  return trimmed ? trimmed : null;
@@ -83,9 +89,11 @@ function resolveRuntimeControl(channel, runtimeControl, metadata) {
83
89
  const approvalMode = runtimeControl?.approvalMode
84
90
  ?? (metadata?.["runtime_control_approved"] === true
85
91
  ? "preapproved"
86
- : channel === "tui" || channel === "cli"
87
- ? "interactive"
88
- : "disallowed");
92
+ : metadata?.["runtime_control_denied"] === true
93
+ ? "disallowed"
94
+ : channel === "tui" || channel === "cli"
95
+ ? "interactive"
96
+ : "disallowed");
89
97
  return {
90
98
  allowed: runtimeControl?.allowed ?? approvalMode !== "disallowed",
91
99
  approvalMode,
@@ -126,22 +134,46 @@ function normalizeActor(channel, input) {
126
134
  ...input.actor,
127
135
  };
128
136
  }
129
- function safeInvoke(handler, event) {
137
+ async function safeInvoke(handler, event) {
130
138
  if (!handler)
131
139
  return;
132
140
  try {
133
- const result = handler(event);
134
- if (result && typeof result.catch === "function") {
135
- void result.catch(() => undefined);
136
- }
141
+ await handler(event);
137
142
  }
138
- catch {
143
+ catch (err) {
139
144
  // Event streaming should not break chat delivery.
145
+ console.warn("[chat] event delivery failed", {
146
+ eventType: event.type,
147
+ error: err instanceof Error ? err.message : String(err),
148
+ });
149
+ }
150
+ }
151
+ class ChatEventDeliveryQueue {
152
+ handler;
153
+ upstream;
154
+ queue = Promise.resolve();
155
+ constructor(handler, upstream) {
156
+ this.handler = handler;
157
+ this.upstream = upstream;
158
+ }
159
+ dispatch = (event) => {
160
+ this.queue = this.queue.then(async () => {
161
+ await safeInvoke(this.handler, event);
162
+ if (this.upstream && this.upstream !== this.handler) {
163
+ await safeInvoke(this.upstream, event);
164
+ }
165
+ });
166
+ return this.queue;
167
+ };
168
+ async drain() {
169
+ await this.queue;
140
170
  }
141
171
  }
142
172
  export class CrossPlatformChatSessionManager {
143
173
  deps;
144
174
  sessions = new Map();
175
+ activeApprovalEventHandlers = new Map();
176
+ approvalSideTurnIngressIds = new Set();
145
177
  ingressRouter = createIngressRouter();
146
178
  constructor(deps) {
147
179
  this.deps = deps;
@@ -165,51 +197,154 @@ export class CrossPlatformChatSessionManager {
165
197
  channel: options.channel ?? (options.platform ? "plugin_gateway" : "cli"),
166
198
  actor: options.actor,
167
199
  replyTarget: options.replyTarget,
168
- runtimeControl: options.runtimeControl ?? {
169
- allowed: true,
170
- approvalMode: "interactive",
171
- },
200
+ runtimeControl: options.runtimeControl,
201
+ companion: options.companion,
172
202
  cwd: options.cwd,
173
203
  timeoutMs: options.timeoutMs,
174
- metadata: options.metadata,
204
+ metadata: {
205
+ ...(options.metadata ?? {}),
206
+ ...(options.runtimeControl ? { runtime_control_explicit: true } : {}),
207
+ },
175
208
  onEvent: options.onEvent,
176
209
  });
210
+ const approvalReply = await this.tryResolveConversationalApprovalReply(ingress);
211
+ if (approvalReply) {
212
+ return {
213
+ success: true,
214
+ output: approvalReply,
215
+ elapsed_ms: 0,
216
+ };
217
+ }
177
218
  const session = this.getOrCreateSession(ingress, options.cwd);
219
+ if (ingress.ingress_id && this.approvalSideTurnIngressIds.delete(ingress.ingress_id)) {
220
+ return this.executeInSession(session, ingress, options);
221
+ }
178
222
  const queueEntry = session.queue.then(() => this.executeInSession(session, ingress, options));
179
223
  session.queue = queueEntry.then(() => undefined, () => undefined);
180
224
  return queueEntry;
181
225
  }
182
226
  async processIncomingMessage(input) {
183
- const result = await this.executeIngress(this.createIngressMessage(input), input);
227
+ const ingress = this.createIngressMessage(input);
228
+ if (input.approvalResponse) {
229
+ return this.resolveConversationalApprovalIngress(ingress, input.approvalResponse);
230
+ }
231
+ const approvalReply = await this.tryResolveConversationalApprovalReply(ingress);
232
+ if (approvalReply) {
233
+ return approvalReply;
234
+ }
235
+ const result = await this.executeIngress(ingress, input);
184
236
  return result.output;
185
237
  }
186
238
  async interruptAndRedirect(input) {
187
- const ingress = this.createIngressMessage(input);
239
+ const ingress = this.ensureCompanionContract(this.createIngressMessage(input));
240
+ const approvalReply = await this.tryResolveConversationalApprovalReply(ingress);
241
+ if (approvalReply) {
242
+ return {
243
+ success: true,
244
+ output: approvalReply,
245
+ elapsed_ms: 0,
246
+ };
247
+ }
188
248
  const session = this.getOrCreateSession(ingress, input.cwd);
249
+ const decision = evaluateCompanionOutputPolicy(ingress.companion.turn_policy);
250
+ if (!decision.delivered) {
251
+ return {
252
+ success: true,
253
+ output: formatCompanionPolicyDecision(decision),
254
+ elapsed_ms: 0,
255
+ };
256
+ }
189
257
  const previousOnEvent = session.runner.onEvent;
258
+ let deliveryQueue = null;
190
259
  if (input.onEvent) {
191
- const handler = input.onEvent;
192
- const upstream = this.deps.onEvent;
193
- session.runner.onEvent = (event) => {
194
- safeInvoke(handler, event);
195
- if (upstream && upstream !== handler) {
196
- safeInvoke(upstream, event);
197
- }
198
- };
260
+ deliveryQueue = new ChatEventDeliveryQueue(input.onEvent, this.deps.onEvent);
261
+ session.runner.onEvent = deliveryQueue.dispatch;
199
262
  }
200
263
  try {
201
264
  return await session.runner.interruptAndRedirect(input.text, session.info.cwd, input.timeoutMs);
202
265
  }
203
266
  finally {
267
+ await deliveryQueue?.drain();
204
268
  session.runner.onEvent = previousOnEvent;
205
269
  }
206
270
  }
207
271
  async executeIngress(ingress, options = {}) {
208
- const session = this.getOrCreateSession(ingress, options.cwd);
209
- const queueEntry = session.queue.then(() => this.executeInSession(session, ingress, options));
272
+ const normalizedIngress = this.ensureCompanionContract(ingress);
273
+ const decision = evaluateCompanionOutputPolicy(normalizedIngress.companion.turn_policy);
274
+ if (!decision.delivered) {
275
+ return {
276
+ success: true,
277
+ output: formatCompanionPolicyDecision(decision),
278
+ elapsed_ms: 0,
279
+ };
280
+ }
281
+ const session = this.getOrCreateSession(normalizedIngress, options.cwd);
282
+ if (normalizedIngress.ingress_id && this.approvalSideTurnIngressIds.delete(normalizedIngress.ingress_id)) {
283
+ return this.executeInSession(session, normalizedIngress, options);
284
+ }
285
+ const queueEntry = session.queue.then(() => this.executeInSession(session, normalizedIngress, options));
210
286
  session.queue = queueEntry.then(() => undefined, () => undefined);
211
287
  return queueEntry;
212
288
  }
289
+ async resolveConversationalApprovalIngress(ingress, response) {
290
+ const broker = this.deps.approvalBroker;
291
+ if (!broker) {
292
+ return "Approval response could not be recorded because approval handling is unavailable.";
293
+ }
294
+ const origin = createApprovalOriginFromIngress(ingress);
295
+ if (!origin) {
296
+ return "Approval response could not be recorded because the conversation origin is incomplete.";
297
+ }
298
+ const resolved = await broker.resolveConversationalApproval(response.approval_id, response.approved, origin);
299
+ return resolved
300
+ ? "Approval response recorded."
301
+ : "Approval response did not match an active approval for this conversation.";
302
+ }
303
+ async tryResolveConversationalApprovalReply(ingress) {
304
+ const broker = this.deps.approvalBroker;
305
+ if (!broker) {
306
+ return null;
307
+ }
308
+ const origin = createApprovalOriginFromIngress(ingress);
309
+ if (!origin) {
310
+ return null;
311
+ }
312
+ const lookup = await broker.findPendingConversationalApproval(origin);
313
+ if (lookup.status === "none") {
314
+ return null;
315
+ }
316
+ if (lookup.status === "ambiguous") {
317
+ return "Multiple active approvals match this conversation. Please use the specific approval response.";
318
+ }
319
+ const approval = lookup.approval;
320
+ const decision = await classifyConversationalApprovalDecision(ingress.text, {
321
+ approval,
322
+ replyOrigin: origin,
323
+ llmClient: this.deps.llmClient,
324
+ priorTurnState: this.describeLastRouteForApproval(ingress),
325
+ });
326
+ if (decision.decision === "approve" || decision.decision === "reject") {
327
+ const resolved = await broker.resolveConversationalApproval(approval.approval_id, decision.decision === "approve", approval.origin ?? origin);
328
+ return resolved
329
+ ? "Approval response recorded."
330
+ : "Approval response did not match an active approval for this conversation.";
331
+ }
332
+ if (decision.decision === "clarify") {
333
+ return decision.clarification ?? "Approval is still pending. Please clarify what you need before approving or rejecting.";
334
+ }
335
+ if (decision.decision === "side_question" || decision.decision === "new_intent") {
336
+ if (ingress.ingress_id) {
337
+ this.approvalSideTurnIngressIds.add(ingress.ingress_id);
338
+ }
339
+ return null;
340
+ }
341
+ return decision.clarification ?? "Approval reply was ambiguous. The approval remains pending.";
342
+ }
343
+ describeLastRouteForApproval(ingress) {
344
+ const session = this.sessions.get(buildSessionKeyFromParts(ingress));
345
+ const route = session?.lastRoute;
346
+ return route ? JSON.stringify(route) : "none";
347
+ }
213
348
  handleIncomingMessage(input) {
214
349
  return this.processIncomingMessage(input);
215
350
  }
@@ -238,6 +373,16 @@ export class CrossPlatformChatSessionManager {
238
373
  const identityKey = normalizeIdentity(input.identity_key) ?? undefined;
239
374
  const conversationId = normalizeIdentity(input.conversation_id) ?? undefined;
240
375
  const messageId = normalizeIdentity(input.message_id) ?? undefined;
376
+ const companion = this.buildCompanionContractForIngress({
377
+ identity_key: identityKey,
378
+ platform,
379
+ conversation_id: conversationId,
380
+ user_id: userId,
381
+ message_id: messageId,
382
+ goal_id: goalId,
383
+ replyTarget: input.replyTarget,
384
+ companion: input.companion,
385
+ });
241
386
  return {
242
387
  ingress_id: randomUUID(),
243
388
  received_at: new Date().toISOString(),
@@ -257,6 +402,7 @@ export class CrossPlatformChatSessionManager {
257
402
  actor: input.actor,
258
403
  }),
259
404
  runtimeControl: resolveRuntimeControl(channel, input.runtimeControl, metadata),
405
+ companion,
260
406
  metadata,
261
407
  replyTarget: normalizeReplyTarget(channel, {
262
408
  platform,
@@ -269,6 +415,43 @@ export class CrossPlatformChatSessionManager {
269
415
  }),
270
416
  };
271
417
  }
418
+ ensureCompanionContract(ingress) {
419
+ if (ingress.companion) {
420
+ return ingress;
421
+ }
422
+ return {
423
+ ...ingress,
424
+ companion: this.buildCompanionContractForIngress({
425
+ identity_key: ingress.identity_key,
426
+ platform: ingress.platform,
427
+ conversation_id: ingress.conversation_id,
428
+ user_id: ingress.user_id,
429
+ message_id: ingress.message_id,
430
+ goal_id: ingress.goal_id,
431
+ replyTarget: ingress.replyTarget,
432
+ }),
433
+ };
434
+ }
435
+ buildCompanionContractForIngress(input) {
436
+ const sessionKey = buildSessionKeyFromParts({
437
+ identity_key: input.identity_key,
438
+ platform: input.platform,
439
+ conversation_id: input.conversation_id,
440
+ user_id: input.user_id,
441
+ });
442
+ const replyTargetId = normalizeIdentity(input.replyTarget?.conversation_id ?? input.conversation_id ?? input.replyTarget?.identity_key ?? input.identity_key) ?? undefined;
443
+ return buildCompanionRuntimeContract({
444
+ sessionKey,
445
+ conversationId: input.conversation_id,
446
+ messageId: input.message_id,
447
+ goalId: input.goal_id,
448
+ replyTargetId,
449
+ presence: input.companion?.presence,
450
+ turnPolicy: input.companion?.turnPolicy,
451
+ inputModality: input.companion?.inputModality ?? "text",
452
+ outputMode: input.companion?.outputMode,
453
+ });
454
+ }
272
455
  /**
273
456
  * Returns the active session info if a matching session is already loaded.
274
457
  */
@@ -295,8 +478,6 @@ export class CrossPlatformChatSessionManager {
295
478
  return existing;
296
479
  }
297
480
  const cwd = resolveGitRoot(cwdOverride?.trim() || process.cwd());
298
- const runner = new ChatRunner(this.deps);
299
- runner.startSession(cwd);
300
481
  const now = new Date().toISOString();
301
482
  const info = {
302
483
  session_key: sessionKey,
@@ -309,6 +490,13 @@ export class CrossPlatformChatSessionManager {
309
490
  last_used_at: now,
310
491
  metadata: {},
311
492
  };
493
+ const approvalFn = this.createApprovalFn(info);
494
+ const runner = new ChatRunner({
495
+ ...this.deps,
496
+ approvalFn: approvalFn ?? this.deps.approvalFn,
497
+ runtimeControlApprovalFn: approvalFn ?? this.deps.runtimeControlApprovalFn,
498
+ });
499
+ runner.startSession(cwd);
312
500
  const created = {
313
501
  runner,
314
502
  info,
@@ -318,6 +506,55 @@ export class CrossPlatformChatSessionManager {
318
506
  this.sessions.set(sessionKey, created);
319
507
  return created;
320
508
  }
509
+ createApprovalFn(info) {
510
+ const broker = this.deps.approvalBroker;
511
+ if (!broker) {
512
+ return null;
513
+ }
514
+ return async (description) => {
515
+ const origin = createApprovalOriginFromSessionInfo(info);
516
+ if (!origin) {
517
+ return false;
518
+ }
519
+ const goalId = typeof info.metadata.goal_id === "string" && info.metadata.goal_id.trim()
520
+ ? info.metadata.goal_id.trim()
521
+ : "chat";
522
+ return broker.requestConversationalApproval(goalId, {
523
+ id: info.last_message_id ?? info.session_key,
524
+ description,
525
+ action: "chat_approval",
526
+ }, {
527
+ origin,
528
+ deliverConversationalApproval: async ({ prompt }) => {
529
+ const handler = this.activeApprovalEventHandlers.get(info.session_key);
530
+ if (!handler) {
531
+ return {
532
+ delivered: false,
533
+ reason: "originating_conversation_unreachable",
534
+ };
535
+ }
536
+ try {
537
+ await handler({
538
+ type: "activity",
539
+ kind: "checkpoint",
540
+ message: prompt,
541
+ sourceId: `approval:${info.last_message_id ?? info.session_key}`,
542
+ runId: info.session_key,
543
+ turnId: info.last_message_id ?? info.session_key,
544
+ createdAt: new Date().toISOString(),
545
+ });
546
+ return { delivered: true };
547
+ }
548
+ catch (err) {
549
+ return {
550
+ delivered: false,
551
+ reason: err instanceof Error ? err.message : "originating_conversation_unreachable",
552
+ };
553
+ }
554
+ },
555
+ });
556
+ };
557
+ }
321
558
  async executeInSession(session, ingress, options = {}) {
322
559
  session.info.last_used_at = new Date().toISOString();
323
560
  session.info.conversation_name = options.conversation_name?.trim() || session.info.conversation_name;
@@ -328,6 +565,9 @@ export class CrossPlatformChatSessionManager {
328
565
  ...ingress.replyTarget,
329
566
  metadata: cloneMetadata(ingress.replyTarget.metadata),
330
567
  };
568
+ if (ingress.companion) {
569
+ session.info.active_companion_contract = ingress.companion;
570
+ }
331
571
  session.info.metadata = cloneMetadata(buildSessionMetadata({
332
572
  metadata: ingress.metadata,
333
573
  channel: ingress.channel,
@@ -342,44 +582,157 @@ export class CrossPlatformChatSessionManager {
342
582
  hasToolLoop: this.deps.llmClient !== undefined,
343
583
  hasRuntimeControlService: this.deps.runtimeControlService !== undefined,
344
584
  };
345
- const runtimeControlAllowed = ingress.runtimeControl.allowed
346
- && ingress.runtimeControl.approvalMode !== "disallowed"
347
- && (capabilities.hasRuntimeControlService
348
- || (!capabilities.hasAgentLoop && !capabilities.hasToolLoop));
349
- const runtimeControlIntent = runtimeControlAllowed
350
- ? await recognizeRuntimeControlIntent(ingress.text, this.deps.llmClient)
585
+ const setupSecretIntake = intakeSetupSecrets(ingress.text);
586
+ const safeIngressText = setupSecretIntake.redactedText;
587
+ const hasSetupSecret = setupSecretIntake.suppliedSecrets.length > 0;
588
+ const shouldPreferFreeformBeforeDeniedRuntimeControl = !hasSetupSecret
589
+ && !capabilities.hasAgentLoop
590
+ && ingress.metadata["runtime_control_denied"] === true
591
+ && ingress.metadata["runtime_control_approved"] !== true
592
+ && ingress.metadata["runtime_control_explicit"] !== true;
593
+ const shouldClassifyRuntimeControlForSafety = !hasSetupSecret
594
+ && capabilities.hasAgentLoop
595
+ && (ingress.metadata["runtime_control_approved"] === true
596
+ || ingress.metadata["runtime_control_denied"] === true
597
+ || ingress.metadata["runtime_control_explicit"] === true);
598
+ const shouldClassifyRuntimeControl = shouldClassifyRuntimeControlForSafety
599
+ || (!hasSetupSecret && !capabilities.hasAgentLoop && ((capabilities.hasRuntimeControlService && ingress.runtimeControl.approvalMode !== "disallowed")
600
+ || ingress.metadata["runtime_control_approved"] === true
601
+ || ingress.metadata["runtime_control_denied"] === true
602
+ || ingress.metadata["runtime_control_explicit"] === true));
603
+ let freeformRouteIntent = shouldPreferFreeformBeforeDeniedRuntimeControl
604
+ ? await classifyFreeformRouteIntent(safeIngressText, this.deps.llmClient)
605
+ : null;
606
+ const runtimeControlClassification = freeformRouteIntent == null && shouldClassifyRuntimeControl
607
+ ? await classifyRuntimeControlIntent(safeIngressText, this.deps.llmClient)
351
608
  : null;
352
- const freeformRouteIntent = runtimeControlIntent === null && capabilities.hasAgentLoop
353
- ? await classifyFreeformRouteIntent(ingress.text, this.deps.llmClient)
609
+ const runtimeControlIntent = runtimeControlClassification?.status === "intent"
610
+ ? runtimeControlClassification.intent
611
+ : null;
612
+ if (!hasSetupSecret && !capabilities.hasAgentLoop && freeformRouteIntent == null && runtimeControlIntent === null) {
613
+ freeformRouteIntent = await classifyFreeformRouteIntent(safeIngressText, this.deps.llmClient);
614
+ }
615
+ const shouldDeriveRunSpecDraft = !capabilities.hasAgentLoop
616
+ && !hasSetupSecret
617
+ && runtimeControlIntent === null
618
+ && freeformRouteIntent != null
619
+ && (freeformRouteIntent.kind === "run_spec"
620
+ || freeformRouteIntent.kind === "configure"
621
+ || freeformRouteIntent.kind === "clarify")
622
+ && freeformRouteIntent.confidence >= 0.7;
623
+ const runSpecDraft = shouldDeriveRunSpecDraft
624
+ ? await deriveRunSpecFromText(safeIngressText, {
625
+ cwd: ingress.cwd ?? session.info.cwd,
626
+ conversationId: ingress.conversation_id ?? null,
627
+ channel: ingress.channel,
628
+ sessionId: session.runner.getSessionId() ?? ingress.conversation_id ?? null,
629
+ replyTarget: ingress.replyTarget,
630
+ originMetadata: {
631
+ ingress_id: ingress.ingress_id ?? null,
632
+ platform: ingress.platform ?? null,
633
+ message_id: ingress.message_id ?? null,
634
+ deliveryMode: ingress.deliveryMode ?? null,
635
+ metadata: ingress.metadata,
636
+ },
637
+ llmClient: this.deps.llmClient,
638
+ })
354
639
  : null;
355
640
  const selectedRoute = this.ingressRouter.selectRoute(ingress, {
356
641
  ...capabilities,
357
642
  runtimeControlIntent,
643
+ runtimeControlUnclassified: shouldClassifyRuntimeControlForSafety
644
+ && runtimeControlClassification?.status === "unclassified"
645
+ && ingress.metadata["runtime_control_explicit"] === true,
358
646
  freeformRouteIntent,
647
+ setupSecretIntake,
648
+ runSpecDraft,
359
649
  });
360
650
  session.lastRoute = selectedRoute;
361
651
  const previousOnEvent = session.runner.onEvent;
652
+ let deliveryQueue = null;
362
653
  if (options.onEvent) {
363
- const handler = options.onEvent;
364
- const upstream = this.deps.onEvent;
365
- session.runner.onEvent = (event) => {
366
- safeInvoke(handler, event);
367
- if (upstream && upstream !== handler) {
368
- safeInvoke(upstream, event);
369
- }
370
- };
654
+ deliveryQueue = new ChatEventDeliveryQueue(options.onEvent, this.deps.onEvent);
655
+ this.activeApprovalEventHandlers.set(session.info.session_key, options.onEvent);
656
+ session.runner.onEvent = deliveryQueue.dispatch;
371
657
  }
372
658
  else {
659
+ this.activeApprovalEventHandlers.delete(session.info.session_key);
373
660
  session.runner.onEvent = undefined;
374
661
  }
375
662
  try {
376
663
  return await session.runner.executeIngressMessage(ingress, session.info.cwd, options.timeoutMs, selectedRoute);
377
664
  }
378
665
  finally {
666
+ await deliveryQueue?.drain();
667
+ this.activeApprovalEventHandlers.delete(session.info.session_key);
379
668
  session.runner.onEvent = previousOnEvent;
380
669
  }
381
670
  }
382
671
  }
672
+ function formatCompanionPolicyDecision(decision) {
673
+ if (decision.reason === "interruption_requires_explicit_request") {
674
+ return "The current companion turn is non-interruptible. Send an explicit interruption request before redirecting it.";
675
+ }
676
+ if (decision.reason === "suppressed_by_quieting") {
677
+ return "Companion output was suppressed by the current quieting policy.";
678
+ }
679
+ if (decision.reason === "deferred_by_quieting") {
680
+ return "Companion output was deferred by the current quieting policy.";
681
+ }
682
+ return "Companion output is allowed.";
683
+ }
684
+ export function createApprovalOriginFromSessionInfo(info) {
685
+ const replyTarget = info.active_reply_target;
686
+ const channel = normalizeIdentity(replyTarget?.platform
687
+ ?? replyTarget?.channel
688
+ ?? replyTarget?.surface
689
+ ?? info.platform);
690
+ const conversationId = normalizeIdentity(replyTarget?.conversation_id
691
+ ?? info.conversation_id
692
+ ?? info.identity_key
693
+ ?? info.session_key);
694
+ if (!channel || !conversationId) {
695
+ return null;
696
+ }
697
+ const userId = normalizeIdentity(replyTarget?.user_id ?? info.user_id) ?? undefined;
698
+ const turnId = normalizeIdentity(replyTarget?.message_id ?? info.last_message_id) ?? undefined;
699
+ return {
700
+ channel,
701
+ conversation_id: conversationId,
702
+ ...(userId ? { user_id: userId } : {}),
703
+ session_id: info.session_key,
704
+ ...(turnId ? { turn_id: turnId } : {}),
705
+ reply_target: {
706
+ ...replyTarget,
707
+ metadata: replyTarget?.metadata ? { ...replyTarget.metadata } : undefined,
708
+ },
709
+ };
710
+ }
711
+ function createApprovalOriginFromIngress(ingress) {
712
+ const channel = normalizeIdentity(ingress.replyTarget.platform
713
+ ?? ingress.replyTarget.channel
714
+ ?? ingress.replyTarget.surface
715
+ ?? ingress.platform);
716
+ const conversationId = normalizeIdentity(ingress.replyTarget.conversation_id
717
+ ?? ingress.conversation_id
718
+ ?? ingress.identity_key);
719
+ const userId = normalizeIdentity(ingress.replyTarget.user_id ?? ingress.user_id) ?? undefined;
720
+ const turnId = normalizeIdentity(ingress.replyTarget.message_id ?? ingress.message_id) ?? undefined;
721
+ if (!channel || !conversationId || !userId || !turnId) {
722
+ return null;
723
+ }
724
+ return {
725
+ channel,
726
+ conversation_id: conversationId,
727
+ user_id: userId,
728
+ session_id: buildSessionKeyFromParts(ingress),
729
+ turn_id: turnId,
730
+ reply_target: {
731
+ ...ingress.replyTarget,
732
+ metadata: cloneMetadata(ingress.replyTarget.metadata),
733
+ },
734
+ };
735
+ }
383
736
  let globalManagerPromise = null;
384
737
  export function getGlobalCrossPlatformChatSessionManager() {
385
738
  if (globalManagerPromise === null) {
@@ -420,10 +773,20 @@ async function createGlobalCrossPlatformChatSessionManager() {
420
773
  });
421
774
  await pluginLoader.loadAll().catch(() => []);
422
775
  await scheduleEngine.syncExternalSources(pluginLoader.getScheduleSources()).catch(() => undefined);
776
+ const runtimeRoot = path.join(stateManager.getBaseDir(), "runtime");
777
+ const runtimeControlService = new RuntimeControlService({
778
+ runtimeRoot,
779
+ stateManager,
780
+ executor: createDaemonRuntimeControlExecutor({
781
+ baseDir: stateManager.getBaseDir(),
782
+ }),
783
+ });
423
784
  for (const tool of createBuiltinTools({
424
785
  stateManager,
425
786
  trustManager,
426
787
  registry: toolRegistry,
788
+ llmClient,
789
+ runtimeControlService,
427
790
  adapterRegistry,
428
791
  knowledgeManager,
429
792
  observationEngine,
@@ -456,6 +819,9 @@ async function createGlobalCrossPlatformChatSessionManager() {
456
819
  traceBaseDir: stateManager.getBaseDir(),
457
820
  })
458
821
  : undefined;
822
+ const approvalBroker = new ApprovalBroker({
823
+ store: new ApprovalStore(createRuntimeStorePaths(runtimeRoot)),
824
+ });
459
825
  return new CrossPlatformChatSessionManager({
460
826
  stateManager,
461
827
  adapter,
@@ -464,13 +830,8 @@ async function createGlobalCrossPlatformChatSessionManager() {
464
830
  toolExecutor,
465
831
  chatAgentLoopRunner,
466
832
  reviewAgentLoopRunner,
467
- runtimeControlService: new RuntimeControlService({
468
- runtimeRoot: path.join(stateManager.getBaseDir(), "runtime"),
469
- stateManager,
470
- executor: createDaemonRuntimeControlExecutor({
471
- baseDir: stateManager.getBaseDir(),
472
- }),
473
- }),
833
+ approvalBroker,
834
+ runtimeControlService,
474
835
  });
475
836
  }
476
837
  registerGlobalCrossPlatformChatSessionManager(getGlobalCrossPlatformChatSessionManager);