@aria-cli/cli 1.0.56 → 1.0.58

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 (622) hide show
  1. package/bin/aria.mjs +2 -2
  2. package/package.json +17 -76
  3. package/dist/.tsbuildinfo +0 -1
  4. package/dist/attached-local-control-client.js +0 -826
  5. package/dist/attached-local-control-client.js.map +0 -1
  6. package/dist/bootstrap-local-control-client.js +0 -2
  7. package/dist/bootstrap-local-control-client.js.map +0 -1
  8. package/dist/capability-aware-method-proxy.js +0 -42
  9. package/dist/capability-aware-method-proxy.js.map +0 -1
  10. package/dist/cli-context.js +0 -160
  11. package/dist/cli-context.js.map +0 -1
  12. package/dist/commands/arions.js +0 -174
  13. package/dist/commands/arions.js.map +0 -1
  14. package/dist/commands/auth.js +0 -123
  15. package/dist/commands/auth.js.map +0 -1
  16. package/dist/commands/daemon.js +0 -367
  17. package/dist/commands/daemon.js.map +0 -1
  18. package/dist/commands/definitions.js +0 -176
  19. package/dist/commands/definitions.js.map +0 -1
  20. package/dist/commands/index.js +0 -80
  21. package/dist/commands/index.js.map +0 -1
  22. package/dist/commands/login-handler.js +0 -1108
  23. package/dist/commands/login-handler.js.map +0 -1
  24. package/dist/commands/logout-handler.js +0 -92
  25. package/dist/commands/logout-handler.js.map +0 -1
  26. package/dist/commands/memory-handlers.js +0 -89
  27. package/dist/commands/memory-handlers.js.map +0 -1
  28. package/dist/commands/pairing.js +0 -60
  29. package/dist/commands/pairing.js.map +0 -1
  30. package/dist/commands/runtime-cutover-reset-command.js +0 -12
  31. package/dist/commands/runtime-cutover-reset-command.js.map +0 -1
  32. package/dist/commands/runtime-cutover-reset.js +0 -265
  33. package/dist/commands/runtime-cutover-reset.js.map +0 -1
  34. package/dist/commands/terminal-setup.js +0 -84
  35. package/dist/commands/terminal-setup.js.map +0 -1
  36. package/dist/config/aria-config.js +0 -238
  37. package/dist/config/aria-config.js.map +0 -1
  38. package/dist/config/index.js +0 -3
  39. package/dist/config/index.js.map +0 -1
  40. package/dist/config/loader.js +0 -97
  41. package/dist/config/loader.js.map +0 -1
  42. package/dist/config.js +0 -142
  43. package/dist/config.js.map +0 -1
  44. package/dist/daemon-info.js +0 -10
  45. package/dist/daemon-info.js.map +0 -1
  46. package/dist/ensure-daemon.js +0 -128
  47. package/dist/ensure-daemon.js.map +0 -1
  48. package/dist/entrypoints/command-mode.js +0 -5
  49. package/dist/entrypoints/command-mode.js.map +0 -1
  50. package/dist/entrypoints/daemon.js +0 -50
  51. package/dist/entrypoints/daemon.js.map +0 -1
  52. package/dist/entrypoints/headless-stdio.js +0 -25
  53. package/dist/entrypoints/headless-stdio.js.map +0 -1
  54. package/dist/entrypoints/interactive.d.ts.map +0 -1
  55. package/dist/entrypoints/interactive.js +0 -80
  56. package/dist/entrypoints/interactive.js.map +0 -1
  57. package/dist/event-loop-watchdog.js +0 -73
  58. package/dist/event-loop-watchdog.js.map +0 -1
  59. package/dist/headless/auth-orchestrator.js +0 -508
  60. package/dist/headless/auth-orchestrator.js.map +0 -1
  61. package/dist/headless/auth-service.js +0 -43
  62. package/dist/headless/auth-service.js.map +0 -1
  63. package/dist/headless/bootstrap-fast-path.js +0 -112
  64. package/dist/headless/bootstrap-fast-path.js.map +0 -1
  65. package/dist/headless/call-command.js +0 -143
  66. package/dist/headless/call-command.js.map +0 -1
  67. package/dist/headless/daemon-service.js +0 -318
  68. package/dist/headless/daemon-service.js.map +0 -1
  69. package/dist/headless/hook-actions.js +0 -235
  70. package/dist/headless/hook-actions.js.map +0 -1
  71. package/dist/headless/hook-service.js +0 -42
  72. package/dist/headless/hook-service.js.map +0 -1
  73. package/dist/headless/kernel-services.js +0 -216
  74. package/dist/headless/kernel-services.js.map +0 -1
  75. package/dist/headless/kernel.js +0 -785
  76. package/dist/headless/kernel.js.map +0 -1
  77. package/dist/headless/operations/arion.js +0 -119
  78. package/dist/headless/operations/arion.js.map +0 -1
  79. package/dist/headless/operations/auth.js +0 -45
  80. package/dist/headless/operations/auth.js.map +0 -1
  81. package/dist/headless/operations/client.js +0 -31
  82. package/dist/headless/operations/client.js.map +0 -1
  83. package/dist/headless/operations/config.js +0 -69
  84. package/dist/headless/operations/config.js.map +0 -1
  85. package/dist/headless/operations/daemon.js +0 -47
  86. package/dist/headless/operations/daemon.js.map +0 -1
  87. package/dist/headless/operations/hook.js +0 -56
  88. package/dist/headless/operations/hook.js.map +0 -1
  89. package/dist/headless/operations/index.js +0 -11
  90. package/dist/headless/operations/index.js.map +0 -1
  91. package/dist/headless/operations/memory.js +0 -102
  92. package/dist/headless/operations/memory.js.map +0 -1
  93. package/dist/headless/operations/message.js +0 -279
  94. package/dist/headless/operations/message.js.map +0 -1
  95. package/dist/headless/operations/model.js +0 -100
  96. package/dist/headless/operations/model.js.map +0 -1
  97. package/dist/headless/operations/peer.js +0 -56
  98. package/dist/headless/operations/peer.js.map +0 -1
  99. package/dist/headless/operations/run.js +0 -24
  100. package/dist/headless/operations/run.js.map +0 -1
  101. package/dist/headless/operations/session.js +0 -90
  102. package/dist/headless/operations/session.js.map +0 -1
  103. package/dist/headless/operations/system.js +0 -19
  104. package/dist/headless/operations/system.js.map +0 -1
  105. package/dist/headless/operations/utils.js +0 -35
  106. package/dist/headless/operations/utils.js.map +0 -1
  107. package/dist/headless/run-orchestrator.js +0 -703
  108. package/dist/headless/run-orchestrator.js.map +0 -1
  109. package/dist/headless/stdio-server.js +0 -439
  110. package/dist/headless/stdio-server.js.map +0 -1
  111. package/dist/history/SessionHistory.js +0 -8
  112. package/dist/history/SessionHistory.js.map +0 -1
  113. package/dist/history/SessionHistoryClient.js +0 -186
  114. package/dist/history/SessionHistoryClient.js.map +0 -1
  115. package/dist/history/conversation-message.js +0 -112
  116. package/dist/history/conversation-message.js.map +0 -1
  117. package/dist/history/index.js +0 -8
  118. package/dist/history/index.js.map +0 -1
  119. package/dist/history/jsonl-replay.js +0 -154
  120. package/dist/history/jsonl-replay.js.map +0 -1
  121. package/dist/history/repair-tool-pairing.js +0 -84
  122. package/dist/history/repair-tool-pairing.js.map +0 -1
  123. package/dist/history/stall-phase-bridge.js +0 -11
  124. package/dist/history/stall-phase-bridge.js.map +0 -1
  125. package/dist/history/turn-accumulator.js +0 -427
  126. package/dist/history/turn-accumulator.js.map +0 -1
  127. package/dist/index.d.ts.map +0 -1
  128. package/dist/index.js +0 -7
  129. package/dist/index.js.map +0 -1
  130. package/dist/ink-repl.d.ts.map +0 -1
  131. package/dist/ink-repl.js +0 -4183
  132. package/dist/ink-repl.js.map +0 -1
  133. package/dist/local-control-bootstrap.js +0 -26
  134. package/dist/local-control-bootstrap.js.map +0 -1
  135. package/dist/local-control-client.js +0 -2
  136. package/dist/local-control-client.js.map +0 -1
  137. package/dist/local-control-error-reporting.js +0 -34
  138. package/dist/local-control-error-reporting.js.map +0 -1
  139. package/dist/local-control-http-client.js +0 -362
  140. package/dist/local-control-http-client.js.map +0 -1
  141. package/dist/local-control-lazy-wrapper.js +0 -363
  142. package/dist/local-control-lazy-wrapper.js.map +0 -1
  143. package/dist/local-control-manager.js +0 -146
  144. package/dist/local-control-manager.js.map +0 -1
  145. package/dist/main.d.ts.map +0 -1
  146. package/dist/main.js +0 -62
  147. package/dist/main.js.map +0 -1
  148. package/dist/network-security.js +0 -62
  149. package/dist/network-security.js.map +0 -1
  150. package/dist/networking-server.js +0 -38
  151. package/dist/networking-server.js.map +0 -1
  152. package/dist/peer-identity.js +0 -23
  153. package/dist/peer-identity.js.map +0 -1
  154. package/dist/polling-subscription.js +0 -34
  155. package/dist/polling-subscription.js.map +0 -1
  156. package/dist/relaunch.d.ts +0 -63
  157. package/dist/relaunch.d.ts.map +0 -1
  158. package/dist/relaunch.js +0 -617
  159. package/dist/relaunch.js.map +0 -1
  160. package/dist/release-notes.js +0 -35
  161. package/dist/release-notes.js.map +0 -1
  162. package/dist/repl-cleanup.js +0 -47
  163. package/dist/repl-cleanup.js.map +0 -1
  164. package/dist/runtime/configure-bun-sqlite.js +0 -3
  165. package/dist/runtime/configure-bun-sqlite.js.map +0 -1
  166. package/dist/runtime/crash-handlers.js +0 -111
  167. package/dist/runtime/crash-handlers.js.map +0 -1
  168. package/dist/runtime/interactive-invocation.js +0 -39
  169. package/dist/runtime/interactive-invocation.js.map +0 -1
  170. package/dist/runtime/internal-mode.js +0 -14
  171. package/dist/runtime/internal-mode.js.map +0 -1
  172. package/dist/runtime/launch-spec.js +0 -64
  173. package/dist/runtime/launch-spec.js.map +0 -1
  174. package/dist/runtime/owner-lease.js +0 -44
  175. package/dist/runtime/owner-lease.js.map +0 -1
  176. package/dist/runtime/public-mode.js +0 -20
  177. package/dist/runtime/public-mode.js.map +0 -1
  178. package/dist/runtime/run-internal-mode.d.ts.map +0 -1
  179. package/dist/runtime/run-internal-mode.js +0 -18
  180. package/dist/runtime/run-internal-mode.js.map +0 -1
  181. package/dist/runtime/runtime-kind.js +0 -32
  182. package/dist/runtime/runtime-kind.js.map +0 -1
  183. package/dist/runtime/spawn-aria.js +0 -38
  184. package/dist/runtime/spawn-aria.js.map +0 -1
  185. package/dist/selectable-client.js +0 -2
  186. package/dist/selectable-client.js.map +0 -1
  187. package/dist/selectable-peer.js +0 -2
  188. package/dist/selectable-peer.js.map +0 -1
  189. package/dist/session.js +0 -203
  190. package/dist/session.js.map +0 -1
  191. package/dist/slash-commands.js +0 -80
  192. package/dist/slash-commands.js.map +0 -1
  193. package/dist/sounds.js +0 -210
  194. package/dist/sounds.js.map +0 -1
  195. package/dist/ui/App.js +0 -526
  196. package/dist/ui/App.js.map +0 -1
  197. package/dist/ui/components/AnthropicMethodPicker.js +0 -6
  198. package/dist/ui/components/AnthropicMethodPicker.js.map +0 -1
  199. package/dist/ui/components/ArionPrompt.js +0 -15
  200. package/dist/ui/components/ArionPrompt.js.map +0 -1
  201. package/dist/ui/components/AutocompleteDropdown.js +0 -23
  202. package/dist/ui/components/AutocompleteDropdown.js.map +0 -1
  203. package/dist/ui/components/AutonomySelector.js +0 -55
  204. package/dist/ui/components/AutonomySelector.js.map +0 -1
  205. package/dist/ui/components/Banner.js +0 -98
  206. package/dist/ui/components/Banner.js.map +0 -1
  207. package/dist/ui/components/ConversationHistory.js +0 -175
  208. package/dist/ui/components/ConversationHistory.js.map +0 -1
  209. package/dist/ui/components/CopilotDeviceLoginFlow.js +0 -88
  210. package/dist/ui/components/CopilotDeviceLoginFlow.js.map +0 -1
  211. package/dist/ui/components/CopilotSourcePicker.js +0 -50
  212. package/dist/ui/components/CopilotSourcePicker.js.map +0 -1
  213. package/dist/ui/components/Cost.js +0 -10
  214. package/dist/ui/components/Cost.js.map +0 -1
  215. package/dist/ui/components/CustomSelect/option-map.js +0 -30
  216. package/dist/ui/components/CustomSelect/option-map.js.map +0 -1
  217. package/dist/ui/components/CustomSelect/select-option.js +0 -13
  218. package/dist/ui/components/CustomSelect/select-option.js.map +0 -1
  219. package/dist/ui/components/CustomSelect/select.js +0 -42
  220. package/dist/ui/components/CustomSelect/select.js.map +0 -1
  221. package/dist/ui/components/CustomSelect/use-select-state.js +0 -179
  222. package/dist/ui/components/CustomSelect/use-select-state.js.map +0 -1
  223. package/dist/ui/components/CustomSelect/use-select.js +0 -15
  224. package/dist/ui/components/CustomSelect/use-select.js.map +0 -1
  225. package/dist/ui/components/ErrorDisplay.js +0 -35
  226. package/dist/ui/components/ErrorDisplay.js.map +0 -1
  227. package/dist/ui/components/FallbackToolUseRejectedMessage.js +0 -7
  228. package/dist/ui/components/FallbackToolUseRejectedMessage.js.map +0 -1
  229. package/dist/ui/components/FileEditToolUpdatedMessage.js +0 -57
  230. package/dist/ui/components/FileEditToolUpdatedMessage.js.map +0 -1
  231. package/dist/ui/components/HandoffMarker.js +0 -18
  232. package/dist/ui/components/HandoffMarker.js.map +0 -1
  233. package/dist/ui/components/HighlightedCode.js +0 -21
  234. package/dist/ui/components/HighlightedCode.js.map +0 -1
  235. package/dist/ui/components/InputArea.js +0 -187
  236. package/dist/ui/components/InputArea.js.map +0 -1
  237. package/dist/ui/components/Message.js +0 -25
  238. package/dist/ui/components/Message.js.map +0 -1
  239. package/dist/ui/components/OAuthLoginFlow.js +0 -113
  240. package/dist/ui/components/OAuthLoginFlow.js.map +0 -1
  241. package/dist/ui/components/OutputTruncation.js +0 -35
  242. package/dist/ui/components/OutputTruncation.js.map +0 -1
  243. package/dist/ui/components/PermissionPrompt.js +0 -79
  244. package/dist/ui/components/PermissionPrompt.js.map +0 -1
  245. package/dist/ui/components/PipelineTimingPanel.js +0 -15
  246. package/dist/ui/components/PipelineTimingPanel.js.map +0 -1
  247. package/dist/ui/components/ProviderMethodPicker.js +0 -61
  248. package/dist/ui/components/ProviderMethodPicker.js.map +0 -1
  249. package/dist/ui/components/ProviderPicker.js +0 -63
  250. package/dist/ui/components/ProviderPicker.js.map +0 -1
  251. package/dist/ui/components/RenderItemView.js +0 -71
  252. package/dist/ui/components/RenderItemView.js.map +0 -1
  253. package/dist/ui/components/Spinner.js +0 -46
  254. package/dist/ui/components/Spinner.js.map +0 -1
  255. package/dist/ui/components/StatusBar.js +0 -95
  256. package/dist/ui/components/StatusBar.js.map +0 -1
  257. package/dist/ui/components/StreamingIndicator.js +0 -55
  258. package/dist/ui/components/StreamingIndicator.js.map +0 -1
  259. package/dist/ui/components/StructuredDiff.js +0 -168
  260. package/dist/ui/components/StructuredDiff.js.map +0 -1
  261. package/dist/ui/components/TextInputOverlay.js +0 -43
  262. package/dist/ui/components/TextInputOverlay.js.map +0 -1
  263. package/dist/ui/components/ThinkingBlock.js +0 -82
  264. package/dist/ui/components/ThinkingBlock.js.map +0 -1
  265. package/dist/ui/components/ToolCost.js +0 -17
  266. package/dist/ui/components/ToolCost.js.map +0 -1
  267. package/dist/ui/components/ToolExecution.js +0 -61
  268. package/dist/ui/components/ToolExecution.js.map +0 -1
  269. package/dist/ui/components/ToolHeader.js +0 -51
  270. package/dist/ui/components/ToolHeader.js.map +0 -1
  271. package/dist/ui/components/ToolRenderLayoutContext.js +0 -14
  272. package/dist/ui/components/ToolRenderLayoutContext.js.map +0 -1
  273. package/dist/ui/components/ToolResultWrapper.js +0 -6
  274. package/dist/ui/components/ToolResultWrapper.js.map +0 -1
  275. package/dist/ui/components/ToolUseLoader.js +0 -35
  276. package/dist/ui/components/ToolUseLoader.js.map +0 -1
  277. package/dist/ui/components/TraceWaterfall.js +0 -91
  278. package/dist/ui/components/TraceWaterfall.js.map +0 -1
  279. package/dist/ui/components/index.js +0 -33
  280. package/dist/ui/components/index.js.map +0 -1
  281. package/dist/ui/components/messages/AssistantTextMessage.js +0 -25
  282. package/dist/ui/components/messages/AssistantTextMessage.js.map +0 -1
  283. package/dist/ui/components/messages/UserImageMessage.js +0 -12
  284. package/dist/ui/components/messages/UserImageMessage.js.map +0 -1
  285. package/dist/ui/components/messages/UserTextMessage.js +0 -12
  286. package/dist/ui/components/messages/UserTextMessage.js.map +0 -1
  287. package/dist/ui/components/overlays/ArionSelector.js +0 -68
  288. package/dist/ui/components/overlays/ArionSelector.js.map +0 -1
  289. package/dist/ui/components/overlays/ClientSelector.js +0 -62
  290. package/dist/ui/components/overlays/ClientSelector.js.map +0 -1
  291. package/dist/ui/components/overlays/CommandPalette.js +0 -67
  292. package/dist/ui/components/overlays/CommandPalette.js.map +0 -1
  293. package/dist/ui/components/overlays/DaemonControl.js +0 -87
  294. package/dist/ui/components/overlays/DaemonControl.js.map +0 -1
  295. package/dist/ui/components/overlays/InviteShareOverlay.js +0 -15
  296. package/dist/ui/components/overlays/InviteShareOverlay.js.map +0 -1
  297. package/dist/ui/components/overlays/JoinInviteOverlay.js +0 -32
  298. package/dist/ui/components/overlays/JoinInviteOverlay.js.map +0 -1
  299. package/dist/ui/components/overlays/MemoryBrowser.js +0 -100
  300. package/dist/ui/components/overlays/MemoryBrowser.js.map +0 -1
  301. package/dist/ui/components/overlays/MessageSelector.js +0 -123
  302. package/dist/ui/components/overlays/MessageSelector.js.map +0 -1
  303. package/dist/ui/components/overlays/ModelSelector.js +0 -211
  304. package/dist/ui/components/overlays/ModelSelector.js.map +0 -1
  305. package/dist/ui/components/overlays/PairRequestOverlay.js +0 -42
  306. package/dist/ui/components/overlays/PairRequestOverlay.js.map +0 -1
  307. package/dist/ui/components/overlays/PeerSelector.js +0 -84
  308. package/dist/ui/components/overlays/PeerSelector.js.map +0 -1
  309. package/dist/ui/components/overlays/SessionSelector.js +0 -102
  310. package/dist/ui/components/overlays/SessionSelector.js.map +0 -1
  311. package/dist/ui/components/overlays/SoundSelector.js +0 -86
  312. package/dist/ui/components/overlays/SoundSelector.js.map +0 -1
  313. package/dist/ui/components/overlays/ThemeSelector.js +0 -139
  314. package/dist/ui/components/overlays/ThemeSelector.js.map +0 -1
  315. package/dist/ui/components/overlays/index.js +0 -15
  316. package/dist/ui/components/overlays/index.js.map +0 -1
  317. package/dist/ui/components/permissions/BashPermissionRequest/BashPermissionRequest.js +0 -53
  318. package/dist/ui/components/permissions/BashPermissionRequest/BashPermissionRequest.js.map +0 -1
  319. package/dist/ui/components/permissions/FallbackPermissionRequest.js +0 -56
  320. package/dist/ui/components/permissions/FallbackPermissionRequest.js.map +0 -1
  321. package/dist/ui/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +0 -76
  322. package/dist/ui/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js.map +0 -1
  323. package/dist/ui/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +0 -18
  324. package/dist/ui/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js.map +0 -1
  325. package/dist/ui/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +0 -64
  326. package/dist/ui/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js.map +0 -1
  327. package/dist/ui/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +0 -26
  328. package/dist/ui/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js.map +0 -1
  329. package/dist/ui/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +0 -141
  330. package/dist/ui/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js.map +0 -1
  331. package/dist/ui/components/permissions/PermissionRequest.js +0 -70
  332. package/dist/ui/components/permissions/PermissionRequest.js.map +0 -1
  333. package/dist/ui/components/permissions/PermissionRequestTitle.js +0 -41
  334. package/dist/ui/components/permissions/PermissionRequestTitle.js.map +0 -1
  335. package/dist/ui/components/permissions/hooks.js +0 -10
  336. package/dist/ui/components/permissions/hooks.js.map +0 -1
  337. package/dist/ui/components/permissions/toolUseOptions.js +0 -68
  338. package/dist/ui/components/permissions/toolUseOptions.js.map +0 -1
  339. package/dist/ui/components/permissions/utils.js +0 -10
  340. package/dist/ui/components/permissions/utils.js.map +0 -1
  341. package/dist/ui/components/text-input/Cursor.js +0 -326
  342. package/dist/ui/components/text-input/Cursor.js.map +0 -1
  343. package/dist/ui/components/text-input/TextInput.js +0 -231
  344. package/dist/ui/components/text-input/TextInput.js.map +0 -1
  345. package/dist/ui/components/text-input/imagePaste.js +0 -28
  346. package/dist/ui/components/text-input/imagePaste.js.map +0 -1
  347. package/dist/ui/components/text-input/index.js +0 -6
  348. package/dist/ui/components/text-input/index.js.map +0 -1
  349. package/dist/ui/components/text-input/useDoublePress.js +0 -30
  350. package/dist/ui/components/text-input/useDoublePress.js.map +0 -1
  351. package/dist/ui/components/text-input/useTextInput.js +0 -245
  352. package/dist/ui/components/text-input/useTextInput.js.map +0 -1
  353. package/dist/ui/components/tool-types.js +0 -9
  354. package/dist/ui/components/tool-types.js.map +0 -1
  355. package/dist/ui/constants/figures.js +0 -4
  356. package/dist/ui/constants/figures.js.map +0 -1
  357. package/dist/ui/constants/index.js +0 -3
  358. package/dist/ui/constants/index.js.map +0 -1
  359. package/dist/ui/display-mode.js +0 -93
  360. package/dist/ui/display-mode.js.map +0 -1
  361. package/dist/ui/display-policy.js +0 -19
  362. package/dist/ui/display-policy.js.map +0 -1
  363. package/dist/ui/hooks/index.js +0 -6
  364. package/dist/ui/hooks/index.js.map +0 -1
  365. package/dist/ui/hooks/useCommandAutocomplete.js +0 -93
  366. package/dist/ui/hooks/useCommandAutocomplete.js.map +0 -1
  367. package/dist/ui/hooks/useDoublePress.js +0 -37
  368. package/dist/ui/hooks/useDoublePress.js.map +0 -1
  369. package/dist/ui/hooks/useIndicatorState.js +0 -55
  370. package/dist/ui/hooks/useIndicatorState.js.map +0 -1
  371. package/dist/ui/hooks/useInterval.js +0 -23
  372. package/dist/ui/hooks/useInterval.js.map +0 -1
  373. package/dist/ui/hooks/useKeyboardShortcuts.js +0 -127
  374. package/dist/ui/hooks/useKeyboardShortcuts.js.map +0 -1
  375. package/dist/ui/hooks/useTerminalSize.js +0 -55
  376. package/dist/ui/hooks/useTerminalSize.js.map +0 -1
  377. package/dist/ui/hooks/useUnifiedMessages.js +0 -117
  378. package/dist/ui/hooks/useUnifiedMessages.js.map +0 -1
  379. package/dist/ui/indicator-state.js +0 -44
  380. package/dist/ui/indicator-state.js.map +0 -1
  381. package/dist/ui/markdown/highlight.js +0 -44
  382. package/dist/ui/markdown/highlight.js.map +0 -1
  383. package/dist/ui/markdown/index.js +0 -1460
  384. package/dist/ui/markdown/index.js.map +0 -1
  385. package/dist/ui/markdown/tokenizer.js +0 -24
  386. package/dist/ui/markdown/tokenizer.js.map +0 -1
  387. package/dist/ui/render-item.js +0 -5
  388. package/dist/ui/render-item.js.map +0 -1
  389. package/dist/ui/screens/REPL.js +0 -119
  390. package/dist/ui/screens/REPL.js.map +0 -1
  391. package/dist/ui/screens/approval-lifecycle.js +0 -38
  392. package/dist/ui/screens/approval-lifecycle.js.map +0 -1
  393. package/dist/ui/status-line.js +0 -72
  394. package/dist/ui/status-line.js.map +0 -1
  395. package/dist/ui/theme/index.js +0 -51
  396. package/dist/ui/theme/index.js.map +0 -1
  397. package/dist/ui/theme/themes/claude-dark-daltonized.js +0 -51
  398. package/dist/ui/theme/themes/claude-dark-daltonized.js.map +0 -1
  399. package/dist/ui/theme/themes/claude-dark.js +0 -50
  400. package/dist/ui/theme/themes/claude-dark.js.map +0 -1
  401. package/dist/ui/theme/themes/claude-light-daltonized.js +0 -51
  402. package/dist/ui/theme/themes/claude-light-daltonized.js.map +0 -1
  403. package/dist/ui/theme/themes/claude-light.js +0 -50
  404. package/dist/ui/theme/themes/claude-light.js.map +0 -1
  405. package/dist/ui/theme/themes/dark-accessible.js +0 -18
  406. package/dist/ui/theme/themes/dark-accessible.js.map +0 -1
  407. package/dist/ui/theme/themes/dark.js +0 -49
  408. package/dist/ui/theme/themes/dark.js.map +0 -1
  409. package/dist/ui/theme/themes/light-accessible.js +0 -18
  410. package/dist/ui/theme/themes/light-accessible.js.map +0 -1
  411. package/dist/ui/theme/themes/light.js +0 -49
  412. package/dist/ui/theme/themes/light.js.map +0 -1
  413. package/dist/ui/theme/types.js +0 -3
  414. package/dist/ui/theme/types.js.map +0 -1
  415. package/dist/ui/theme.js +0 -142
  416. package/dist/ui/theme.js.map +0 -1
  417. package/dist/ui/to-render-items.js +0 -145
  418. package/dist/ui/to-render-items.js.map +0 -1
  419. package/dist/ui/tools/AgentTool/index.js +0 -30
  420. package/dist/ui/tools/AgentTool/index.js.map +0 -1
  421. package/dist/ui/tools/ArchitectTool/index.js +0 -31
  422. package/dist/ui/tools/ArchitectTool/index.js.map +0 -1
  423. package/dist/ui/tools/AskUserTool/index.js +0 -46
  424. package/dist/ui/tools/AskUserTool/index.js.map +0 -1
  425. package/dist/ui/tools/BashTool/BashToolResultMessage.js +0 -11
  426. package/dist/ui/tools/BashTool/BashToolResultMessage.js.map +0 -1
  427. package/dist/ui/tools/BashTool/OutputLine.js +0 -21
  428. package/dist/ui/tools/BashTool/OutputLine.js.map +0 -1
  429. package/dist/ui/tools/BashTool/index.js +0 -91
  430. package/dist/ui/tools/BashTool/index.js.map +0 -1
  431. package/dist/ui/tools/BrowseTool/index.js +0 -43
  432. package/dist/ui/tools/BrowseTool/index.js.map +0 -1
  433. package/dist/ui/tools/BrowserTool/index.js +0 -47
  434. package/dist/ui/tools/BrowserTool/index.js.map +0 -1
  435. package/dist/ui/tools/CbmTool/index.js +0 -188
  436. package/dist/ui/tools/CbmTool/index.js.map +0 -1
  437. package/dist/ui/tools/CheckDelegationTool/index.js +0 -46
  438. package/dist/ui/tools/CheckDelegationTool/index.js.map +0 -1
  439. package/dist/ui/tools/CheckMessagesTool/index.js +0 -85
  440. package/dist/ui/tools/CheckMessagesTool/index.js.map +0 -1
  441. package/dist/ui/tools/CreateQuipTool/index.js +0 -30
  442. package/dist/ui/tools/CreateQuipTool/index.js.map +0 -1
  443. package/dist/ui/tools/CreateSkillTool/index.js +0 -22
  444. package/dist/ui/tools/CreateSkillTool/index.js.map +0 -1
  445. package/dist/ui/tools/CreateToolTool/index.js +0 -31
  446. package/dist/ui/tools/CreateToolTool/index.js.map +0 -1
  447. package/dist/ui/tools/DelegateRemoteTool/index.js +0 -42
  448. package/dist/ui/tools/DelegateRemoteTool/index.js.map +0 -1
  449. package/dist/ui/tools/DeployTool/index.js +0 -47
  450. package/dist/ui/tools/DeployTool/index.js.map +0 -1
  451. package/dist/ui/tools/FffTool/index.js +0 -103
  452. package/dist/ui/tools/FffTool/index.js.map +0 -1
  453. package/dist/ui/tools/FileEditTool/index.js +0 -67
  454. package/dist/ui/tools/FileEditTool/index.js.map +0 -1
  455. package/dist/ui/tools/FileReadTool/index.js +0 -68
  456. package/dist/ui/tools/FileReadTool/index.js.map +0 -1
  457. package/dist/ui/tools/FileWriteTool/index.js +0 -61
  458. package/dist/ui/tools/FileWriteTool/index.js.map +0 -1
  459. package/dist/ui/tools/ForkTool/index.js +0 -47
  460. package/dist/ui/tools/ForkTool/index.js.map +0 -1
  461. package/dist/ui/tools/FrgTool/index.js +0 -96
  462. package/dist/ui/tools/FrgTool/index.js.map +0 -1
  463. package/dist/ui/tools/GetThreadTool/index.js +0 -39
  464. package/dist/ui/tools/GetThreadTool/index.js.map +0 -1
  465. package/dist/ui/tools/GlobTool/index.js +0 -50
  466. package/dist/ui/tools/GlobTool/index.js.map +0 -1
  467. package/dist/ui/tools/GrepTool/index.js +0 -84
  468. package/dist/ui/tools/GrepTool/index.js.map +0 -1
  469. package/dist/ui/tools/HatchArionTool/index.js +0 -36
  470. package/dist/ui/tools/HatchArionTool/index.js.map +0 -1
  471. package/dist/ui/tools/LearnSkillTool/index.js +0 -22
  472. package/dist/ui/tools/LearnSkillTool/index.js.map +0 -1
  473. package/dist/ui/tools/LearnTool/index.js +0 -43
  474. package/dist/ui/tools/LearnTool/index.js.map +0 -1
  475. package/dist/ui/tools/LearnToolTool/index.js +0 -22
  476. package/dist/ui/tools/LearnToolTool/index.js.map +0 -1
  477. package/dist/ui/tools/ListClientsTool/index.js +0 -39
  478. package/dist/ui/tools/ListClientsTool/index.js.map +0 -1
  479. package/dist/ui/tools/LspTool/index.js +0 -261
  480. package/dist/ui/tools/LspTool/index.js.map +0 -1
  481. package/dist/ui/tools/MCPTool/index.js +0 -33
  482. package/dist/ui/tools/MCPTool/index.js.map +0 -1
  483. package/dist/ui/tools/ManageNetworkTool/index.js +0 -53
  484. package/dist/ui/tools/ManageNetworkTool/index.js.map +0 -1
  485. package/dist/ui/tools/MemoryReadTool/index.js +0 -64
  486. package/dist/ui/tools/MemoryReadTool/index.js.map +0 -1
  487. package/dist/ui/tools/MemoryWriteTool/index.js +0 -20
  488. package/dist/ui/tools/MemoryWriteTool/index.js.map +0 -1
  489. package/dist/ui/tools/NotebookEditTool/index.js +0 -33
  490. package/dist/ui/tools/NotebookEditTool/index.js.map +0 -1
  491. package/dist/ui/tools/NotebookReadTool/index.js +0 -25
  492. package/dist/ui/tools/NotebookReadTool/index.js.map +0 -1
  493. package/dist/ui/tools/OutlookReadTool/index.js +0 -66
  494. package/dist/ui/tools/OutlookReadTool/index.js.map +0 -1
  495. package/dist/ui/tools/OutlookReplyTool/index.js +0 -49
  496. package/dist/ui/tools/OutlookReplyTool/index.js.map +0 -1
  497. package/dist/ui/tools/OutlookSendTool/index.js +0 -49
  498. package/dist/ui/tools/OutlookSendTool/index.js.map +0 -1
  499. package/dist/ui/tools/PauseDelegationTool/index.js +0 -35
  500. package/dist/ui/tools/PauseDelegationTool/index.js.map +0 -1
  501. package/dist/ui/tools/ProbeTool/index.js +0 -121
  502. package/dist/ui/tools/ProbeTool/index.js.map +0 -1
  503. package/dist/ui/tools/ProcessTool/index.js +0 -66
  504. package/dist/ui/tools/ProcessTool/index.js.map +0 -1
  505. package/dist/ui/tools/QuestListTool/index.js +0 -46
  506. package/dist/ui/tools/QuestListTool/index.js.map +0 -1
  507. package/dist/ui/tools/QuestReportTool/index.js +0 -49
  508. package/dist/ui/tools/QuestReportTool/index.js.map +0 -1
  509. package/dist/ui/tools/QuestUpdateTool/index.js +0 -87
  510. package/dist/ui/tools/QuestUpdateTool/index.js.map +0 -1
  511. package/dist/ui/tools/QuipCommentTool/index.js +0 -69
  512. package/dist/ui/tools/QuipCommentTool/index.js.map +0 -1
  513. package/dist/ui/tools/QuipReadTool/index.js +0 -71
  514. package/dist/ui/tools/QuipReadTool/index.js.map +0 -1
  515. package/dist/ui/tools/RestArionTool/index.js +0 -32
  516. package/dist/ui/tools/RestArionTool/index.js.map +0 -1
  517. package/dist/ui/tools/RestartTool/index.js +0 -35
  518. package/dist/ui/tools/RestartTool/index.js.map +0 -1
  519. package/dist/ui/tools/ResumeDelegationTool/index.js +0 -35
  520. package/dist/ui/tools/ResumeDelegationTool/index.js.map +0 -1
  521. package/dist/ui/tools/RetireArionTool/index.js +0 -32
  522. package/dist/ui/tools/RetireArionTool/index.js.map +0 -1
  523. package/dist/ui/tools/RgTool/index.js +0 -73
  524. package/dist/ui/tools/RgTool/index.js.map +0 -1
  525. package/dist/ui/tools/SearchKnowledgeTool/index.js +0 -43
  526. package/dist/ui/tools/SearchKnowledgeTool/index.js.map +0 -1
  527. package/dist/ui/tools/SearchMessagesTool/index.js +0 -43
  528. package/dist/ui/tools/SearchMessagesTool/index.js.map +0 -1
  529. package/dist/ui/tools/SelfDiagnoseTool/index.js +0 -61
  530. package/dist/ui/tools/SelfDiagnoseTool/index.js.map +0 -1
  531. package/dist/ui/tools/SendMessageTool/index.js +0 -45
  532. package/dist/ui/tools/SendMessageTool/index.js.map +0 -1
  533. package/dist/ui/tools/SerenaTool/index.js +0 -124
  534. package/dist/ui/tools/SerenaTool/index.js.map +0 -1
  535. package/dist/ui/tools/SessionHistoryTool/index.js +0 -52
  536. package/dist/ui/tools/SessionHistoryTool/index.js.map +0 -1
  537. package/dist/ui/tools/SgTool/index.js +0 -80
  538. package/dist/ui/tools/SgTool/index.js.map +0 -1
  539. package/dist/ui/tools/SlackReactTool/index.js +0 -41
  540. package/dist/ui/tools/SlackReactTool/index.js.map +0 -1
  541. package/dist/ui/tools/SlackReadTool/index.js +0 -48
  542. package/dist/ui/tools/SlackReadTool/index.js.map +0 -1
  543. package/dist/ui/tools/SlackSendTool/index.js +0 -45
  544. package/dist/ui/tools/SlackSendTool/index.js.map +0 -1
  545. package/dist/ui/tools/SpawnWorkerTool/index.js +0 -33
  546. package/dist/ui/tools/SpawnWorkerTool/index.js.map +0 -1
  547. package/dist/ui/tools/StickerRequestTool/index.js +0 -19
  548. package/dist/ui/tools/StickerRequestTool/index.js.map +0 -1
  549. package/dist/ui/tools/ThinkTool/index.js +0 -17
  550. package/dist/ui/tools/ThinkTool/index.js.map +0 -1
  551. package/dist/ui/tools/UgTool/index.js +0 -108
  552. package/dist/ui/tools/UgTool/index.js.map +0 -1
  553. package/dist/ui/tools/UseSkillTool/index.js +0 -22
  554. package/dist/ui/tools/UseSkillTool/index.js.map +0 -1
  555. package/dist/ui/tools/WakeArionTool/index.js +0 -32
  556. package/dist/ui/tools/WakeArionTool/index.js.map +0 -1
  557. package/dist/ui/tools/WebFetchTool/index.js +0 -56
  558. package/dist/ui/tools/WebFetchTool/index.js.map +0 -1
  559. package/dist/ui/tools/WebSearchTool/index.js +0 -44
  560. package/dist/ui/tools/WebSearchTool/index.js.map +0 -1
  561. package/dist/ui/tools/lsTool/index.js +0 -58
  562. package/dist/ui/tools/lsTool/index.js.map +0 -1
  563. package/dist/ui/tools/registry.js +0 -197
  564. package/dist/ui/tools/registry.js.map +0 -1
  565. package/dist/ui/tools/tool-renderer.js +0 -11
  566. package/dist/ui/tools/tool-renderer.js.map +0 -1
  567. package/dist/ui/tools/truncation.js +0 -35
  568. package/dist/ui/tools/truncation.js.map +0 -1
  569. package/dist/ui/types/anthropic.js +0 -4
  570. package/dist/ui/types/anthropic.js.map +0 -1
  571. package/dist/ui/types/index.js +0 -2
  572. package/dist/ui/types/index.js.map +0 -1
  573. package/dist/ui/types/message.js +0 -3
  574. package/dist/ui/types/message.js.map +0 -1
  575. package/dist/ui/types/tool.js +0 -4
  576. package/dist/ui/types/tool.js.map +0 -1
  577. package/dist/ui/utils/array.js +0 -4
  578. package/dist/ui/utils/array.js.map +0 -1
  579. package/dist/ui/utils/cursor.js +0 -131
  580. package/dist/ui/utils/cursor.js.map +0 -1
  581. package/dist/ui/utils/diff.js +0 -120
  582. package/dist/ui/utils/diff.js.map +0 -1
  583. package/dist/ui/utils/format.js +0 -42
  584. package/dist/ui/utils/format.js.map +0 -1
  585. package/dist/ui/utils/fuzzy.js +0 -59
  586. package/dist/ui/utils/fuzzy.js.map +0 -1
  587. package/dist/ui/utils/index.js +0 -11
  588. package/dist/ui/utils/index.js.map +0 -1
  589. package/dist/ui/utils/keys.js +0 -8
  590. package/dist/ui/utils/keys.js.map +0 -1
  591. package/dist/ui/utils/patch.js +0 -17
  592. package/dist/ui/utils/patch.js.map +0 -1
  593. package/dist/ui/utils/risk.js +0 -114
  594. package/dist/ui/utils/risk.js.map +0 -1
  595. package/dist/ui/utils/terminal-image.js +0 -70
  596. package/dist/ui/utils/terminal-image.js.map +0 -1
  597. package/dist/ui/utils/validation.js +0 -48
  598. package/dist/ui/utils/validation.js.map +0 -1
  599. package/dist/ui/verb-pairs.js +0 -248
  600. package/dist/ui/verb-pairs.js.map +0 -1
  601. package/dist/ui.js +0 -131
  602. package/dist/ui.js.map +0 -1
  603. package/src/entrypoints/command-mode.ts +0 -5
  604. package/src/entrypoints/daemon.ts +0 -54
  605. package/src/entrypoints/headless-stdio.ts +0 -27
  606. package/src/entrypoints/interactive.ts +0 -112
  607. package/src/main.ts +0 -72
  608. package/src/runtime/configure-bun-sqlite.ts +0 -3
  609. package/src/runtime/crash-handlers.ts +0 -128
  610. package/src/runtime/interactive-invocation.test.ts +0 -42
  611. package/src/runtime/interactive-invocation.ts +0 -51
  612. package/src/runtime/internal-mode.test.ts +0 -19
  613. package/src/runtime/internal-mode.ts +0 -24
  614. package/src/runtime/launch-spec.test.ts +0 -26
  615. package/src/runtime/launch-spec.ts +0 -84
  616. package/src/runtime/owner-lease.ts +0 -52
  617. package/src/runtime/public-mode.test.ts +0 -18
  618. package/src/runtime/public-mode.ts +0 -19
  619. package/src/runtime/run-internal-mode.ts +0 -19
  620. package/src/runtime/runtime-kind.test.ts +0 -23
  621. package/src/runtime/runtime-kind.ts +0 -41
  622. package/src/runtime/spawn-aria.ts +0 -62
