@cleocode/cleo 2026.3.74 → 2026.3.76

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 (718) hide show
  1. package/README.md +1 -1
  2. package/dist/cli/index.js +3922 -1260
  3. package/dist/cli/index.js.map +4 -4
  4. package/dist/mcp/index.js +3428 -1165
  5. package/dist/mcp/index.js.map +4 -4
  6. package/package.json +7 -5
  7. package/dist/cli/commander-shim.d.ts +0 -112
  8. package/dist/cli/commander-shim.d.ts.map +0 -1
  9. package/dist/cli/commander-shim.js +0 -233
  10. package/dist/cli/commander-shim.js.map +0 -1
  11. package/dist/cli/commands/add.d.ts +0 -12
  12. package/dist/cli/commands/add.d.ts.map +0 -1
  13. package/dist/cli/commands/add.js +0 -94
  14. package/dist/cli/commands/add.js.map +0 -1
  15. package/dist/cli/commands/adr.d.ts +0 -27
  16. package/dist/cli/commands/adr.d.ts.map +0 -1
  17. package/dist/cli/commands/adr.js +0 -79
  18. package/dist/cli/commands/adr.js.map +0 -1
  19. package/dist/cli/commands/agents.d.ts +0 -31
  20. package/dist/cli/commands/agents.d.ts.map +0 -1
  21. package/dist/cli/commands/agents.js +0 -104
  22. package/dist/cli/commands/agents.js.map +0 -1
  23. package/dist/cli/commands/analyze.d.ts +0 -12
  24. package/dist/cli/commands/analyze.d.ts.map +0 -1
  25. package/dist/cli/commands/analyze.js +0 -20
  26. package/dist/cli/commands/analyze.js.map +0 -1
  27. package/dist/cli/commands/archive-stats.d.ts +0 -18
  28. package/dist/cli/commands/archive-stats.d.ts.map +0 -1
  29. package/dist/cli/commands/archive-stats.js +0 -49
  30. package/dist/cli/commands/archive-stats.js.map +0 -1
  31. package/dist/cli/commands/archive.d.ts +0 -12
  32. package/dist/cli/commands/archive.d.ts.map +0 -1
  33. package/dist/cli/commands/archive.js +0 -32
  34. package/dist/cli/commands/archive.js.map +0 -1
  35. package/dist/cli/commands/backfill.d.ts +0 -32
  36. package/dist/cli/commands/backfill.d.ts.map +0 -1
  37. package/dist/cli/commands/backfill.js +0 -101
  38. package/dist/cli/commands/backfill.js.map +0 -1
  39. package/dist/cli/commands/backup.d.ts +0 -8
  40. package/dist/cli/commands/backup.d.ts.map +0 -1
  41. package/dist/cli/commands/backup.js +0 -35
  42. package/dist/cli/commands/backup.js.map +0 -1
  43. package/dist/cli/commands/blockers.d.ts +0 -7
  44. package/dist/cli/commands/blockers.d.ts.map +0 -1
  45. package/dist/cli/commands/blockers.js +0 -16
  46. package/dist/cli/commands/blockers.js.map +0 -1
  47. package/dist/cli/commands/briefing.d.ts +0 -22
  48. package/dist/cli/commands/briefing.d.ts.map +0 -1
  49. package/dist/cli/commands/briefing.js +0 -45
  50. package/dist/cli/commands/briefing.js.map +0 -1
  51. package/dist/cli/commands/bug.d.ts +0 -12
  52. package/dist/cli/commands/bug.d.ts.map +0 -1
  53. package/dist/cli/commands/bug.js +0 -81
  54. package/dist/cli/commands/bug.js.map +0 -1
  55. package/dist/cli/commands/checkpoint.d.ts +0 -15
  56. package/dist/cli/commands/checkpoint.d.ts.map +0 -1
  57. package/dist/cli/commands/checkpoint.js +0 -91
  58. package/dist/cli/commands/checkpoint.js.map +0 -1
  59. package/dist/cli/commands/commands.d.ts +0 -13
  60. package/dist/cli/commands/commands.d.ts.map +0 -1
  61. package/dist/cli/commands/commands.js +0 -30
  62. package/dist/cli/commands/commands.js.map +0 -1
  63. package/dist/cli/commands/complete.d.ts +0 -12
  64. package/dist/cli/commands/complete.d.ts.map +0 -1
  65. package/dist/cli/commands/complete.js +0 -43
  66. package/dist/cli/commands/complete.js.map +0 -1
  67. package/dist/cli/commands/compliance.d.ts +0 -8
  68. package/dist/cli/commands/compliance.d.ts.map +0 -1
  69. package/dist/cli/commands/compliance.js +0 -85
  70. package/dist/cli/commands/compliance.js.map +0 -1
  71. package/dist/cli/commands/config.d.ts +0 -10
  72. package/dist/cli/commands/config.d.ts.map +0 -1
  73. package/dist/cli/commands/config.js +0 -69
  74. package/dist/cli/commands/config.js.map +0 -1
  75. package/dist/cli/commands/consensus.d.ts +0 -13
  76. package/dist/cli/commands/consensus.d.ts.map +0 -1
  77. package/dist/cli/commands/consensus.js +0 -45
  78. package/dist/cli/commands/consensus.js.map +0 -1
  79. package/dist/cli/commands/context.d.ts +0 -8
  80. package/dist/cli/commands/context.d.ts.map +0 -1
  81. package/dist/cli/commands/context.js +0 -40
  82. package/dist/cli/commands/context.js.map +0 -1
  83. package/dist/cli/commands/contribution.d.ts +0 -13
  84. package/dist/cli/commands/contribution.d.ts.map +0 -1
  85. package/dist/cli/commands/contribution.js +0 -41
  86. package/dist/cli/commands/contribution.js.map +0 -1
  87. package/dist/cli/commands/current.d.ts +0 -13
  88. package/dist/cli/commands/current.d.ts.map +0 -1
  89. package/dist/cli/commands/current.js +0 -20
  90. package/dist/cli/commands/current.js.map +0 -1
  91. package/dist/cli/commands/dash.d.ts +0 -12
  92. package/dist/cli/commands/dash.d.ts.map +0 -1
  93. package/dist/cli/commands/dash.js +0 -24
  94. package/dist/cli/commands/dash.js.map +0 -1
  95. package/dist/cli/commands/decomposition.d.ts +0 -13
  96. package/dist/cli/commands/decomposition.d.ts.map +0 -1
  97. package/dist/cli/commands/decomposition.js +0 -45
  98. package/dist/cli/commands/decomposition.js.map +0 -1
  99. package/dist/cli/commands/delete.d.ts +0 -12
  100. package/dist/cli/commands/delete.d.ts.map +0 -1
  101. package/dist/cli/commands/delete.js +0 -37
  102. package/dist/cli/commands/delete.js.map +0 -1
  103. package/dist/cli/commands/deps.d.ts +0 -24
  104. package/dist/cli/commands/deps.d.ts.map +0 -1
  105. package/dist/cli/commands/deps.js +0 -98
  106. package/dist/cli/commands/deps.js.map +0 -1
  107. package/dist/cli/commands/detect-drift.d.ts +0 -15
  108. package/dist/cli/commands/detect-drift.d.ts.map +0 -1
  109. package/dist/cli/commands/detect-drift.js +0 -429
  110. package/dist/cli/commands/detect-drift.js.map +0 -1
  111. package/dist/cli/commands/detect.d.ts +0 -10
  112. package/dist/cli/commands/detect.d.ts.map +0 -1
  113. package/dist/cli/commands/detect.js +0 -24
  114. package/dist/cli/commands/detect.js.map +0 -1
  115. package/dist/cli/commands/docs.d.ts +0 -13
  116. package/dist/cli/commands/docs.d.ts.map +0 -1
  117. package/dist/cli/commands/docs.js +0 -169
  118. package/dist/cli/commands/docs.js.map +0 -1
  119. package/dist/cli/commands/doctor.d.ts +0 -13
  120. package/dist/cli/commands/doctor.d.ts.map +0 -1
  121. package/dist/cli/commands/doctor.js +0 -64
  122. package/dist/cli/commands/doctor.js.map +0 -1
  123. package/dist/cli/commands/dynamic.d.ts +0 -24
  124. package/dist/cli/commands/dynamic.d.ts.map +0 -1
  125. package/dist/cli/commands/dynamic.js +0 -27
  126. package/dist/cli/commands/dynamic.js.map +0 -1
  127. package/dist/cli/commands/env.d.ts +0 -12
  128. package/dist/cli/commands/env.d.ts.map +0 -1
  129. package/dist/cli/commands/env.js +0 -44
  130. package/dist/cli/commands/env.js.map +0 -1
  131. package/dist/cli/commands/exists.d.ts +0 -22
  132. package/dist/cli/commands/exists.d.ts.map +0 -1
  133. package/dist/cli/commands/exists.js +0 -51
  134. package/dist/cli/commands/exists.js.map +0 -1
  135. package/dist/cli/commands/export-tasks.d.ts +0 -10
  136. package/dist/cli/commands/export-tasks.d.ts.map +0 -1
  137. package/dist/cli/commands/export-tasks.js +0 -47
  138. package/dist/cli/commands/export-tasks.js.map +0 -1
  139. package/dist/cli/commands/export.d.ts +0 -9
  140. package/dist/cli/commands/export.d.ts.map +0 -1
  141. package/dist/cli/commands/export.js +0 -46
  142. package/dist/cli/commands/export.js.map +0 -1
  143. package/dist/cli/commands/find.d.ts +0 -14
  144. package/dist/cli/commands/find.d.ts.map +0 -1
  145. package/dist/cli/commands/find.js +0 -70
  146. package/dist/cli/commands/find.js.map +0 -1
  147. package/dist/cli/commands/generate-changelog.d.ts +0 -14
  148. package/dist/cli/commands/generate-changelog.d.ts.map +0 -1
  149. package/dist/cli/commands/generate-changelog.js +0 -252
  150. package/dist/cli/commands/generate-changelog.js.map +0 -1
  151. package/dist/cli/commands/grade.d.ts +0 -13
  152. package/dist/cli/commands/grade.d.ts.map +0 -1
  153. package/dist/cli/commands/grade.js +0 -26
  154. package/dist/cli/commands/grade.js.map +0 -1
  155. package/dist/cli/commands/history.d.ts +0 -9
  156. package/dist/cli/commands/history.d.ts.map +0 -1
  157. package/dist/cli/commands/history.js +0 -30
  158. package/dist/cli/commands/history.js.map +0 -1
  159. package/dist/cli/commands/implementation.d.ts +0 -13
  160. package/dist/cli/commands/implementation.d.ts.map +0 -1
  161. package/dist/cli/commands/implementation.js +0 -41
  162. package/dist/cli/commands/implementation.js.map +0 -1
  163. package/dist/cli/commands/import-tasks.d.ts +0 -10
  164. package/dist/cli/commands/import-tasks.d.ts.map +0 -1
  165. package/dist/cli/commands/import-tasks.js +0 -38
  166. package/dist/cli/commands/import-tasks.js.map +0 -1
  167. package/dist/cli/commands/import.d.ts +0 -9
  168. package/dist/cli/commands/import.d.ts.map +0 -1
  169. package/dist/cli/commands/import.js +0 -28
  170. package/dist/cli/commands/import.js.map +0 -1
  171. package/dist/cli/commands/init.d.ts +0 -34
  172. package/dist/cli/commands/init.d.ts.map +0 -1
  173. package/dist/cli/commands/init.js +0 -89
  174. package/dist/cli/commands/init.js.map +0 -1
  175. package/dist/cli/commands/inject.d.ts +0 -8
  176. package/dist/cli/commands/inject.d.ts.map +0 -1
  177. package/dist/cli/commands/inject.js +0 -28
  178. package/dist/cli/commands/inject.js.map +0 -1
  179. package/dist/cli/commands/install-global.d.ts +0 -19
  180. package/dist/cli/commands/install-global.d.ts.map +0 -1
  181. package/dist/cli/commands/install-global.js +0 -50
  182. package/dist/cli/commands/install-global.js.map +0 -1
  183. package/dist/cli/commands/issue.d.ts +0 -17
  184. package/dist/cli/commands/issue.d.ts.map +0 -1
  185. package/dist/cli/commands/issue.js +0 -107
  186. package/dist/cli/commands/issue.js.map +0 -1
  187. package/dist/cli/commands/labels.d.ts +0 -13
  188. package/dist/cli/commands/labels.d.ts.map +0 -1
  189. package/dist/cli/commands/labels.js +0 -44
  190. package/dist/cli/commands/labels.js.map +0 -1
  191. package/dist/cli/commands/lifecycle.d.ts +0 -8
  192. package/dist/cli/commands/lifecycle.d.ts.map +0 -1
  193. package/dist/cli/commands/lifecycle.js +0 -72
  194. package/dist/cli/commands/lifecycle.js.map +0 -1
  195. package/dist/cli/commands/list.d.ts +0 -14
  196. package/dist/cli/commands/list.d.ts.map +0 -1
  197. package/dist/cli/commands/list.js +0 -71
  198. package/dist/cli/commands/list.js.map +0 -1
  199. package/dist/cli/commands/log.d.ts +0 -12
  200. package/dist/cli/commands/log.d.ts.map +0 -1
  201. package/dist/cli/commands/log.js +0 -30
  202. package/dist/cli/commands/log.js.map +0 -1
  203. package/dist/cli/commands/map.d.ts +0 -10
  204. package/dist/cli/commands/map.d.ts.map +0 -1
  205. package/dist/cli/commands/map.js +0 -23
  206. package/dist/cli/commands/map.js.map +0 -1
  207. package/dist/cli/commands/mcp-install.d.ts +0 -17
  208. package/dist/cli/commands/mcp-install.d.ts.map +0 -1
  209. package/dist/cli/commands/mcp-install.js +0 -128
  210. package/dist/cli/commands/mcp-install.js.map +0 -1
  211. package/dist/cli/commands/memory-brain.d.ts +0 -14
  212. package/dist/cli/commands/memory-brain.d.ts.map +0 -1
  213. package/dist/cli/commands/memory-brain.js +0 -151
  214. package/dist/cli/commands/memory-brain.js.map +0 -1
  215. package/dist/cli/commands/migrate-claude-mem.d.ts +0 -18
  216. package/dist/cli/commands/migrate-claude-mem.d.ts.map +0 -1
  217. package/dist/cli/commands/migrate-claude-mem.js +0 -60
  218. package/dist/cli/commands/migrate-claude-mem.js.map +0 -1
  219. package/dist/cli/commands/next.d.ts +0 -9
  220. package/dist/cli/commands/next.d.ts.map +0 -1
  221. package/dist/cli/commands/next.js +0 -20
  222. package/dist/cli/commands/next.js.map +0 -1
  223. package/dist/cli/commands/nexus.d.ts +0 -16
  224. package/dist/cli/commands/nexus.d.ts.map +0 -1
  225. package/dist/cli/commands/nexus.js +0 -155
  226. package/dist/cli/commands/nexus.js.map +0 -1
  227. package/dist/cli/commands/observe.d.ts +0 -9
  228. package/dist/cli/commands/observe.d.ts.map +0 -1
  229. package/dist/cli/commands/observe.js +0 -39
  230. package/dist/cli/commands/observe.js.map +0 -1
  231. package/dist/cli/commands/ops.d.ts +0 -10
  232. package/dist/cli/commands/ops.d.ts.map +0 -1
  233. package/dist/cli/commands/ops.js +0 -19
  234. package/dist/cli/commands/ops.js.map +0 -1
  235. package/dist/cli/commands/orchestrate.d.ts +0 -8
  236. package/dist/cli/commands/orchestrate.d.ts.map +0 -1
  237. package/dist/cli/commands/orchestrate.js +0 -58
  238. package/dist/cli/commands/orchestrate.js.map +0 -1
  239. package/dist/cli/commands/otel.d.ts +0 -12
  240. package/dist/cli/commands/otel.d.ts.map +0 -1
  241. package/dist/cli/commands/otel.js +0 -128
  242. package/dist/cli/commands/otel.js.map +0 -1
  243. package/dist/cli/commands/phase.d.ts +0 -12
  244. package/dist/cli/commands/phase.d.ts.map +0 -1
  245. package/dist/cli/commands/phase.js +0 -88
  246. package/dist/cli/commands/phase.js.map +0 -1
  247. package/dist/cli/commands/phases.d.ts +0 -12
  248. package/dist/cli/commands/phases.d.ts.map +0 -1
  249. package/dist/cli/commands/phases.js +0 -37
  250. package/dist/cli/commands/phases.js.map +0 -1
  251. package/dist/cli/commands/plan.d.ts +0 -8
  252. package/dist/cli/commands/plan.d.ts.map +0 -1
  253. package/dist/cli/commands/plan.js +0 -15
  254. package/dist/cli/commands/plan.js.map +0 -1
  255. package/dist/cli/commands/promote.d.ts +0 -7
  256. package/dist/cli/commands/promote.d.ts.map +0 -1
  257. package/dist/cli/commands/promote.js +0 -15
  258. package/dist/cli/commands/promote.js.map +0 -1
  259. package/dist/cli/commands/reason.d.ts +0 -35
  260. package/dist/cli/commands/reason.d.ts.map +0 -1
  261. package/dist/cli/commands/reason.js +0 -104
  262. package/dist/cli/commands/reason.js.map +0 -1
  263. package/dist/cli/commands/refresh-memory.d.ts +0 -9
  264. package/dist/cli/commands/refresh-memory.d.ts.map +0 -1
  265. package/dist/cli/commands/refresh-memory.js +0 -24
  266. package/dist/cli/commands/refresh-memory.js.map +0 -1
  267. package/dist/cli/commands/relates.d.ts +0 -12
  268. package/dist/cli/commands/relates.d.ts.map +0 -1
  269. package/dist/cli/commands/relates.js +0 -53
  270. package/dist/cli/commands/relates.js.map +0 -1
  271. package/dist/cli/commands/release.d.ts +0 -8
  272. package/dist/cli/commands/release.d.ts.map +0 -1
  273. package/dist/cli/commands/release.js +0 -72
  274. package/dist/cli/commands/release.js.map +0 -1
  275. package/dist/cli/commands/remote.d.ts +0 -12
  276. package/dist/cli/commands/remote.d.ts.map +0 -1
  277. package/dist/cli/commands/remote.js +0 -207
  278. package/dist/cli/commands/remote.js.map +0 -1
  279. package/dist/cli/commands/reorder.d.ts +0 -7
  280. package/dist/cli/commands/reorder.d.ts.map +0 -1
  281. package/dist/cli/commands/reorder.js +0 -20
  282. package/dist/cli/commands/reorder.js.map +0 -1
  283. package/dist/cli/commands/reparent.d.ts +0 -10
  284. package/dist/cli/commands/reparent.d.ts.map +0 -1
  285. package/dist/cli/commands/reparent.js +0 -19
  286. package/dist/cli/commands/reparent.js.map +0 -1
  287. package/dist/cli/commands/research.d.ts +0 -8
  288. package/dist/cli/commands/research.d.ts.map +0 -1
  289. package/dist/cli/commands/research.js +0 -129
  290. package/dist/cli/commands/research.js.map +0 -1
  291. package/dist/cli/commands/restore.d.ts +0 -11
  292. package/dist/cli/commands/restore.d.ts.map +0 -1
  293. package/dist/cli/commands/restore.js +0 -224
  294. package/dist/cli/commands/restore.js.map +0 -1
  295. package/dist/cli/commands/roadmap.d.ts +0 -8
  296. package/dist/cli/commands/roadmap.d.ts.map +0 -1
  297. package/dist/cli/commands/roadmap.js +0 -21
  298. package/dist/cli/commands/roadmap.js.map +0 -1
  299. package/dist/cli/commands/safestop.d.ts +0 -14
  300. package/dist/cli/commands/safestop.d.ts.map +0 -1
  301. package/dist/cli/commands/safestop.js +0 -32
  302. package/dist/cli/commands/safestop.js.map +0 -1
  303. package/dist/cli/commands/self-update.d.ts +0 -15
  304. package/dist/cli/commands/self-update.d.ts.map +0 -1
  305. package/dist/cli/commands/self-update.js +0 -329
  306. package/dist/cli/commands/self-update.js.map +0 -1
  307. package/dist/cli/commands/sequence.d.ts +0 -8
  308. package/dist/cli/commands/sequence.d.ts.map +0 -1
  309. package/dist/cli/commands/sequence.js +0 -30
  310. package/dist/cli/commands/sequence.js.map +0 -1
  311. package/dist/cli/commands/session.d.ts +0 -12
  312. package/dist/cli/commands/session.d.ts.map +0 -1
  313. package/dist/cli/commands/session.js +0 -175
  314. package/dist/cli/commands/session.js.map +0 -1
  315. package/dist/cli/commands/show.d.ts +0 -13
  316. package/dist/cli/commands/show.d.ts.map +0 -1
  317. package/dist/cli/commands/show.js +0 -20
  318. package/dist/cli/commands/show.js.map +0 -1
  319. package/dist/cli/commands/skills.d.ts +0 -13
  320. package/dist/cli/commands/skills.d.ts.map +0 -1
  321. package/dist/cli/commands/skills.js +0 -131
  322. package/dist/cli/commands/skills.js.map +0 -1
  323. package/dist/cli/commands/snapshot.d.ts +0 -9
  324. package/dist/cli/commands/snapshot.d.ts.map +0 -1
  325. package/dist/cli/commands/snapshot.js +0 -50
  326. package/dist/cli/commands/snapshot.js.map +0 -1
  327. package/dist/cli/commands/specification.d.ts +0 -13
  328. package/dist/cli/commands/specification.d.ts.map +0 -1
  329. package/dist/cli/commands/specification.js +0 -45
  330. package/dist/cli/commands/specification.js.map +0 -1
  331. package/dist/cli/commands/start.d.ts +0 -13
  332. package/dist/cli/commands/start.d.ts.map +0 -1
  333. package/dist/cli/commands/start.js +0 -20
  334. package/dist/cli/commands/start.js.map +0 -1
  335. package/dist/cli/commands/stats.d.ts +0 -12
  336. package/dist/cli/commands/stats.d.ts.map +0 -1
  337. package/dist/cli/commands/stats.js +0 -35
  338. package/dist/cli/commands/stats.js.map +0 -1
  339. package/dist/cli/commands/sticky.d.ts +0 -16
  340. package/dist/cli/commands/sticky.d.ts.map +0 -1
  341. package/dist/cli/commands/sticky.js +0 -211
  342. package/dist/cli/commands/sticky.js.map +0 -1
  343. package/dist/cli/commands/stop.d.ts +0 -13
  344. package/dist/cli/commands/stop.d.ts.map +0 -1
  345. package/dist/cli/commands/stop.js +0 -20
  346. package/dist/cli/commands/stop.js.map +0 -1
  347. package/dist/cli/commands/testing.d.ts +0 -13
  348. package/dist/cli/commands/testing.d.ts.map +0 -1
  349. package/dist/cli/commands/testing.js +0 -64
  350. package/dist/cli/commands/testing.js.map +0 -1
  351. package/dist/cli/commands/token.d.ts +0 -10
  352. package/dist/cli/commands/token.d.ts.map +0 -1
  353. package/dist/cli/commands/token.js +0 -135
  354. package/dist/cli/commands/token.js.map +0 -1
  355. package/dist/cli/commands/update.d.ts +0 -12
  356. package/dist/cli/commands/update.d.ts.map +0 -1
  357. package/dist/cli/commands/update.js +0 -83
  358. package/dist/cli/commands/update.js.map +0 -1
  359. package/dist/cli/commands/upgrade.d.ts +0 -18
  360. package/dist/cli/commands/upgrade.d.ts.map +0 -1
  361. package/dist/cli/commands/upgrade.js +0 -103
  362. package/dist/cli/commands/upgrade.js.map +0 -1
  363. package/dist/cli/commands/validate.d.ts +0 -12
  364. package/dist/cli/commands/validate.d.ts.map +0 -1
  365. package/dist/cli/commands/validate.js +0 -23
  366. package/dist/cli/commands/validate.js.map +0 -1
  367. package/dist/cli/commands/verify.d.ts +0 -8
  368. package/dist/cli/commands/verify.d.ts.map +0 -1
  369. package/dist/cli/commands/verify.js +0 -28
  370. package/dist/cli/commands/verify.js.map +0 -1
  371. package/dist/cli/commands/web.d.ts +0 -13
  372. package/dist/cli/commands/web.d.ts.map +0 -1
  373. package/dist/cli/commands/web.js +0 -264
  374. package/dist/cli/commands/web.js.map +0 -1
  375. package/dist/cli/field-context.d.ts +0 -32
  376. package/dist/cli/field-context.d.ts.map +0 -1
  377. package/dist/cli/field-context.js +0 -47
  378. package/dist/cli/field-context.js.map +0 -1
  379. package/dist/cli/format-context.d.ts +0 -32
  380. package/dist/cli/format-context.d.ts.map +0 -1
  381. package/dist/cli/format-context.js +0 -50
  382. package/dist/cli/format-context.js.map +0 -1
  383. package/dist/cli/index.d.ts +0 -9
  384. package/dist/cli/index.d.ts.map +0 -1
  385. package/dist/cli/logger-bootstrap.d.ts +0 -6
  386. package/dist/cli/logger-bootstrap.d.ts.map +0 -1
  387. package/dist/cli/logger-bootstrap.js +0 -10
  388. package/dist/cli/logger-bootstrap.js.map +0 -1
  389. package/dist/cli/middleware/output-format.d.ts +0 -30
  390. package/dist/cli/middleware/output-format.d.ts.map +0 -1
  391. package/dist/cli/middleware/output-format.js +0 -35
  392. package/dist/cli/middleware/output-format.js.map +0 -1
  393. package/dist/cli/progress.d.ts +0 -84
  394. package/dist/cli/progress.d.ts.map +0 -1
  395. package/dist/cli/progress.js +0 -169
  396. package/dist/cli/progress.js.map +0 -1
  397. package/dist/cli/renderers/colors.d.ts +0 -32
  398. package/dist/cli/renderers/colors.d.ts.map +0 -1
  399. package/dist/cli/renderers/colors.js +0 -141
  400. package/dist/cli/renderers/colors.js.map +0 -1
  401. package/dist/cli/renderers/error.d.ts +0 -13
  402. package/dist/cli/renderers/error.d.ts.map +0 -1
  403. package/dist/cli/renderers/error.js +0 -42
  404. package/dist/cli/renderers/error.js.map +0 -1
  405. package/dist/cli/renderers/index.d.ts +0 -59
  406. package/dist/cli/renderers/index.d.ts.map +0 -1
  407. package/dist/cli/renderers/index.js +0 -184
  408. package/dist/cli/renderers/index.js.map +0 -1
  409. package/dist/cli/renderers/normalizer.d.ts +0 -21
  410. package/dist/cli/renderers/normalizer.d.ts.map +0 -1
  411. package/dist/cli/renderers/normalizer.js +0 -106
  412. package/dist/cli/renderers/normalizer.js.map +0 -1
  413. package/dist/cli/renderers/system.d.ts +0 -25
  414. package/dist/cli/renderers/system.d.ts.map +0 -1
  415. package/dist/cli/renderers/system.js +0 -416
  416. package/dist/cli/renderers/system.js.map +0 -1
  417. package/dist/cli/renderers/tasks.d.ts +0 -28
  418. package/dist/cli/renderers/tasks.d.ts.map +0 -1
  419. package/dist/cli/renderers/tasks.js +0 -306
  420. package/dist/cli/renderers/tasks.js.map +0 -1
  421. package/dist/dispatch/adapters/cli.d.ts +0 -67
  422. package/dist/dispatch/adapters/cli.d.ts.map +0 -1
  423. package/dist/dispatch/adapters/cli.js +0 -205
  424. package/dist/dispatch/adapters/cli.js.map +0 -1
  425. package/dist/dispatch/adapters/mcp.d.ts +0 -37
  426. package/dist/dispatch/adapters/mcp.d.ts.map +0 -1
  427. package/dist/dispatch/adapters/mcp.js +0 -122
  428. package/dist/dispatch/adapters/mcp.js.map +0 -1
  429. package/dist/dispatch/context/session-context.d.ts +0 -54
  430. package/dist/dispatch/context/session-context.d.ts.map +0 -1
  431. package/dist/dispatch/context/session-context.js +0 -61
  432. package/dist/dispatch/context/session-context.js.map +0 -1
  433. package/dist/dispatch/dispatcher.d.ts +0 -23
  434. package/dist/dispatch/dispatcher.d.ts.map +0 -1
  435. package/dist/dispatch/dispatcher.js +0 -84
  436. package/dist/dispatch/dispatcher.js.map +0 -1
  437. package/dist/dispatch/domains/_base.d.ts +0 -59
  438. package/dist/dispatch/domains/_base.d.ts.map +0 -1
  439. package/dist/dispatch/domains/_base.js +0 -77
  440. package/dist/dispatch/domains/_base.js.map +0 -1
  441. package/dist/dispatch/domains/_meta.d.ts +0 -23
  442. package/dist/dispatch/domains/_meta.d.ts.map +0 -1
  443. package/dist/dispatch/domains/_meta.js +0 -25
  444. package/dist/dispatch/domains/_meta.js.map +0 -1
  445. package/dist/dispatch/domains/_routing.d.ts +0 -8
  446. package/dist/dispatch/domains/_routing.d.ts.map +0 -1
  447. package/dist/dispatch/domains/_routing.js +0 -20
  448. package/dist/dispatch/domains/_routing.js.map +0 -1
  449. package/dist/dispatch/domains/admin.d.ts +0 -25
  450. package/dist/dispatch/domains/admin.d.ts.map +0 -1
  451. package/dist/dispatch/domains/admin.js +0 -699
  452. package/dist/dispatch/domains/admin.js.map +0 -1
  453. package/dist/dispatch/domains/check.d.ts +0 -22
  454. package/dist/dispatch/domains/check.d.ts.map +0 -1
  455. package/dist/dispatch/domains/check.js +0 -293
  456. package/dist/dispatch/domains/check.js.map +0 -1
  457. package/dist/dispatch/domains/index.d.ts +0 -26
  458. package/dist/dispatch/domains/index.d.ts.map +0 -1
  459. package/dist/dispatch/domains/index.js +0 -38
  460. package/dist/dispatch/domains/index.js.map +0 -1
  461. package/dist/dispatch/domains/memory.d.ts +0 -22
  462. package/dist/dispatch/domains/memory.d.ts.map +0 -1
  463. package/dist/dispatch/domains/memory.js +0 -303
  464. package/dist/dispatch/domains/memory.js.map +0 -1
  465. package/dist/dispatch/domains/nexus.d.ts +0 -22
  466. package/dist/dispatch/domains/nexus.d.ts.map +0 -1
  467. package/dist/dispatch/domains/nexus.js +0 -286
  468. package/dist/dispatch/domains/nexus.js.map +0 -1
  469. package/dist/dispatch/domains/orchestrate.d.ts +0 -19
  470. package/dist/dispatch/domains/orchestrate.d.ts.map +0 -1
  471. package/dist/dispatch/domains/orchestrate.js +0 -259
  472. package/dist/dispatch/domains/orchestrate.js.map +0 -1
  473. package/dist/dispatch/domains/pipeline.d.ts +0 -35
  474. package/dist/dispatch/domains/pipeline.d.ts.map +0 -1
  475. package/dist/dispatch/domains/pipeline.js +0 -555
  476. package/dist/dispatch/domains/pipeline.js.map +0 -1
  477. package/dist/dispatch/domains/session.d.ts +0 -22
  478. package/dist/dispatch/domains/session.d.ts.map +0 -1
  479. package/dist/dispatch/domains/session.js +0 -255
  480. package/dist/dispatch/domains/session.js.map +0 -1
  481. package/dist/dispatch/domains/sticky.d.ts +0 -20
  482. package/dist/dispatch/domains/sticky.d.ts.map +0 -1
  483. package/dist/dispatch/domains/sticky.js +0 -164
  484. package/dist/dispatch/domains/sticky.js.map +0 -1
  485. package/dist/dispatch/domains/tasks.d.ts +0 -25
  486. package/dist/dispatch/domains/tasks.d.ts.map +0 -1
  487. package/dist/dispatch/domains/tasks.js +0 -339
  488. package/dist/dispatch/domains/tasks.js.map +0 -1
  489. package/dist/dispatch/domains/tools.d.ts +0 -36
  490. package/dist/dispatch/domains/tools.d.ts.map +0 -1
  491. package/dist/dispatch/domains/tools.js +0 -451
  492. package/dist/dispatch/domains/tools.js.map +0 -1
  493. package/dist/dispatch/engines/_error.d.ts +0 -42
  494. package/dist/dispatch/engines/_error.d.ts.map +0 -1
  495. package/dist/dispatch/engines/_error.js +0 -201
  496. package/dist/dispatch/engines/_error.js.map +0 -1
  497. package/dist/dispatch/engines/codebase-map-engine.d.ts +0 -17
  498. package/dist/dispatch/engines/codebase-map-engine.d.ts.map +0 -1
  499. package/dist/dispatch/engines/codebase-map-engine.js +0 -29
  500. package/dist/dispatch/engines/codebase-map-engine.js.map +0 -1
  501. package/dist/dispatch/engines/config-engine.d.ts +0 -32
  502. package/dist/dispatch/engines/config-engine.d.ts.map +0 -1
  503. package/dist/dispatch/engines/config-engine.js +0 -70
  504. package/dist/dispatch/engines/config-engine.js.map +0 -1
  505. package/dist/dispatch/engines/hooks-engine.d.ts +0 -47
  506. package/dist/dispatch/engines/hooks-engine.d.ts.map +0 -1
  507. package/dist/dispatch/engines/hooks-engine.js +0 -57
  508. package/dist/dispatch/engines/hooks-engine.js.map +0 -1
  509. package/dist/dispatch/engines/init-engine.d.ts +0 -43
  510. package/dist/dispatch/engines/init-engine.d.ts.map +0 -1
  511. package/dist/dispatch/engines/init-engine.js +0 -73
  512. package/dist/dispatch/engines/init-engine.js.map +0 -1
  513. package/dist/dispatch/engines/lifecycle-engine.d.ts +0 -66
  514. package/dist/dispatch/engines/lifecycle-engine.d.ts.map +0 -1
  515. package/dist/dispatch/engines/lifecycle-engine.js +0 -213
  516. package/dist/dispatch/engines/lifecycle-engine.js.map +0 -1
  517. package/dist/dispatch/engines/memory-engine.d.ts +0 -10
  518. package/dist/dispatch/engines/memory-engine.d.ts.map +0 -1
  519. package/dist/dispatch/engines/memory-engine.js +0 -10
  520. package/dist/dispatch/engines/memory-engine.js.map +0 -1
  521. package/dist/dispatch/engines/nexus-engine.d.ts +0 -167
  522. package/dist/dispatch/engines/nexus-engine.d.ts.map +0 -1
  523. package/dist/dispatch/engines/nexus-engine.js +0 -356
  524. package/dist/dispatch/engines/nexus-engine.js.map +0 -1
  525. package/dist/dispatch/engines/orchestrate-engine.d.ts +0 -133
  526. package/dist/dispatch/engines/orchestrate-engine.d.ts.map +0 -1
  527. package/dist/dispatch/engines/orchestrate-engine.js +0 -769
  528. package/dist/dispatch/engines/orchestrate-engine.js.map +0 -1
  529. package/dist/dispatch/engines/pipeline-engine.d.ts +0 -51
  530. package/dist/dispatch/engines/pipeline-engine.d.ts.map +0 -1
  531. package/dist/dispatch/engines/pipeline-engine.js +0 -191
  532. package/dist/dispatch/engines/pipeline-engine.js.map +0 -1
  533. package/dist/dispatch/engines/release-engine.d.ts +0 -94
  534. package/dist/dispatch/engines/release-engine.d.ts.map +0 -1
  535. package/dist/dispatch/engines/release-engine.js +0 -669
  536. package/dist/dispatch/engines/release-engine.js.map +0 -1
  537. package/dist/dispatch/engines/session-engine.d.ts +0 -323
  538. package/dist/dispatch/engines/session-engine.d.ts.map +0 -1
  539. package/dist/dispatch/engines/session-engine.js +0 -869
  540. package/dist/dispatch/engines/session-engine.js.map +0 -1
  541. package/dist/dispatch/engines/sticky-engine.d.ts +0 -100
  542. package/dist/dispatch/engines/sticky-engine.d.ts.map +0 -1
  543. package/dist/dispatch/engines/sticky-engine.js +0 -181
  544. package/dist/dispatch/engines/sticky-engine.js.map +0 -1
  545. package/dist/dispatch/engines/system-engine.d.ts +0 -409
  546. package/dist/dispatch/engines/system-engine.d.ts.map +0 -1
  547. package/dist/dispatch/engines/system-engine.js +0 -1180
  548. package/dist/dispatch/engines/system-engine.js.map +0 -1
  549. package/dist/dispatch/engines/task-engine.d.ts +0 -630
  550. package/dist/dispatch/engines/task-engine.d.ts.map +0 -1
  551. package/dist/dispatch/engines/task-engine.js +0 -979
  552. package/dist/dispatch/engines/task-engine.js.map +0 -1
  553. package/dist/dispatch/engines/template-parser.d.ts +0 -34
  554. package/dist/dispatch/engines/template-parser.d.ts.map +0 -1
  555. package/dist/dispatch/engines/template-parser.js +0 -57
  556. package/dist/dispatch/engines/template-parser.js.map +0 -1
  557. package/dist/dispatch/engines/tools-engine.d.ts +0 -270
  558. package/dist/dispatch/engines/tools-engine.d.ts.map +0 -1
  559. package/dist/dispatch/engines/tools-engine.js +0 -636
  560. package/dist/dispatch/engines/tools-engine.js.map +0 -1
  561. package/dist/dispatch/engines/validate-engine.d.ts +0 -154
  562. package/dist/dispatch/engines/validate-engine.d.ts.map +0 -1
  563. package/dist/dispatch/engines/validate-engine.js +0 -524
  564. package/dist/dispatch/engines/validate-engine.js.map +0 -1
  565. package/dist/dispatch/index.d.ts +0 -20
  566. package/dist/dispatch/index.d.ts.map +0 -1
  567. package/dist/dispatch/index.js +0 -19
  568. package/dist/dispatch/index.js.map +0 -1
  569. package/dist/dispatch/lib/capability-matrix.d.ts +0 -11
  570. package/dist/dispatch/lib/capability-matrix.d.ts.map +0 -1
  571. package/dist/dispatch/lib/capability-matrix.js +0 -10
  572. package/dist/dispatch/lib/capability-matrix.js.map +0 -1
  573. package/dist/dispatch/lib/config.d.ts +0 -16
  574. package/dist/dispatch/lib/config.d.ts.map +0 -1
  575. package/dist/dispatch/lib/config.js +0 -15
  576. package/dist/dispatch/lib/config.js.map +0 -1
  577. package/dist/dispatch/lib/engine.d.ts +0 -25
  578. package/dist/dispatch/lib/engine.d.ts.map +0 -1
  579. package/dist/dispatch/lib/engine.js +0 -44
  580. package/dist/dispatch/lib/engine.js.map +0 -1
  581. package/dist/dispatch/lib/meta.d.ts +0 -26
  582. package/dist/dispatch/lib/meta.d.ts.map +0 -1
  583. package/dist/dispatch/lib/meta.js +0 -37
  584. package/dist/dispatch/lib/meta.js.map +0 -1
  585. package/dist/dispatch/lib/param-utils.d.ts +0 -11
  586. package/dist/dispatch/lib/param-utils.d.ts.map +0 -1
  587. package/dist/dispatch/lib/param-utils.js +0 -10
  588. package/dist/dispatch/lib/param-utils.js.map +0 -1
  589. package/dist/dispatch/lib/projections.d.ts +0 -23
  590. package/dist/dispatch/lib/projections.d.ts.map +0 -1
  591. package/dist/dispatch/lib/projections.js +0 -48
  592. package/dist/dispatch/lib/projections.js.map +0 -1
  593. package/dist/dispatch/lib/schema-utils.d.ts +0 -42
  594. package/dist/dispatch/lib/schema-utils.d.ts.map +0 -1
  595. package/dist/dispatch/lib/schema-utils.js +0 -93
  596. package/dist/dispatch/lib/schema-utils.js.map +0 -1
  597. package/dist/dispatch/lib/security.d.ts +0 -11
  598. package/dist/dispatch/lib/security.d.ts.map +0 -1
  599. package/dist/dispatch/lib/security.js +0 -10
  600. package/dist/dispatch/lib/security.js.map +0 -1
  601. package/dist/dispatch/middleware/audit.d.ts +0 -23
  602. package/dist/dispatch/middleware/audit.d.ts.map +0 -1
  603. package/dist/dispatch/middleware/audit.js +0 -169
  604. package/dist/dispatch/middleware/audit.js.map +0 -1
  605. package/dist/dispatch/middleware/field-filter.d.ts +0 -24
  606. package/dist/dispatch/middleware/field-filter.d.ts.map +0 -1
  607. package/dist/dispatch/middleware/field-filter.js +0 -65
  608. package/dist/dispatch/middleware/field-filter.js.map +0 -1
  609. package/dist/dispatch/middleware/pipeline.d.ts +0 -20
  610. package/dist/dispatch/middleware/pipeline.d.ts.map +0 -1
  611. package/dist/dispatch/middleware/pipeline.js +0 -47
  612. package/dist/dispatch/middleware/pipeline.js.map +0 -1
  613. package/dist/dispatch/middleware/projection.d.ts +0 -35
  614. package/dist/dispatch/middleware/projection.d.ts.map +0 -1
  615. package/dist/dispatch/middleware/projection.js +0 -145
  616. package/dist/dispatch/middleware/projection.js.map +0 -1
  617. package/dist/dispatch/middleware/protocol-enforcement.d.ts +0 -12
  618. package/dist/dispatch/middleware/protocol-enforcement.d.ts.map +0 -1
  619. package/dist/dispatch/middleware/protocol-enforcement.js +0 -30
  620. package/dist/dispatch/middleware/protocol-enforcement.js.map +0 -1
  621. package/dist/dispatch/middleware/rate-limiter.d.ts +0 -30
  622. package/dist/dispatch/middleware/rate-limiter.d.ts.map +0 -1
  623. package/dist/dispatch/middleware/rate-limiter.js +0 -101
  624. package/dist/dispatch/middleware/rate-limiter.js.map +0 -1
  625. package/dist/dispatch/middleware/sanitizer.d.ts +0 -10
  626. package/dist/dispatch/middleware/sanitizer.d.ts.map +0 -1
  627. package/dist/dispatch/middleware/sanitizer.js +0 -42
  628. package/dist/dispatch/middleware/sanitizer.js.map +0 -1
  629. package/dist/dispatch/middleware/session-resolver.d.ts +0 -26
  630. package/dist/dispatch/middleware/session-resolver.d.ts.map +0 -1
  631. package/dist/dispatch/middleware/session-resolver.js +0 -65
  632. package/dist/dispatch/middleware/session-resolver.js.map +0 -1
  633. package/dist/dispatch/middleware/verification-gates.d.ts +0 -3
  634. package/dist/dispatch/middleware/verification-gates.d.ts.map +0 -1
  635. package/dist/dispatch/middleware/verification-gates.js +0 -40
  636. package/dist/dispatch/middleware/verification-gates.js.map +0 -1
  637. package/dist/dispatch/registry.d.ts +0 -91
  638. package/dist/dispatch/registry.d.ts.map +0 -1
  639. package/dist/dispatch/registry.js +0 -2924
  640. package/dist/dispatch/registry.js.map +0 -1
  641. package/dist/dispatch/types.d.ts +0 -218
  642. package/dist/dispatch/types.d.ts.map +0 -1
  643. package/dist/dispatch/types.js +0 -25
  644. package/dist/dispatch/types.js.map +0 -1
  645. package/dist/mcp/gateways/mutate.d.ts +0 -146
  646. package/dist/mcp/gateways/mutate.d.ts.map +0 -1
  647. package/dist/mcp/gateways/mutate.js +0 -1016
  648. package/dist/mcp/gateways/mutate.js.map +0 -1
  649. package/dist/mcp/gateways/query.d.ts +0 -138
  650. package/dist/mcp/gateways/query.d.ts.map +0 -1
  651. package/dist/mcp/gateways/query.js +0 -186
  652. package/dist/mcp/gateways/query.js.map +0 -1
  653. package/dist/mcp/index.d.ts +0 -16
  654. package/dist/mcp/index.d.ts.map +0 -1
  655. package/dist/mcp/lib/background-jobs.d.ts +0 -86
  656. package/dist/mcp/lib/background-jobs.d.ts.map +0 -1
  657. package/dist/mcp/lib/background-jobs.js +0 -183
  658. package/dist/mcp/lib/background-jobs.js.map +0 -1
  659. package/dist/mcp/lib/budget.d.ts +0 -35
  660. package/dist/mcp/lib/budget.d.ts.map +0 -1
  661. package/dist/mcp/lib/budget.js +0 -102
  662. package/dist/mcp/lib/budget.js.map +0 -1
  663. package/dist/mcp/lib/cache.d.ts +0 -78
  664. package/dist/mcp/lib/cache.d.ts.map +0 -1
  665. package/dist/mcp/lib/cache.js +0 -207
  666. package/dist/mcp/lib/cache.js.map +0 -1
  667. package/dist/mcp/lib/config.d.ts +0 -42
  668. package/dist/mcp/lib/config.d.ts.map +0 -1
  669. package/dist/mcp/lib/config.js +0 -241
  670. package/dist/mcp/lib/config.js.map +0 -1
  671. package/dist/mcp/lib/defaults.d.ts +0 -115
  672. package/dist/mcp/lib/defaults.d.ts.map +0 -1
  673. package/dist/mcp/lib/defaults.js +0 -61
  674. package/dist/mcp/lib/defaults.js.map +0 -1
  675. package/dist/mcp/lib/gate-validators.d.ts +0 -13
  676. package/dist/mcp/lib/gate-validators.d.ts.map +0 -1
  677. package/dist/mcp/lib/gate-validators.js +0 -13
  678. package/dist/mcp/lib/gate-validators.js.map +0 -1
  679. package/dist/mcp/lib/gateway-meta.d.ts +0 -37
  680. package/dist/mcp/lib/gateway-meta.d.ts.map +0 -1
  681. package/dist/mcp/lib/gateway-meta.js +0 -50
  682. package/dist/mcp/lib/gateway-meta.js.map +0 -1
  683. package/dist/mcp/lib/job-manager-accessor.d.ts +0 -10
  684. package/dist/mcp/lib/job-manager-accessor.d.ts.map +0 -1
  685. package/dist/mcp/lib/job-manager-accessor.js +0 -14
  686. package/dist/mcp/lib/job-manager-accessor.js.map +0 -1
  687. package/dist/mcp/lib/protocol-enforcement.d.ts +0 -12
  688. package/dist/mcp/lib/protocol-enforcement.d.ts.map +0 -1
  689. package/dist/mcp/lib/protocol-enforcement.js +0 -12
  690. package/dist/mcp/lib/protocol-enforcement.js.map +0 -1
  691. package/dist/mcp/lib/protocol-rules.d.ts +0 -12
  692. package/dist/mcp/lib/protocol-rules.d.ts.map +0 -1
  693. package/dist/mcp/lib/protocol-rules.js +0 -12
  694. package/dist/mcp/lib/protocol-rules.js.map +0 -1
  695. package/dist/mcp/lib/rate-limiter.d.ts +0 -110
  696. package/dist/mcp/lib/rate-limiter.d.ts.map +0 -1
  697. package/dist/mcp/lib/rate-limiter.js +0 -208
  698. package/dist/mcp/lib/rate-limiter.js.map +0 -1
  699. package/dist/mcp/lib/router.d.ts +0 -58
  700. package/dist/mcp/lib/router.d.ts.map +0 -1
  701. package/dist/mcp/lib/router.js +0 -12
  702. package/dist/mcp/lib/router.js.map +0 -1
  703. package/dist/mcp/lib/security.d.ts +0 -161
  704. package/dist/mcp/lib/security.d.ts.map +0 -1
  705. package/dist/mcp/lib/security.js +0 -360
  706. package/dist/mcp/lib/security.js.map +0 -1
  707. package/dist/mcp/lib/verification-gates.d.ts +0 -13
  708. package/dist/mcp/lib/verification-gates.d.ts.map +0 -1
  709. package/dist/mcp/lib/verification-gates.js +0 -12
  710. package/dist/mcp/lib/verification-gates.js.map +0 -1
  711. package/dist/mcp/resources/budget.d.ts +0 -22
  712. package/dist/mcp/resources/budget.d.ts.map +0 -1
  713. package/dist/mcp/resources/budget.js +0 -46
  714. package/dist/mcp/resources/budget.js.map +0 -1
  715. package/dist/mcp/resources/index.d.ts +0 -53
  716. package/dist/mcp/resources/index.d.ts.map +0 -1
  717. package/dist/mcp/resources/index.js +0 -278
  718. package/dist/mcp/resources/index.js.map +0 -1
