agentplane 0.3.7 → 0.3.8

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 (625) hide show
  1. package/assets/AGENTS.md +11 -1
  2. package/assets/RUNNER.md +17 -0
  3. package/bin/agentplane.js +16 -7
  4. package/bin/framework-dev-contract.d.ts +6 -0
  5. package/bin/framework-dev-contract.js +13 -0
  6. package/bin/stale-dist-policy.js +6 -1
  7. package/dist/.build-manifest.json +694 -339
  8. package/dist/adapters/task-backend/task-backend-adapter.d.ts +3 -1
  9. package/dist/adapters/task-backend/task-backend-adapter.d.ts.map +1 -1
  10. package/dist/adapters/task-backend/task-backend-adapter.js +13 -0
  11. package/dist/backends/task-backend/local-backend-doc.d.ts +5 -0
  12. package/dist/backends/task-backend/local-backend-doc.d.ts.map +1 -0
  13. package/dist/backends/task-backend/local-backend-doc.js +98 -0
  14. package/dist/backends/task-backend/local-backend-read.d.ts +7 -0
  15. package/dist/backends/task-backend/local-backend-read.d.ts.map +1 -0
  16. package/dist/backends/task-backend/local-backend-read.js +186 -0
  17. package/dist/backends/task-backend/local-backend-state.d.ts +17 -0
  18. package/dist/backends/task-backend/local-backend-state.d.ts.map +1 -0
  19. package/dist/backends/task-backend/local-backend-state.js +50 -0
  20. package/dist/backends/task-backend/local-backend-write.d.ts +15 -0
  21. package/dist/backends/task-backend/local-backend-write.d.ts.map +1 -0
  22. package/dist/backends/task-backend/local-backend-write.js +254 -0
  23. package/dist/backends/task-backend/local-backend.d.ts +4 -2
  24. package/dist/backends/task-backend/local-backend.d.ts.map +1 -1
  25. package/dist/backends/task-backend/local-backend.js +26 -403
  26. package/dist/backends/task-backend/redmine/backend-cache-doc.d.ts +40 -0
  27. package/dist/backends/task-backend/redmine/backend-cache-doc.d.ts.map +1 -0
  28. package/dist/backends/task-backend/redmine/backend-cache-doc.js +178 -0
  29. package/dist/backends/task-backend/redmine/backend-report.d.ts +10 -0
  30. package/dist/backends/task-backend/redmine/backend-report.d.ts.map +1 -0
  31. package/dist/backends/task-backend/redmine/backend-report.js +43 -0
  32. package/dist/backends/task-backend/redmine/backend-sync.d.ts +67 -0
  33. package/dist/backends/task-backend/redmine/backend-sync.d.ts.map +1 -0
  34. package/dist/backends/task-backend/redmine/backend-sync.js +367 -0
  35. package/dist/backends/task-backend/redmine/mapping.d.ts +2 -1
  36. package/dist/backends/task-backend/redmine/mapping.d.ts.map +1 -1
  37. package/dist/backends/task-backend/redmine/mapping.js +12 -2
  38. package/dist/backends/task-backend/redmine/parse.d.ts +2 -1
  39. package/dist/backends/task-backend/redmine/parse.d.ts.map +1 -1
  40. package/dist/backends/task-backend/redmine/parse.js +5 -3
  41. package/dist/backends/task-backend/redmine/state.d.ts +2 -0
  42. package/dist/backends/task-backend/redmine/state.d.ts.map +1 -1
  43. package/dist/backends/task-backend/redmine/state.js +15 -1
  44. package/dist/backends/task-backend/redmine-backend.d.ts +5 -2
  45. package/dist/backends/task-backend/redmine-backend.d.ts.map +1 -1
  46. package/dist/backends/task-backend/redmine-backend.js +88 -536
  47. package/dist/backends/task-backend/shared/constants.d.ts +2 -1
  48. package/dist/backends/task-backend/shared/constants.d.ts.map +1 -1
  49. package/dist/backends/task-backend/shared/doc.d.ts.map +1 -1
  50. package/dist/backends/task-backend/shared/doc.js +25 -39
  51. package/dist/backends/task-backend/shared/export.d.ts +2 -9
  52. package/dist/backends/task-backend/shared/export.d.ts.map +1 -1
  53. package/dist/backends/task-backend/shared/export.js +73 -8
  54. package/dist/backends/task-backend/shared/normalize.d.ts +5 -1
  55. package/dist/backends/task-backend/shared/normalize.d.ts.map +1 -1
  56. package/dist/backends/task-backend/shared/normalize.js +166 -0
  57. package/dist/backends/task-backend/shared/record.d.ts +1 -1
  58. package/dist/backends/task-backend/shared/record.d.ts.map +1 -1
  59. package/dist/backends/task-backend/shared/record.js +7 -2
  60. package/dist/backends/task-backend/shared/types.d.ts +38 -36
  61. package/dist/backends/task-backend/shared/types.d.ts.map +1 -1
  62. package/dist/backends/task-backend/shared.d.ts +2 -2
  63. package/dist/backends/task-backend/shared.d.ts.map +1 -1
  64. package/dist/backends/task-backend/shared.js +1 -1
  65. package/dist/backends/task-backend.d.ts +1 -1
  66. package/dist/backends/task-backend.d.ts.map +1 -1
  67. package/dist/backends/task-backend.js +1 -1
  68. package/dist/backends/task-index.d.ts +2 -2
  69. package/dist/backends/task-index.d.ts.map +1 -1
  70. package/dist/backends/task-index.js +9 -6
  71. package/dist/cli/bootstrap-guide.d.ts +2 -2
  72. package/dist/cli/bootstrap-guide.d.ts.map +1 -1
  73. package/dist/cli/bootstrap-guide.js +10 -10
  74. package/dist/cli/command-guide.d.ts.map +1 -1
  75. package/dist/cli/command-guide.js +11 -9
  76. package/dist/cli/command-invocations.d.ts +4 -0
  77. package/dist/cli/command-invocations.d.ts.map +1 -0
  78. package/dist/cli/command-invocations.js +35 -0
  79. package/dist/cli/command-snippets.d.ts +12 -8
  80. package/dist/cli/command-snippets.d.ts.map +1 -1
  81. package/dist/cli/command-snippets.js +14 -8
  82. package/dist/cli/exit-codes.d.ts.map +1 -1
  83. package/dist/cli/exit-codes.js +1 -0
  84. package/dist/cli/group-command.d.ts +18 -0
  85. package/dist/cli/group-command.d.ts.map +1 -0
  86. package/dist/cli/group-command.js +45 -0
  87. package/dist/cli/output.d.ts +29 -0
  88. package/dist/cli/output.d.ts.map +1 -1
  89. package/dist/cli/output.js +76 -0
  90. package/dist/cli/prompts.d.ts.map +1 -1
  91. package/dist/cli/prompts.js +5 -1
  92. package/dist/cli/run-cli/command-catalog/core.d.ts.map +1 -1
  93. package/dist/cli/run-cli/command-catalog/core.js +38 -29
  94. package/dist/cli/run-cli/command-catalog/lifecycle.d.ts.map +1 -1
  95. package/dist/cli/run-cli/command-catalog/lifecycle.js +9 -6
  96. package/dist/cli/run-cli/command-catalog/project.d.ts +1 -1
  97. package/dist/cli/run-cli/command-catalog/project.d.ts.map +1 -1
  98. package/dist/cli/run-cli/command-catalog/project.js +8 -6
  99. package/dist/cli/run-cli/command-catalog/shared.d.ts +12 -3
  100. package/dist/cli/run-cli/command-catalog/shared.d.ts.map +1 -1
  101. package/dist/cli/run-cli/command-catalog/shared.js +6 -3
  102. package/dist/cli/run-cli/command-catalog/task.d.ts +1 -1
  103. package/dist/cli/run-cli/command-catalog/task.d.ts.map +1 -1
  104. package/dist/cli/run-cli/command-catalog/task.js +46 -11
  105. package/dist/cli/run-cli/command-catalog.d.ts +11 -1
  106. package/dist/cli/run-cli/command-catalog.d.ts.map +1 -1
  107. package/dist/cli/run-cli/command-catalog.js +29 -0
  108. package/dist/cli/run-cli/commands/config.d.ts.map +1 -1
  109. package/dist/cli/run-cli/commands/config.js +52 -6
  110. package/dist/cli/run-cli/commands/core/agent-profiles.d.ts +34 -0
  111. package/dist/cli/run-cli/commands/core/agent-profiles.d.ts.map +1 -0
  112. package/dist/cli/run-cli/commands/core/agent-profiles.js +97 -0
  113. package/dist/cli/run-cli/commands/core/agents.d.ts +7 -0
  114. package/dist/cli/run-cli/commands/core/agents.d.ts.map +1 -0
  115. package/dist/cli/run-cli/commands/core/agents.js +97 -0
  116. package/dist/cli/run-cli/commands/core/preflight.d.ts +10 -0
  117. package/dist/cli/run-cli/commands/core/preflight.d.ts.map +1 -0
  118. package/dist/cli/run-cli/commands/core/preflight.js +286 -0
  119. package/dist/cli/run-cli/commands/core/quickstart.d.ts +8 -0
  120. package/dist/cli/run-cli/commands/core/quickstart.d.ts.map +1 -0
  121. package/dist/cli/run-cli/commands/core/quickstart.js +43 -0
  122. package/dist/cli/run-cli/commands/core/role.d.ts +9 -0
  123. package/dist/cli/run-cli/commands/core/role.d.ts.map +1 -0
  124. package/dist/cli/run-cli/commands/core/role.js +128 -0
  125. package/dist/cli/run-cli/commands/core.d.ts +4 -24
  126. package/dist/cli/run-cli/commands/core.d.ts.map +1 -1
  127. package/dist/cli/run-cli/commands/core.js +4 -630
  128. package/dist/cli/run-cli/error-guidance.js +10 -0
  129. package/dist/cli/run-cli/globals.d.ts +5 -2
  130. package/dist/cli/run-cli/globals.d.ts.map +1 -1
  131. package/dist/cli/run-cli/globals.js +82 -86
  132. package/dist/cli/run-cli.d.ts.map +1 -1
  133. package/dist/cli/run-cli.js +137 -100
  134. package/dist/cli/run-cli.test-helpers.d.ts +21 -0
  135. package/dist/cli/run-cli.test-helpers.d.ts.map +1 -1
  136. package/dist/cli/run-cli.test-helpers.js +88 -4
  137. package/dist/cli/spec/help.d.ts +10 -2
  138. package/dist/cli/spec/help.d.ts.map +1 -1
  139. package/dist/cli/spec/help.js +7 -5
  140. package/dist/cli/spec/registry.d.ts +27 -1
  141. package/dist/cli/spec/registry.d.ts.map +1 -1
  142. package/dist/cli/spec/registry.js +98 -25
  143. package/dist/commands/backend/sync.command.d.ts +3 -5
  144. package/dist/commands/backend/sync.command.d.ts.map +1 -1
  145. package/dist/commands/backend/sync.command.js +9 -12
  146. package/dist/commands/backend.d.ts.map +1 -1
  147. package/dist/commands/backend.js +8 -7
  148. package/dist/commands/branch/base.command.d.ts +2 -3
  149. package/dist/commands/branch/base.command.d.ts.map +1 -1
  150. package/dist/commands/branch/base.command.js +8 -12
  151. package/dist/commands/branch/base.d.ts.map +1 -1
  152. package/dist/commands/branch/base.js +11 -7
  153. package/dist/commands/branch/cleanup-merged.d.ts.map +1 -1
  154. package/dist/commands/branch/cleanup-merged.js +9 -8
  155. package/dist/commands/branch/remove.d.ts.map +1 -1
  156. package/dist/commands/branch/remove.js +4 -3
  157. package/dist/commands/branch/status.d.ts.map +1 -1
  158. package/dist/commands/branch/status.js +4 -3
  159. package/dist/commands/branch/work-start.d.ts.map +1 -1
  160. package/dist/commands/branch/work-start.js +48 -5
  161. package/dist/commands/cleanup/merged.command.d.ts +2 -3
  162. package/dist/commands/cleanup/merged.command.d.ts.map +1 -1
  163. package/dist/commands/cleanup/merged.command.js +8 -12
  164. package/dist/commands/docs/cli.command.js +2 -2
  165. package/dist/commands/doctor/runtime.js +1 -1
  166. package/dist/commands/doctor/workflow.d.ts.map +1 -1
  167. package/dist/commands/doctor/workflow.js +10 -1
  168. package/dist/commands/finish.spec.d.ts.map +1 -1
  169. package/dist/commands/finish.spec.js +7 -0
  170. package/dist/commands/guard/guard.command.d.ts +3 -3
  171. package/dist/commands/guard/guard.command.d.ts.map +1 -1
  172. package/dist/commands/guard/guard.command.js +9 -14
  173. package/dist/commands/guard/impl/commands.d.ts +2 -0
  174. package/dist/commands/guard/impl/commands.d.ts.map +1 -1
  175. package/dist/commands/guard/impl/commands.js +55 -7
  176. package/dist/commands/guard/impl/policy.d.ts +1 -0
  177. package/dist/commands/guard/impl/policy.d.ts.map +1 -1
  178. package/dist/commands/guard/impl/policy.js +9 -6
  179. package/dist/commands/hooks/hooks.command.d.ts +3 -3
  180. package/dist/commands/hooks/hooks.command.d.ts.map +1 -1
  181. package/dist/commands/hooks/hooks.command.js +9 -11
  182. package/dist/commands/pr/check.d.ts.map +1 -1
  183. package/dist/commands/pr/check.js +90 -18
  184. package/dist/commands/pr/integrate/cmd.d.ts.map +1 -1
  185. package/dist/commands/pr/integrate/cmd.js +31 -3
  186. package/dist/commands/pr/integrate/internal/cleanup.d.ts +12 -0
  187. package/dist/commands/pr/integrate/internal/cleanup.d.ts.map +1 -0
  188. package/dist/commands/pr/integrate/internal/cleanup.js +46 -0
  189. package/dist/commands/pr/integrate/internal/finalize.d.ts +4 -0
  190. package/dist/commands/pr/integrate/internal/finalize.d.ts.map +1 -1
  191. package/dist/commands/pr/integrate/internal/finalize.js +34 -40
  192. package/dist/commands/pr/integrate/internal/merge.d.ts +6 -0
  193. package/dist/commands/pr/integrate/internal/merge.d.ts.map +1 -1
  194. package/dist/commands/pr/integrate/internal/merge.js +92 -0
  195. package/dist/commands/pr/integrate/internal/prepare.d.ts +1 -0
  196. package/dist/commands/pr/integrate/internal/prepare.d.ts.map +1 -1
  197. package/dist/commands/pr/integrate/internal/prepare.js +1 -0
  198. package/dist/commands/pr/integrate/verify.d.ts.map +1 -1
  199. package/dist/commands/pr/integrate/verify.js +4 -3
  200. package/dist/commands/pr/note.d.ts.map +1 -1
  201. package/dist/commands/pr/note.js +3 -2
  202. package/dist/commands/pr/open.d.ts.map +1 -1
  203. package/dist/commands/pr/open.js +9 -12
  204. package/dist/commands/pr/pr.command.d.ts +3 -4
  205. package/dist/commands/pr/pr.command.d.ts.map +1 -1
  206. package/dist/commands/pr/pr.command.js +6 -11
  207. package/dist/commands/pr/update.d.ts.map +1 -1
  208. package/dist/commands/pr/update.js +5 -10
  209. package/dist/commands/recipes/cache.command.d.ts +3 -4
  210. package/dist/commands/recipes/cache.command.d.ts.map +1 -1
  211. package/dist/commands/recipes/cache.command.js +8 -26
  212. package/dist/commands/recipes/impl/apply.d.ts +1 -1
  213. package/dist/commands/recipes/impl/apply.d.ts.map +1 -1
  214. package/dist/commands/recipes/impl/apply.js +1 -1
  215. package/dist/commands/recipes/impl/commands/explain.js +1 -1
  216. package/dist/commands/recipes/impl/commands/install.d.ts.map +1 -1
  217. package/dist/commands/recipes/impl/commands/install.js +1 -2
  218. package/dist/commands/recipes/impl/installed-recipes.d.ts +1 -1
  219. package/dist/commands/recipes/impl/installed-recipes.d.ts.map +1 -1
  220. package/dist/commands/recipes/impl/installed-recipes.js +1 -2
  221. package/dist/commands/recipes/impl/manifest.d.ts.map +1 -1
  222. package/dist/commands/recipes/impl/manifest.js +0 -10
  223. package/dist/commands/recipes/impl/project-installed-recipes.d.ts +1 -1
  224. package/dist/commands/recipes/impl/project-installed-recipes.d.ts.map +1 -1
  225. package/dist/commands/recipes/impl/project-installed-recipes.js +1 -2
  226. package/dist/commands/recipes/impl/resolver.d.ts +1 -1
  227. package/dist/commands/recipes/impl/resolver.d.ts.map +1 -1
  228. package/dist/commands/recipes/impl/resolver.js +26 -16
  229. package/dist/commands/recipes/impl/scenario.d.ts.map +1 -1
  230. package/dist/commands/recipes/impl/scenario.js +80 -0
  231. package/dist/commands/recipes/impl/types.d.ts +27 -13
  232. package/dist/commands/recipes/impl/types.d.ts.map +1 -1
  233. package/dist/commands/recipes/recipes.command.d.ts +3 -4
  234. package/dist/commands/recipes/recipes.command.d.ts.map +1 -1
  235. package/dist/commands/recipes/recipes.command.js +8 -34
  236. package/dist/commands/recipes.d.ts +4 -4
  237. package/dist/commands/recipes.d.ts.map +1 -1
  238. package/dist/commands/recipes.js +3 -3
  239. package/dist/commands/recipes.test-helpers.d.ts +17 -0
  240. package/dist/commands/recipes.test-helpers.d.ts.map +1 -1
  241. package/dist/commands/recipes.test-helpers.js +56 -2
  242. package/dist/commands/release/apply.command.d.ts.map +1 -1
  243. package/dist/commands/release/apply.command.js +77 -56
  244. package/dist/commands/release/plan.command.d.ts.map +1 -1
  245. package/dist/commands/release/plan.command.js +7 -3
  246. package/dist/commands/release/release.command.d.ts +3 -3
  247. package/dist/commands/release/release.command.d.ts.map +1 -1
  248. package/dist/commands/release/release.command.js +9 -11
  249. package/dist/commands/release.test-helpers.d.ts +20 -0
  250. package/dist/commands/release.test-helpers.d.ts.map +1 -0
  251. package/dist/commands/release.test-helpers.js +37 -0
  252. package/dist/commands/runtime.command.d.ts +7 -7
  253. package/dist/commands/runtime.command.d.ts.map +1 -1
  254. package/dist/commands/runtime.command.js +29 -33
  255. package/dist/commands/scenario/execute.command.d.ts +8 -0
  256. package/dist/commands/scenario/execute.command.d.ts.map +1 -0
  257. package/dist/commands/scenario/execute.command.js +117 -0
  258. package/dist/commands/scenario/impl/commands.d.ts.map +1 -1
  259. package/dist/commands/scenario/impl/commands.js +45 -32
  260. package/dist/commands/scenario/run.command.js +2 -2
  261. package/dist/commands/scenario/scenario.command.d.ts +3 -4
  262. package/dist/commands/scenario/scenario.command.d.ts.map +1 -1
  263. package/dist/commands/scenario/scenario.command.js +8 -26
  264. package/dist/commands/shared/git-context.d.ts +1 -0
  265. package/dist/commands/shared/git-context.d.ts.map +1 -1
  266. package/dist/commands/shared/git-context.js +4 -2
  267. package/dist/commands/shared/git-ops.d.ts +1 -0
  268. package/dist/commands/shared/git-ops.d.ts.map +1 -1
  269. package/dist/commands/shared/git-ops.js +13 -0
  270. package/dist/commands/shared/operator-pipeline.d.ts +10 -0
  271. package/dist/commands/shared/operator-pipeline.d.ts.map +1 -0
  272. package/dist/commands/shared/operator-pipeline.js +16 -0
  273. package/dist/commands/shared/pr-meta.d.ts +32 -12
  274. package/dist/commands/shared/pr-meta.d.ts.map +1 -1
  275. package/dist/commands/shared/pr-meta.js +49 -14
  276. package/dist/commands/shared/reconcile-check.d.ts.map +1 -1
  277. package/dist/commands/shared/reconcile-check.js +28 -3
  278. package/dist/commands/shared/task-backend.d.ts +10 -6
  279. package/dist/commands/shared/task-backend.d.ts.map +1 -1
  280. package/dist/commands/shared/task-backend.js +99 -25
  281. package/dist/commands/shared/task-handoff.d.ts +64 -0
  282. package/dist/commands/shared/task-handoff.d.ts.map +1 -0
  283. package/dist/commands/shared/task-handoff.js +151 -0
  284. package/dist/commands/shared/task-mutation.d.ts +36 -0
  285. package/dist/commands/shared/task-mutation.d.ts.map +1 -0
  286. package/dist/commands/shared/task-mutation.js +67 -0
  287. package/dist/commands/shared/task-store.d.ts +5 -1
  288. package/dist/commands/shared/task-store.d.ts.map +1 -1
  289. package/dist/commands/shared/task-store.js +72 -92
  290. package/dist/commands/task/add.d.ts.map +1 -1
  291. package/dist/commands/task/add.js +41 -39
  292. package/dist/commands/task/block.d.ts.map +1 -1
  293. package/dist/commands/task/block.js +31 -110
  294. package/dist/commands/task/close-duplicate.d.ts.map +1 -1
  295. package/dist/commands/task/close-duplicate.js +0 -7
  296. package/dist/commands/task/close-noop.d.ts.map +1 -1
  297. package/dist/commands/task/close-noop.js +0 -21
  298. package/dist/commands/task/close-shared.d.ts +0 -2
  299. package/dist/commands/task/close-shared.d.ts.map +1 -1
  300. package/dist/commands/task/close-shared.js +25 -55
  301. package/dist/commands/task/comment.d.ts.map +1 -1
  302. package/dist/commands/task/comment.js +48 -37
  303. package/dist/commands/task/derive.d.ts.map +1 -1
  304. package/dist/commands/task/derive.js +14 -7
  305. package/dist/commands/task/doc.command.d.ts.map +1 -1
  306. package/dist/commands/task/doc.command.js +7 -6
  307. package/dist/commands/task/doc.d.ts.map +1 -1
  308. package/dist/commands/task/doc.js +58 -62
  309. package/dist/commands/task/finish-shared.d.ts +60 -0
  310. package/dist/commands/task/finish-shared.d.ts.map +1 -0
  311. package/dist/commands/task/finish-shared.js +181 -0
  312. package/dist/commands/task/finish.d.ts +1 -0
  313. package/dist/commands/task/finish.d.ts.map +1 -1
  314. package/dist/commands/task/finish.js +79 -210
  315. package/dist/commands/task/handoff-record.command.d.ts +17 -0
  316. package/dist/commands/task/handoff-record.command.d.ts.map +1 -0
  317. package/dist/commands/task/handoff-record.command.js +140 -0
  318. package/dist/commands/task/handoff-show.command.d.ts +8 -0
  319. package/dist/commands/task/handoff-show.command.d.ts.map +1 -0
  320. package/dist/commands/task/handoff-show.command.js +77 -0
  321. package/dist/commands/task/handoff.command.d.ts +7 -0
  322. package/dist/commands/task/handoff.command.d.ts.map +1 -0
  323. package/dist/commands/task/handoff.command.js +21 -0
  324. package/dist/commands/task/handoff.shared.d.ts +39 -0
  325. package/dist/commands/task/handoff.shared.d.ts.map +1 -0
  326. package/dist/commands/task/handoff.shared.js +134 -0
  327. package/dist/commands/task/hosted-close.command.d.ts +9 -0
  328. package/dist/commands/task/hosted-close.command.d.ts.map +1 -0
  329. package/dist/commands/task/hosted-close.command.js +190 -0
  330. package/dist/commands/task/hosted-merge-sync.d.ts +40 -0
  331. package/dist/commands/task/hosted-merge-sync.d.ts.map +1 -0
  332. package/dist/commands/task/hosted-merge-sync.js +277 -0
  333. package/dist/commands/task/list.d.ts.map +1 -1
  334. package/dist/commands/task/list.js +7 -24
  335. package/dist/commands/task/new.d.ts.map +1 -1
  336. package/dist/commands/task/new.js +26 -6
  337. package/dist/commands/task/next.d.ts.map +1 -1
  338. package/dist/commands/task/next.js +10 -28
  339. package/dist/commands/task/normalize.command.d.ts +1 -0
  340. package/dist/commands/task/normalize.command.d.ts.map +1 -1
  341. package/dist/commands/task/normalize.command.js +12 -0
  342. package/dist/commands/task/normalize.d.ts +1 -0
  343. package/dist/commands/task/normalize.d.ts.map +1 -1
  344. package/dist/commands/task/normalize.js +21 -9
  345. package/dist/commands/task/plan.command.d.ts +3 -4
  346. package/dist/commands/task/plan.command.d.ts.map +1 -1
  347. package/dist/commands/task/plan.command.js +6 -12
  348. package/dist/commands/task/plan.d.ts.map +1 -1
  349. package/dist/commands/task/plan.js +96 -103
  350. package/dist/commands/task/reclaim.command.d.ts +11 -0
  351. package/dist/commands/task/reclaim.command.d.ts.map +1 -0
  352. package/dist/commands/task/reclaim.command.js +102 -0
  353. package/dist/commands/task/resume-context.command.d.ts +9 -0
  354. package/dist/commands/task/resume-context.command.d.ts.map +1 -0
  355. package/dist/commands/task/resume-context.command.js +60 -0
  356. package/dist/commands/task/run-cancel.command.d.ts +6 -0
  357. package/dist/commands/task/run-cancel.command.d.ts.map +1 -0
  358. package/dist/commands/task/run-cancel.command.js +45 -0
  359. package/dist/commands/task/run-cancel.spec.d.ts +7 -0
  360. package/dist/commands/task/run-cancel.spec.d.ts.map +1 -0
  361. package/dist/commands/task/run-cancel.spec.js +20 -0
  362. package/dist/commands/task/run-resume.command.d.ts +6 -0
  363. package/dist/commands/task/run-resume.command.d.ts.map +1 -0
  364. package/dist/commands/task/run-resume.command.js +55 -0
  365. package/dist/commands/task/run-resume.spec.d.ts +7 -0
  366. package/dist/commands/task/run-resume.spec.d.ts.map +1 -0
  367. package/dist/commands/task/run-resume.spec.js +20 -0
  368. package/dist/commands/task/run-retry.command.d.ts +6 -0
  369. package/dist/commands/task/run-retry.command.d.ts.map +1 -0
  370. package/dist/commands/task/run-retry.command.js +56 -0
  371. package/dist/commands/task/run-retry.spec.d.ts +7 -0
  372. package/dist/commands/task/run-retry.spec.d.ts.map +1 -0
  373. package/dist/commands/task/run-retry.spec.js +20 -0
  374. package/dist/commands/task/run-show.command.d.ts +6 -0
  375. package/dist/commands/task/run-show.command.d.ts.map +1 -0
  376. package/dist/commands/task/run-show.command.js +133 -0
  377. package/dist/commands/task/run-show.spec.d.ts +8 -0
  378. package/dist/commands/task/run-show.spec.d.ts.map +1 -0
  379. package/dist/commands/task/run-show.spec.js +44 -0
  380. package/dist/commands/task/run-tail.command.d.ts +6 -0
  381. package/dist/commands/task/run-tail.command.d.ts.map +1 -0
  382. package/dist/commands/task/run-tail.command.js +26 -0
  383. package/dist/commands/task/run-tail.spec.d.ts +8 -0
  384. package/dist/commands/task/run-tail.spec.d.ts.map +1 -0
  385. package/dist/commands/task/run-tail.spec.js +51 -0
  386. package/dist/commands/task/run-trace.command.d.ts +6 -0
  387. package/dist/commands/task/run-trace.command.d.ts.map +1 -0
  388. package/dist/commands/task/run-trace.command.js +25 -0
  389. package/dist/commands/task/run-trace.spec.d.ts +7 -0
  390. package/dist/commands/task/run-trace.spec.d.ts.map +1 -0
  391. package/dist/commands/task/run-trace.spec.js +31 -0
  392. package/dist/commands/task/run.command.d.ts +6 -0
  393. package/dist/commands/task/run.command.d.ts.map +1 -0
  394. package/dist/commands/task/run.command.js +74 -0
  395. package/dist/commands/task/run.spec.d.ts +7 -0
  396. package/dist/commands/task/run.spec.d.ts.map +1 -0
  397. package/dist/commands/task/run.spec.js +26 -0
  398. package/dist/commands/task/scaffold.d.ts.map +1 -1
  399. package/dist/commands/task/scaffold.js +4 -2
  400. package/dist/commands/task/scrub.d.ts.map +1 -1
  401. package/dist/commands/task/scrub.js +27 -24
  402. package/dist/commands/task/search.d.ts.map +1 -1
  403. package/dist/commands/task/search.js +21 -31
  404. package/dist/commands/task/set-status.d.ts.map +1 -1
  405. package/dist/commands/task/set-status.js +36 -152
  406. package/dist/commands/task/shared/dependencies.d.ts +4 -4
  407. package/dist/commands/task/shared/dependencies.d.ts.map +1 -1
  408. package/dist/commands/task/shared/dependencies.js +10 -2
  409. package/dist/commands/task/shared/docs.d.ts +6 -1
  410. package/dist/commands/task/shared/docs.d.ts.map +1 -1
  411. package/dist/commands/task/shared/docs.js +13 -0
  412. package/dist/commands/task/shared/listing.d.ts +16 -2
  413. package/dist/commands/task/shared/listing.d.ts.map +1 -1
  414. package/dist/commands/task/shared/listing.js +56 -0
  415. package/dist/commands/task/shared/transition-command.d.ts +15 -0
  416. package/dist/commands/task/shared/transition-command.d.ts.map +1 -0
  417. package/dist/commands/task/shared/transition-command.js +43 -0
  418. package/dist/commands/task/shared/transitions.d.ts +39 -0
  419. package/dist/commands/task/shared/transitions.d.ts.map +1 -1
  420. package/dist/commands/task/shared/transitions.js +62 -1
  421. package/dist/commands/task/shared/workflow-transition-service.d.ts +75 -0
  422. package/dist/commands/task/shared/workflow-transition-service.d.ts.map +1 -0
  423. package/dist/commands/task/shared/workflow-transition-service.js +226 -0
  424. package/dist/commands/task/shared.d.ts +5 -3
  425. package/dist/commands/task/shared.d.ts.map +1 -1
  426. package/dist/commands/task/shared.js +5 -3
  427. package/dist/commands/task/show.d.ts.map +1 -1
  428. package/dist/commands/task/show.js +37 -3
  429. package/dist/commands/task/start.d.ts.map +1 -1
  430. package/dist/commands/task/start.js +33 -119
  431. package/dist/commands/task/task.command.d.ts +3 -4
  432. package/dist/commands/task/task.command.d.ts.map +1 -1
  433. package/dist/commands/task/task.command.js +22 -37
  434. package/dist/commands/task/verify-record.d.ts.map +1 -1
  435. package/dist/commands/task/verify-record.js +16 -141
  436. package/dist/commands/task/verify.command.d.ts.map +1 -1
  437. package/dist/commands/task/verify.command.js +7 -6
  438. package/dist/commands/task.test-helpers.d.ts +13 -0
  439. package/dist/commands/task.test-helpers.d.ts.map +1 -0
  440. package/dist/commands/task.test-helpers.js +65 -0
  441. package/dist/commands/upgrade/materialize.d.ts +28 -0
  442. package/dist/commands/upgrade/materialize.d.ts.map +1 -0
  443. package/dist/commands/upgrade/materialize.js +154 -0
  444. package/dist/commands/upgrade/plan.d.ts +18 -0
  445. package/dist/commands/upgrade/plan.d.ts.map +1 -0
  446. package/dist/commands/upgrade/plan.js +219 -0
  447. package/dist/commands/upgrade/policy.d.ts +24 -0
  448. package/dist/commands/upgrade/policy.d.ts.map +1 -0
  449. package/dist/commands/upgrade/policy.js +182 -0
  450. package/dist/commands/upgrade/report.d.ts.map +1 -1
  451. package/dist/commands/upgrade/report.js +7 -5
  452. package/dist/commands/upgrade.d.ts.map +1 -1
  453. package/dist/commands/upgrade.js +154 -642
  454. package/dist/commands/workflow.command.d.ts +3 -4
  455. package/dist/commands/workflow.command.d.ts.map +1 -1
  456. package/dist/commands/workflow.command.js +8 -25
  457. package/dist/ports/task-backend-port.d.ts +3 -1
  458. package/dist/ports/task-backend-port.d.ts.map +1 -1
  459. package/dist/runner/adapters/codex.d.ts +9 -0
  460. package/dist/runner/adapters/codex.d.ts.map +1 -0
  461. package/dist/runner/adapters/codex.js +414 -0
  462. package/dist/runner/adapters/custom.d.ts +12 -0
  463. package/dist/runner/adapters/custom.d.ts.map +1 -0
  464. package/dist/runner/adapters/custom.js +512 -0
  465. package/dist/runner/adapters/index.d.ts +8 -0
  466. package/dist/runner/adapters/index.d.ts.map +1 -0
  467. package/dist/runner/adapters/index.js +15 -0
  468. package/dist/runner/adapters/recipe-run-profile.d.ts +8 -0
  469. package/dist/runner/adapters/recipe-run-profile.d.ts.map +1 -0
  470. package/dist/runner/adapters/recipe-run-profile.js +53 -0
  471. package/dist/runner/adapters/shared.d.ts +45 -0
  472. package/dist/runner/adapters/shared.d.ts.map +1 -0
  473. package/dist/runner/adapters/shared.js +58 -0
  474. package/dist/runner/artifacts.d.ts +31 -0
  475. package/dist/runner/artifacts.d.ts.map +1 -0
  476. package/dist/runner/artifacts.js +153 -0
  477. package/dist/runner/codex-approval-probe.d.ts +23 -0
  478. package/dist/runner/codex-approval-probe.d.ts.map +1 -0
  479. package/dist/runner/codex-approval-probe.js +55 -0
  480. package/dist/runner/codex-smoke.d.ts +11 -0
  481. package/dist/runner/codex-smoke.d.ts.map +1 -0
  482. package/dist/runner/codex-smoke.js +45 -0
  483. package/dist/runner/config.d.ts +6 -0
  484. package/dist/runner/config.d.ts.map +1 -0
  485. package/dist/runner/config.js +15 -0
  486. package/dist/runner/context/base-prompts.d.ts +10 -0
  487. package/dist/runner/context/base-prompts.d.ts.map +1 -0
  488. package/dist/runner/context/base-prompts.js +255 -0
  489. package/dist/runner/context/recipe-context.d.ts +17 -0
  490. package/dist/runner/context/recipe-context.d.ts.map +1 -0
  491. package/dist/runner/context/recipe-context.js +48 -0
  492. package/dist/runner/context/task-context.d.ts +24 -0
  493. package/dist/runner/context/task-context.d.ts.map +1 -0
  494. package/dist/runner/context/task-context.js +266 -0
  495. package/dist/runner/index.d.ts +12 -0
  496. package/dist/runner/index.d.ts.map +1 -0
  497. package/dist/runner/index.js +11 -0
  498. package/dist/runner/policy-decision.d.ts +12 -0
  499. package/dist/runner/policy-decision.d.ts.map +1 -0
  500. package/dist/runner/policy-decision.js +89 -0
  501. package/dist/runner/policy-display.d.ts +4 -0
  502. package/dist/runner/policy-display.d.ts.map +1 -0
  503. package/dist/runner/policy-display.js +41 -0
  504. package/dist/runner/process-supervision.d.ts +48 -0
  505. package/dist/runner/process-supervision.d.ts.map +1 -0
  506. package/dist/runner/process-supervision.js +490 -0
  507. package/dist/runner/result-manifest-policy.d.ts +9 -0
  508. package/dist/runner/result-manifest-policy.d.ts.map +1 -0
  509. package/dist/runner/result-manifest-policy.js +96 -0
  510. package/dist/runner/result-manifest.d.ts +30 -0
  511. package/dist/runner/result-manifest.d.ts.map +1 -0
  512. package/dist/runner/result-manifest.js +322 -0
  513. package/dist/runner/run-id.d.ts +2 -0
  514. package/dist/runner/run-id.d.ts.map +1 -0
  515. package/dist/runner/run-id.js +3 -0
  516. package/dist/runner/run-repository.d.ts +51 -0
  517. package/dist/runner/run-repository.d.ts.map +1 -0
  518. package/dist/runner/run-repository.js +222 -0
  519. package/dist/runner/task-run-paths.d.ts +19 -0
  520. package/dist/runner/task-run-paths.d.ts.map +1 -0
  521. package/dist/runner/task-run-paths.js +25 -0
  522. package/dist/runner/task-state.d.ts +9 -0
  523. package/dist/runner/task-state.d.ts.map +1 -0
  524. package/dist/runner/task-state.js +354 -0
  525. package/dist/runner/test-helpers.d.ts +30 -0
  526. package/dist/runner/test-helpers.d.ts.map +1 -0
  527. package/dist/runner/test-helpers.js +97 -0
  528. package/dist/runner/trace-artifacts.d.ts +14 -0
  529. package/dist/runner/trace-artifacts.d.ts.map +1 -0
  530. package/dist/runner/trace-artifacts.js +80 -0
  531. package/dist/runner/trace.d.ts +10 -0
  532. package/dist/runner/trace.d.ts.map +1 -0
  533. package/dist/runner/trace.js +37 -0
  534. package/dist/runner/types.d.ts +317 -0
  535. package/dist/runner/types.d.ts.map +1 -0
  536. package/dist/runner/types.js +3 -0
  537. package/dist/runner/usecases/scenario-materialize-task.d.ts +29 -0
  538. package/dist/runner/usecases/scenario-materialize-task.d.ts.map +1 -0
  539. package/dist/runner/usecases/scenario-materialize-task.js +151 -0
  540. package/dist/runner/usecases/task-run-inspect.d.ts +41 -0
  541. package/dist/runner/usecases/task-run-inspect.d.ts.map +1 -0
  542. package/dist/runner/usecases/task-run-inspect.js +74 -0
  543. package/dist/runner/usecases/task-run-lifecycle-cancel.d.ts +10 -0
  544. package/dist/runner/usecases/task-run-lifecycle-cancel.d.ts.map +1 -0
  545. package/dist/runner/usecases/task-run-lifecycle-cancel.js +172 -0
  546. package/dist/runner/usecases/task-run-lifecycle-replay.d.ts +18 -0
  547. package/dist/runner/usecases/task-run-lifecycle-replay.d.ts.map +1 -0
  548. package/dist/runner/usecases/task-run-lifecycle-replay.js +128 -0
  549. package/dist/runner/usecases/task-run-lifecycle-shared.d.ts +45 -0
  550. package/dist/runner/usecases/task-run-lifecycle-shared.d.ts.map +1 -0
  551. package/dist/runner/usecases/task-run-lifecycle-shared.js +172 -0
  552. package/dist/runner/usecases/task-run-lifecycle.d.ts +4 -0
  553. package/dist/runner/usecases/task-run-lifecycle.d.ts.map +1 -0
  554. package/dist/runner/usecases/task-run-lifecycle.js +2 -0
  555. package/dist/runner/usecases/task-run.d.ts +32 -0
  556. package/dist/runner/usecases/task-run.d.ts.map +1 -0
  557. package/dist/runner/usecases/task-run.js +278 -0
  558. package/dist/shared/agent-emoji.d.ts.map +1 -1
  559. package/dist/shared/agent-emoji.js +1 -0
  560. package/dist/shared/errors.d.ts +1 -1
  561. package/dist/shared/errors.d.ts.map +1 -1
  562. package/dist/shared/guards.d.ts.map +1 -1
  563. package/dist/shared/guards.js +1 -0
  564. package/dist/shared/repo-cli-version.d.ts.map +1 -1
  565. package/dist/shared/repo-cli-version.js +7 -5
  566. package/dist/shared/task-doc-conflicts.d.ts +12 -0
  567. package/dist/shared/task-doc-conflicts.d.ts.map +1 -0
  568. package/dist/shared/task-doc-conflicts.js +40 -0
  569. package/dist/shared/task-doc-state.d.ts +10 -0
  570. package/dist/shared/task-doc-state.d.ts.map +1 -0
  571. package/dist/shared/task-doc-state.js +15 -0
  572. package/dist/test-helpers/fs.d.ts +2 -0
  573. package/dist/test-helpers/fs.d.ts.map +1 -0
  574. package/dist/test-helpers/fs.js +9 -0
  575. package/dist/usecases/context/resolve-context.d.ts +2 -0
  576. package/dist/usecases/context/resolve-context.d.ts.map +1 -1
  577. package/dist/usecases/context/resolve-context.js +4 -1
  578. package/dist/usecases/task/task-list-usecase.d.ts.map +1 -1
  579. package/dist/usecases/task/task-list-usecase.js +2 -8
  580. package/dist/workflow-runtime/fix.d.ts +9 -1
  581. package/dist/workflow-runtime/fix.d.ts.map +1 -1
  582. package/dist/workflow-runtime/fix.js +9 -1
  583. package/package.json +3 -2
  584. package/dist/backends/task-backend.test-helpers.d.ts +0 -4
  585. package/dist/backends/task-backend.test-helpers.d.ts.map +0 -1
  586. package/dist/backends/task-backend.test-helpers.js +0 -33
  587. package/dist/cli/run-cli/catalog.d.ts +0 -7
  588. package/dist/cli/run-cli/catalog.d.ts.map +0 -1
  589. package/dist/cli/run-cli/catalog.js +0 -22
  590. package/dist/cli/run-cli.core.pr-flow.test-helpers.d.ts +0 -3
  591. package/dist/cli/run-cli.core.pr-flow.test-helpers.d.ts.map +0 -1
  592. package/dist/cli/run-cli.core.pr-flow.test-helpers.js +0 -41
  593. package/dist/cli/run-cli.core.tasks.test-helpers.d.ts +0 -2
  594. package/dist/cli/run-cli.core.tasks.test-helpers.d.ts.map +0 -1
  595. package/dist/cli/run-cli.core.tasks.test-helpers.js +0 -6
  596. package/dist/commands/block.command.d.ts +0 -4
  597. package/dist/commands/block.command.d.ts.map +0 -1
  598. package/dist/commands/block.command.js +0 -2
  599. package/dist/commands/doctor.command.d.ts +0 -3
  600. package/dist/commands/doctor.command.d.ts.map +0 -1
  601. package/dist/commands/doctor.command.js +0 -2
  602. package/dist/commands/finish.command.d.ts +0 -4
  603. package/dist/commands/finish.command.d.ts.map +0 -1
  604. package/dist/commands/finish.command.js +0 -2
  605. package/dist/commands/recipes/install.command.d.ts +0 -3
  606. package/dist/commands/recipes/install.command.d.ts.map +0 -1
  607. package/dist/commands/recipes/install.command.js +0 -2
  608. package/dist/commands/start.command.d.ts +0 -4
  609. package/dist/commands/start.command.d.ts.map +0 -1
  610. package/dist/commands/start.command.js +0 -2
  611. package/dist/commands/task/list.command.d.ts +0 -4
  612. package/dist/commands/task/list.command.d.ts.map +0 -1
  613. package/dist/commands/task/list.command.js +0 -2
  614. package/dist/commands/task/next.command.d.ts +0 -4
  615. package/dist/commands/task/next.command.d.ts.map +0 -1
  616. package/dist/commands/task/next.command.js +0 -2
  617. package/dist/commands/task/search.command.d.ts +0 -4
  618. package/dist/commands/task/search.command.d.ts.map +0 -1
  619. package/dist/commands/task/search.command.js +0 -2
  620. package/dist/commands/task/show.command.d.ts +0 -4
  621. package/dist/commands/task/show.command.d.ts.map +0 -1
  622. package/dist/commands/task/show.command.js +0 -2
  623. package/dist/commands/verify.command.d.ts +0 -4
  624. package/dist/commands/verify.command.d.ts.map +0 -1
  625. package/dist/commands/verify.command.js +0 -2