@@ -1,703 +0,0 @@
1
- import { randomUUID } from "node:crypto";
2
- import { isDeepStrictEqual } from "node:util";
3
- import { setStallPhase, clearStallPhase } from "../event-loop-watchdog.js";
4
- import { resolveTrustedRuntimeErrorMessage } from "@aria-cli/tools";
5
- import { fromModelMessages } from "../history/conversation-message.js";
6
- const SESSION_LEASE_MS = 30_000;
7
- const SESSION_LEASE_RENEW_INTERVAL_MS = 10_000;
8
- function initialRunSynthesisState() {
9
- return {
10
- output: "",
11
- messages: [],
12
- toolCalls: [],
13
- usage: undefined,
14
- turnCount: 0,
15
- thinking: [],
16
- nativeToolResults: [],
17
- pipelineTiming: undefined,
18
- guardrailEvents: [],
19
- handoffs: [],
20
- pausedState: null,
21
- };
22
- }
23
- function synthesizeRunResult(state) {
24
- return {
25
- success: !state.pausedState,
26
- ...(state.output ? { output: state.output } : {}),
27
- ...(state.messages.length > 0 ? { messages: state.messages } : {}),
28
- ...(state.toolCalls.length > 0 ? { toolCalls: state.toolCalls } : {}),
29
- ...(state.usage !== undefined ? { usage: state.usage } : {}),
30
- ...(state.turnCount > 0 ? { turnCount: state.turnCount } : {}),
31
- ...(state.thinking.length > 0 ? { thinking: state.thinking } : {}),
32
- ...(state.nativeToolResults.length > 0 ? { nativeToolResults: state.nativeToolResults } : {}),
33
- ...(state.pipelineTiming !== undefined ? { pipelineTiming: state.pipelineTiming } : {}),
34
- ...(state.guardrailEvents.length > 0 ? { guardrailEvents: state.guardrailEvents } : {}),
35
- ...(state.handoffs.length > 0 ? { handoffs: state.handoffs } : {}),
36
- ...(state.pausedState ? { state: state.pausedState } : {}),
37
- };
38
- }
39
- function toHeadlessError(code, message, details) {
40
- return {
41
- code,
42
- message,
43
- ...(details ? { details } : {}),
44
- };
45
- }
46
- function toFailureResult(requestId, op, code, message, details) {
47
- return {
48
- kind: "result",
49
- requestId,
50
- op,
51
- ok: false,
52
- error: toHeadlessError(code, message, details),
53
- };
54
- }
55
- function toSuccessResult(requestId, op, result) {
56
- return {
57
- kind: "result",
58
- requestId,
59
- op,
60
- ok: true,
61
- result,
62
- };
63
- }
64
- function buildPolicySnapshot(request) {
65
- return {
66
- ...(request.arion ? { arion: request.arion } : {}),
67
- ...(request.cwd ? { cwd: request.cwd } : {}),
68
- ...(request.requestedModel ? { requestedModel: request.requestedModel } : {}),
69
- ...(request.preferredTier ? { preferredTier: request.preferredTier } : {}),
70
- ...(typeof request.budget === "number" ? { budget: request.budget } : {}),
71
- ...(typeof request.maxTurns === "number" ? { maxTurns: request.maxTurns } : {}),
72
- ...(request.autonomy ? { autonomy: request.autonomy } : {}),
73
- ...(request.allowedTools ? { allowedTools: request.allowedTools } : {}),
74
- ...(request.deniedTools ? { deniedTools: request.deniedTools } : {}),
75
- ...(typeof request.noMemory === "boolean" ? { noMemory: request.noMemory } : {}),
76
- ...(request.systemPrompt ? { systemPrompt: request.systemPrompt } : {}),
77
- };
78
- }
79
- function applySessionArionToRunRequest(request, sessionArion) {
80
- if (request.arion || !sessionArion) {
81
- return request;
82
- }
83
- return {
84
- ...request,
85
- arion: sessionArion,
86
- };
87
- }
88
- function toRuntimeRunRequest(request) {
89
- const { sessionId: _sessionId, ...runtimeRequest } = request;
90
- return runtimeRequest;
91
- }
92
- function toRuntimeResumeRequest(request) {
93
- const { sessionId: _sessionId, ...runtimeRequest } = request;
94
- return runtimeRequest;
95
- }
96
- function applySessionModelToRunRequest(request, sessionModel) {
97
- if (request.requestedModel || !sessionModel) {
98
- return request;
99
- }
100
- return {
101
- ...request,
102
- requestedModel: sessionModel,
103
- };
104
- }
105
- function persistTranscript(sessionLedger, sessionId, messages) {
106
- if (!Array.isArray(messages) || messages.length === 0) {
107
- return;
108
- }
109
- sessionLedger.replaceConversationMessages(sessionId, fromModelMessages(messages));
110
- }
111
- function buildInteractionRequest(requestId, sessionId, pausedState) {
112
- if ((pausedState.pendingUserQuestions?.length ?? 0) > 0) {
113
- const interactionId = `${sessionId}:questionnaire:${randomUUID()}`;
114
- const interaction = {
115
- kind: "questionnaire",
116
- questions: pausedState.pendingUserQuestions ?? [],
117
- };
118
- return {
119
- record: {
120
- interactionId,
121
- requestId,
122
- source: "run",
123
- kind: interaction.kind,
124
- prompt: interaction,
125
- },
126
- frame: {
127
- kind: "interaction.required",
128
- requestId,
129
- interactionId,
130
- source: "run",
131
- interaction,
132
- },
133
- };
134
- }
135
- if ((pausedState.pendingToolCalls?.length ?? 0) > 0) {
136
- const pendingTool = pausedState.pendingToolCalls[0];
137
- const interactionId = `${sessionId}:tool-approval:${randomUUID()}`;
138
- const interaction = {
139
- kind: "tool_approval",
140
- toolName: pendingTool.name,
141
- toolInput: pendingTool.arguments,
142
- prompt: `Approval required for ${pendingTool.name}`,
143
- };
144
- return {
145
- record: {
146
- interactionId,
147
- requestId,
148
- source: "run",
149
- kind: interaction.kind,
150
- prompt: interaction,
151
- },
152
- frame: {
153
- kind: "interaction.required",
154
- requestId,
155
- interactionId,
156
- source: "run",
157
- interaction,
158
- },
159
- };
160
- }
161
- return null;
162
- }
163
- function buildResumeRequestFromInteraction(pausedState, interaction, response, runtimeStateRevision, runtimeStatePolicySnapshot) {
164
- const baseRequest = {
165
- state: pausedState,
166
- ...(runtimeStatePolicySnapshot ?? {}),
167
- };
168
- if (interaction.kind === "tool_approval") {
169
- if (response.response.kind !== "confirm") {
170
- throw new Error(`Interaction ${interaction.interactionId} requires a confirm response`);
171
- }
172
- return {
173
- ...baseRequest,
174
- approvalMode: response.response.approved ? "approve" : "deny",
175
- // Preserve a revision breadcrumb for diagnostics only; ignored by schema consumers.
176
- ...(runtimeStateRevision >= 0 ? {} : {}),
177
- };
178
- }
179
- if (interaction.kind === "questionnaire") {
180
- if (response.response.kind !== "questionnaire") {
181
- throw new Error(`Interaction ${interaction.interactionId} requires a questionnaire response`);
182
- }
183
- return {
184
- ...baseRequest,
185
- askUserAnswers: response.response.answers,
186
- };
187
- }
188
- throw new Error(`Unsupported run interaction kind ${interaction.kind}`);
189
- }
190
- export class HeadlessRunOrchestrator {
191
- ctx;
192
- constructor(ctx) {
193
- this.ctx = ctx;
194
- }
195
- renewSessionLease(sessionId, ownerId) {
196
- const ledger = this.ctx.sessionLedger;
197
- if (typeof ledger.renewSessionClaim === "function") {
198
- return ledger.renewSessionClaim(sessionId, ownerId, SESSION_LEASE_MS);
199
- }
200
- return ledger.claimSessionForMutation(sessionId, ownerId, SESSION_LEASE_MS);
201
- }
202
- clearRunningSession(sessionId, ownerId, expectedRevision) {
203
- const ledger = this.ctx.sessionLedger;
204
- if (typeof ledger.clearActiveRun === "function") {
205
- return ledger.clearActiveRun(sessionId, { ownerId, expectedRevision });
206
- }
207
- return ledger.completeRun(sessionId, {}, { ownerId, expectedRevision });
208
- }
209
- releaseClaimOnce(sessionId, ownerId) {
210
- let released = false;
211
- return () => {
212
- if (released) {
213
- return;
214
- }
215
- released = true;
216
- this.ctx.sessionLedger.releaseSessionClaim(sessionId, ownerId);
217
- };
218
- }
219
- static isAbortError(error) {
220
- return (error instanceof Error &&
221
- (error.name === "AbortError" ||
222
- error.message === "The operation was aborted" ||
223
- error.message === "This operation was aborted"));
224
- }
225
- static createAbortReason(code, message) {
226
- const error = new Error(message);
227
- error.name = "AbortError";
228
- error.code = code;
229
- return error;
230
- }
231
- static getAbortCode(signal, error) {
232
- const candidate = signal?.aborted ? signal.reason : error;
233
- if (candidate &&
234
- typeof candidate === "object" &&
235
- "code" in candidate &&
236
- typeof candidate.code === "string") {
237
- return candidate.code;
238
- }
239
- return signal?.aborted || HeadlessRunOrchestrator.isAbortError(error) ? "RUN_ABORTED" : null;
240
- }
241
- static getAbortMessage(signal, error) {
242
- const candidate = signal?.aborted ? signal.reason : error;
243
- if (candidate instanceof Error && candidate.message) {
244
- return candidate.message;
245
- }
246
- return "Run aborted before completion.";
247
- }
248
- async *start(requestId, request, signal) {
249
- const sessionId = request.sessionId?.trim() || requestId;
250
- const ownerId = `headless:${requestId}`;
251
- const sessionModel = this.ctx.getSessionModel?.();
252
- const sessionArion = this.ctx.getSessionArion?.();
253
- const effectiveRequest = applySessionModelToRunRequest(applySessionArionToRunRequest(request, sessionArion), sessionModel);
254
- const arionName = effectiveRequest.arion ?? this.ctx.getSessionArion?.() ?? "ARIA";
255
- const model = effectiveRequest.requestedModel ?? effectiveRequest.preferredTier ?? "balanced";
256
- const policySnapshot = buildPolicySnapshot(effectiveRequest);
257
- if (!this.ctx.sessionLedger.loadSession(sessionId)) {
258
- this.ctx.sessionLedger.createSession(arionName, model, sessionId);
259
- }
260
- let claimed = this.ctx.sessionLedger.claimSessionForMutation(sessionId, ownerId, 30_000);
261
- const releaseClaim = this.releaseClaimOnce(sessionId, ownerId);
262
- const state = initialRunSynthesisState();
263
- const controller = new AbortController();
264
- let releaseExternalAbort = null;
265
- let renewalTimer = null;
266
- // Deferred persistence closure — captured in the success path, executed
267
- // from the finally block via setTimeout(0). This architectural boundary
268
- // ensures persistence (DELETE+INSERT of entire transcript) NEVER blocks
269
- // the consumer from receiving the result frame and updating the UI.
270
- let deferredPersistence = null;
271
- if (signal) {
272
- const onAbort = () => {
273
- controller.abort(HeadlessRunOrchestrator.createAbortReason("CONNECTION_CLOSED", "Connection closed before request completed"));
274
- };
275
- if (signal.aborted) {
276
- onAbort();
277
- }
278
- else {
279
- signal.addEventListener("abort", onAbort, { once: true });
280
- releaseExternalAbort = () => signal.removeEventListener("abort", onAbort);
281
- }
282
- }
283
- renewalTimer = setInterval(() => {
284
- try {
285
- claimed = this.renewSessionLease(sessionId, ownerId);
286
- }
287
- catch (error) {
288
- controller.abort(HeadlessRunOrchestrator.createAbortReason("SESSION_LEASE_LOST", error instanceof Error ? error.message : String(error)));
289
- }
290
- }, SESSION_LEASE_RENEW_INTERVAL_MS);
291
- try {
292
- for await (const event of this.ctx.localControl.streamRun(toRuntimeRunRequest(effectiveRequest), controller.signal)) {
293
- if (controller.signal.aborted) {
294
- releaseClaim();
295
- return;
296
- }
297
- this.consumeRunEvent(state, event);
298
- yield {
299
- kind: "event",
300
- requestId,
301
- seq: state.turnCount + state.toolCalls.length + state.thinking.length,
302
- op: "run.start",
303
- event,
304
- };
305
- }
306
- if (controller.signal.aborted) {
307
- persistTranscript(this.ctx.sessionLedger, sessionId, state.messages);
308
- this.clearRunningSession(sessionId, ownerId, claimed.revision);
309
- releaseClaim();
310
- const abortCode = HeadlessRunOrchestrator.getAbortCode(controller.signal);
311
- if (abortCode !== "CONNECTION_CLOSED") {
312
- yield toFailureResult(requestId, "run.start", abortCode ?? "RUN_ABORTED", HeadlessRunOrchestrator.getAbortMessage(controller.signal), { sessionId, runId: `run:${sessionId}` });
313
- }
314
- return;
315
- }
316
- if (state.pausedState) {
317
- persistTranscript(this.ctx.sessionLedger, sessionId, state.pausedState.messages);
318
- const interaction = buildInteractionRequest(requestId, sessionId, state.pausedState);
319
- this.ctx.sessionLedger.recordPausedRun(sessionId, `run:${sessionId}`, state.pausedState, policySnapshot, interaction?.record, {
320
- ownerId,
321
- expectedRevision: claimed.revision,
322
- });
323
- releaseClaim();
324
- if (interaction) {
325
- yield interaction.frame;
326
- }
327
- yield toFailureResult(requestId, "run.start", "INTERACTION_REQUIRED", "Run paused and requires interaction before it can continue.", {
328
- sessionId,
329
- ...(interaction
330
- ? {
331
- interactionId: interaction.frame.interactionId,
332
- source: interaction.frame.source,
333
- interaction: interaction.frame.interaction,
334
- }
335
- : {}),
336
- });
337
- return;
338
- }
339
- const result = synthesizeRunResult(state);
340
- // Yield result BEFORE persistence — the consumer must receive the result
341
- // frame without waiting for SQLite writes. persistTranscript does
342
- // DELETE + INSERT for the entire conversation transcript, which blocks
343
- // the event loop for 100-500ms on long conversations. Deferring it to
344
- // the finally block (via setTimeout) ensures the consumer's for-await
345
- // loop exits immediately after this yield.
346
- deferredPersistence = () => {
347
- const msgCount = Array.isArray(result.messages) ? result.messages.length : 0;
348
- setStallPhase(`orchestrator:persistTranscript(${msgCount} msgs)`);
349
- const _pt0 = performance.now();
350
- persistTranscript(this.ctx.sessionLedger, sessionId, result.messages);
351
- const _pt1 = performance.now();
352
- setStallPhase("orchestrator:completeRun");
353
- this.ctx.sessionLedger.completeRun(sessionId, result, {
354
- ownerId,
355
- expectedRevision: claimed.revision,
356
- });
357
- const _pt2 = performance.now();
358
- clearStallPhase();
359
- releaseClaim();
360
- const _total = _pt2 - _pt0;
361
- if (_total > 100) {
362
- try {
363
- process.stderr.write(`[Orchestrator][DIAG] deferredPersistence: ` +
364
- `total=${_total.toFixed(0)}ms transcript=${(_pt1 - _pt0).toFixed(0)}ms ` +
365
- `completeRun=${(_pt2 - _pt1).toFixed(0)}ms msgs=${msgCount}\n`);
366
- }
367
- catch {
368
- /* best effort */
369
- }
370
- }
371
- };
372
- yield toSuccessResult(requestId, "run.start", result);
373
- }
374
- catch (error) {
375
- try {
376
- if (controller.signal.aborted || HeadlessRunOrchestrator.isAbortError(error)) {
377
- persistTranscript(this.ctx.sessionLedger, sessionId, state.messages);
378
- this.clearRunningSession(sessionId, ownerId, claimed.revision);
379
- }
380
- releaseClaim();
381
- }
382
- catch {
383
- // Best effort cleanup on failure.
384
- }
385
- if (controller.signal.aborted || HeadlessRunOrchestrator.isAbortError(error)) {
386
- const abortCode = HeadlessRunOrchestrator.getAbortCode(controller.signal, error);
387
- if (abortCode !== "CONNECTION_CLOSED") {
388
- yield toFailureResult(requestId, "run.start", abortCode ?? "RUN_ABORTED", HeadlessRunOrchestrator.getAbortMessage(controller.signal, error), { sessionId, runId: `run:${sessionId}` });
389
- }
390
- return;
391
- }
392
- yield toFailureResult(requestId, "run.start", "RUN_START_FAILED", error instanceof Error ? error.message : String(error));
393
- }
394
- finally {
395
- if (renewalTimer) {
396
- clearInterval(renewalTimer);
397
- }
398
- releaseExternalAbort?.();
399
- // Execute deferred persistence from the success path. Scheduled via
400
- // setTimeout(0) so it runs AFTER React's microtask render cycle —
401
- // the consumer sets isStreaming=false and yields, React renders the
402
- // input area, THEN persistence runs. This makes it structurally
403
- // impossible for transcript persistence to block the UI transition.
404
- if (deferredPersistence) {
405
- const persist = deferredPersistence;
406
- deferredPersistence = null;
407
- setTimeout(() => {
408
- try {
409
- setStallPhase("orchestrator:deferredPersistence");
410
- const dpT0 = performance.now();
411
- persist();
412
- const dpElapsed = performance.now() - dpT0;
413
- clearStallPhase();
414
- if (dpElapsed > 200) {
415
- try {
416
- process.stderr.write(`[Orchestrator][DIAG] deferredPersistence blocked ${dpElapsed.toFixed(0)}ms\n`);
417
- }
418
- catch {
419
- /* best effort */
420
- }
421
- }
422
- }
423
- catch {
424
- clearStallPhase();
425
- // Non-fatal: consumer already has the result frame.
426
- // Crash recovery handles stale session state on next startup.
427
- releaseClaim();
428
- }
429
- }, 0);
430
- }
431
- }
432
- }
433
- async *resume(requestId, request, signal) {
434
- const sessionId = request.sessionId?.trim();
435
- const ownerId = `headless:${requestId}`;
436
- const sessionModel = this.ctx.getSessionModel?.();
437
- const sessionArion = this.ctx.getSessionArion?.();
438
- const effectiveRequest = applySessionModelToRunRequest(applySessionArionToRunRequest(request, sessionArion), sessionModel);
439
- const runtimeRequest = toRuntimeResumeRequest(effectiveRequest);
440
- const policySnapshot = buildPolicySnapshot(runtimeRequest);
441
- let createdSession = false;
442
- let claimed = null;
443
- try {
444
- if (signal?.aborted) {
445
- return;
446
- }
447
- if (sessionId) {
448
- if (!this.ctx.sessionLedger.loadSession(sessionId)) {
449
- this.ctx.sessionLedger.createSession(effectiveRequest.arion ?? this.ctx.getSessionArion?.() ?? "ARIA", effectiveRequest.requestedModel ?? effectiveRequest.preferredTier ?? "balanced", sessionId);
450
- createdSession = true;
451
- }
452
- claimed = this.ctx.sessionLedger.claimSessionForMutation(sessionId, ownerId, 30_000);
453
- }
454
- const result = await this.ctx.localControl.resumeRun(runtimeRequest);
455
- if (signal?.aborted) {
456
- if (sessionId && claimed) {
457
- this.ctx.sessionLedger.releaseSessionClaim(sessionId, ownerId);
458
- if (createdSession) {
459
- this.ctx.sessionLedger.deleteSession(sessionId);
460
- }
461
- }
462
- return;
463
- }
464
- if (sessionId && claimed) {
465
- if (result.state) {
466
- const pausedState = result.state;
467
- persistTranscript(this.ctx.sessionLedger, sessionId, pausedState.messages);
468
- const nextInteraction = buildInteractionRequest(requestId, sessionId, pausedState);
469
- this.ctx.sessionLedger.recordPausedRun(sessionId, `run:${sessionId}`, pausedState, policySnapshot, nextInteraction?.record, {
470
- ownerId,
471
- expectedRevision: claimed.revision,
472
- });
473
- this.ctx.sessionLedger.releaseSessionClaim(sessionId, ownerId);
474
- if (nextInteraction) {
475
- yield nextInteraction.frame;
476
- }
477
- yield toFailureResult(requestId, "run.resume", "INTERACTION_REQUIRED", "Run paused and requires interaction before it can continue.", {
478
- sessionId,
479
- ...(nextInteraction
480
- ? {
481
- interactionId: nextInteraction.frame.interactionId,
482
- source: nextInteraction.frame.source,
483
- interaction: nextInteraction.frame.interaction,
484
- }
485
- : {}),
486
- });
487
- return;
488
- }
489
- persistTranscript(this.ctx.sessionLedger, sessionId, result.messages);
490
- this.ctx.sessionLedger.completeRun(sessionId, result, {
491
- ownerId,
492
- expectedRevision: claimed.revision,
493
- });
494
- this.ctx.sessionLedger.releaseSessionClaim(sessionId, ownerId);
495
- }
496
- yield toSuccessResult(requestId, "run.resume", result);
497
- }
498
- catch (error) {
499
- if (sessionId && claimed) {
500
- try {
501
- this.ctx.sessionLedger.releaseSessionClaim(sessionId, ownerId);
502
- if (createdSession) {
503
- this.ctx.sessionLedger.deleteSession(sessionId);
504
- }
505
- }
506
- catch {
507
- // Best effort cleanup.
508
- }
509
- }
510
- if (signal?.aborted || HeadlessRunOrchestrator.isAbortError(error)) {
511
- return;
512
- }
513
- yield toFailureResult(requestId, "run.resume", "RUN_RESUME_FAILED", error instanceof Error ? error.message : String(error));
514
- }
515
- }
516
- async *abort(requestId, input, activeRunController) {
517
- const aborted = await (activeRunController ?? this.ctx.activeRunController)?.abort(input);
518
- if (aborted) {
519
- yield {
520
- kind: "result",
521
- requestId,
522
- op: "run.abort",
523
- ok: true,
524
- result: {
525
- aborted: true,
526
- ...(input.runId ? { runId: input.runId } : {}),
527
- ...(input.sessionId ? { sessionId: input.sessionId } : {}),
528
- },
529
- };
530
- return;
531
- }
532
- yield toFailureResult(requestId, "run.abort", "RUN_NOT_FOUND", "No active run matched the requested runId or sessionId.", {
533
- ...(input.runId ? { runId: input.runId } : {}),
534
- ...(input.sessionId ? { sessionId: input.sessionId } : {}),
535
- });
536
- }
537
- async *respond(response, signal) {
538
- const interaction = this.ctx.sessionLedger.getInteraction(response.interactionId);
539
- if (!interaction) {
540
- yield toFailureResult(response.requestId, "interaction.respond", "INTERACTION_NOT_FOUND", `Unknown interaction ${response.interactionId}`);
541
- return;
542
- }
543
- if (interaction.source !== "run") {
544
- yield toFailureResult(response.requestId, "interaction.respond", "UNSUPPORTED_INTERACTION_SOURCE", `Interaction source ${interaction.source} is not handled by the run orchestrator`);
545
- return;
546
- }
547
- const runtimeState = this.ctx.sessionLedger.getSessionRuntimeState(interaction.sessionId);
548
- if (!runtimeState?.pausedState) {
549
- yield toFailureResult(response.requestId, "interaction.respond", "SESSION_NOT_PAUSED", `Session ${interaction.sessionId} is not paused`);
550
- return;
551
- }
552
- const ownerId = `headless:${response.requestId}`;
553
- try {
554
- if (signal?.aborted) {
555
- return;
556
- }
557
- const claimed = this.ctx.sessionLedger.claimSessionForMutation(interaction.sessionId, ownerId, 30_000);
558
- let effectiveResponse = response.response;
559
- let responseRevision = claimed.revision;
560
- if (interaction.status === "pending") {
561
- this.ctx.sessionLedger.recordInteractionResponse(interaction.sessionId, interaction.interactionId, effectiveResponse, {
562
- ownerId,
563
- expectedRevision: claimed.revision,
564
- });
565
- responseRevision += 1;
566
- }
567
- else if (interaction.status === "answered") {
568
- if (!interaction.response) {
569
- this.ctx.sessionLedger.releaseSessionClaim(interaction.sessionId, ownerId);
570
- yield toFailureResult(response.requestId, "interaction.respond", "INVALID_INTERACTION_STATE", `Interaction ${interaction.interactionId} is missing its recorded response`);
571
- return;
572
- }
573
- if (!isDeepStrictEqual(interaction.response, effectiveResponse)) {
574
- this.ctx.sessionLedger.releaseSessionClaim(interaction.sessionId, ownerId);
575
- yield toFailureResult(response.requestId, "interaction.respond", "INTERACTION_ALREADY_ANSWERED", `Interaction ${interaction.interactionId} was already answered with a different response`);
576
- return;
577
- }
578
- effectiveResponse = interaction.response;
579
- }
580
- else {
581
- this.ctx.sessionLedger.releaseSessionClaim(interaction.sessionId, ownerId);
582
- yield toFailureResult(response.requestId, "interaction.respond", "INTERACTION_NOT_PENDING", `Interaction ${interaction.interactionId} is not resumable in state ${interaction.status}`);
583
- return;
584
- }
585
- const resumeRequest = buildResumeRequestFromInteraction(runtimeState.pausedState, interaction, {
586
- ...response,
587
- response: effectiveResponse,
588
- }, runtimeState.revision, runtimeState.policySnapshot);
589
- const result = await this.ctx.localControl.resumeRun(resumeRequest);
590
- if (signal?.aborted) {
591
- this.ctx.sessionLedger.releaseSessionClaim(interaction.sessionId, ownerId);
592
- return;
593
- }
594
- if (result.state) {
595
- const pausedState = result.state;
596
- persistTranscript(this.ctx.sessionLedger, interaction.sessionId, pausedState.messages);
597
- const nextInteraction = buildInteractionRequest(response.requestId, interaction.sessionId, pausedState);
598
- this.ctx.sessionLedger.recordPausedRun(interaction.sessionId, runtimeState.activeRunId ?? `run:${interaction.sessionId}`, pausedState, runtimeState.policySnapshot ?? {}, nextInteraction?.record, {
599
- ownerId,
600
- expectedRevision: responseRevision,
601
- });
602
- this.ctx.sessionLedger.releaseSessionClaim(interaction.sessionId, ownerId);
603
- if (nextInteraction) {
604
- yield nextInteraction.frame;
605
- }
606
- yield toFailureResult(response.requestId, "interaction.respond", "INTERACTION_REQUIRED", "Run paused again and requires another interaction.", {
607
- sessionId: interaction.sessionId,
608
- ...(nextInteraction
609
- ? {
610
- interactionId: nextInteraction.frame.interactionId,
611
- source: nextInteraction.frame.source,
612
- interaction: nextInteraction.frame.interaction,
613
- }
614
- : {}),
615
- });
616
- return;
617
- }
618
- persistTranscript(this.ctx.sessionLedger, interaction.sessionId, result.messages);
619
- this.ctx.sessionLedger.completeRun(interaction.sessionId, result, {
620
- ownerId,
621
- expectedRevision: responseRevision,
622
- });
623
- this.ctx.sessionLedger.releaseSessionClaim(interaction.sessionId, ownerId);
624
- yield toSuccessResult(response.requestId, "interaction.respond", result);
625
- }
626
- catch (error) {
627
- try {
628
- this.ctx.sessionLedger.releaseSessionClaim(interaction.sessionId, ownerId);
629
- }
630
- catch {
631
- // Best effort.
632
- }
633
- if (signal?.aborted || HeadlessRunOrchestrator.isAbortError(error)) {
634
- return;
635
- }
636
- yield toFailureResult(response.requestId, "interaction.respond", "INTERACTION_RESPONSE_FAILED", error instanceof Error ? error.message : String(error));
637
- }
638
- }
639
- consumeRunEvent(state, event) {
640
- switch (event.type) {
641
- case "text_delta":
642
- state.output += event.content;
643
- break;
644
- case "tool_result":
645
- state.toolCalls.push({
646
- id: event.id,
647
- name: event.name,
648
- input: event.input,
649
- result: event.result,
650
- durationMs: event.durationMs,
651
- });
652
- break;
653
- case "usage_update":
654
- state.usage = event.usage;
655
- break;
656
- case "turn_complete":
657
- state.turnCount = event.turnNumber;
658
- break;
659
- case "guardrail_rejected":
660
- state.guardrailEvents.push({
661
- stage: event.stage,
662
- message: event.message,
663
- });
664
- break;
665
- case "pipeline_timing":
666
- state.pipelineTiming = event.report;
667
- break;
668
- case "messages_snapshot":
669
- state.messages = Array.isArray(event.messages) ? event.messages : [];
670
- break;
671
- case "thinking_end":
672
- if (event.blocks)
673
- state.thinking.push(...event.blocks);
674
- break;
675
- case "native_tool_result":
676
- state.nativeToolResults.push(event.metadata);
677
- break;
678
- case "handoff_start":
679
- state.handoffs.push({
680
- type: "start",
681
- target: event.target,
682
- id: event.id,
683
- });
684
- break;
685
- case "handoff_result":
686
- state.handoffs.push({
687
- type: "result",
688
- target: event.target,
689
- id: event.id,
690
- result: event.result,
691
- });
692
- break;
693
- case "paused":
694
- state.pausedState = event.state;
695
- break;
696
- case "error":
697
- throw new Error(resolveTrustedRuntimeErrorMessage(event.error.message, "diagnostic" in event.error ? event.error.diagnostic : undefined) ?? event.error.message);
698
- default:
699
- break;
700
- }
701
- }
702
- }
703
- //# sourceMappingURL=run-orchestrator.js.map