@@ -1,769 +0,0 @@
1
- /**
2
- * Orchestrate Engine
3
- *
4
- * Thin wrapper layer that delegates to core modules.
5
- * All business logic lives in src/core/orchestration/.
6
- *
7
- * @task T4478
8
- * @task T4784
9
- */
10
- // Core module imports
11
- import { orchestrationAnalyzeDependencies as analyzeDependencies, analyzeEpic, buildBrainState, computeEpicStatus, computeOverallStatus, computeProgress, computeStartupSummary, endParallelExecution, estimateContext, getAccessor, orchestrationGetCriticalPath as getCriticalPath, getEnrichedWaves, orchestrationGetNextTask as getNextTask, getParallelStatus, orchestrationGetReadyTasks as getReadyTasks, getSkillContent, getUnblockOpportunities, prepareSpawn, resolveProjectRoot, startParallelExecution, validateSpawnReadiness, } from '@cleocode/core/internal';
12
- import { engineError } from './_error.js';
13
- import { sessionContextInject, sessionEnd, sessionStatus } from './session-engine.js';
14
- /**
15
- * Load all tasks from task data.
16
- */
17
- async function loadTasks(projectRoot) {
18
- const root = projectRoot || resolveProjectRoot();
19
- try {
20
- const accessor = await getAccessor(root);
21
- const result = await accessor.queryTasks({});
22
- return result?.tasks ?? [];
23
- }
24
- catch {
25
- return [];
26
- }
27
- }
28
- /**
29
- * orchestrate.status - Get orchestrator status
30
- * @task T4478
31
- */
32
- export async function orchestrateStatus(epicId, projectRoot) {
33
- try {
34
- const root = projectRoot || resolveProjectRoot();
35
- const tasks = await loadTasks(root);
36
- if (epicId) {
37
- const epic = tasks.find((t) => t.id === epicId);
38
- if (!epic) {
39
- return engineError('E_NOT_FOUND', `Epic ${epicId} not found`);
40
- }
41
- const children = tasks.filter((t) => t.parentId === epicId);
42
- const status = computeEpicStatus(epicId, epic.title, children);
43
- return { success: true, data: status };
44
- }
45
- // No epicId - return overall status
46
- const status = computeOverallStatus(tasks);
47
- return { success: true, data: status };
48
- }
49
- catch (err) {
50
- return engineError('E_GENERAL', err.message);
51
- }
52
- }
53
- /**
54
- * orchestrate.analyze - Dependency analysis
55
- * @task T4478
56
- */
57
- export async function orchestrateAnalyze(epicId, projectRoot, mode) {
58
- // Mode: critical-path (delegates to critical path engine)
59
- if (mode === 'critical-path') {
60
- return orchestrateCriticalPath(projectRoot);
61
- }
62
- // Default mode: analysis (requires epicId)
63
- if (!epicId) {
64
- return engineError('E_INVALID_INPUT', 'epicId is required for standard analysis');
65
- }
66
- try {
67
- const root = projectRoot || resolveProjectRoot();
68
- const accessor = await getAccessor(root);
69
- const result = await analyzeEpic(epicId, root, accessor);
70
- // Add dependency graph and circular dep detection via core analyze module
71
- const tasks = await loadTasks(root);
72
- const children = tasks.filter((t) => t.parentId === epicId);
73
- const depAnalysis = analyzeDependencies(children, tasks);
74
- return {
75
- success: true,
76
- data: {
77
- epicId: result.epicId,
78
- epicTitle: tasks.find((t) => t.id === epicId)?.title || epicId,
79
- totalTasks: result.totalTasks,
80
- waves: result.waves,
81
- circularDependencies: depAnalysis.circularDependencies,
82
- missingDependencies: depAnalysis.missingDependencies,
83
- dependencyGraph: depAnalysis.dependencyGraph,
84
- },
85
- };
86
- }
87
- catch (err) {
88
- const code = err.code ?? 'E_GENERAL';
89
- return engineError(code, err.message);
90
- }
91
- }
92
- /**
93
- * orchestrate.ready - Get parallel-safe tasks (ready to execute)
94
- * @task T4478
95
- */
96
- export async function orchestrateReady(epicId, projectRoot) {
97
- if (!epicId) {
98
- return engineError('E_INVALID_INPUT', 'epicId is required');
99
- }
100
- try {
101
- const root = projectRoot || resolveProjectRoot();
102
- const accessor = await getAccessor(root);
103
- const readyTasks = await getReadyTasks(epicId, root, accessor);
104
- const ready = readyTasks.filter((t) => t.ready);
105
- return {
106
- success: true,
107
- data: {
108
- epicId,
109
- readyTasks: ready.map((t) => ({
110
- id: t.taskId,
111
- title: t.title,
112
- priority: 'medium', // getReadyTasks doesn't return priority
113
- depends: t.blockers,
114
- })),
115
- total: ready.length,
116
- },
117
- };
118
- }
119
- catch (err) {
120
- const code = err.code ?? 'E_GENERAL';
121
- return engineError(code, err.message);
122
- }
123
- }
124
- /**
125
- * orchestrate.next - Next task to spawn
126
- * @task T4478
127
- */
128
- export async function orchestrateNext(epicId, projectRoot) {
129
- if (!epicId) {
130
- return engineError('E_INVALID_INPUT', 'epicId is required');
131
- }
132
- try {
133
- const root = projectRoot || resolveProjectRoot();
134
- const accessor = await getAccessor(root);
135
- const nextTask = await getNextTask(epicId, root, accessor);
136
- if (!nextTask) {
137
- return {
138
- success: true,
139
- data: {
140
- epicId,
141
- nextTask: null,
142
- message: 'No tasks ready to spawn. All pending tasks may have unmet dependencies.',
143
- },
144
- };
145
- }
146
- // Get all ready tasks for alternatives
147
- const readyTasks = await getReadyTasks(epicId, root, accessor);
148
- const ready = readyTasks.filter((t) => t.ready);
149
- return {
150
- success: true,
151
- data: {
152
- epicId,
153
- nextTask: { id: nextTask.taskId, title: nextTask.title, priority: 'medium' },
154
- alternatives: ready
155
- .slice(1, 4)
156
- .map((t) => ({ id: t.taskId, title: t.title, priority: 'medium' })),
157
- totalReady: ready.length,
158
- },
159
- };
160
- }
161
- catch (err) {
162
- const code = err.code ?? 'E_GENERAL';
163
- return engineError(code, err.message);
164
- }
165
- }
166
- /**
167
- * orchestrate.waves - Compute dependency waves
168
- * @task T4478
169
- */
170
- export async function orchestrateWaves(epicId, projectRoot) {
171
- if (!epicId) {
172
- return engineError('E_INVALID_INPUT', 'epicId is required');
173
- }
174
- try {
175
- const root = projectRoot || resolveProjectRoot();
176
- const accessor = await getAccessor(root);
177
- const result = await getEnrichedWaves(epicId, root, accessor);
178
- return { success: true, data: result };
179
- }
180
- catch (err) {
181
- const code = err.code ?? 'E_GENERAL';
182
- return engineError(code, err.message);
183
- }
184
- }
185
- /**
186
- * orchestrate.context - Context usage check
187
- * @task T4478
188
- */
189
- export async function orchestrateContext(epicId, projectRoot) {
190
- try {
191
- const root = projectRoot || resolveProjectRoot();
192
- const tasks = await loadTasks(root);
193
- let taskCount = tasks.length;
194
- if (epicId) {
195
- taskCount = tasks.filter((t) => t.parentId === epicId).length;
196
- }
197
- const contextData = estimateContext(taskCount, root, epicId);
198
- return { success: true, data: contextData };
199
- }
200
- catch (err) {
201
- return engineError('E_GENERAL', err.message);
202
- }
203
- }
204
- /**
205
- * orchestrate.validate - Validate spawn readiness for a task
206
- * @task T4478
207
- */
208
- export async function orchestrateValidate(taskId, projectRoot) {
209
- if (!taskId) {
210
- return engineError('E_INVALID_INPUT', 'taskId is required');
211
- }
212
- try {
213
- const root = projectRoot || resolveProjectRoot();
214
- const accessor = await getAccessor(root);
215
- const result = await validateSpawnReadiness(taskId, root, accessor);
216
- return { success: true, data: result };
217
- }
218
- catch (err) {
219
- return engineError('E_VALIDATION', err.message);
220
- }
221
- }
222
- /**
223
- * orchestrate.spawn.select - Select best provider for spawn based on required capabilities
224
- * @task T5236
225
- */
226
- export async function orchestrateSpawnSelectProvider(capabilities, _projectRoot) {
227
- if (!capabilities || capabilities.length === 0) {
228
- return engineError('E_INVALID_INPUT', 'At least one capability is required');
229
- }
230
- try {
231
- const { initializeDefaultAdapters, spawnRegistry } = await import('@cleocode/core/internal');
232
- const { getAllProviders, getProvidersBySpawnCapability, providerSupportsById } = await import('@cleocode/caamp');
233
- await initializeDefaultAdapters();
234
- // Get providers matching all required capabilities
235
- let matchingProviders = [];
236
- if (capabilities.length === 1) {
237
- // Single capability - use direct filter
238
- matchingProviders = getProvidersBySpawnCapability(capabilities[0]);
239
- }
240
- else {
241
- // Multiple capabilities - find intersection
242
- const providerSets = capabilities.map((cap) => new Set(getProvidersBySpawnCapability(cap).map((p) => p.id)));
243
- // Find intersection of all provider IDs
244
- const allProviders = await spawnRegistry.listSpawnCapable();
245
- const intersection = allProviders
246
- .filter((adapter) => providerSets.every((set) => set.has(adapter.providerId)))
247
- .map((adapter) => getAllProviders().find((p) => p.id === adapter.providerId))
248
- .filter((provider) => provider !== undefined);
249
- matchingProviders = intersection;
250
- }
251
- if (matchingProviders.length === 0) {
252
- return {
253
- success: false,
254
- error: {
255
- code: 'E_SPAWN_NO_PROVIDER',
256
- message: `No provider found with all required capabilities: ${capabilities.join(', ')}`,
257
- exitCode: 60,
258
- },
259
- };
260
- }
261
- // Get first registered adapter for the matching providers
262
- const adapter = matchingProviders
263
- .map((p) => spawnRegistry.getForProvider(p.id))
264
- .find((a) => a !== undefined);
265
- if (!adapter) {
266
- return {
267
- success: false,
268
- error: {
269
- code: 'E_SPAWN_NO_ADAPTER',
270
- message: 'No spawn adapter registered for matching providers',
271
- exitCode: 60,
272
- },
273
- };
274
- }
275
- // Verify adapter can actually spawn
276
- const canSpawn = await adapter.canSpawn();
277
- if (!canSpawn) {
278
- return {
279
- success: false,
280
- error: {
281
- code: 'E_SPAWN_ADAPTER_UNAVAILABLE',
282
- message: `Selected adapter '${adapter.id}' cannot spawn in current environment`,
283
- exitCode: 63,
284
- },
285
- };
286
- }
287
- return {
288
- success: true,
289
- data: {
290
- providerId: adapter.providerId,
291
- adapterId: adapter.id,
292
- capabilities: capabilities.filter((cap) => providerSupportsById(adapter.providerId, `spawn.${cap}`)),
293
- },
294
- };
295
- }
296
- catch (err) {
297
- return engineError('E_GENERAL', err.message);
298
- }
299
- }
300
- /**
301
- * orchestrate.spawn.execute - Execute spawn for a task using adapter registry
302
- * @task T5236
303
- */
304
- export async function orchestrateSpawnExecute(taskId, adapterId, protocolType, projectRoot, tier) {
305
- const cwd = projectRoot ?? process.cwd();
306
- try {
307
- // Get spawn registry
308
- const { initializeDefaultAdapters, spawnRegistry } = await import('@cleocode/core/internal');
309
- await initializeDefaultAdapters();
310
- // Find adapter
311
- let adapter;
312
- if (adapterId) {
313
- adapter = spawnRegistry.get(adapterId);
314
- }
315
- else {
316
- // Auto-select first capable adapter
317
- const capable = await spawnRegistry.listSpawnCapable();
318
- adapter = capable[0];
319
- }
320
- if (!adapter) {
321
- return {
322
- success: false,
323
- error: {
324
- code: 'E_SPAWN_NO_ADAPTER',
325
- message: 'No spawn adapter available for this provider',
326
- exitCode: 60,
327
- },
328
- };
329
- }
330
- // Verify provider supports subagents using providerSupportsById
331
- const { providerSupportsById } = await import('@cleocode/caamp');
332
- if (!providerSupportsById(adapter.providerId, 'spawn.supportsSubagents')) {
333
- return {
334
- success: false,
335
- error: {
336
- code: 'E_SPAWN_CAPABILITY_UNSUPPORTED',
337
- message: `Provider ${adapter.providerId} does not support spawning subagents`,
338
- exitCode: 60,
339
- },
340
- };
341
- }
342
- // Prepare spawn context (reuse existing prepareSpawn logic)
343
- const { prepareSpawn } = await import('@cleocode/core/internal');
344
- const accessor = await getAccessor(cwd);
345
- const spawnContext = await prepareSpawn(taskId, cwd, accessor);
346
- // Check for unresolved tokens
347
- if (!spawnContext.tokenResolution.fullyResolved) {
348
- return {
349
- success: false,
350
- error: {
351
- code: 'E_SPAWN_VALIDATION_FAILED',
352
- message: `Unresolved tokens in spawn context: ${spawnContext.tokenResolution.unresolvedTokens.join(', ')}`,
353
- exitCode: 63,
354
- },
355
- };
356
- }
357
- // Build CLEO spawn context from core spawn context
358
- const { getSpawnCapableProviders } = await import('@cleocode/caamp');
359
- const providers = getSpawnCapableProviders();
360
- const provider = providers.find((p) => p.id === adapter.providerId);
361
- if (!provider) {
362
- return {
363
- success: false,
364
- error: {
365
- code: 'E_SPAWN_NO_PROVIDER',
366
- message: `Provider ${adapter.providerId} not found`,
367
- exitCode: 60,
368
- },
369
- };
370
- }
371
- const cleoSpawnContext = {
372
- taskId: spawnContext.taskId,
373
- protocol: protocolType || spawnContext.protocol,
374
- prompt: spawnContext.prompt,
375
- provider: provider.id,
376
- options: {
377
- prompt: spawnContext.prompt,
378
- },
379
- workingDirectory: cwd,
380
- tokenResolution: {
381
- resolved: [],
382
- unresolved: spawnContext.tokenResolution.unresolvedTokens,
383
- totalTokens: 0,
384
- },
385
- };
386
- // Execute spawn
387
- const result = await adapter.spawn(cleoSpawnContext);
388
- return {
389
- success: true,
390
- data: {
391
- instanceId: result.instanceId,
392
- status: result.status,
393
- providerId: adapter.providerId,
394
- taskId,
395
- timing: result.timing,
396
- tier: tier ?? null,
397
- },
398
- };
399
- }
400
- catch (error) {
401
- return {
402
- success: false,
403
- error: {
404
- code: 'E_SPAWN_FAILED',
405
- message: error instanceof Error ? error.message : 'Unknown spawn error',
406
- exitCode: 60,
407
- },
408
- };
409
- }
410
- }
411
- /**
412
- * orchestrate.spawn - Generate spawn prompt for a task
413
- * @task T4478
414
- */
415
- export async function orchestrateSpawn(taskId, protocolType, projectRoot, tier) {
416
- if (!taskId) {
417
- return engineError('E_INVALID_INPUT', 'taskId is required');
418
- }
419
- try {
420
- const root = projectRoot || resolveProjectRoot();
421
- // Validate readiness first
422
- const accessor = await getAccessor(root);
423
- const validation = await validateSpawnReadiness(taskId, root, accessor);
424
- if (!validation.ready) {
425
- return engineError('E_SPAWN_VALIDATION_FAILED', `Task ${taskId} is not ready to spawn`, {
426
- details: { issues: validation.issues },
427
- });
428
- }
429
- // Prepare spawn context via core
430
- const spawnContext = await prepareSpawn(taskId, root, accessor);
431
- return {
432
- success: true,
433
- data: {
434
- taskId,
435
- spawnContext: {
436
- taskId: spawnContext.taskId,
437
- protocol: spawnContext.protocol,
438
- protocolType: protocolType || spawnContext.protocol,
439
- tier: tier ?? null,
440
- },
441
- protocolType: protocolType || spawnContext.protocol,
442
- tier: tier ?? null,
443
- tokenResolution: spawnContext.tokenResolution,
444
- },
445
- };
446
- }
447
- catch (err) {
448
- const code = err.code ?? 'E_GENERAL';
449
- return engineError(code, err.message);
450
- }
451
- }
452
- /**
453
- * orchestrate.startup - Initialize orchestration for an epic
454
- * @task T4478
455
- */
456
- export async function orchestrateStartup(epicId, projectRoot) {
457
- if (!epicId) {
458
- return engineError('E_INVALID_INPUT', 'epicId is required');
459
- }
460
- try {
461
- const root = projectRoot || resolveProjectRoot();
462
- const accessor = await getAccessor(root);
463
- const tasks = await loadTasks(root);
464
- const epic = tasks.find((t) => t.id === epicId);
465
- if (!epic) {
466
- return engineError('E_NOT_FOUND', `Epic ${epicId} not found`);
467
- }
468
- const children = tasks.filter((t) => t.parentId === epicId);
469
- const readyTasks = await getReadyTasks(epicId, root, accessor);
470
- const ready = readyTasks.filter((t) => t.ready);
471
- const summary = computeStartupSummary(epicId, epic.title, children, ready.length);
472
- return { success: true, data: summary };
473
- }
474
- catch (err) {
475
- const code = err.code ?? 'E_GENERAL';
476
- return engineError(code, err.message);
477
- }
478
- }
479
- /**
480
- * orchestrate.bootstrap - Load brain state for agent bootstrapping
481
- * @task T4478
482
- * @task T4657
483
- */
484
- export async function orchestrateBootstrap(projectRoot, params) {
485
- try {
486
- const root = projectRoot || resolveProjectRoot();
487
- const accessor = await getAccessor(root);
488
- const brain = await buildBrainState(root, params, accessor);
489
- return { success: true, data: brain };
490
- }
491
- catch (err) {
492
- return engineError('E_GENERAL', err.message);
493
- }
494
- }
495
- /**
496
- * orchestrate.critical-path - Find the longest dependency chain
497
- * @task T4478
498
- */
499
- export async function orchestrateCriticalPath(projectRoot) {
500
- try {
501
- const root = projectRoot || resolveProjectRoot();
502
- const accessor = await getAccessor(root);
503
- const result = await getCriticalPath(root, accessor);
504
- return { success: true, data: result };
505
- }
506
- catch (err) {
507
- return engineError('E_GENERAL', err.message);
508
- }
509
- }
510
- /**
511
- * orchestrate.unblock-opportunities - Analyze dependency graph for unblocking opportunities
512
- * @task T4478
513
- */
514
- export async function orchestrateUnblockOpportunities(projectRoot) {
515
- try {
516
- const root = projectRoot || resolveProjectRoot();
517
- const accessor = await getAccessor(root);
518
- const result = await getUnblockOpportunities(root, accessor);
519
- return { success: true, data: result };
520
- }
521
- catch (err) {
522
- return engineError('E_GENERAL', err.message);
523
- }
524
- }
525
- /**
526
- * orchestrate.parallel - Manage parallel execution (start/end)
527
- * @task T4632
528
- */
529
- export async function orchestrateParallel(action, epicId, wave, projectRoot) {
530
- if (action === 'start') {
531
- if (wave === undefined || wave === null) {
532
- return engineError('E_INVALID_INPUT', 'wave number is required for start action');
533
- }
534
- return orchestrateParallelStart(epicId, wave, projectRoot);
535
- }
536
- if (action === 'end') {
537
- // wave is technically optional for end if we want to end ANY parallel execution,
538
- // but the current implementation expects wave.
539
- // However, endParallelExecution calls endParallelExecution(epicId, wave, root)
540
- if (wave === undefined || wave === null) {
541
- // If wave is not provided, maybe we can find the active one?
542
- // For now, let's require it to match the underlying signature or default to 0/current?
543
- // The underlying `endParallelExecution` signature is `(epicId: string, wave: number, root: string)`.
544
- // Let's require it for now to be safe, or check if we can improve this.
545
- return engineError('E_INVALID_INPUT', 'wave number is required for end action');
546
- }
547
- return orchestrateParallelEnd(epicId, wave, projectRoot);
548
- }
549
- return engineError('E_INVALID_INPUT', `Unknown parallel action: ${action}`);
550
- }
551
- /**
552
- * orchestrate.parallel.start - Start parallel execution for a wave
553
- * @task T4632
554
- */
555
- export async function orchestrateParallelStart(epicId, wave, projectRoot) {
556
- if (!epicId) {
557
- return engineError('E_INVALID_INPUT', 'epicId is required');
558
- }
559
- if (wave === undefined || wave === null) {
560
- return engineError('E_INVALID_INPUT', 'wave number is required');
561
- }
562
- try {
563
- const root = projectRoot || resolveProjectRoot();
564
- const accessor = await getAccessor(root);
565
- const result = await startParallelExecution(epicId, wave, root, accessor);
566
- return { success: true, data: result };
567
- }
568
- catch (err) {
569
- const code = err.code ?? 'E_GENERAL';
570
- return engineError(code, err.message);
571
- }
572
- }
573
- /**
574
- * orchestrate.parallel.end - End parallel execution for a wave
575
- * @task T4632
576
- */
577
- export async function orchestrateParallelEnd(epicId, wave, projectRoot) {
578
- if (!epicId) {
579
- return engineError('E_INVALID_INPUT', 'epicId is required');
580
- }
581
- try {
582
- const root = projectRoot || resolveProjectRoot();
583
- const result = await endParallelExecution(epicId, wave, root);
584
- if (result.alreadyEnded) {
585
- return {
586
- success: true,
587
- data: {
588
- epicId,
589
- wave,
590
- message: 'No parallel execution was active',
591
- alreadyEnded: true,
592
- },
593
- };
594
- }
595
- return { success: true, data: result };
596
- }
597
- catch (err) {
598
- const code = err.code ?? 'E_GENERAL';
599
- return engineError(code, err.message);
600
- }
601
- }
602
- /**
603
- * orchestrate.check - Check current orchestration state
604
- * @task T4632
605
- */
606
- export async function orchestrateCheck(projectRoot) {
607
- try {
608
- const root = projectRoot || resolveProjectRoot();
609
- const parallelState = await getParallelStatus(root);
610
- const tasks = await loadTasks(root);
611
- const activeTasks = tasks.filter((t) => t.status === 'active');
612
- const progress = computeProgress(tasks);
613
- return {
614
- success: true,
615
- data: {
616
- parallelExecution: {
617
- active: parallelState.active,
618
- epicId: parallelState.epicId || null,
619
- wave: parallelState.wave || null,
620
- tasks: parallelState.tasks || [],
621
- startedAt: parallelState.startedAt || null,
622
- },
623
- activeTasks: activeTasks.map((t) => ({ id: t.id, title: t.title, status: t.status })),
624
- progress,
625
- },
626
- };
627
- }
628
- catch (err) {
629
- return engineError('E_GENERAL', err.message);
630
- }
631
- }
632
- /**
633
- * orchestrate.skill.inject - Read skill content for injection into agent context
634
- * @task T4632
635
- */
636
- export function orchestrateSkillInject(skillName, projectRoot) {
637
- try {
638
- const root = projectRoot || resolveProjectRoot();
639
- const result = getSkillContent(skillName, root);
640
- return { success: true, data: result };
641
- }
642
- catch (err) {
643
- const code = err.code ?? 'E_GENERAL';
644
- return engineError(code, err.message);
645
- }
646
- }
647
- /**
648
- * orchestrate.handoff - Composite session handoff + successor spawn
649
- *
650
- * Step order is explicit and fixed:
651
- * 1) session.context.inject
652
- * 2) session.end
653
- * 3) orchestrate.spawn
654
- *
655
- * Idempotency policy:
656
- * - Non-idempotent overall. A retry after step 2 can duplicate spawn output.
657
- * - Failures include exact step state and a safe retry entry point.
658
- */
659
- export async function orchestrateHandoff(params, projectRoot) {
660
- if (!params.taskId) {
661
- return engineError('E_INVALID_INPUT', 'taskId is required');
662
- }
663
- if (!params.protocolType) {
664
- return engineError('E_INVALID_INPUT', 'protocolType is required');
665
- }
666
- const root = projectRoot || resolveProjectRoot();
667
- const steps = {
668
- contextInject: { status: 'pending', operation: 'session.context.inject' },
669
- sessionEnd: { status: 'pending', operation: 'session.end' },
670
- spawn: { status: 'pending', operation: 'orchestrate.spawn' },
671
- };
672
- const idempotency = {
673
- key: params.idempotencyKey ?? null,
674
- policy: 'non-idempotent',
675
- safeRetryFrom: 'start',
676
- reason: 'session.end and orchestrate.spawn mutate state and may be executed independently on retry',
677
- };
678
- let activeSessionId = null;
679
- let endedSessionId = null;
680
- const failWithStep = (code, message, failedStep, safeRetryFrom) => {
681
- idempotency.safeRetryFrom = safeRetryFrom;
682
- return engineError(code, message, {
683
- details: {
684
- failedStep,
685
- activeSessionId,
686
- endedSessionId,
687
- idempotency,
688
- steps,
689
- },
690
- fix: safeRetryFrom === 'orchestrate.spawn'
691
- ? 'Retry only step 3 with mutate orchestrate spawn'
692
- : 'Retry from step 1 with mutate orchestrate handoff',
693
- alternatives: [
694
- {
695
- action: 'Run canonical multi-op fallback manually',
696
- command: 'mutate session context.inject -> mutate session end -> mutate orchestrate spawn',
697
- },
698
- ],
699
- });
700
- };
701
- const preflight = await sessionStatus(root);
702
- if (!preflight.success) {
703
- return failWithStep(preflight.error?.code ?? 'E_NOT_INITIALIZED', preflight.error?.message ?? 'Unable to load session status', 'session.context.inject', 'start');
704
- }
705
- if (!preflight.data?.hasActiveSession || !preflight.data.session?.id) {
706
- steps.contextInject.status = 'skipped';
707
- steps.contextInject.message = 'No active session available for handoff';
708
- steps.sessionEnd.status = 'skipped';
709
- steps.sessionEnd.message = 'No active session available for handoff';
710
- steps.spawn.status = 'skipped';
711
- steps.spawn.message = 'No active session available for handoff';
712
- return failWithStep('E_SESSION_REQUIRED', 'orchestrate.handoff requires an active session', 'session.end', 'start');
713
- }
714
- activeSessionId = preflight.data.session.id;
715
- const injectResult = sessionContextInject(params.protocolType, { taskId: params.taskId, variant: params.variant }, root);
716
- if (!injectResult.success) {
717
- steps.contextInject.status = 'failed';
718
- steps.contextInject.message = injectResult.error?.message;
719
- steps.sessionEnd.status = 'skipped';
720
- steps.sessionEnd.message = 'Blocked by session.context.inject failure';
721
- steps.spawn.status = 'skipped';
722
- steps.spawn.message = 'Blocked by session.context.inject failure';
723
- return failWithStep(injectResult.error?.code ?? 'E_GENERAL', injectResult.error?.message ?? 'Failed to inject handoff context', 'session.context.inject', 'start');
724
- }
725
- steps.contextInject.status = 'completed';
726
- steps.contextInject.message = 'Handoff context injected';
727
- const endResult = await sessionEnd(root, params.note);
728
- if (!endResult.success) {
729
- steps.sessionEnd.status = 'failed';
730
- steps.sessionEnd.message = endResult.error?.message;
731
- steps.spawn.status = 'skipped';
732
- steps.spawn.message = 'Blocked by session.end failure';
733
- return failWithStep(endResult.error?.code ?? 'E_GENERAL', endResult.error?.message ?? 'Failed to end predecessor session', 'session.end', 'start');
734
- }
735
- endedSessionId = endResult.data?.sessionId ?? null;
736
- if (endedSessionId !== activeSessionId) {
737
- steps.sessionEnd.status = 'failed';
738
- steps.sessionEnd.message = `Ended session '${endedSessionId ?? 'null'}' does not match active session '${activeSessionId}'`;
739
- steps.spawn.status = 'skipped';
740
- steps.spawn.message = 'Blocked by session mismatch';
741
- return failWithStep('E_CONCURRENT_SESSION', 'Active session changed during orchestrate.handoff', 'session.end', 'start');
742
- }
743
- steps.sessionEnd.status = 'completed';
744
- steps.sessionEnd.message = `Ended session ${endedSessionId}`;
745
- const spawnResult = await orchestrateSpawn(params.taskId, params.protocolType, root, params.tier);
746
- if (!spawnResult.success) {
747
- steps.spawn.status = 'failed';
748
- steps.spawn.message = spawnResult.error?.message;
749
- return failWithStep(spawnResult.error?.code ?? 'E_GENERAL', spawnResult.error?.message ?? 'Failed to prepare successor spawn context', 'orchestrate.spawn', 'orchestrate.spawn');
750
- }
751
- steps.spawn.status = 'completed';
752
- steps.spawn.message = `Spawn prepared for ${params.taskId}`;
753
- return {
754
- success: true,
755
- data: {
756
- taskId: params.taskId,
757
- predecessorSessionId: activeSessionId,
758
- endedSessionId,
759
- protocolType: params.protocolType,
760
- note: params.note ?? null,
761
- nextAction: params.nextAction ?? null,
762
- idempotency,
763
- steps,
764
- contextInject: injectResult.data,
765
- spawn: spawnResult.data,
766
- },
767
- };
768
- }
769
- //# sourceMappingURL=orchestrate-engine.js.map