@@ -0,0 +1,89 @@
1
+ import { readRecipeRunProfile } from "./adapters/recipe-run-profile.js";
2
+ function toRequestedMap(profile) {
3
+ if (!profile)
4
+ return {};
5
+ const requested = {};
6
+ for (const [key, value] of Object.entries(profile)) {
7
+ if (value !== undefined) {
8
+ requested[key] = value;
9
+ }
10
+ }
11
+ return requested;
12
+ }
13
+ export function buildRunnerPolicyDecision(opts) {
14
+ const profile = readRecipeRunProfile(opts.recipe);
15
+ const requested = toRequestedMap(profile);
16
+ const effective = {};
17
+ const fields = {};
18
+ const capabilityFields = opts.capabilities?.fields ?? {};
19
+ for (const [fieldName, capability] of Object.entries(capabilityFields)) {
20
+ const hasRequest = Object.hasOwn(requested, fieldName);
21
+ const requestedValue = hasRequest ? requested[fieldName] : undefined;
22
+ const decision = {
23
+ requested: requestedValue,
24
+ status: "not_requested",
25
+ capability_level: capability.level,
26
+ channel: capability.channel,
27
+ ...(capability.supported_values ? { supported_values: capability.supported_values } : {}),
28
+ ...(capability.note ? { note: capability.note } : {}),
29
+ };
30
+ if (!hasRequest) {
31
+ fields[fieldName] = decision;
32
+ continue;
33
+ }
34
+ if (capability.level === "native" || capability.level === "wrapper") {
35
+ if (Array.isArray(capability.supported_values) &&
36
+ typeof requestedValue === "string" &&
37
+ !capability.supported_values.includes(requestedValue)) {
38
+ fields[fieldName] = {
39
+ ...decision,
40
+ status: "unsupported",
41
+ };
42
+ continue;
43
+ }
44
+ effective[fieldName] = requestedValue;
45
+ fields[fieldName] = {
46
+ ...decision,
47
+ effective: requestedValue,
48
+ status: "enforced",
49
+ };
50
+ continue;
51
+ }
52
+ fields[fieldName] = {
53
+ ...decision,
54
+ status: capability.level === "advisory" ? "advisory" : "unsupported",
55
+ };
56
+ }
57
+ for (const [fieldName, requestedValue] of Object.entries(requested)) {
58
+ if (Object.hasOwn(fields, fieldName))
59
+ continue;
60
+ fields[fieldName] = {
61
+ requested: requestedValue,
62
+ status: "unsupported",
63
+ capability_level: "unsupported",
64
+ channel: "none",
65
+ };
66
+ }
67
+ return {
68
+ adapter_id: opts.adapter_id,
69
+ requested,
70
+ effective,
71
+ fields,
72
+ refusal_reason: null,
73
+ };
74
+ }
75
+ export function applyRunnerPolicyRefusal(opts) {
76
+ return {
77
+ ...opts.decision,
78
+ refusal_reason: {
79
+ code: opts.error.code,
80
+ message: opts.error.message,
81
+ ...(typeof opts.error.context?.policy_field === "string"
82
+ ? { policy_field: opts.error.context.policy_field }
83
+ : {}),
84
+ ...(Object.hasOwn(opts.error.context ?? {}, "declared_value")
85
+ ? { declared_value: opts.error.context?.declared_value }
86
+ : {}),
87
+ },
88
+ };
89
+ }
@@ -0,0 +1,4 @@
1
+ import type { RunnerAdapterCapabilities, RunnerPolicyDecision } from "./types.js";
2
+ export declare function formatRunnerCapabilitySummaryLines(capabilities: RunnerAdapterCapabilities | undefined): string[];
3
+ export declare function formatRunnerPolicyFieldSummaryLines(decision: RunnerPolicyDecision | undefined): string[];
4
+ //# sourceMappingURL=policy-display.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policy-display.d.ts","sourceRoot":"","sources":["../../src/runner/policy-display.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,yBAAyB,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAYlF,wBAAgB,kCAAkC,CAChD,YAAY,EAAE,yBAAyB,GAAG,SAAS,GAClD,MAAM,EAAE,CAgBV;AAED,wBAAgB,mCAAmC,CACjD,QAAQ,EAAE,oBAAoB,GAAG,SAAS,GACzC,MAAM,EAAE,CAmBV"}
@@ -0,0 +1,41 @@
1
+ function appendPart(parts, key, value) {
2
+ if (!value)
3
+ return;
4
+ parts.push(`${key}=${value}`);
5
+ }
6
+ function renderValue(value) {
7
+ if (value === undefined)
8
+ return null;
9
+ return JSON.stringify(value);
10
+ }
11
+ export function formatRunnerCapabilitySummaryLines(capabilities) {
12
+ if (!capabilities)
13
+ return [];
14
+ return Object.entries(capabilities.fields).map(([fieldName, capability]) => {
15
+ const parts = [
16
+ `capability[${fieldName}]:`,
17
+ `level=${capability.level}`,
18
+ `channel=${capability.channel}`,
19
+ ];
20
+ appendPart(parts, "supported", capability.supported_values?.length ? capability.supported_values.join(",") : null);
21
+ appendPart(parts, "note", capability.note ?? null);
22
+ return parts.join(" ");
23
+ });
24
+ }
25
+ export function formatRunnerPolicyFieldSummaryLines(decision) {
26
+ if (!decision)
27
+ return [];
28
+ return Object.entries(decision.fields).map(([fieldName, field]) => {
29
+ const parts = [
30
+ `policy_field[${fieldName}]:`,
31
+ `status=${field.status}`,
32
+ `capability=${field.capability_level}`,
33
+ `channel=${field.channel}`,
34
+ ];
35
+ appendPart(parts, "requested", renderValue(field.requested));
36
+ appendPart(parts, "effective", renderValue(field.effective));
37
+ appendPart(parts, "supported", field.supported_values?.length ? field.supported_values.join(",") : null);
38
+ appendPart(parts, "note", field.note ?? null);
39
+ return parts.join(" ");
40
+ });
41
+ }
@@ -0,0 +1,48 @@
1
+ import type { RunnerInvocation, RunnerProcessSignal, RunnerRunState, RunnerTimeoutReason } from "./types.js";
2
+ export type SupervisedProcessResult = {
3
+ exit_code: number | null;
4
+ exit_signal: RunnerProcessSignal | null;
5
+ stdout_tail: string;
6
+ stderr_tail: string;
7
+ stdout_bytes: number;
8
+ stderr_bytes: number;
9
+ pid: number | null;
10
+ started_at: string;
11
+ ended_at: string;
12
+ cancel_requested_at: string | null;
13
+ cancel_signal: RunnerProcessSignal | null;
14
+ timeout_reason: RunnerTimeoutReason | null;
15
+ timeout_requested_at: string | null;
16
+ terminate_sent_at: string | null;
17
+ kill_sent_at: string | null;
18
+ force_killed: boolean;
19
+ heartbeat_at: string;
20
+ trace_artifact_path: string | null;
21
+ trace_archive_path: string | null;
22
+ stderr_artifact_path: string | null;
23
+ stderr_archive_path: string | null;
24
+ };
25
+ export type ObservedProcessIdentity = {
26
+ pid: number;
27
+ command: string | null;
28
+ started_at: string | null;
29
+ };
30
+ export declare function exitCodeForSignal(signal: RunnerProcessSignal | null): number | null;
31
+ export declare function isProcessAlive(pid: number): boolean;
32
+ export declare function readObservedProcessIdentity(pid: number): Promise<ObservedProcessIdentity | null>;
33
+ export declare function waitForProcessExit(opts: {
34
+ pid: number;
35
+ timeout_ms: number;
36
+ poll_ms?: number;
37
+ }): Promise<boolean>;
38
+ export declare function runSupervisedProcess(opts: {
39
+ invocation: RunnerInvocation;
40
+ stdin_text: string;
41
+ start_message: string;
42
+ }): Promise<SupervisedProcessResult>;
43
+ export declare function waitForRunnerStateStop(opts: {
44
+ state_path: string;
45
+ timeout_ms: number;
46
+ poll_ms?: number;
47
+ }): Promise<RunnerRunState | null>;
48
+ //# sourceMappingURL=process-supervision.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"process-supervision.d.ts","sourceRoot":"","sources":["../../src/runner/process-supervision.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EACV,gBAAgB,EAChB,mBAAmB,EACnB,cAAc,EAEd,mBAAmB,EACpB,MAAM,YAAY,CAAC;AAapB,MAAM,MAAM,uBAAuB,GAAG;IACpC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,WAAW,EAAE,mBAAmB,GAAG,IAAI,CAAC;IACxC,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,aAAa,EAAE,mBAAmB,GAAG,IAAI,CAAC;IAC1C,cAAc,EAAE,mBAAmB,GAAG,IAAI,CAAC;IAC3C,oBAAoB,EAAE,MAAM,GAAG,IAAI,CAAC;IACpC,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,YAAY,EAAE,OAAO,CAAC;IACtB,YAAY,EAAE,MAAM,CAAC;IACrB,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,oBAAoB,EAAE,MAAM,GAAG,IAAI,CAAC;IACpC,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC;CACpC,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;CAC3B,CAAC;AA2EF,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,mBAAmB,GAAG,IAAI,GAAG,MAAM,GAAG,IAAI,CAOnF;AAED,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAUnD;AAED,wBAAsB,2BAA2B,CAC/C,GAAG,EAAE,MAAM,GACV,OAAO,CAAC,uBAAuB,GAAG,IAAI,CAAC,CA6BzC;AAED,wBAAsB,kBAAkB,CAAC,IAAI,EAAE;IAC7C,GAAG,EAAE,MAAM,CAAC;IACZ,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,GAAG,OAAO,CAAC,OAAO,CAAC,CAQnB;AAED,wBAAsB,oBAAoB,CAAC,IAAI,EAAE;IAC/C,UAAU,EAAE,gBAAgB,CAAC;IAC7B,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;CACvB,GAAG,OAAO,CAAC,uBAAuB,CAAC,CA+UnC;AAED,wBAAsB,sBAAsB,CAAC,IAAI,EAAE;IACjD,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,GAAG,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC,CAUjC"}
@@ -0,0 +1,490 @@
1
+ import { execFile, spawn } from "node:child_process";
2
+ import { appendFileSync } from "node:fs";
3
+ import { promisify } from "node:util";
4
+ import { appendRunnerEvent, evolveRunnerRunState, readRunnerRunState, writeRunnerRunState, } from "./artifacts.js";
5
+ import { finalizeTraceArtifact, redactTraceText } from "./trace-artifacts.js";
6
+ import { createRunnerTraceEvent, serializeRunnerTraceEvent } from "./trace.js";
7
+ const SUPPORTED_SIGNALS = new Set([
8
+ "SIGHUP",
9
+ "SIGINT",
10
+ "SIGQUIT",
11
+ "SIGTERM",
12
+ "SIGKILL",
13
+ ]);
14
+ const execFileAsync = promisify(execFile);
15
+ function renderInvocationCommand(invocation) {
16
+ const commandLine = invocation.argv
17
+ .map((part) => part.trim())
18
+ .filter((part) => part.length > 0)
19
+ .join(" ");
20
+ return commandLine.length > 0 ? commandLine : null;
21
+ }
22
+ function normalizeSignal(signal) {
23
+ if (!signal)
24
+ return null;
25
+ return SUPPORTED_SIGNALS.has(signal)
26
+ ? signal
27
+ : null;
28
+ }
29
+ function mergeSupervisionState(current, patch) {
30
+ return {
31
+ ...current,
32
+ ...Object.fromEntries(Object.entries(patch).filter(([, value]) => value !== undefined)),
33
+ };
34
+ }
35
+ function buildInvocationEventData(invocation, pid) {
36
+ return {
37
+ executable: invocation.argv[0] ?? null,
38
+ argv_count: invocation.argv.length,
39
+ cwd: invocation.run_dir,
40
+ env_keys: Object.keys(invocation.env).toSorted(),
41
+ has_bootstrap_path: typeof invocation.bootstrap_path === "string" && invocation.bootstrap_path.trim().length > 0,
42
+ has_output_last_message_path: typeof invocation.output_last_message_path === "string" &&
43
+ invocation.output_last_message_path.trim().length > 0,
44
+ has_trace_path: typeof invocation.trace_path === "string" && invocation.trace_path.trim().length > 0,
45
+ has_stderr_path: typeof invocation.stderr_path === "string" && invocation.stderr_path.trim().length > 0,
46
+ trace_policy: invocation.trace_policy,
47
+ timeout_policy: invocation.timeout_policy,
48
+ pid,
49
+ };
50
+ }
51
+ function appendTail(current, incoming, maxBytes) {
52
+ const combined = Buffer.from(`${current}${incoming}`, "utf8");
53
+ if (combined.length <= maxBytes)
54
+ return combined.toString("utf8");
55
+ return combined.subarray(combined.length - maxBytes).toString("utf8");
56
+ }
57
+ function splitCompletedLines(buffer) {
58
+ const lines = [];
59
+ let start = 0;
60
+ while (start < buffer.length) {
61
+ const newlineIndex = buffer.indexOf("\n", start);
62
+ if (newlineIndex === -1) {
63
+ return { lines, remainder: buffer.slice(start) };
64
+ }
65
+ let line = buffer.slice(start, newlineIndex);
66
+ if (line.endsWith("\r")) {
67
+ line = line.slice(0, -1);
68
+ }
69
+ lines.push(line);
70
+ start = newlineIndex + 1;
71
+ }
72
+ return { lines, remainder: "" };
73
+ }
74
+ export function exitCodeForSignal(signal) {
75
+ if (signal === "SIGINT")
76
+ return 130;
77
+ if (signal === "SIGTERM")
78
+ return 143;
79
+ if (signal === "SIGKILL")
80
+ return 137;
81
+ if (signal === "SIGHUP")
82
+ return 129;
83
+ if (signal === "SIGQUIT")
84
+ return 131;
85
+ return null;
86
+ }
87
+ export function isProcessAlive(pid) {
88
+ try {
89
+ process.kill(pid, 0);
90
+ return true;
91
+ }
92
+ catch (err) {
93
+ const code = err?.code;
94
+ if (code === "ESRCH")
95
+ return false;
96
+ if (code === "EPERM")
97
+ return true;
98
+ throw err;
99
+ }
100
+ }
101
+ export async function readObservedProcessIdentity(pid) {
102
+ try {
103
+ const { stdout } = await execFileAsync("ps", ["-o", "lstart=,command=", "-p", String(pid)], {
104
+ encoding: "utf8",
105
+ });
106
+ const line = stdout
107
+ .split("\n")
108
+ .map((entry) => entry.trim())
109
+ .find((entry) => entry.length > 0);
110
+ if (!line)
111
+ return null;
112
+ const match = /^([A-Z][a-z]{2}\s+[A-Z][a-z]{2}\s+\d{1,2}\s+\d\d:\d\d:\d\d\s+\d{4})\s+(.*)$/u.exec(line);
113
+ const startedAtRaw = match?.[1]?.trim() ?? null;
114
+ const command = match?.[2]?.trim() ?? null;
115
+ const parsedStartedAt = startedAtRaw && !Number.isNaN(Date.parse(startedAtRaw))
116
+ ? new Date(startedAtRaw).toISOString()
117
+ : null;
118
+ return {
119
+ pid,
120
+ command,
121
+ started_at: parsedStartedAt,
122
+ };
123
+ }
124
+ catch (err) {
125
+ const errno = err?.code;
126
+ const exitCode = err?.code;
127
+ if (errno === "ESRCH" || exitCode === 1)
128
+ return null;
129
+ throw err;
130
+ }
131
+ }
132
+ export async function waitForProcessExit(opts) {
133
+ const started = Date.now();
134
+ const poll_ms = opts.poll_ms ?? 100;
135
+ while (Date.now() - started < opts.timeout_ms) {
136
+ if (!isProcessAlive(opts.pid))
137
+ return true;
138
+ await new Promise((resolve) => setTimeout(resolve, poll_ms));
139
+ }
140
+ return !isProcessAlive(opts.pid);
141
+ }
142
+ export async function runSupervisedProcess(opts) {
143
+ return await new Promise((resolve, reject) => {
144
+ const [command, ...args] = opts.invocation.argv;
145
+ if (!command) {
146
+ reject(new Error("Runner invocation is missing the executable command"));
147
+ return;
148
+ }
149
+ const child = spawn(command, args, {
150
+ cwd: opts.invocation.run_dir,
151
+ env: { ...process.env, ...opts.invocation.env },
152
+ stdio: ["pipe", "pipe", "pipe"],
153
+ });
154
+ const pid = typeof child.pid === "number" ? child.pid : null;
155
+ const started_at = new Date().toISOString();
156
+ let heartbeat_at = started_at;
157
+ let stdout_tail = "";
158
+ let stderr_tail = "";
159
+ let stdout_bytes = 0;
160
+ let stderr_bytes = 0;
161
+ let stdout_buffer = "";
162
+ let stderr_buffer = "";
163
+ let trace_seq = 0;
164
+ let settled = false;
165
+ const tracePolicy = opts.invocation.trace_policy;
166
+ const timeoutPolicy = opts.invocation.timeout_policy;
167
+ const traceMode = tracePolicy.mode;
168
+ const captureStderr = tracePolicy.capture_stderr;
169
+ const maxTailBytes = tracePolicy.max_tail_bytes;
170
+ const redactPatterns = tracePolicy.redact_patterns ?? [];
171
+ let timeoutReason = null;
172
+ let timeoutRequestedAt = null;
173
+ let terminateSentAt = null;
174
+ let killSentAt = null;
175
+ let idleTimer = null;
176
+ let wallTimer = null;
177
+ let killTimer = null;
178
+ const queueAppend = (kind, text) => {
179
+ if (kind === "trace" && traceMode !== "raw")
180
+ return;
181
+ if (kind === "stderr" && !captureStderr)
182
+ return;
183
+ const path = kind === "trace" ? opts.invocation.trace_path : opts.invocation.stderr_path;
184
+ try {
185
+ appendFileSync(path, text, "utf8");
186
+ }
187
+ catch (err) {
188
+ finishWithError(err);
189
+ }
190
+ };
191
+ const writeTraceLine = (stream, raw) => {
192
+ trace_seq += 1;
193
+ queueAppend("trace", serializeRunnerTraceEvent(createRunnerTraceEvent({
194
+ ts: new Date().toISOString(),
195
+ seq: trace_seq,
196
+ stream,
197
+ adapter_id: opts.invocation.adapter_id,
198
+ raw,
199
+ })));
200
+ };
201
+ const flushTraceBuffer = (buffer, stream) => {
202
+ const { lines, remainder } = splitCompletedLines(buffer);
203
+ for (const line of lines) {
204
+ writeTraceLine(stream, line);
205
+ }
206
+ return remainder;
207
+ };
208
+ const clearTimers = () => {
209
+ if (idleTimer)
210
+ clearTimeout(idleTimer);
211
+ if (wallTimer)
212
+ clearTimeout(wallTimer);
213
+ if (killTimer)
214
+ clearTimeout(killTimer);
215
+ idleTimer = null;
216
+ wallTimer = null;
217
+ killTimer = null;
218
+ };
219
+ const patchRunningSupervision = async (patch) => {
220
+ const currentState = await readRunnerRunState(opts.invocation.state_path);
221
+ if (!currentState)
222
+ return;
223
+ await writeRunnerRunState({
224
+ state_path: opts.invocation.state_path,
225
+ state: evolveRunnerRunState({
226
+ state: currentState,
227
+ status: currentState.status,
228
+ updated_at: new Date().toISOString(),
229
+ supervision: mergeSupervisionState(currentState.supervision, patch),
230
+ }),
231
+ });
232
+ };
233
+ const requestTimeout = (reason) => {
234
+ if (settled || timeoutReason)
235
+ return;
236
+ timeoutReason = reason;
237
+ timeoutRequestedAt = new Date().toISOString();
238
+ terminateSentAt = timeoutRequestedAt;
239
+ void patchRunningSupervision({
240
+ timeout_reason: reason,
241
+ timeout_requested_at: timeoutRequestedAt,
242
+ terminate_sent_at: terminateSentAt,
243
+ heartbeat_at: timeoutRequestedAt,
244
+ }).catch(finishWithError);
245
+ void appendRunnerEvent({
246
+ events_path: opts.invocation.events_path,
247
+ event: {
248
+ at: timeoutRequestedAt,
249
+ type: "runner_timeout_requested",
250
+ message: `runner timeout requested (${reason})`,
251
+ data: {
252
+ reason,
253
+ pid,
254
+ timeout_policy: timeoutPolicy,
255
+ },
256
+ },
257
+ }).catch(finishWithError);
258
+ if (pid && isProcessAlive(pid)) {
259
+ try {
260
+ process.kill(pid, "SIGTERM");
261
+ }
262
+ catch (err) {
263
+ const code = err?.code;
264
+ if (code !== "ESRCH") {
265
+ finishWithError(err);
266
+ return;
267
+ }
268
+ }
269
+ }
270
+ const graceMs = timeoutPolicy.terminate_grace_ms;
271
+ if (graceMs <= 0) {
272
+ killSentAt = new Date().toISOString();
273
+ void patchRunningSupervision({
274
+ timeout_reason: reason,
275
+ timeout_requested_at: timeoutRequestedAt,
276
+ terminate_sent_at: terminateSentAt,
277
+ kill_sent_at: killSentAt,
278
+ force_killed: true,
279
+ heartbeat_at: killSentAt,
280
+ }).catch(finishWithError);
281
+ if (pid && isProcessAlive(pid)) {
282
+ try {
283
+ process.kill(pid, "SIGKILL");
284
+ }
285
+ catch (err) {
286
+ const code = err?.code;
287
+ if (code !== "ESRCH") {
288
+ finishWithError(err);
289
+ }
290
+ }
291
+ }
292
+ return;
293
+ }
294
+ killTimer = setTimeout(() => {
295
+ if (settled || !timeoutReason)
296
+ return;
297
+ killSentAt = new Date().toISOString();
298
+ void patchRunningSupervision({
299
+ timeout_reason: timeoutReason,
300
+ timeout_requested_at: timeoutRequestedAt,
301
+ terminate_sent_at: terminateSentAt,
302
+ kill_sent_at: killSentAt,
303
+ force_killed: true,
304
+ heartbeat_at: killSentAt,
305
+ }).catch(finishWithError);
306
+ void appendRunnerEvent({
307
+ events_path: opts.invocation.events_path,
308
+ event: {
309
+ at: killSentAt,
310
+ type: "runner_timeout_force_kill",
311
+ message: `runner force-killed after timeout (${timeoutReason})`,
312
+ data: {
313
+ reason: timeoutReason,
314
+ pid,
315
+ timeout_policy: timeoutPolicy,
316
+ },
317
+ },
318
+ }).catch(finishWithError);
319
+ if (pid && isProcessAlive(pid)) {
320
+ try {
321
+ process.kill(pid, "SIGKILL");
322
+ }
323
+ catch (err) {
324
+ const code = err?.code;
325
+ if (code !== "ESRCH") {
326
+ finishWithError(err);
327
+ }
328
+ }
329
+ }
330
+ }, graceMs);
331
+ };
332
+ const resetIdleTimer = () => {
333
+ if (timeoutPolicy.idle_ms <= 0 || settled || timeoutReason)
334
+ return;
335
+ if (idleTimer)
336
+ clearTimeout(idleTimer);
337
+ idleTimer = setTimeout(() => {
338
+ requestTimeout("idle");
339
+ }, timeoutPolicy.idle_ms);
340
+ };
341
+ const updateRunningState = async () => {
342
+ const initialState = await readRunnerRunState(opts.invocation.state_path);
343
+ if (!initialState)
344
+ return;
345
+ const supervision = mergeSupervisionState(initialState.supervision, {
346
+ pid,
347
+ command: renderInvocationCommand(opts.invocation),
348
+ started_at,
349
+ heartbeat_at,
350
+ exit_signal: null,
351
+ timeout_reason: null,
352
+ });
353
+ await writeRunnerRunState({
354
+ state_path: opts.invocation.state_path,
355
+ state: evolveRunnerRunState({
356
+ state: initialState,
357
+ status: "running",
358
+ updated_at: started_at,
359
+ supervision,
360
+ }),
361
+ });
362
+ await appendRunnerEvent({
363
+ events_path: opts.invocation.events_path,
364
+ event: {
365
+ at: started_at,
366
+ type: "runner_execute_start",
367
+ message: opts.start_message,
368
+ data: buildInvocationEventData(opts.invocation, pid),
369
+ },
370
+ });
371
+ };
372
+ const finishWithError = (err) => {
373
+ if (settled)
374
+ return;
375
+ clearTimers();
376
+ settled = true;
377
+ reject(err instanceof Error ? err : new Error(String(err)));
378
+ };
379
+ void updateRunningState().catch((err) => {
380
+ if (pid && isProcessAlive(pid)) {
381
+ try {
382
+ process.kill(pid, "SIGKILL");
383
+ }
384
+ catch {
385
+ // best effort
386
+ }
387
+ }
388
+ finishWithError(err);
389
+ });
390
+ child.stdout.on("data", (chunk) => {
391
+ const text = chunk.toString();
392
+ const persistedText = redactTraceText(text, redactPatterns);
393
+ heartbeat_at = new Date().toISOString();
394
+ resetIdleTimer();
395
+ stdout_bytes += Buffer.byteLength(text, "utf8");
396
+ stdout_tail = appendTail(stdout_tail, persistedText, maxTailBytes);
397
+ stdout_buffer = flushTraceBuffer(`${stdout_buffer}${persistedText}`, "stdout");
398
+ });
399
+ child.stderr.on("data", (chunk) => {
400
+ const text = chunk.toString();
401
+ const persistedText = redactTraceText(text, redactPatterns);
402
+ heartbeat_at = new Date().toISOString();
403
+ resetIdleTimer();
404
+ stderr_bytes += Buffer.byteLength(text, "utf8");
405
+ stderr_tail = appendTail(stderr_tail, persistedText, maxTailBytes);
406
+ stderr_buffer = flushTraceBuffer(`${stderr_buffer}${persistedText}`, "stderr");
407
+ queueAppend("stderr", persistedText);
408
+ });
409
+ child.on("error", finishWithError);
410
+ child.on("close", async (code, signal) => {
411
+ if (settled)
412
+ return;
413
+ clearTimers();
414
+ const ended_at = new Date().toISOString();
415
+ if (stdout_buffer) {
416
+ writeTraceLine("stdout", stdout_buffer);
417
+ }
418
+ if (stderr_buffer) {
419
+ writeTraceLine("stderr", stderr_buffer);
420
+ }
421
+ if (settled)
422
+ return;
423
+ const normalizedSignal = normalizeSignal(signal);
424
+ const currentState = await readRunnerRunState(opts.invocation.state_path);
425
+ const supervision = currentState?.supervision;
426
+ const runStatus = supervision?.cancel_requested_at
427
+ ? "cancelled"
428
+ : timeoutReason
429
+ ? "failed"
430
+ : code === 0
431
+ ? "success"
432
+ : "failed";
433
+ const [traceArtifact, stderrArtifact] = await Promise.all([
434
+ finalizeTraceArtifact({
435
+ file_path: opts.invocation.trace_path,
436
+ policy: tracePolicy,
437
+ run_status: runStatus,
438
+ }),
439
+ finalizeTraceArtifact({
440
+ file_path: opts.invocation.stderr_path,
441
+ policy: tracePolicy,
442
+ run_status: runStatus,
443
+ }),
444
+ ]);
445
+ settled = true;
446
+ resolve({
447
+ exit_code: code,
448
+ exit_signal: normalizedSignal,
449
+ stdout_tail,
450
+ stderr_tail,
451
+ stdout_bytes,
452
+ stderr_bytes,
453
+ pid,
454
+ started_at,
455
+ ended_at,
456
+ cancel_requested_at: supervision?.cancel_requested_at ?? null,
457
+ cancel_signal: supervision?.cancel_signal ?? null,
458
+ timeout_reason: supervision?.timeout_reason ?? timeoutReason,
459
+ timeout_requested_at: supervision?.timeout_requested_at ?? timeoutRequestedAt,
460
+ terminate_sent_at: supervision?.terminate_sent_at ?? terminateSentAt,
461
+ kill_sent_at: supervision?.kill_sent_at ?? killSentAt,
462
+ force_killed: supervision?.force_killed === true || killSentAt !== null,
463
+ heartbeat_at: heartbeat_at || ended_at,
464
+ trace_artifact_path: traceArtifact.artifact_path,
465
+ trace_archive_path: traceArtifact.archive_path,
466
+ stderr_artifact_path: stderrArtifact.artifact_path,
467
+ stderr_archive_path: stderrArtifact.archive_path,
468
+ });
469
+ });
470
+ if (timeoutPolicy.wall_clock_ms > 0) {
471
+ wallTimer = setTimeout(() => {
472
+ requestTimeout("wall_clock");
473
+ }, timeoutPolicy.wall_clock_ms);
474
+ }
475
+ resetIdleTimer();
476
+ child.stdin.end(opts.stdin_text);
477
+ });
478
+ }
479
+ export async function waitForRunnerStateStop(opts) {
480
+ const started = Date.now();
481
+ const poll_ms = opts.poll_ms ?? 100;
482
+ while (Date.now() - started < opts.timeout_ms) {
483
+ const state = await readRunnerRunState(opts.state_path);
484
+ if (state && state.status !== "running")
485
+ return state;
486
+ await new Promise((resolve) => setTimeout(resolve, poll_ms));
487
+ }
488
+ const state = await readRunnerRunState(opts.state_path);
489
+ return state && state.status !== "running" ? state : null;
490
+ }