pulseed 0.6.1 → 0.6.2

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 (831) hide show
  1. package/README.md +1 -1
  2. package/dist/adapters/types/a2a.d.ts +24 -24
  3. package/dist/base/config/global-config.d.ts +4 -4
  4. package/dist/base/state/state-manager-goal-write.d.ts +1 -1
  5. package/dist/base/state/state-manager-goal-write.d.ts.map +1 -1
  6. package/dist/base/state/state-manager.d.ts +2 -6
  7. package/dist/base/state/state-manager.d.ts.map +1 -1
  8. package/dist/base/state/state-manager.js.map +1 -1
  9. package/dist/base/state/state-write-fence.d.ts +7 -0
  10. package/dist/base/state/state-write-fence.d.ts.map +1 -0
  11. package/dist/base/state/state-write-fence.js +2 -0
  12. package/dist/base/state/state-write-fence.js.map +1 -0
  13. package/dist/base/types/companion.d.ts +2 -0
  14. package/dist/base/types/companion.d.ts.map +1 -0
  15. package/dist/base/types/companion.js +2 -0
  16. package/dist/base/types/companion.js.map +1 -0
  17. package/dist/base/types/index.d.ts +1 -0
  18. package/dist/base/types/index.d.ts.map +1 -1
  19. package/dist/base/types/index.js +1 -0
  20. package/dist/base/types/index.js.map +1 -1
  21. package/dist/index.d.ts +4 -2
  22. package/dist/index.d.ts.map +1 -1
  23. package/dist/index.js +2 -1
  24. package/dist/index.js.map +1 -1
  25. package/dist/interface/chat/chat-event-state.d.ts +2 -0
  26. package/dist/interface/chat/chat-event-state.d.ts.map +1 -1
  27. package/dist/interface/chat/chat-event-state.js +28 -11
  28. package/dist/interface/chat/chat-event-state.js.map +1 -1
  29. package/dist/interface/chat/chat-events.d.ts +9 -1
  30. package/dist/interface/chat/chat-events.d.ts.map +1 -1
  31. package/dist/interface/chat/chat-history.d.ts +4739 -1
  32. package/dist/interface/chat/chat-history.d.ts.map +1 -1
  33. package/dist/interface/chat/chat-history.js +40 -2
  34. package/dist/interface/chat/chat-history.js.map +1 -1
  35. package/dist/interface/chat/chat-runner-commands.d.ts +2 -32
  36. package/dist/interface/chat/chat-runner-commands.d.ts.map +1 -1
  37. package/dist/interface/chat/chat-runner-commands.js +2 -2
  38. package/dist/interface/chat/chat-runner-commands.js.map +1 -1
  39. package/dist/interface/chat/chat-runner-contracts.d.ts +152 -0
  40. package/dist/interface/chat/chat-runner-contracts.d.ts.map +1 -0
  41. package/dist/interface/chat/chat-runner-contracts.js +2 -0
  42. package/dist/interface/chat/chat-runner-contracts.js.map +1 -0
  43. package/dist/interface/chat/chat-runner-event-bridge.d.ts +8 -2
  44. package/dist/interface/chat/chat-runner-event-bridge.d.ts.map +1 -1
  45. package/dist/interface/chat/chat-runner-event-bridge.js +76 -11
  46. package/dist/interface/chat/chat-runner-event-bridge.js.map +1 -1
  47. package/dist/interface/chat/chat-runner-routes.d.ts +66 -12
  48. package/dist/interface/chat/chat-runner-routes.d.ts.map +1 -1
  49. package/dist/interface/chat/chat-runner-routes.js +322 -30
  50. package/dist/interface/chat/chat-runner-routes.js.map +1 -1
  51. package/dist/interface/chat/chat-runner-runtime.d.ts +1 -1
  52. package/dist/interface/chat/chat-runner-runtime.d.ts.map +1 -1
  53. package/dist/interface/chat/chat-runner-runtime.js +4 -0
  54. package/dist/interface/chat/chat-runner-runtime.js.map +1 -1
  55. package/dist/interface/chat/chat-runner.d.ts +10 -71
  56. package/dist/interface/chat/chat-runner.d.ts.map +1 -1
  57. package/dist/interface/chat/chat-runner.js +403 -58
  58. package/dist/interface/chat/chat-runner.js.map +1 -1
  59. package/dist/interface/chat/chat-session-store.d.ts +2 -0
  60. package/dist/interface/chat/chat-session-store.d.ts.map +1 -1
  61. package/dist/interface/chat/chat-session-store.js +3 -6
  62. package/dist/interface/chat/chat-session-store.js.map +1 -1
  63. package/dist/interface/chat/cross-platform-session-global.d.ts +2 -1
  64. package/dist/interface/chat/cross-platform-session-global.d.ts.map +1 -1
  65. package/dist/interface/chat/cross-platform-session-global.js +4 -10
  66. package/dist/interface/chat/cross-platform-session-global.js.map +1 -1
  67. package/dist/interface/chat/cross-platform-session.d.ts +30 -1
  68. package/dist/interface/chat/cross-platform-session.d.ts.map +1 -1
  69. package/dist/interface/chat/cross-platform-session.js +413 -52
  70. package/dist/interface/chat/cross-platform-session.js.map +1 -1
  71. package/dist/interface/chat/event-subscriber.js +2 -2
  72. package/dist/interface/chat/event-subscriber.js.map +1 -1
  73. package/dist/interface/chat/failure-recovery.js +1 -1
  74. package/dist/interface/chat/failure-recovery.js.map +1 -1
  75. package/dist/interface/chat/freeform-route-classifier.d.ts +5 -5
  76. package/dist/interface/chat/freeform-route-classifier.js +3 -2
  77. package/dist/interface/chat/freeform-route-classifier.js.map +1 -1
  78. package/dist/interface/chat/gateway-setup-status.d.ts +33 -0
  79. package/dist/interface/chat/gateway-setup-status.d.ts.map +1 -0
  80. package/dist/interface/chat/gateway-setup-status.js +44 -0
  81. package/dist/interface/chat/gateway-setup-status.js.map +1 -0
  82. package/dist/interface/chat/ingress-router.d.ts +22 -0
  83. package/dist/interface/chat/ingress-router.d.ts.map +1 -1
  84. package/dist/interface/chat/ingress-router.js +148 -11
  85. package/dist/interface/chat/ingress-router.js.map +1 -1
  86. package/dist/interface/chat/operation-progress.d.ts +17 -0
  87. package/dist/interface/chat/operation-progress.d.ts.map +1 -0
  88. package/dist/interface/chat/operation-progress.js +29 -0
  89. package/dist/interface/chat/operation-progress.js.map +1 -0
  90. package/dist/interface/chat/setup-config-write.d.ts +27 -0
  91. package/dist/interface/chat/setup-config-write.d.ts.map +1 -0
  92. package/dist/interface/chat/setup-config-write.js +79 -0
  93. package/dist/interface/chat/setup-config-write.js.map +1 -0
  94. package/dist/interface/chat/setup-dialogue.d.ts +199 -0
  95. package/dist/interface/chat/setup-dialogue.d.ts.map +1 -0
  96. package/dist/interface/chat/setup-dialogue.js +97 -0
  97. package/dist/interface/chat/setup-dialogue.js.map +1 -0
  98. package/dist/interface/chat/setup-secret-intake.d.ts +68 -0
  99. package/dist/interface/chat/setup-secret-intake.d.ts.map +1 -0
  100. package/dist/interface/chat/setup-secret-intake.js +84 -0
  101. package/dist/interface/chat/setup-secret-intake.js.map +1 -0
  102. package/dist/interface/chat/turn-language.d.ts +23 -0
  103. package/dist/interface/chat/turn-language.d.ts.map +1 -0
  104. package/dist/interface/chat/turn-language.js +46 -0
  105. package/dist/interface/chat/turn-language.js.map +1 -0
  106. package/dist/interface/cli/cli-command-registry.d.ts +1 -1
  107. package/dist/interface/cli/cli-command-registry.d.ts.map +1 -1
  108. package/dist/interface/cli/cli-runner.js +1 -1
  109. package/dist/interface/cli/cli-runner.js.map +1 -1
  110. package/dist/interface/cli/commands/daemon.d.ts.map +1 -1
  111. package/dist/interface/cli/commands/daemon.js +3 -0
  112. package/dist/interface/cli/commands/daemon.js.map +1 -1
  113. package/dist/interface/cli/commands/operator-binding-status.d.ts +59 -0
  114. package/dist/interface/cli/commands/operator-binding-status.d.ts.map +1 -0
  115. package/dist/interface/cli/commands/operator-binding-status.js +257 -0
  116. package/dist/interface/cli/commands/operator-binding-status.js.map +1 -0
  117. package/dist/interface/cli/commands/run.d.ts +2 -2
  118. package/dist/interface/cli/commands/run.d.ts.map +1 -1
  119. package/dist/interface/cli/commands/run.js.map +1 -1
  120. package/dist/interface/cli/commands/runtime.d.ts.map +1 -1
  121. package/dist/interface/cli/commands/runtime.js +8 -1
  122. package/dist/interface/cli/commands/runtime.js.map +1 -1
  123. package/dist/interface/cli/commands/setup/steps-gateway.js +14 -3
  124. package/dist/interface/cli/commands/setup/steps-gateway.js.map +1 -1
  125. package/dist/interface/cli/commands/setup-wizard.d.ts +31 -0
  126. package/dist/interface/cli/commands/setup-wizard.d.ts.map +1 -1
  127. package/dist/interface/cli/commands/setup-wizard.js +88 -0
  128. package/dist/interface/cli/commands/setup-wizard.js.map +1 -1
  129. package/dist/interface/cli/commands/telegram.d.ts.map +1 -1
  130. package/dist/interface/cli/commands/telegram.js +27 -3
  131. package/dist/interface/cli/commands/telegram.js.map +1 -1
  132. package/dist/interface/cli/setup.d.ts +3 -3
  133. package/dist/interface/cli/setup.d.ts.map +1 -1
  134. package/dist/interface/cli/setup.js +3 -2
  135. package/dist/interface/cli/setup.js.map +1 -1
  136. package/dist/interface/cli/utils/loop-runner.d.ts +1 -1
  137. package/dist/interface/cli/utils/loop-runner.d.ts.map +1 -1
  138. package/dist/interface/cli/utils.js +1 -1
  139. package/dist/interface/tui/actions.d.ts.map +1 -1
  140. package/dist/interface/tui/actions.js +14 -6
  141. package/dist/interface/tui/actions.js.map +1 -1
  142. package/dist/interface/tui/app.d.ts +1 -7
  143. package/dist/interface/tui/app.d.ts.map +1 -1
  144. package/dist/interface/tui/app.js +71 -120
  145. package/dist/interface/tui/app.js.map +1 -1
  146. package/dist/interface/tui/chat-surface.d.ts +1 -0
  147. package/dist/interface/tui/chat-surface.d.ts.map +1 -1
  148. package/dist/interface/tui/chat-surface.js +15 -0
  149. package/dist/interface/tui/chat-surface.js.map +1 -1
  150. package/dist/interface/tui/entry-approval.js +2 -2
  151. package/dist/interface/tui/entry-approval.js.map +1 -1
  152. package/dist/interface/tui/entry-deps.d.ts +1 -1
  153. package/dist/interface/tui/entry-deps.d.ts.map +1 -1
  154. package/dist/interface/tui/entry-deps.js +54 -8
  155. package/dist/interface/tui/entry-deps.js.map +1 -1
  156. package/dist/interface/tui/input-action.d.ts +49 -0
  157. package/dist/interface/tui/input-action.d.ts.map +1 -0
  158. package/dist/interface/tui/input-action.js +46 -0
  159. package/dist/interface/tui/input-action.js.map +1 -0
  160. package/dist/interface/tui/markdown-renderer.d.ts.map +1 -1
  161. package/dist/interface/tui/markdown-renderer.js +4 -1
  162. package/dist/interface/tui/markdown-renderer.js.map +1 -1
  163. package/dist/interface/tui/use-loop.d.ts +1 -1
  164. package/dist/interface/tui/use-loop.d.ts.map +1 -1
  165. package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.d.ts.map +1 -1
  166. package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.js +14 -0
  167. package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.js.map +1 -1
  168. package/dist/orchestrator/execution/agent-loop/agent-loop-events.d.ts +3 -0
  169. package/dist/orchestrator/execution/agent-loop/agent-loop-events.d.ts.map +1 -1
  170. package/dist/orchestrator/execution/agent-loop/agent-loop-events.js.map +1 -1
  171. package/dist/orchestrator/execution/agent-loop/agent-loop-result.d.ts +17 -0
  172. package/dist/orchestrator/execution/agent-loop/agent-loop-result.d.ts.map +1 -1
  173. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-output.d.ts +3 -0
  174. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-output.d.ts.map +1 -1
  175. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.d.ts +1 -0
  176. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.d.ts.map +1 -1
  177. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.js +20 -3
  178. package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.js.map +1 -1
  179. package/dist/orchestrator/execution/agent-loop/agent-loop-trace-store.d.ts.map +1 -1
  180. package/dist/orchestrator/execution/agent-loop/agent-loop-trace-store.js +5 -3
  181. package/dist/orchestrator/execution/agent-loop/agent-loop-trace-store.js.map +1 -1
  182. package/dist/orchestrator/execution/agent-loop/agent-timeline.d.ts +3 -1
  183. package/dist/orchestrator/execution/agent-loop/agent-timeline.d.ts.map +1 -1
  184. package/dist/orchestrator/execution/agent-loop/agent-timeline.js +8 -20
  185. package/dist/orchestrator/execution/agent-loop/agent-timeline.js.map +1 -1
  186. package/dist/orchestrator/execution/agent-loop/bounded-agent-loop-runner.d.ts.map +1 -1
  187. package/dist/orchestrator/execution/agent-loop/bounded-agent-loop-runner.js +38 -25
  188. package/dist/orchestrator/execution/agent-loop/bounded-agent-loop-runner.js.map +1 -1
  189. package/dist/orchestrator/execution/agent-loop/chat-agent-loop-runner.d.ts.map +1 -1
  190. package/dist/orchestrator/execution/agent-loop/chat-agent-loop-runner.js +20 -4
  191. package/dist/orchestrator/execution/agent-loop/chat-agent-loop-runner.js.map +1 -1
  192. package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.d.ts +1 -51
  193. package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.d.ts.map +1 -1
  194. package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.js +3 -239
  195. package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.js.map +1 -1
  196. package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.d.ts +60 -0
  197. package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.d.ts.map +1 -0
  198. package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.js +244 -0
  199. package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.js.map +1 -0
  200. package/dist/orchestrator/execution/agent-loop/index.d.ts +1 -1
  201. package/dist/orchestrator/execution/agent-loop/index.d.ts.map +1 -1
  202. package/dist/orchestrator/execution/agent-loop/index.js +1 -1
  203. package/dist/orchestrator/execution/agent-loop/index.js.map +1 -1
  204. package/dist/orchestrator/execution/task/task-generation.d.ts +50 -2
  205. package/dist/orchestrator/execution/task/task-generation.d.ts.map +1 -1
  206. package/dist/orchestrator/execution/task/task-generation.js +19 -1
  207. package/dist/orchestrator/execution/task/task-generation.js.map +1 -1
  208. package/dist/orchestrator/execution/task/task-lifecycle.js +8 -11
  209. package/dist/orchestrator/execution/task/task-lifecycle.js.map +1 -1
  210. package/dist/orchestrator/execution/task/task-prompt-builder.d.ts.map +1 -1
  211. package/dist/orchestrator/execution/task/task-prompt-builder.js +9 -0
  212. package/dist/orchestrator/execution/task/task-prompt-builder.js.map +1 -1
  213. package/dist/orchestrator/execution/types/task-group.d.ts +68 -4
  214. package/dist/orchestrator/execution/types/task-group.d.ts.map +1 -1
  215. package/dist/orchestrator/execution/types/task.d.ts +100 -2
  216. package/dist/orchestrator/execution/types/task.d.ts.map +1 -1
  217. package/dist/orchestrator/execution/types/task.js +10 -0
  218. package/dist/orchestrator/execution/types/task.js.map +1 -1
  219. package/dist/orchestrator/goal/goal-decomposer.d.ts.map +1 -1
  220. package/dist/orchestrator/goal/goal-decomposer.js +2 -1
  221. package/dist/orchestrator/goal/goal-decomposer.js.map +1 -1
  222. package/dist/orchestrator/goal/goal-negotiator.d.ts.map +1 -1
  223. package/dist/orchestrator/goal/goal-negotiator.js +5 -2
  224. package/dist/orchestrator/goal/goal-negotiator.js.map +1 -1
  225. package/dist/orchestrator/goal/goal-suggest.d.ts +6 -6
  226. package/dist/orchestrator/goal/goal-validation.d.ts +4 -5
  227. package/dist/orchestrator/goal/goal-validation.d.ts.map +1 -1
  228. package/dist/orchestrator/goal/goal-validation.js +11 -17
  229. package/dist/orchestrator/goal/goal-validation.js.map +1 -1
  230. package/dist/orchestrator/goal/negotiator-prompts.d.ts.map +1 -1
  231. package/dist/orchestrator/goal/negotiator-prompts.js +8 -4
  232. package/dist/orchestrator/goal/negotiator-prompts.js.map +1 -1
  233. package/dist/orchestrator/goal/negotiator-steps.d.ts.map +1 -1
  234. package/dist/orchestrator/goal/negotiator-steps.js +7 -11
  235. package/dist/orchestrator/goal/negotiator-steps.js.map +1 -1
  236. package/dist/orchestrator/goal/types/goal-refiner.d.ts +6 -6
  237. package/dist/orchestrator/goal/types/goal.d.ts +161 -0
  238. package/dist/orchestrator/goal/types/goal.d.ts.map +1 -1
  239. package/dist/orchestrator/goal/types/goal.js +8 -0
  240. package/dist/orchestrator/goal/types/goal.js.map +1 -1
  241. package/dist/orchestrator/goal/types/negotiation.d.ts +120 -6
  242. package/dist/orchestrator/goal/types/negotiation.d.ts.map +1 -1
  243. package/dist/orchestrator/goal/types/negotiation.js +3 -0
  244. package/dist/orchestrator/goal/types/negotiation.js.map +1 -1
  245. package/dist/orchestrator/goal/types/suggest.d.ts +6 -6
  246. package/dist/orchestrator/loop/checkpoint-manager-loop.d.ts +1 -1
  247. package/dist/orchestrator/loop/checkpoint-manager-loop.d.ts.map +1 -1
  248. package/dist/orchestrator/loop/core-loop/capability.d.ts +1 -21
  249. package/dist/orchestrator/loop/core-loop/capability.d.ts.map +1 -1
  250. package/dist/orchestrator/loop/core-loop/capability.js +1 -150
  251. package/dist/orchestrator/loop/core-loop/capability.js.map +1 -1
  252. package/dist/orchestrator/loop/core-loop/contracts.d.ts +1 -318
  253. package/dist/orchestrator/loop/core-loop/contracts.d.ts.map +1 -1
  254. package/dist/orchestrator/loop/core-loop/contracts.js +1 -39
  255. package/dist/orchestrator/loop/core-loop/contracts.js.map +1 -1
  256. package/dist/orchestrator/loop/core-loop/control.d.ts +1 -26
  257. package/dist/orchestrator/loop/core-loop/control.d.ts.map +1 -1
  258. package/dist/orchestrator/loop/core-loop/control.js +1 -71
  259. package/dist/orchestrator/loop/core-loop/control.js.map +1 -1
  260. package/dist/orchestrator/loop/core-loop/decision-engine.d.ts +1 -78
  261. package/dist/orchestrator/loop/core-loop/decision-engine.d.ts.map +1 -1
  262. package/dist/orchestrator/loop/core-loop/decision-engine.js +1 -144
  263. package/dist/orchestrator/loop/core-loop/decision-engine.js.map +1 -1
  264. package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.d.ts +1 -47
  265. package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.d.ts.map +1 -1
  266. package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.js +1 -385
  267. package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.js.map +1 -1
  268. package/dist/orchestrator/loop/core-loop/evidence-ledger.d.ts +1 -21
  269. package/dist/orchestrator/loop/core-loop/evidence-ledger.d.ts.map +1 -1
  270. package/dist/orchestrator/loop/core-loop/evidence-ledger.js +1 -35
  271. package/dist/orchestrator/loop/core-loop/evidence-ledger.js.map +1 -1
  272. package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.d.ts +1 -6
  273. package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.d.ts.map +1 -1
  274. package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.js +1 -42
  275. package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.js.map +1 -1
  276. package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.d.ts +1 -13
  277. package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.d.ts.map +1 -1
  278. package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.js +1 -40
  279. package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.js.map +1 -1
  280. package/dist/orchestrator/loop/core-loop/iteration-kernel.d.ts +1 -36
  281. package/dist/orchestrator/loop/core-loop/iteration-kernel.d.ts.map +1 -1
  282. package/dist/orchestrator/loop/core-loop/iteration-kernel.js +1 -834
  283. package/dist/orchestrator/loop/core-loop/iteration-kernel.js.map +1 -1
  284. package/dist/orchestrator/loop/core-loop/learning.d.ts +1 -30
  285. package/dist/orchestrator/loop/core-loop/learning.d.ts.map +1 -1
  286. package/dist/orchestrator/loop/core-loop/learning.js +1 -91
  287. package/dist/orchestrator/loop/core-loop/learning.js.map +1 -1
  288. package/dist/orchestrator/loop/core-loop/phase-policy.d.ts +1 -19
  289. package/dist/orchestrator/loop/core-loop/phase-policy.d.ts.map +1 -1
  290. package/dist/orchestrator/loop/core-loop/phase-policy.js +1 -157
  291. package/dist/orchestrator/loop/core-loop/phase-policy.js.map +1 -1
  292. package/dist/orchestrator/loop/core-loop/phase-runtime.d.ts +1 -30
  293. package/dist/orchestrator/loop/core-loop/phase-runtime.d.ts.map +1 -1
  294. package/dist/orchestrator/loop/core-loop/phase-runtime.js +1 -102
  295. package/dist/orchestrator/loop/core-loop/phase-runtime.js.map +1 -1
  296. package/dist/orchestrator/loop/core-loop/phase-specs.d.ts +1 -1268
  297. package/dist/orchestrator/loop/core-loop/phase-specs.d.ts.map +1 -1
  298. package/dist/orchestrator/loop/core-loop/phase-specs.js +1 -348
  299. package/dist/orchestrator/loop/core-loop/phase-specs.js.map +1 -1
  300. package/dist/orchestrator/loop/core-loop/preparation.d.ts +1 -58
  301. package/dist/orchestrator/loop/core-loop/preparation.d.ts.map +1 -1
  302. package/dist/orchestrator/loop/core-loop/preparation.js +1 -367
  303. package/dist/orchestrator/loop/core-loop/preparation.js.map +1 -1
  304. package/dist/orchestrator/loop/core-loop/public-research.d.ts +1 -31
  305. package/dist/orchestrator/loop/core-loop/public-research.d.ts.map +1 -1
  306. package/dist/orchestrator/loop/core-loop/public-research.js +1 -111
  307. package/dist/orchestrator/loop/core-loop/public-research.js.map +1 -1
  308. package/dist/orchestrator/loop/core-loop/task-cycle-stall.d.ts +1 -8
  309. package/dist/orchestrator/loop/core-loop/task-cycle-stall.d.ts.map +1 -1
  310. package/dist/orchestrator/loop/core-loop/task-cycle-stall.js +1 -432
  311. package/dist/orchestrator/loop/core-loop/task-cycle-stall.js.map +1 -1
  312. package/dist/orchestrator/loop/core-loop/task-cycle-wait.d.ts +1 -10
  313. package/dist/orchestrator/loop/core-loop/task-cycle-wait.d.ts.map +1 -1
  314. package/dist/orchestrator/loop/core-loop/task-cycle-wait.js +1 -175
  315. package/dist/orchestrator/loop/core-loop/task-cycle-wait.js.map +1 -1
  316. package/dist/orchestrator/loop/core-loop/task-cycle.d.ts +1 -40
  317. package/dist/orchestrator/loop/core-loop/task-cycle.d.ts.map +1 -1
  318. package/dist/orchestrator/loop/core-loop/task-cycle.js +1 -429
  319. package/dist/orchestrator/loop/core-loop/task-cycle.js.map +1 -1
  320. package/dist/orchestrator/loop/core-loop.d.ts +1 -85
  321. package/dist/orchestrator/loop/core-loop.d.ts.map +1 -1
  322. package/dist/orchestrator/loop/core-loop.js +3 -625
  323. package/dist/orchestrator/loop/core-loop.js.map +1 -1
  324. package/dist/orchestrator/loop/durable-loop/capability.d.ts +22 -0
  325. package/dist/orchestrator/loop/durable-loop/capability.d.ts.map +1 -0
  326. package/dist/orchestrator/loop/durable-loop/capability.js +151 -0
  327. package/dist/orchestrator/loop/durable-loop/capability.js.map +1 -0
  328. package/dist/orchestrator/loop/durable-loop/contracts.d.ts +319 -0
  329. package/dist/orchestrator/loop/durable-loop/contracts.d.ts.map +1 -0
  330. package/dist/orchestrator/loop/durable-loop/contracts.js +40 -0
  331. package/dist/orchestrator/loop/durable-loop/contracts.js.map +1 -0
  332. package/dist/orchestrator/loop/durable-loop/control.d.ts +27 -0
  333. package/dist/orchestrator/loop/durable-loop/control.d.ts.map +1 -0
  334. package/dist/orchestrator/loop/durable-loop/control.js +72 -0
  335. package/dist/orchestrator/loop/durable-loop/control.js.map +1 -0
  336. package/dist/orchestrator/loop/durable-loop/decision-engine.d.ts +79 -0
  337. package/dist/orchestrator/loop/durable-loop/decision-engine.d.ts.map +1 -0
  338. package/dist/orchestrator/loop/durable-loop/decision-engine.js +145 -0
  339. package/dist/orchestrator/loop/durable-loop/decision-engine.js.map +1 -0
  340. package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.d.ts +48 -0
  341. package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.d.ts.map +1 -0
  342. package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.js +386 -0
  343. package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.js.map +1 -0
  344. package/dist/orchestrator/loop/durable-loop/evidence-ledger.d.ts +22 -0
  345. package/dist/orchestrator/loop/durable-loop/evidence-ledger.d.ts.map +1 -0
  346. package/dist/orchestrator/loop/durable-loop/evidence-ledger.js +36 -0
  347. package/dist/orchestrator/loop/durable-loop/evidence-ledger.js.map +1 -0
  348. package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.d.ts +7 -0
  349. package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.d.ts.map +1 -0
  350. package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.js +43 -0
  351. package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.js.map +1 -0
  352. package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.d.ts +14 -0
  353. package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.d.ts.map +1 -0
  354. package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.js +41 -0
  355. package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.js.map +1 -0
  356. package/dist/orchestrator/loop/durable-loop/iteration-kernel.d.ts +37 -0
  357. package/dist/orchestrator/loop/durable-loop/iteration-kernel.d.ts.map +1 -0
  358. package/dist/orchestrator/loop/durable-loop/iteration-kernel.js +835 -0
  359. package/dist/orchestrator/loop/durable-loop/iteration-kernel.js.map +1 -0
  360. package/dist/orchestrator/loop/durable-loop/learning.d.ts +31 -0
  361. package/dist/orchestrator/loop/durable-loop/learning.d.ts.map +1 -0
  362. package/dist/orchestrator/loop/durable-loop/learning.js +92 -0
  363. package/dist/orchestrator/loop/durable-loop/learning.js.map +1 -0
  364. package/dist/orchestrator/loop/durable-loop/phase-policy.d.ts +20 -0
  365. package/dist/orchestrator/loop/durable-loop/phase-policy.d.ts.map +1 -0
  366. package/dist/orchestrator/loop/durable-loop/phase-policy.js +158 -0
  367. package/dist/orchestrator/loop/durable-loop/phase-policy.js.map +1 -0
  368. package/dist/orchestrator/loop/durable-loop/phase-runtime.d.ts +31 -0
  369. package/dist/orchestrator/loop/durable-loop/phase-runtime.d.ts.map +1 -0
  370. package/dist/orchestrator/loop/durable-loop/phase-runtime.js +103 -0
  371. package/dist/orchestrator/loop/durable-loop/phase-runtime.js.map +1 -0
  372. package/dist/orchestrator/loop/durable-loop/phase-specs.d.ts +1269 -0
  373. package/dist/orchestrator/loop/durable-loop/phase-specs.d.ts.map +1 -0
  374. package/dist/orchestrator/loop/durable-loop/phase-specs.js +349 -0
  375. package/dist/orchestrator/loop/durable-loop/phase-specs.js.map +1 -0
  376. package/dist/orchestrator/loop/durable-loop/preparation.d.ts +59 -0
  377. package/dist/orchestrator/loop/durable-loop/preparation.d.ts.map +1 -0
  378. package/dist/orchestrator/loop/durable-loop/preparation.js +368 -0
  379. package/dist/orchestrator/loop/durable-loop/preparation.js.map +1 -0
  380. package/dist/orchestrator/loop/durable-loop/public-research.d.ts +32 -0
  381. package/dist/orchestrator/loop/durable-loop/public-research.d.ts.map +1 -0
  382. package/dist/orchestrator/loop/durable-loop/public-research.js +112 -0
  383. package/dist/orchestrator/loop/durable-loop/public-research.js.map +1 -0
  384. package/dist/orchestrator/loop/durable-loop/task-cycle-stall.d.ts +9 -0
  385. package/dist/orchestrator/loop/durable-loop/task-cycle-stall.d.ts.map +1 -0
  386. package/dist/orchestrator/loop/durable-loop/task-cycle-stall.js +464 -0
  387. package/dist/orchestrator/loop/durable-loop/task-cycle-stall.js.map +1 -0
  388. package/dist/orchestrator/loop/durable-loop/task-cycle-wait.d.ts +11 -0
  389. package/dist/orchestrator/loop/durable-loop/task-cycle-wait.d.ts.map +1 -0
  390. package/dist/orchestrator/loop/durable-loop/task-cycle-wait.js +176 -0
  391. package/dist/orchestrator/loop/durable-loop/task-cycle-wait.js.map +1 -0
  392. package/dist/orchestrator/loop/durable-loop/task-cycle.d.ts +41 -0
  393. package/dist/orchestrator/loop/durable-loop/task-cycle.d.ts.map +1 -0
  394. package/dist/orchestrator/loop/durable-loop/task-cycle.js +430 -0
  395. package/dist/orchestrator/loop/durable-loop/task-cycle.js.map +1 -0
  396. package/dist/orchestrator/loop/durable-loop.d.ts +92 -0
  397. package/dist/orchestrator/loop/durable-loop.d.ts.map +1 -0
  398. package/dist/orchestrator/loop/durable-loop.js +631 -0
  399. package/dist/orchestrator/loop/durable-loop.js.map +1 -0
  400. package/dist/orchestrator/loop/loop-report-helper.d.ts +1 -1
  401. package/dist/orchestrator/loop/loop-report-helper.d.ts.map +1 -1
  402. package/dist/orchestrator/loop/loop-result-types.d.ts +1 -1
  403. package/dist/orchestrator/loop/loop-result-types.d.ts.map +1 -1
  404. package/dist/orchestrator/loop/parallel-dispatch.d.ts +2 -2
  405. package/dist/orchestrator/loop/parallel-dispatch.d.ts.map +1 -1
  406. package/dist/orchestrator/loop/post-loop-hooks.d.ts +1 -1
  407. package/dist/orchestrator/loop/post-loop-hooks.d.ts.map +1 -1
  408. package/dist/orchestrator/loop/run-policy.d.ts +1 -1
  409. package/dist/orchestrator/loop/run-policy.d.ts.map +1 -1
  410. package/dist/orchestrator/loop/tree-loop-runner.d.ts +1 -1
  411. package/dist/orchestrator/loop/tree-loop-runner.d.ts.map +1 -1
  412. package/dist/orchestrator/loop/tree-loop-runner.js +1 -1
  413. package/dist/orchestrator/loop/tree-loop-runner.js.map +1 -1
  414. package/dist/orchestrator/strategy/divergent-exploration.d.ts +2 -1
  415. package/dist/orchestrator/strategy/divergent-exploration.d.ts.map +1 -1
  416. package/dist/orchestrator/strategy/divergent-exploration.js +119 -36
  417. package/dist/orchestrator/strategy/divergent-exploration.js.map +1 -1
  418. package/dist/orchestrator/strategy/strategy-helpers.d.ts +86 -4
  419. package/dist/orchestrator/strategy/strategy-helpers.d.ts.map +1 -1
  420. package/dist/orchestrator/strategy/strategy-manager-base.d.ts +6 -2
  421. package/dist/orchestrator/strategy/strategy-manager-base.d.ts.map +1 -1
  422. package/dist/orchestrator/strategy/strategy-manager-base.js +71 -18
  423. package/dist/orchestrator/strategy/strategy-manager-base.js.map +1 -1
  424. package/dist/orchestrator/strategy/types/strategy.d.ts +450 -14
  425. package/dist/orchestrator/strategy/types/strategy.d.ts.map +1 -1
  426. package/dist/orchestrator/strategy/types/strategy.js +30 -0
  427. package/dist/orchestrator/strategy/types/strategy.js.map +1 -1
  428. package/dist/platform/code-search/contracts.d.ts +3 -0
  429. package/dist/platform/code-search/contracts.d.ts.map +1 -1
  430. package/dist/platform/code-search/contracts.js.map +1 -1
  431. package/dist/platform/code-search/indexes/indexer.d.ts.map +1 -1
  432. package/dist/platform/code-search/indexes/indexer.js +3 -0
  433. package/dist/platform/code-search/indexes/indexer.js.map +1 -1
  434. package/dist/platform/code-search/indexes/semantic-index.d.ts.map +1 -1
  435. package/dist/platform/code-search/indexes/semantic-index.js +3 -0
  436. package/dist/platform/code-search/indexes/semantic-index.js.map +1 -1
  437. package/dist/platform/code-search/orchestrator.d.ts.map +1 -1
  438. package/dist/platform/code-search/orchestrator.js +14 -3
  439. package/dist/platform/code-search/orchestrator.js.map +1 -1
  440. package/dist/platform/code-search/query-planner.d.ts.map +1 -1
  441. package/dist/platform/code-search/query-planner.js +1 -17
  442. package/dist/platform/code-search/query-planner.js.map +1 -1
  443. package/dist/platform/code-search/reranker.d.ts +5 -1
  444. package/dist/platform/code-search/reranker.d.ts.map +1 -1
  445. package/dist/platform/code-search/reranker.js +9 -5
  446. package/dist/platform/code-search/reranker.js.map +1 -1
  447. package/dist/platform/corrections/memory-correction-ledger.d.ts +30 -30
  448. package/dist/platform/dream/dream-activation.d.ts +161 -1
  449. package/dist/platform/dream/dream-activation.d.ts.map +1 -1
  450. package/dist/platform/dream/dream-activation.js +63 -14
  451. package/dist/platform/dream/dream-activation.js.map +1 -1
  452. package/dist/platform/dream/dream-event-workflows.d.ts +2 -2
  453. package/dist/platform/dream/dream-types.d.ts +52 -52
  454. package/dist/platform/dream/playbook-memory.d.ts +3 -3
  455. package/dist/platform/drive/stall-detector/repetitive.d.ts.map +1 -1
  456. package/dist/platform/drive/stall-detector/repetitive.js +50 -5
  457. package/dist/platform/drive/stall-detector/repetitive.js.map +1 -1
  458. package/dist/platform/drive/stall-detector.d.ts +19 -0
  459. package/dist/platform/drive/stall-detector.d.ts.map +1 -1
  460. package/dist/platform/drive/stall-detector.js.map +1 -1
  461. package/dist/platform/drive/types/stall.d.ts +1 -1
  462. package/dist/platform/knowledge/transfer/knowledge-transfer-apply.d.ts.map +1 -1
  463. package/dist/platform/knowledge/transfer/knowledge-transfer-apply.js +7 -3
  464. package/dist/platform/knowledge/transfer/knowledge-transfer-apply.js.map +1 -1
  465. package/dist/platform/knowledge/types/agent-memory.d.ts +46 -46
  466. package/dist/platform/knowledge/types/embedding.d.ts +4 -4
  467. package/dist/platform/knowledge/types/knowledge.d.ts +53 -0
  468. package/dist/platform/knowledge/types/knowledge.d.ts.map +1 -1
  469. package/dist/platform/knowledge/types/knowledge.js +15 -0
  470. package/dist/platform/knowledge/types/knowledge.js.map +1 -1
  471. package/dist/platform/knowledge/types/memory-lifecycle.d.ts +2 -2
  472. package/dist/platform/observation/capability-detector/types.d.ts +4 -4
  473. package/dist/platform/observation/context-provider/collector.d.ts +2 -0
  474. package/dist/platform/observation/context-provider/collector.d.ts.map +1 -1
  475. package/dist/platform/observation/context-provider/collector.js +27 -2
  476. package/dist/platform/observation/context-provider/collector.js.map +1 -1
  477. package/dist/platform/observation/context-provider.d.ts +4 -0
  478. package/dist/platform/observation/context-provider.d.ts.map +1 -1
  479. package/dist/platform/observation/context-provider.js.map +1 -1
  480. package/dist/platform/observation/engine/observe-datasource-stage.d.ts +3 -2
  481. package/dist/platform/observation/engine/observe-datasource-stage.d.ts.map +1 -1
  482. package/dist/platform/observation/engine/observe-datasource-stage.js +2 -2
  483. package/dist/platform/observation/engine/observe-datasource-stage.js.map +1 -1
  484. package/dist/platform/observation/observation-apply.d.ts +1 -1
  485. package/dist/platform/observation/observation-apply.d.ts.map +1 -1
  486. package/dist/platform/observation/observation-apply.js +3 -3
  487. package/dist/platform/observation/observation-apply.js.map +1 -1
  488. package/dist/platform/observation/observation-datasource.d.ts +2 -2
  489. package/dist/platform/observation/observation-datasource.d.ts.map +1 -1
  490. package/dist/platform/observation/observation-datasource.js +13 -7
  491. package/dist/platform/observation/observation-datasource.js.map +1 -1
  492. package/dist/platform/observation/observation-engine.d.ts +1 -1
  493. package/dist/platform/observation/observation-engine.d.ts.map +1 -1
  494. package/dist/platform/observation/observation-engine.js +8 -6
  495. package/dist/platform/observation/observation-engine.js.map +1 -1
  496. package/dist/platform/observation/types/capability.d.ts +16 -16
  497. package/dist/platform/observation/workspace-context.d.ts +8 -1
  498. package/dist/platform/observation/workspace-context.d.ts.map +1 -1
  499. package/dist/platform/observation/workspace-context.js +35 -14
  500. package/dist/platform/observation/workspace-context.js.map +1 -1
  501. package/dist/platform/profile/profile-change-proposal.d.ts +20 -20
  502. package/dist/platform/profile/relationship-profile.d.ts +6 -6
  503. package/dist/platform/profile/user-md-profile-import.d.ts +2 -2
  504. package/dist/platform/soil/contracts.d.ts +98 -98
  505. package/dist/platform/soil/types.d.ts +8 -8
  506. package/dist/platform/traits/curiosity-engine.d.ts +2 -5
  507. package/dist/platform/traits/curiosity-engine.d.ts.map +1 -1
  508. package/dist/platform/traits/curiosity-engine.js.map +1 -1
  509. package/dist/platform/traits/curiosity-proposals.d.ts +2 -0
  510. package/dist/platform/traits/curiosity-proposals.d.ts.map +1 -1
  511. package/dist/platform/traits/curiosity-proposals.js +36 -17
  512. package/dist/platform/traits/curiosity-proposals.js.map +1 -1
  513. package/dist/platform/traits/curiosity-transfer.d.ts +9 -5
  514. package/dist/platform/traits/curiosity-transfer.d.ts.map +1 -1
  515. package/dist/platform/traits/curiosity-transfer.js +4 -1
  516. package/dist/platform/traits/curiosity-transfer.js.map +1 -1
  517. package/dist/platform/traits/ethics-gate.d.ts +16 -17
  518. package/dist/platform/traits/ethics-gate.d.ts.map +1 -1
  519. package/dist/platform/traits/ethics-gate.js +83 -47
  520. package/dist/platform/traits/ethics-gate.js.map +1 -1
  521. package/dist/platform/traits/ethics-rules.d.ts +4 -6
  522. package/dist/platform/traits/ethics-rules.d.ts.map +1 -1
  523. package/dist/platform/traits/ethics-rules.js +19 -261
  524. package/dist/platform/traits/ethics-rules.js.map +1 -1
  525. package/dist/platform/traits/types/curiosity.d.ts +157 -10
  526. package/dist/platform/traits/types/curiosity.d.ts.map +1 -1
  527. package/dist/platform/traits/types/curiosity.js +10 -0
  528. package/dist/platform/traits/types/curiosity.js.map +1 -1
  529. package/dist/platform/traits/types/guardrail.d.ts +6 -6
  530. package/dist/prompt/purposes/curiosity.d.ts +4 -4
  531. package/dist/runtime/approval-broker.d.ts +33 -0
  532. package/dist/runtime/approval-broker.d.ts.map +1 -1
  533. package/dist/runtime/approval-broker.js +155 -17
  534. package/dist/runtime/approval-broker.js.map +1 -1
  535. package/dist/runtime/companion-policy.d.ts +27 -0
  536. package/dist/runtime/companion-policy.d.ts.map +1 -0
  537. package/dist/runtime/companion-policy.js +135 -0
  538. package/dist/runtime/companion-policy.js.map +1 -0
  539. package/dist/runtime/confirmation-decision.d.ts +2 -2
  540. package/dist/runtime/control/daemon-runtime-control-executor.d.ts +0 -6
  541. package/dist/runtime/control/daemon-runtime-control-executor.d.ts.map +1 -1
  542. package/dist/runtime/control/daemon-runtime-control-executor.js +1 -1
  543. package/dist/runtime/control/daemon-runtime-control-executor.js.map +1 -1
  544. package/dist/runtime/control/index.d.ts +6 -3
  545. package/dist/runtime/control/index.d.ts.map +1 -1
  546. package/dist/runtime/control/index.js +2 -1
  547. package/dist/runtime/control/index.js.map +1 -1
  548. package/dist/runtime/control/runtime-control-intent.d.ts +16 -1
  549. package/dist/runtime/control/runtime-control-intent.d.ts.map +1 -1
  550. package/dist/runtime/control/runtime-control-intent.js +26 -13
  551. package/dist/runtime/control/runtime-control-intent.js.map +1 -1
  552. package/dist/runtime/control/runtime-control-service.d.ts +1 -1
  553. package/dist/runtime/control/runtime-control-service.d.ts.map +1 -1
  554. package/dist/runtime/control/runtime-control-service.js +29 -64
  555. package/dist/runtime/control/runtime-control-service.js.map +1 -1
  556. package/dist/runtime/control/runtime-target-resolver.d.ts +39 -0
  557. package/dist/runtime/control/runtime-target-resolver.d.ts.map +1 -0
  558. package/dist/runtime/control/runtime-target-resolver.js +112 -0
  559. package/dist/runtime/control/runtime-target-resolver.js.map +1 -0
  560. package/dist/runtime/conversational-approval-decision.d.ts +29 -0
  561. package/dist/runtime/conversational-approval-decision.d.ts.map +1 -0
  562. package/dist/runtime/conversational-approval-decision.js +92 -0
  563. package/dist/runtime/conversational-approval-decision.js.map +1 -0
  564. package/dist/runtime/daemon/client.d.ts +1 -4
  565. package/dist/runtime/daemon/client.d.ts.map +1 -1
  566. package/dist/runtime/daemon/client.js +0 -3
  567. package/dist/runtime/daemon/client.js.map +1 -1
  568. package/dist/runtime/daemon/control-contracts.d.ts +7 -0
  569. package/dist/runtime/daemon/control-contracts.d.ts.map +1 -0
  570. package/dist/runtime/daemon/control-contracts.js +2 -0
  571. package/dist/runtime/daemon/control-contracts.js.map +1 -0
  572. package/dist/runtime/daemon/runner-startup.js +1 -1
  573. package/dist/runtime/daemon/runner-startup.js.map +1 -1
  574. package/dist/runtime/daemon/runner.d.ts +1 -1
  575. package/dist/runtime/daemon/runner.d.ts.map +1 -1
  576. package/dist/runtime/executor/goal-worker.d.ts +3 -3
  577. package/dist/runtime/executor/goal-worker.d.ts.map +1 -1
  578. package/dist/runtime/executor/loop-supervisor.d.ts +2 -2
  579. package/dist/runtime/executor/loop-supervisor.d.ts.map +1 -1
  580. package/dist/runtime/executor/loop-supervisor.js +2 -2
  581. package/dist/runtime/executor/loop-supervisor.js.map +1 -1
  582. package/dist/runtime/gateway/channel-adapter.d.ts +19 -0
  583. package/dist/runtime/gateway/channel-adapter.d.ts.map +1 -1
  584. package/dist/runtime/gateway/channel-policy.d.ts +1 -0
  585. package/dist/runtime/gateway/channel-policy.d.ts.map +1 -1
  586. package/dist/runtime/gateway/channel-policy.js +6 -4
  587. package/dist/runtime/gateway/channel-policy.js.map +1 -1
  588. package/dist/runtime/gateway/chat-event-rendering.d.ts +34 -0
  589. package/dist/runtime/gateway/chat-event-rendering.d.ts.map +1 -0
  590. package/dist/runtime/gateway/chat-event-rendering.js +61 -0
  591. package/dist/runtime/gateway/chat-event-rendering.js.map +1 -0
  592. package/dist/runtime/gateway/chat-session-dispatch.d.ts +2 -13
  593. package/dist/runtime/gateway/chat-session-dispatch.d.ts.map +1 -1
  594. package/dist/runtime/gateway/chat-session-dispatch.js +6 -3
  595. package/dist/runtime/gateway/chat-session-dispatch.js.map +1 -1
  596. package/dist/runtime/gateway/chat-session-port.d.ts +25 -0
  597. package/dist/runtime/gateway/chat-session-port.d.ts.map +1 -0
  598. package/dist/runtime/gateway/chat-session-port.js +20 -0
  599. package/dist/runtime/gateway/chat-session-port.js.map +1 -0
  600. package/dist/runtime/gateway/discord-gateway-adapter.d.ts +3 -1
  601. package/dist/runtime/gateway/discord-gateway-adapter.d.ts.map +1 -1
  602. package/dist/runtime/gateway/discord-gateway-adapter.js +34 -2
  603. package/dist/runtime/gateway/discord-gateway-adapter.js.map +1 -1
  604. package/dist/runtime/gateway/index.d.ts +2 -0
  605. package/dist/runtime/gateway/index.d.ts.map +1 -1
  606. package/dist/runtime/gateway/index.js +1 -0
  607. package/dist/runtime/gateway/index.js.map +1 -1
  608. package/dist/runtime/gateway/ingress-gateway.d.ts.map +1 -1
  609. package/dist/runtime/gateway/ingress-gateway.js +1 -0
  610. package/dist/runtime/gateway/ingress-gateway.js.map +1 -1
  611. package/dist/runtime/gateway/signal-gateway-adapter.d.ts +2 -1
  612. package/dist/runtime/gateway/signal-gateway-adapter.d.ts.map +1 -1
  613. package/dist/runtime/gateway/signal-gateway-adapter.js +13 -3
  614. package/dist/runtime/gateway/signal-gateway-adapter.js.map +1 -1
  615. package/dist/runtime/gateway/slack-channel-adapter.d.ts +2 -1
  616. package/dist/runtime/gateway/slack-channel-adapter.d.ts.map +1 -1
  617. package/dist/runtime/gateway/slack-channel-adapter.js +6 -2
  618. package/dist/runtime/gateway/slack-channel-adapter.js.map +1 -1
  619. package/dist/runtime/gateway/telegram-gateway-adapter.d.ts +9 -2
  620. package/dist/runtime/gateway/telegram-gateway-adapter.d.ts.map +1 -1
  621. package/dist/runtime/gateway/telegram-gateway-adapter.js +141 -13
  622. package/dist/runtime/gateway/telegram-gateway-adapter.js.map +1 -1
  623. package/dist/runtime/gateway/typing-indicator.d.ts +11 -0
  624. package/dist/runtime/gateway/typing-indicator.d.ts.map +1 -0
  625. package/dist/runtime/gateway/typing-indicator.js +68 -0
  626. package/dist/runtime/gateway/typing-indicator.js.map +1 -0
  627. package/dist/runtime/gateway/whatsapp-gateway-adapter.d.ts +2 -1
  628. package/dist/runtime/gateway/whatsapp-gateway-adapter.d.ts.map +1 -1
  629. package/dist/runtime/gateway/whatsapp-gateway-adapter.js +22 -8
  630. package/dist/runtime/gateway/whatsapp-gateway-adapter.js.map +1 -1
  631. package/dist/runtime/gateway/ws-channel-adapter.d.ts.map +1 -1
  632. package/dist/runtime/gateway/ws-channel-adapter.js +1 -0
  633. package/dist/runtime/gateway/ws-channel-adapter.js.map +1 -1
  634. package/dist/runtime/interactive-automation/failure-classifier.d.ts +0 -1
  635. package/dist/runtime/interactive-automation/failure-classifier.d.ts.map +1 -1
  636. package/dist/runtime/interactive-automation/failure-classifier.js +0 -19
  637. package/dist/runtime/interactive-automation/failure-classifier.js.map +1 -1
  638. package/dist/runtime/interactive-automation/providers/manus-browser.d.ts.map +1 -1
  639. package/dist/runtime/interactive-automation/providers/manus-browser.js +30 -1
  640. package/dist/runtime/interactive-automation/providers/manus-browser.js.map +1 -1
  641. package/dist/runtime/logger.d.ts.map +1 -1
  642. package/dist/runtime/logger.js +5 -2
  643. package/dist/runtime/logger.js.map +1 -1
  644. package/dist/runtime/plugin-loader.js +2 -2
  645. package/dist/runtime/plugin-loader.js.map +1 -1
  646. package/dist/runtime/run-spec/derive.d.ts +24 -24
  647. package/dist/runtime/run-spec/derive.d.ts.map +1 -1
  648. package/dist/runtime/run-spec/derive.js +6 -0
  649. package/dist/runtime/run-spec/derive.js.map +1 -1
  650. package/dist/runtime/run-spec/handoff.d.ts +74 -0
  651. package/dist/runtime/run-spec/handoff.d.ts.map +1 -0
  652. package/dist/runtime/run-spec/handoff.js +496 -0
  653. package/dist/runtime/run-spec/handoff.js.map +1 -0
  654. package/dist/runtime/run-spec/index.d.ts +2 -0
  655. package/dist/runtime/run-spec/index.d.ts.map +1 -1
  656. package/dist/runtime/run-spec/index.js +2 -0
  657. package/dist/runtime/run-spec/index.js.map +1 -1
  658. package/dist/runtime/run-spec/pending-dialogue-arbiter.d.ts +25 -0
  659. package/dist/runtime/run-spec/pending-dialogue-arbiter.d.ts.map +1 -0
  660. package/dist/runtime/run-spec/pending-dialogue-arbiter.js +81 -0
  661. package/dist/runtime/run-spec/pending-dialogue-arbiter.js.map +1 -0
  662. package/dist/runtime/run-spec/types.d.ts +91 -42
  663. package/dist/runtime/run-spec/types.d.ts.map +1 -1
  664. package/dist/runtime/run-spec/types.js +7 -0
  665. package/dist/runtime/run-spec/types.js.map +1 -1
  666. package/dist/runtime/schedule/engine-execution.js +2 -35
  667. package/dist/runtime/schedule/engine-execution.js.map +1 -1
  668. package/dist/runtime/schedule/history.d.ts +2 -2
  669. package/dist/runtime/schedule/presets.d.ts +4 -4
  670. package/dist/runtime/schedule/source.d.ts +1 -1
  671. package/dist/runtime/session-registry/registry.d.ts.map +1 -1
  672. package/dist/runtime/session-registry/registry.js +27 -2
  673. package/dist/runtime/session-registry/registry.js.map +1 -1
  674. package/dist/runtime/session-registry/types.d.ts +120 -112
  675. package/dist/runtime/session-registry/types.d.ts.map +1 -1
  676. package/dist/runtime/session-registry/types.js +1 -0
  677. package/dist/runtime/session-registry/types.js.map +1 -1
  678. package/dist/runtime/store/artifact-retention.d.ts +11 -6
  679. package/dist/runtime/store/artifact-retention.d.ts.map +1 -1
  680. package/dist/runtime/store/artifact-retention.js +0 -13
  681. package/dist/runtime/store/artifact-retention.js.map +1 -1
  682. package/dist/runtime/store/background-run-store.d.ts +1 -0
  683. package/dist/runtime/store/background-run-store.d.ts.map +1 -1
  684. package/dist/runtime/store/background-run-store.js +1 -0
  685. package/dist/runtime/store/background-run-store.js.map +1 -1
  686. package/dist/runtime/store/budget-store.d.ts +8 -8
  687. package/dist/runtime/store/dream-checkpoints.d.ts +1 -1
  688. package/dist/runtime/store/dream-checkpoints.d.ts.map +1 -1
  689. package/dist/runtime/store/evaluator-results.d.ts +1 -1
  690. package/dist/runtime/store/evaluator-results.d.ts.map +1 -1
  691. package/dist/runtime/store/evidence-ledger.d.ts +39 -6377
  692. package/dist/runtime/store/evidence-ledger.d.ts.map +1 -1
  693. package/dist/runtime/store/evidence-ledger.js +415 -501
  694. package/dist/runtime/store/evidence-ledger.js.map +1 -1
  695. package/dist/runtime/store/evidence-types.d.ts +6378 -0
  696. package/dist/runtime/store/evidence-types.d.ts.map +1 -0
  697. package/dist/runtime/store/evidence-types.js +459 -0
  698. package/dist/runtime/store/evidence-types.js.map +1 -0
  699. package/dist/runtime/store/experiment-queue-store.d.ts +109 -109
  700. package/dist/runtime/store/experiment-queue-store.d.ts.map +1 -1
  701. package/dist/runtime/store/experiment-queue-store.js +1 -1
  702. package/dist/runtime/store/experiment-queue-store.js.map +1 -1
  703. package/dist/runtime/store/index.d.ts +4 -4
  704. package/dist/runtime/store/index.d.ts.map +1 -1
  705. package/dist/runtime/store/index.js +2 -2
  706. package/dist/runtime/store/index.js.map +1 -1
  707. package/dist/runtime/store/metric-history.d.ts +1 -1
  708. package/dist/runtime/store/metric-history.d.ts.map +1 -1
  709. package/dist/runtime/store/operator-handoff-store.d.ts +12 -12
  710. package/dist/runtime/store/postmortem-report.d.ts +38 -38
  711. package/dist/runtime/store/postmortem-report.js.map +1 -1
  712. package/dist/runtime/store/proactive-intervention-store.d.ts +8 -8
  713. package/dist/runtime/store/reproducibility-manifest.d.ts +27 -27
  714. package/dist/runtime/store/reproducibility-manifest.d.ts.map +1 -1
  715. package/dist/runtime/store/reproducibility-manifest.js.map +1 -1
  716. package/dist/runtime/store/research-evidence.d.ts +1 -1
  717. package/dist/runtime/store/research-evidence.d.ts.map +1 -1
  718. package/dist/runtime/store/runtime-operation-schemas.d.ts +46 -46
  719. package/dist/runtime/store/runtime-schemas.d.ts +73 -12
  720. package/dist/runtime/store/runtime-schemas.d.ts.map +1 -1
  721. package/dist/runtime/store/runtime-schemas.js +9 -0
  722. package/dist/runtime/store/runtime-schemas.js.map +1 -1
  723. package/dist/runtime/types/companion.d.ts +394 -0
  724. package/dist/runtime/types/companion.d.ts.map +1 -0
  725. package/dist/runtime/types/companion.js +87 -0
  726. package/dist/runtime/types/companion.js.map +1 -0
  727. package/dist/runtime/types/daemon.d.ts +3 -3
  728. package/dist/runtime/types/hook.d.ts +12 -12
  729. package/dist/runtime/types/schedule.d.ts +32 -32
  730. package/dist/tools/builtin/exports.d.ts +2 -0
  731. package/dist/tools/builtin/exports.d.ts.map +1 -1
  732. package/dist/tools/builtin/exports.js +2 -0
  733. package/dist/tools/builtin/exports.js.map +1 -1
  734. package/dist/tools/builtin/factory.d.ts +10 -1
  735. package/dist/tools/builtin/factory.d.ts.map +1 -1
  736. package/dist/tools/builtin/factory.js +18 -1
  737. package/dist/tools/builtin/factory.js.map +1 -1
  738. package/dist/tools/executor.d.ts.map +1 -1
  739. package/dist/tools/executor.js +8 -6
  740. package/dist/tools/executor.js.map +1 -1
  741. package/dist/tools/fs/ApplyPatchTool/ApplyPatchTool.d.ts.map +1 -1
  742. package/dist/tools/fs/ApplyPatchTool/ApplyPatchTool.js +1 -0
  743. package/dist/tools/fs/ApplyPatchTool/ApplyPatchTool.js.map +1 -1
  744. package/dist/tools/fs/FileEditTool/FileEditTool.d.ts.map +1 -1
  745. package/dist/tools/fs/FileEditTool/FileEditTool.js +1 -0
  746. package/dist/tools/fs/FileEditTool/FileEditTool.js.map +1 -1
  747. package/dist/tools/fs/FileWriteTool/FileWriteTool.d.ts.map +1 -1
  748. package/dist/tools/fs/FileWriteTool/FileWriteTool.js +1 -0
  749. package/dist/tools/fs/FileWriteTool/FileWriteTool.js.map +1 -1
  750. package/dist/tools/fs/GlobTool/GlobTool.d.ts.map +1 -1
  751. package/dist/tools/fs/GlobTool/GlobTool.js +1 -0
  752. package/dist/tools/fs/GlobTool/GlobTool.js.map +1 -1
  753. package/dist/tools/fs/GrepTool/GrepTool.d.ts.map +1 -1
  754. package/dist/tools/fs/GrepTool/GrepTool.js +1 -0
  755. package/dist/tools/fs/GrepTool/GrepTool.js.map +1 -1
  756. package/dist/tools/fs/JsonQueryTool/JsonQueryTool.d.ts.map +1 -1
  757. package/dist/tools/fs/JsonQueryTool/JsonQueryTool.js +1 -0
  758. package/dist/tools/fs/JsonQueryTool/JsonQueryTool.js.map +1 -1
  759. package/dist/tools/fs/ListDirTool/ListDirTool.d.ts.map +1 -1
  760. package/dist/tools/fs/ListDirTool/ListDirTool.js +1 -0
  761. package/dist/tools/fs/ListDirTool/ListDirTool.js.map +1 -1
  762. package/dist/tools/fs/ReadTool/ReadTool.d.ts.map +1 -1
  763. package/dist/tools/fs/ReadTool/ReadTool.js +1 -0
  764. package/dist/tools/fs/ReadTool/ReadTool.js.map +1 -1
  765. package/dist/tools/kaggle/KaggleSubmissionTools.d.ts +4 -4
  766. package/dist/tools/kaggle/metrics.d.ts +4 -4
  767. package/dist/tools/mutation/TaskCreateTool/TaskCreateTool.d.ts +4 -4
  768. package/dist/tools/mutation/TaskUpdateTool/TaskUpdateTool.d.ts +4 -4
  769. package/dist/tools/network/GitHubCliTool/GitHubCliTool.d.ts +8 -8
  770. package/dist/tools/network/HttpFetchTool/HttpFetchTool.d.ts.map +1 -1
  771. package/dist/tools/network/HttpFetchTool/HttpFetchTool.js +1 -0
  772. package/dist/tools/network/HttpFetchTool/HttpFetchTool.js.map +1 -1
  773. package/dist/tools/network/WebSearchTool/WebSearchTool.d.ts.map +1 -1
  774. package/dist/tools/network/WebSearchTool/WebSearchTool.js +1 -0
  775. package/dist/tools/network/WebSearchTool/WebSearchTool.js.map +1 -1
  776. package/dist/tools/query/ArchitectureTool/ArchitectureTool.js +3 -3
  777. package/dist/tools/query/ArchitectureTool/ArchitectureTool.js.map +1 -1
  778. package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.d.ts +20 -20
  779. package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.d.ts.map +1 -1
  780. package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.js +1 -0
  781. package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.js.map +1 -1
  782. package/dist/tools/query/CodeSearchRepairTool/CodeSearchRepairTool.d.ts.map +1 -1
  783. package/dist/tools/query/CodeSearchRepairTool/CodeSearchRepairTool.js +1 -0
  784. package/dist/tools/query/CodeSearchRepairTool/CodeSearchRepairTool.js.map +1 -1
  785. package/dist/tools/query/CodeSearchTool/CodeSearchTool.d.ts.map +1 -1
  786. package/dist/tools/query/CodeSearchTool/CodeSearchTool.js +1 -0
  787. package/dist/tools/query/CodeSearchTool/CodeSearchTool.js.map +1 -1
  788. package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.d.ts.map +1 -1
  789. package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.js +1 -0
  790. package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.js.map +1 -1
  791. package/dist/tools/query/SkillSearchTool/SkillSearchTool.d.ts.map +1 -1
  792. package/dist/tools/query/SkillSearchTool/SkillSearchTool.js +1 -0
  793. package/dist/tools/query/SkillSearchTool/SkillSearchTool.js.map +1 -1
  794. package/dist/tools/query/ToolSearchTool/ToolSearchTool.d.ts.map +1 -1
  795. package/dist/tools/query/ToolSearchTool/ToolSearchTool.js +1 -0
  796. package/dist/tools/query/ToolSearchTool/ToolSearchTool.js.map +1 -1
  797. package/dist/tools/runtime/LongRunningRuntimeTools.d.ts +32 -32
  798. package/dist/tools/runtime/RunSpecHandoffTools.d.ts +12 -0
  799. package/dist/tools/runtime/RunSpecHandoffTools.d.ts.map +1 -0
  800. package/dist/tools/runtime/RunSpecHandoffTools.js +224 -0
  801. package/dist/tools/runtime/RunSpecHandoffTools.js.map +1 -0
  802. package/dist/tools/runtime/SetupRuntimeControlTools.d.ts +11 -0
  803. package/dist/tools/runtime/SetupRuntimeControlTools.d.ts.map +1 -0
  804. package/dist/tools/runtime/SetupRuntimeControlTools.js +463 -0
  805. package/dist/tools/runtime/SetupRuntimeControlTools.js.map +1 -0
  806. package/dist/tools/schedule/CreateScheduleTool/CreateScheduleTool.d.ts +28 -28
  807. package/dist/tools/schedule/UpdateScheduleTool/UpdateScheduleTool.d.ts +32 -32
  808. package/dist/tools/system/GitDiffTool/GitDiffTool.d.ts.map +1 -1
  809. package/dist/tools/system/GitDiffTool/GitDiffTool.js +1 -0
  810. package/dist/tools/system/GitDiffTool/GitDiffTool.js.map +1 -1
  811. package/dist/tools/system/GitLogTool/GitLogTool.d.ts.map +1 -1
  812. package/dist/tools/system/GitLogTool/GitLogTool.js +1 -0
  813. package/dist/tools/system/GitLogTool/GitLogTool.js.map +1 -1
  814. package/dist/tools/system/ShellTool/ShellTool.d.ts.map +1 -1
  815. package/dist/tools/system/ShellTool/ShellTool.js +1 -0
  816. package/dist/tools/system/ShellTool/ShellTool.js.map +1 -1
  817. package/dist/tools/system/TestRunnerTool/TestRunnerTool.d.ts.map +1 -1
  818. package/dist/tools/system/TestRunnerTool/TestRunnerTool.js +1 -0
  819. package/dist/tools/system/TestRunnerTool/TestRunnerTool.js.map +1 -1
  820. package/dist/tools/system/UpdatePlanTool/UpdatePlanTool.d.ts.map +1 -1
  821. package/dist/tools/system/UpdatePlanTool/UpdatePlanTool.js +1 -0
  822. package/dist/tools/system/UpdatePlanTool/UpdatePlanTool.js.map +1 -1
  823. package/dist/tools/types.d.ts +62 -2
  824. package/dist/tools/types.d.ts.map +1 -1
  825. package/dist/tools/types.js +25 -0
  826. package/dist/tools/types.js.map +1 -1
  827. package/package.json +1 -1
  828. package/dist/interface/tui/approval-overlay.d.ts +0 -8
  829. package/dist/interface/tui/approval-overlay.d.ts.map +0 -1
  830. package/dist/interface/tui/approval-overlay.js +0 -21
  831. 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);