@cleocode/cleo 2026.3.73 → 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 +4928 -1914
  3. package/dist/cli/index.js.map +4 -4
  4. package/dist/mcp/index.js +4971 -2409
  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,1180 +0,0 @@
1
- /**
2
- * System Engine
3
- *
4
- * Thin wrapper layer that delegates to core modules.
5
- * All business logic lives in src/core/.
6
- *
7
- * Read-only queries: dash, stats, labels, archive-stats, log, context, sequence,
8
- * metrics, health, diagnostics, help, roadmap, compliance
9
- * Mutate operations: inject.generate, backup, restore, migrate, cleanup, audit,
10
- * sync, safestop, uncancel
11
- *
12
- * @task T4631
13
- * @task T4783
14
- */
15
- import { existsSync, readdirSync, readFileSync } from 'node:fs';
16
- import { basename, join } from 'node:path';
17
- import { auditData, cleanupSystem, systemCreateBackup as createBackup, generateInjection, getAccessor, getArchiveStats, getDashboard, getLabels, getMigrationStatus, getProjectStats, getRoadmap, getRuntimeDiagnostics, getSystemDiagnostics, getSystemHealth, getSystemMetrics, listSystemBackups, repairSequence, restoreBackup, safestop, uncancelTask, } from '@cleocode/core/internal';
18
- import { engineError } from './_error.js';
19
- // ===== Help topics (static data, stays in engine) =====
20
- const HELP_TOPICS = {
21
- session: {
22
- topic: 'session',
23
- content: [
24
- 'Session Management',
25
- '',
26
- ' ct session list - List all sessions',
27
- ' ct session start --scope epic:T001 - Start session',
28
- ' ct session end --note "Progress" - End session',
29
- ' ct session resume <id> - Resume session',
30
- ].join('\n'),
31
- relatedCommands: ['ct session list', 'ct session start', 'ct session end'],
32
- },
33
- tasks: {
34
- topic: 'tasks',
35
- content: [
36
- 'Task Operations',
37
- '',
38
- ' ct add "Title" --desc "Description" - Create task',
39
- ' ct update T1234 --status active - Update task',
40
- ' ct complete T1234 - Complete task',
41
- ' ct find "query" - Search tasks',
42
- ' ct show T1234 - Show task details',
43
- ].join('\n'),
44
- relatedCommands: ['ct add', 'ct update', 'ct complete', 'ct find', 'ct show'],
45
- },
46
- focus: {
47
- topic: 'focus',
48
- content: [
49
- 'Task Work Management',
50
- '',
51
- ' ct start T1234 - Start working on task',
52
- ' ct current - Show current task',
53
- ' ct stop - Stop working on current task',
54
- ].join('\n'),
55
- relatedCommands: ['ct start', 'ct current', 'ct stop'],
56
- },
57
- labels: {
58
- topic: 'labels',
59
- content: [
60
- 'Label Operations',
61
- '',
62
- ' ct labels - List all labels',
63
- ' ct labels show <name> - Show tasks with label',
64
- ].join('\n'),
65
- relatedCommands: ['ct labels'],
66
- },
67
- compliance: {
68
- topic: 'compliance',
69
- content: [
70
- 'Compliance Monitoring',
71
- '',
72
- ' ct compliance summary - Compliance overview',
73
- ' ct compliance violations - List violations',
74
- ' ct compliance trend - Compliance trend',
75
- ].join('\n'),
76
- relatedCommands: ['ct compliance summary', 'ct compliance violations'],
77
- },
78
- };
79
- // ===== Dashboard =====
80
- /**
81
- * Project dashboard: task counts by status, active session info,
82
- * current focus, recent completions.
83
- */
84
- export async function systemDash(projectRoot, params) {
85
- try {
86
- const accessor = await getAccessor(projectRoot);
87
- const result = await getDashboard({ cwd: projectRoot, blockedTasksLimit: params?.blockedTasksLimit }, accessor);
88
- // Add missing fields that core doesn't produce
89
- const data = result;
90
- const summary = data.summary;
91
- return {
92
- success: true,
93
- data: {
94
- project: data.project,
95
- currentPhase: data.currentPhase,
96
- summary: {
97
- pending: summary.pending,
98
- active: summary.active,
99
- blocked: summary.blocked,
100
- done: summary.done,
101
- cancelled: summary.cancelled ?? 0,
102
- total: summary.total,
103
- archived: summary.archived ?? 0,
104
- grandTotal: summary.grandTotal ?? summary.total,
105
- },
106
- taskWork: (data.focus ?? data.taskWork),
107
- activeSession: data.activeSession ?? null,
108
- highPriority: data.highPriority,
109
- blockedTasks: data.blockedTasks,
110
- recentCompletions: (data.recentCompletions ?? []),
111
- topLabels: data.topLabels,
112
- },
113
- };
114
- }
115
- catch (err) {
116
- return engineError('E_NOT_INITIALIZED', err.message);
117
- }
118
- }
119
- // ===== Stats =====
120
- /**
121
- * Detailed statistics: tasks by status/priority/type/phase,
122
- * completion rate, average cycle time.
123
- */
124
- export async function systemStats(projectRoot, params) {
125
- try {
126
- const accessor = await getAccessor(projectRoot);
127
- const result = await getProjectStats({ period: String(params?.period ?? 30), cwd: projectRoot }, accessor);
128
- // Core stats lacks byPriority, byType, byPhase, cycleTimes — fill from accessor
129
- const queryResult = await accessor.queryTasks({});
130
- const tasks = queryResult?.tasks ?? [];
131
- // Distribution breakdowns: active tasks only (exclude cancelled — not actionable work)
132
- const activeTasks = tasks.filter((t) => t.status !== 'cancelled');
133
- const byPriority = {};
134
- for (const t of activeTasks) {
135
- byPriority[t.priority] = (byPriority[t.priority] ?? 0) + 1;
136
- }
137
- const byType = {};
138
- for (const t of activeTasks) {
139
- const type = t.type || 'task';
140
- byType[type] = (byType[type] ?? 0) + 1;
141
- }
142
- const byPhase = {};
143
- for (const t of activeTasks) {
144
- const phase = t.phase || 'unassigned';
145
- byPhase[phase] = (byPhase[phase] ?? 0) + 1;
146
- }
147
- // Cycle times
148
- const completedTasks = tasks.filter((t) => t.status === 'done' && t.completedAt && t.createdAt);
149
- let totalCycleDays = 0;
150
- let samples = 0;
151
- for (const t of completedTasks) {
152
- const created = new Date(t.createdAt).getTime();
153
- const completed = new Date(t.completedAt).getTime();
154
- if (completed > created) {
155
- totalCycleDays += (completed - created) / 86400000;
156
- samples++;
157
- }
158
- }
159
- const averageDays = samples > 0 ? Math.round((totalCycleDays / samples) * 100) / 100 : null;
160
- const coreData = result;
161
- const currentState = coreData.currentState;
162
- const completionMetrics = coreData.completionMetrics;
163
- const activityMetrics = coreData.activityMetrics;
164
- const allTime = coreData.allTime;
165
- return {
166
- success: true,
167
- data: {
168
- currentState: {
169
- pending: currentState.pending,
170
- active: currentState.active,
171
- done: currentState.done,
172
- blocked: currentState.blocked,
173
- cancelled: tasks.filter((t) => t.status === 'cancelled').length,
174
- totalActive: currentState.totalActive,
175
- archived: currentState.archived ?? 0,
176
- grandTotal: currentState.grandTotal ?? currentState.totalActive,
177
- },
178
- byPriority,
179
- byType,
180
- byPhase,
181
- completionMetrics: completionMetrics,
182
- activityMetrics: activityMetrics,
183
- allTime: allTime,
184
- cycleTimes: { averageDays, samples },
185
- },
186
- };
187
- }
188
- catch (err) {
189
- return engineError('E_NOT_INITIALIZED', err.message);
190
- }
191
- }
192
- // ===== Labels =====
193
- /**
194
- * List all unique labels across tasks with counts and task IDs per label.
195
- */
196
- export async function systemLabels(projectRoot) {
197
- try {
198
- const accessor = await getAccessor(projectRoot);
199
- const result = await getLabels(projectRoot, accessor);
200
- return { success: true, data: result };
201
- }
202
- catch (err) {
203
- return engineError('E_NOT_INITIALIZED', err.message);
204
- }
205
- }
206
- // ===== Archive Stats =====
207
- /**
208
- * Archive metrics: total archived, by reason, average cycle time, archive rate.
209
- */
210
- export async function systemArchiveStats(projectRoot, params) {
211
- try {
212
- const accessor = await getAccessor(projectRoot);
213
- const result = await getArchiveStats({ period: params?.period, cwd: projectRoot }, accessor);
214
- return { success: true, data: result };
215
- }
216
- catch (err) {
217
- return engineError('E_NOT_INITIALIZED', err.message);
218
- }
219
- }
220
- // ===== Log =====
221
- /**
222
- * Query audit log with optional filters.
223
- * Reads from SQLite audit_log table.
224
- *
225
- * @task T4837
226
- */
227
- export async function systemLog(projectRoot, filters) {
228
- try {
229
- // Canonical path: SQLite audit_log table.
230
- const entries = await queryAuditLogSqlite(projectRoot, filters);
231
- return { success: true, data: entries };
232
- }
233
- catch (err) {
234
- return engineError('E_FILE_ERROR', err.message);
235
- }
236
- }
237
- /**
238
- * Query audit_log from SQLite.
239
- * Includes dispatch-level fields (domain, requestId, durationMs, success,
240
- * source, gateway, errorMessage) when present (T4844).
241
- *
242
- * @task T4837
243
- * @task T4844
244
- */
245
- async function queryAuditLogSqlite(projectRoot, filters) {
246
- try {
247
- const { join } = await import('node:path');
248
- const { existsSync } = await import('node:fs');
249
- const dbPath = join(projectRoot, '.cleo', 'tasks.db');
250
- if (!existsSync(dbPath)) {
251
- const offset = filters?.offset ?? 0;
252
- const limit = filters?.limit ?? 20;
253
- return {
254
- entries: [],
255
- pagination: { total: 0, offset, limit, hasMore: false },
256
- };
257
- }
258
- const { getDb } = await import('@cleocode/core/internal');
259
- const { auditLog } = await import('@cleocode/core/internal');
260
- const { sql } = await import('drizzle-orm');
261
- const db = await getDb(projectRoot);
262
- // Check if audit_log table exists and has data
263
- try {
264
- // Build dynamic WHERE conditions
265
- const conditions = [];
266
- if (filters?.operation) {
267
- // Match against both legacy 'action' column and new 'operation' column
268
- conditions.push(sql `(${auditLog.action} = ${filters.operation} OR ${auditLog.operation} = ${filters.operation})`);
269
- }
270
- if (filters?.taskId) {
271
- conditions.push(sql `${auditLog.taskId} = ${filters.taskId}`);
272
- }
273
- if (filters?.since) {
274
- conditions.push(sql `${auditLog.timestamp} >= ${filters.since}`);
275
- }
276
- if (filters?.until) {
277
- conditions.push(sql `${auditLog.timestamp} <= ${filters.until}`);
278
- }
279
- const whereClause = conditions.length > 0 ? sql.join(conditions, sql ` AND `) : sql `1=1`;
280
- // Count total matching entries
281
- const countResult = await db.all(sql `SELECT count(*) as cnt FROM ${auditLog} WHERE ${whereClause}`);
282
- const total = countResult[0]?.cnt ?? 0;
283
- if (total === 0) {
284
- return {
285
- entries: [],
286
- pagination: {
287
- total: 0,
288
- offset: filters?.offset ?? 0,
289
- limit: filters?.limit ?? 20,
290
- hasMore: false,
291
- },
292
- };
293
- }
294
- const offset = filters?.offset ?? 0;
295
- const limit = filters?.limit ?? 20;
296
- // Fetch paginated results (includes dispatch-level columns)
297
- const rows = await db.all(sql `SELECT * FROM ${auditLog}
298
- WHERE ${whereClause}
299
- ORDER BY ${auditLog.timestamp} DESC
300
- LIMIT ${limit} OFFSET ${offset}`);
301
- const entries = rows.map((row) => ({
302
- operation: row.operation ?? row.action,
303
- taskId: row.task_id,
304
- timestamp: row.timestamp,
305
- actor: row.actor,
306
- details: row.details_json ? JSON.parse(row.details_json) : {},
307
- before: row.before_json ? JSON.parse(row.before_json) : undefined,
308
- after: row.after_json ? JSON.parse(row.after_json) : undefined,
309
- // Dispatch-level fields (may be null for legacy task-only entries)
310
- ...(row.domain != null && {
311
- domain: row.domain,
312
- sessionId: row.session_id,
313
- requestId: row.request_id,
314
- durationMs: row.duration_ms,
315
- success: row.success === 1,
316
- source: row.source,
317
- gateway: row.gateway,
318
- error: row.error_message,
319
- }),
320
- }));
321
- return {
322
- entries,
323
- pagination: { total, offset, limit, hasMore: offset + limit < total },
324
- };
325
- }
326
- catch {
327
- const offset = filters?.offset ?? 0;
328
- const limit = filters?.limit ?? 20;
329
- return {
330
- entries: [],
331
- pagination: { total: 0, offset, limit, hasMore: false },
332
- };
333
- }
334
- }
335
- catch {
336
- const offset = filters?.offset ?? 0;
337
- const limit = filters?.limit ?? 20;
338
- return {
339
- entries: [],
340
- pagination: { total: 0, offset, limit, hasMore: false },
341
- };
342
- }
343
- }
344
- // ===== Context =====
345
- /**
346
- * Context window tracking: estimate token usage from current session/state.
347
- */
348
- export function systemContext(projectRoot, params) {
349
- try {
350
- const cleoDir = join(projectRoot, '.cleo');
351
- // Resolve state file
352
- let stateFile;
353
- if (params?.session) {
354
- const sessionFile = join(cleoDir, 'context-states', `context-state-${params.session}.json`);
355
- stateFile = existsSync(sessionFile) ? sessionFile : join(cleoDir, '.context-state.json');
356
- }
357
- else {
358
- const currentSessionPath = join(cleoDir, '.current-session');
359
- if (existsSync(currentSessionPath)) {
360
- const currentSession = readFileSync(currentSessionPath, 'utf-8').trim();
361
- if (currentSession) {
362
- const sessionFile = join(cleoDir, 'context-states', `context-state-${currentSession}.json`);
363
- stateFile = existsSync(sessionFile) ? sessionFile : join(cleoDir, '.context-state.json');
364
- }
365
- else {
366
- stateFile = join(cleoDir, '.context-state.json');
367
- }
368
- }
369
- else {
370
- stateFile = join(cleoDir, '.context-state.json');
371
- }
372
- }
373
- // Collect session files
374
- const sessions = [];
375
- const statesDir = join(cleoDir, 'context-states');
376
- if (existsSync(statesDir)) {
377
- for (const file of readdirSync(statesDir)) {
378
- if (file.startsWith('context-state-') && file.endsWith('.json')) {
379
- try {
380
- const state = JSON.parse(readFileSync(join(statesDir, file), 'utf-8'));
381
- sessions.push({
382
- file: basename(file),
383
- sessionId: state.sessionId ?? null,
384
- percentage: state.contextWindow?.percentage ?? 0,
385
- status: state.status ?? 'unknown',
386
- timestamp: state.timestamp,
387
- });
388
- }
389
- catch {
390
- // skip invalid files
391
- }
392
- }
393
- }
394
- }
395
- const singletonFile = join(cleoDir, '.context-state.json');
396
- if (existsSync(singletonFile)) {
397
- try {
398
- const state = JSON.parse(readFileSync(singletonFile, 'utf-8'));
399
- sessions.push({
400
- file: '.context-state.json',
401
- sessionId: state.sessionId ?? 'global',
402
- percentage: state.contextWindow?.percentage ?? 0,
403
- status: state.status ?? 'unknown',
404
- timestamp: state.timestamp,
405
- });
406
- }
407
- catch {
408
- // skip
409
- }
410
- }
411
- if (!existsSync(stateFile)) {
412
- return {
413
- success: true,
414
- data: {
415
- available: false,
416
- status: 'unavailable',
417
- percentage: 0,
418
- currentTokens: 0,
419
- maxTokens: 0,
420
- timestamp: null,
421
- stale: true,
422
- sessions,
423
- },
424
- };
425
- }
426
- try {
427
- const state = JSON.parse(readFileSync(stateFile, 'utf-8'));
428
- const timestamp = state.timestamp;
429
- const staleMs = state.staleAfterMs ?? 5000;
430
- const percentage = state.contextWindow?.percentage ?? 0;
431
- const current = state.contextWindow?.currentTokens ?? 0;
432
- const max = state.contextWindow?.maxTokens ?? 0;
433
- let status = state.status ?? 'unknown';
434
- const fileTime = new Date(timestamp).getTime();
435
- if (Date.now() - fileTime > staleMs) {
436
- status = 'stale';
437
- }
438
- return {
439
- success: true,
440
- data: {
441
- available: true,
442
- status,
443
- percentage,
444
- currentTokens: current,
445
- maxTokens: max,
446
- timestamp,
447
- stale: status === 'stale',
448
- sessions,
449
- },
450
- };
451
- }
452
- catch {
453
- return {
454
- success: true,
455
- data: {
456
- available: false,
457
- status: 'error',
458
- percentage: 0,
459
- currentTokens: 0,
460
- maxTokens: 0,
461
- timestamp: null,
462
- stale: true,
463
- sessions,
464
- },
465
- };
466
- }
467
- }
468
- catch (err) {
469
- return engineError('E_GENERAL', err.message);
470
- }
471
- }
472
- // ===== Sequence =====
473
- /**
474
- * Read task ID sequence state from canonical SQLite metadata.
475
- * Supports 'show' and 'check' actions.
476
- * @task T4815
477
- */
478
- export async function systemSequence(projectRoot, params) {
479
- const { showSequence, checkSequence } = await import('@cleocode/core/internal');
480
- try {
481
- const action = params?.action ?? 'show';
482
- if (action === 'check') {
483
- const check = await checkSequence(projectRoot);
484
- return { success: true, data: check };
485
- }
486
- const seq = await showSequence(projectRoot);
487
- return {
488
- success: true,
489
- data: {
490
- counter: Number(seq.counter ?? 0),
491
- lastId: String(seq.lastId ?? ''),
492
- checksum: String(seq.checksum ?? ''),
493
- nextId: String(seq.nextId ?? ''),
494
- },
495
- };
496
- }
497
- catch (err) {
498
- return engineError('E_NOT_FOUND', err.message);
499
- }
500
- }
501
- // ===== Inject Generate (MVI) =====
502
- /**
503
- * Generate Minimum Viable Injection (MVI).
504
- */
505
- export async function systemInjectGenerate(projectRoot) {
506
- try {
507
- const root = projectRoot || process.cwd();
508
- const accessor = await getAccessor(root);
509
- const result = await generateInjection(root, accessor);
510
- return { success: true, data: result };
511
- }
512
- catch (err) {
513
- return engineError('E_GENERAL', err.message);
514
- }
515
- }
516
- // ===== Metrics =====
517
- /**
518
- * System metrics: token usage, compliance summary, session counts.
519
- * @task T4631
520
- */
521
- export async function systemMetrics(projectRoot, params) {
522
- try {
523
- const accessor = await getAccessor(projectRoot);
524
- const result = await getSystemMetrics(projectRoot, params, accessor);
525
- return { success: true, data: result };
526
- }
527
- catch (err) {
528
- return engineError('E_GENERAL', err.message);
529
- }
530
- }
531
- // ===== Health =====
532
- /**
533
- * System health check: verify core data files exist and are valid.
534
- * @task T4631
535
- */
536
- export function systemHealth(projectRoot, params) {
537
- try {
538
- const result = getSystemHealth(projectRoot, params);
539
- return { success: true, data: result };
540
- }
541
- catch (err) {
542
- return engineError('E_GENERAL', err.message);
543
- }
544
- }
545
- // ===== Diagnostics =====
546
- /**
547
- * System diagnostics: extended health checks with fix suggestions.
548
- * @task T4631
549
- */
550
- export async function systemDiagnostics(projectRoot, params) {
551
- try {
552
- const result = await getSystemDiagnostics(projectRoot, params);
553
- return { success: true, data: result };
554
- }
555
- catch (err) {
556
- return engineError('E_GENERAL', err.message);
557
- }
558
- }
559
- // ===== Help =====
560
- /**
561
- * Return help text for the system.
562
- * @task T4631
563
- */
564
- export function systemHelp(_projectRoot, params) {
565
- const topic = params?.topic;
566
- if (topic) {
567
- const topicHelp = HELP_TOPICS[topic];
568
- if (topicHelp) {
569
- return { success: true, data: topicHelp };
570
- }
571
- return engineError('E_NOT_FOUND', `Unknown help topic: ${topic}. Available topics: ${Object.keys(HELP_TOPICS).join(', ')}`);
572
- }
573
- return {
574
- success: true,
575
- data: {
576
- content: [
577
- 'CLEO Task Management System',
578
- '',
579
- 'Essential Commands:',
580
- ' ct find "query" - Fuzzy search tasks',
581
- ' ct show T1234 - Full task details',
582
- ' ct add "Task" - Create task',
583
- ' ct done <id> - Complete task',
584
- ' ct start <id> - Start working on task',
585
- ' ct dash - Project overview',
586
- ' ct session list - List sessions',
587
- '',
588
- 'Help Topics: session, tasks, focus, labels, compliance',
589
- ].join('\n'),
590
- relatedCommands: ['ct find', 'ct show', 'ct add', 'ct done', 'ct dash'],
591
- },
592
- };
593
- }
594
- // ===== Roadmap =====
595
- /**
596
- * Generate roadmap from pending epics and optional CHANGELOG history.
597
- * @task T4631
598
- */
599
- export async function systemRoadmap(projectRoot, params) {
600
- try {
601
- const accessor = await getAccessor(projectRoot);
602
- const result = await getRoadmap({
603
- includeHistory: params?.includeHistory,
604
- upcomingOnly: params?.upcomingOnly,
605
- cwd: projectRoot,
606
- }, accessor);
607
- return { success: true, data: result };
608
- }
609
- catch (err) {
610
- return engineError('E_NOT_INITIALIZED', err.message);
611
- }
612
- }
613
- // ===== Compliance =====
614
- /**
615
- * System compliance report from COMPLIANCE.jsonl.
616
- * @task T4631
617
- */
618
- export function systemCompliance(projectRoot, params) {
619
- try {
620
- if (params?.subcommand === 'trend') {
621
- const compliancePath = join(projectRoot, '.cleo', 'metrics', 'COMPLIANCE.jsonl');
622
- let entries = [];
623
- if (existsSync(compliancePath)) {
624
- const content = readFileSync(compliancePath, 'utf-8').trim();
625
- if (content) {
626
- entries = content
627
- .split('\n')
628
- .filter((l) => l.trim())
629
- .map((l) => JSON.parse(l));
630
- }
631
- }
632
- if (params.epic) {
633
- entries = entries.filter((e) => {
634
- const ctx = (e._context ?? {});
635
- return ctx.epic_id === params.epic || ctx.task_id === params.epic;
636
- });
637
- }
638
- if (params.days) {
639
- const cutoff = new Date(Date.now() - params.days * 86400000).toISOString();
640
- entries = entries.filter((e) => e.timestamp >= cutoff);
641
- }
642
- const totalEntries = entries.length;
643
- const compliance = entries.map((e) => (e.compliance ?? {}));
644
- const avgPassRate = totalEntries > 0
645
- ? Math.round((compliance.reduce((sum, c) => sum + (c.compliance_pass_rate ?? 0), 0) /
646
- totalEntries) *
647
- 1000) / 1000
648
- : 0;
649
- const avgAdherence = totalEntries > 0
650
- ? Math.round((compliance.reduce((sum, c) => sum + (c.rule_adherence_score ?? 0), 0) /
651
- totalEntries) *
652
- 1000) / 1000
653
- : 0;
654
- const totalViolations = compliance.reduce((sum, c) => sum + (c.violation_count ?? 0), 0);
655
- const byDate = {};
656
- for (const e of entries) {
657
- const date = e.timestamp.split('T')[0];
658
- if (!byDate[date])
659
- byDate[date] = [];
660
- byDate[date].push(e);
661
- }
662
- const dataPoints = Object.entries(byDate)
663
- .sort(([a], [b]) => a.localeCompare(b))
664
- .map(([date, dayEntries]) => {
665
- const dayCompliance = dayEntries.map((de) => (de.compliance ?? {}));
666
- return {
667
- date,
668
- entries: dayEntries.length,
669
- avgPassRate: dayCompliance.reduce((s, c) => s + (c.compliance_pass_rate ?? 0), 0) /
670
- dayEntries.length,
671
- violations: dayCompliance.reduce((s, c) => s + (c.violation_count ?? 0), 0),
672
- };
673
- });
674
- let trend;
675
- if (dataPoints.length >= 2) {
676
- const first = dataPoints[0].avgPassRate;
677
- const last = dataPoints[dataPoints.length - 1].avgPassRate;
678
- trend = last > first ? 'improving' : last < first ? 'declining' : 'stable';
679
- }
680
- else {
681
- trend = 'insufficient_data';
682
- }
683
- return {
684
- success: true,
685
- data: {
686
- totalEntries,
687
- averagePassRate: avgPassRate,
688
- averageAdherence: avgAdherence,
689
- totalViolations,
690
- trend,
691
- dataPoints,
692
- },
693
- };
694
- }
695
- // Default: summary (possibly filtered by epic/days)
696
- const compliancePath = join(projectRoot, '.cleo', 'metrics', 'COMPLIANCE.jsonl');
697
- let entries = [];
698
- if (existsSync(compliancePath)) {
699
- const content = readFileSync(compliancePath, 'utf-8').trim();
700
- if (content) {
701
- entries = content
702
- .split('\n')
703
- .filter((l) => l.trim())
704
- .map((l) => JSON.parse(l));
705
- }
706
- }
707
- if (params?.epic) {
708
- entries = entries.filter((e) => {
709
- const ctx = (e._context ?? {});
710
- return ctx.epic_id === params.epic || ctx.task_id === params.epic;
711
- });
712
- }
713
- if (params?.days) {
714
- const cutoff = new Date(Date.now() - params.days * 86400000).toISOString();
715
- entries = entries.filter((e) => e.timestamp >= cutoff);
716
- }
717
- const totalEntries = entries.length;
718
- const compliance = entries.map((e) => (e.compliance ?? {}));
719
- const avgPassRate = totalEntries > 0
720
- ? Math.round((compliance.reduce((sum, c) => sum + (c.compliance_pass_rate ?? 0), 0) /
721
- totalEntries) *
722
- 1000) / 1000
723
- : 0;
724
- const avgAdherence = totalEntries > 0
725
- ? Math.round((compliance.reduce((sum, c) => sum + (c.rule_adherence_score ?? 0), 0) /
726
- totalEntries) *
727
- 1000) / 1000
728
- : 0;
729
- const totalViolations = compliance.reduce((sum, c) => sum + (c.violation_count ?? 0), 0);
730
- return {
731
- success: true,
732
- data: {
733
- totalEntries,
734
- averagePassRate: avgPassRate,
735
- averageAdherence: avgAdherence,
736
- totalViolations,
737
- },
738
- };
739
- }
740
- catch (err) {
741
- return engineError('E_GENERAL', err.message);
742
- }
743
- }
744
- // ===== Backup =====
745
- /**
746
- * Create a backup of CLEO data files.
747
- * @task T4631
748
- */
749
- export function systemBackup(projectRoot, params) {
750
- try {
751
- const result = createBackup(projectRoot, params);
752
- return { success: true, data: result };
753
- }
754
- catch (err) {
755
- return engineError('E_GENERAL', err.message);
756
- }
757
- }
758
- /**
759
- * List available system backups (read-only).
760
- * @task T4783
761
- */
762
- export function systemListBackups(projectRoot) {
763
- try {
764
- const result = listSystemBackups(projectRoot);
765
- return { success: true, data: result };
766
- }
767
- catch (err) {
768
- return engineError('E_GENERAL', err.message);
769
- }
770
- }
771
- // ===== Restore =====
772
- /**
773
- * Restore from a backup.
774
- * @task T4631
775
- */
776
- export function systemRestore(projectRoot, params) {
777
- try {
778
- const result = restoreBackup(projectRoot, params);
779
- return { success: true, data: result };
780
- }
781
- catch (err) {
782
- const code = err.code ?? 'E_RESTORE_FAILED';
783
- return engineError(code, err.message);
784
- }
785
- }
786
- /**
787
- * Restore an individual file from backup.
788
- * @task T5329
789
- */
790
- export async function backupRestore(projectRoot, fileName, options) {
791
- try {
792
- const { getBackupDir, getTaskPath, getConfigPath } = await import('@cleocode/core/internal');
793
- const { restoreFromBackup, listBackups } = await import('@cleocode/core/internal');
794
- const backupDir = getBackupDir(projectRoot);
795
- const targetPathMap = {
796
- 'tasks.db': getTaskPath,
797
- 'config.json': getConfigPath,
798
- };
799
- const pathGetter = targetPathMap[fileName];
800
- if (!pathGetter) {
801
- return engineError('E_INVALID_INPUT', `Unknown file: ${fileName}. Valid files: tasks.db, config.json`);
802
- }
803
- const targetPath = pathGetter();
804
- const backups = await listBackups(fileName, backupDir);
805
- if (backups.length === 0) {
806
- return engineError('E_NOT_FOUND', `No backups found for ${fileName}`);
807
- }
808
- if (options?.dryRun) {
809
- return {
810
- success: true,
811
- data: {
812
- restored: false,
813
- file: fileName,
814
- from: backups[0],
815
- targetPath,
816
- dryRun: true,
817
- },
818
- };
819
- }
820
- const restoredFrom = await restoreFromBackup(fileName, backupDir, targetPath);
821
- return {
822
- success: true,
823
- data: {
824
- restored: true,
825
- file: fileName,
826
- from: restoredFrom,
827
- targetPath,
828
- },
829
- };
830
- }
831
- catch (err) {
832
- const message = err instanceof Error ? err.message : String(err);
833
- if (message.includes('not found') || message.includes('No backups')) {
834
- return engineError('E_NOT_FOUND', message);
835
- }
836
- return engineError('E_GENERAL', `Backup restore failed: ${message}`);
837
- }
838
- }
839
- // ===== Migrate =====
840
- /**
841
- * Check/run schema migrations.
842
- * @task T4631
843
- */
844
- export async function systemMigrate(projectRoot, params) {
845
- try {
846
- const result = await getMigrationStatus(projectRoot, params);
847
- return { success: true, data: result };
848
- }
849
- catch (err) {
850
- const code = err.code ?? 'E_MIGRATE_FAILED';
851
- return engineError(code, err.message);
852
- }
853
- }
854
- // ===== Cleanup =====
855
- /**
856
- * Cleanup stale data (sessions, backups, logs).
857
- * @task T4631
858
- */
859
- export async function systemCleanup(projectRoot, params) {
860
- try {
861
- const result = await cleanupSystem(projectRoot, params);
862
- return { success: true, data: result };
863
- }
864
- catch (err) {
865
- const code = err.code ?? 'E_CLEANUP_FAILED';
866
- return engineError(code, err.message);
867
- }
868
- }
869
- // ===== Audit =====
870
- /**
871
- * Audit data integrity.
872
- * @task T4631
873
- */
874
- export async function systemAudit(projectRoot, params) {
875
- try {
876
- const result = await auditData(projectRoot, params);
877
- return { success: true, data: result };
878
- }
879
- catch (err) {
880
- return engineError('E_GENERAL', err.message);
881
- }
882
- }
883
- /**
884
- * Sync check (no external sync targets in native mode).
885
- * @task T4631
886
- */
887
- export function systemSync(_projectRoot, params) {
888
- return {
889
- success: true,
890
- data: {
891
- direction: params?.direction ?? 'up',
892
- synced: 0,
893
- conflicts: 0,
894
- message: 'Sync is a no-op in native mode (no external sync targets configured)',
895
- },
896
- };
897
- }
898
- // ===== Safestop =====
899
- /**
900
- * Safe stop: signal clean shutdown for agents.
901
- * @task T4631
902
- */
903
- export function systemSafestop(projectRoot, params) {
904
- try {
905
- const result = safestop(projectRoot, params);
906
- return { success: true, data: result };
907
- }
908
- catch (err) {
909
- return engineError('E_GENERAL', err.message);
910
- }
911
- }
912
- // ===== Uncancel =====
913
- /**
914
- * Uncancel a cancelled task (restore to pending).
915
- * @task T4631
916
- */
917
- export async function systemUncancel(projectRoot, params) {
918
- try {
919
- const result = await uncancelTask(projectRoot, params);
920
- return { success: true, data: result };
921
- }
922
- catch (err) {
923
- const code = err.code ?? 'E_UNCANCEL_FAILED';
924
- return engineError(code, err.message);
925
- }
926
- }
927
- // ===== Doctor Report =====
928
- /**
929
- * Run comprehensive doctor diagnostics.
930
- * @task T4795
931
- */
932
- export async function systemDoctor(projectRoot) {
933
- const { coreDoctorReport } = await import('@cleocode/core/internal');
934
- try {
935
- const result = await coreDoctorReport(projectRoot);
936
- return { success: true, data: result };
937
- }
938
- catch (err) {
939
- return engineError('E_GENERAL', err.message);
940
- }
941
- }
942
- // ===== Doctor Fix =====
943
- /**
944
- * Run auto-fix for failed doctor checks.
945
- * @task T4795
946
- */
947
- export async function systemFix(projectRoot) {
948
- const { runDoctorFixes } = await import('@cleocode/core/internal');
949
- try {
950
- const result = await runDoctorFixes(projectRoot);
951
- return { success: true, data: result };
952
- }
953
- catch (err) {
954
- return engineError('E_GENERAL', err.message);
955
- }
956
- }
957
- /**
958
- * Runtime/channel diagnostics for CLI/MCP installation mode checks.
959
- * @task T4815
960
- */
961
- export async function systemRuntime(_projectRoot, params) {
962
- try {
963
- const data = await getRuntimeDiagnostics({ detailed: params?.detailed ?? false });
964
- return { success: true, data };
965
- }
966
- catch (err) {
967
- return engineError('E_RUNTIME_ERROR', err.message);
968
- }
969
- }
970
- /**
971
- * Repair task ID sequence using canonical core implementation.
972
- * @task T4815
973
- */
974
- export async function systemSequenceRepair(projectRoot) {
975
- try {
976
- const repair = await repairSequence(projectRoot);
977
- return {
978
- success: true,
979
- data: {
980
- repaired: repair.repaired,
981
- message: repair.message,
982
- counter: repair.counter,
983
- oldCounter: repair.oldCounter,
984
- newCounter: repair.newCounter,
985
- },
986
- };
987
- }
988
- catch (err) {
989
- return engineError('E_SEQUENCE_REPAIR_FAILED', err.message);
990
- }
991
- }
992
- /**
993
- * Smoke-test definitions: one lightweight read-only query per domain.
994
- * Each probe exercises the full dispatch pipeline (middleware, handler, engine, core).
995
- */
996
- const SMOKE_PROBES = [
997
- { domain: 'admin', operation: 'version' },
998
- { domain: 'tasks', operation: 'find', params: { query: '__smoke_probe__', limit: 1 } },
999
- { domain: 'session', operation: 'status' },
1000
- { domain: 'memory', operation: 'find', params: { query: '__smoke_probe__' } },
1001
- { domain: 'pipeline', operation: 'list' },
1002
- { domain: 'check', operation: 'schema' },
1003
- { domain: 'tools', operation: 'list', params: { limit: 1 } },
1004
- { domain: 'sticky', operation: 'list', params: { limit: 1 } },
1005
- { domain: 'nexus', operation: 'status' },
1006
- { domain: 'orchestrate', operation: 'status' },
1007
- ];
1008
- /**
1009
- * Run operational smoke tests across all domains.
1010
- *
1011
- * Dispatches one read-only query per domain through the full CLI dispatch
1012
- * pipeline and reports pass/fail with timing. Catches crashes (TypeError,
1013
- * ReferenceError, etc.) not just structured error responses.
1014
- *
1015
- * @task T130
1016
- */
1017
- export async function systemSmoke() {
1018
- const { dispatchRaw } = await import('../adapters/cli.js');
1019
- const totalStart = Date.now();
1020
- const probes = [];
1021
- for (const probe of SMOKE_PROBES) {
1022
- const start = Date.now();
1023
- try {
1024
- const response = await dispatchRaw('query', probe.domain, probe.operation, probe.params);
1025
- const elapsed = Date.now() - start;
1026
- if (response.success) {
1027
- probes.push({
1028
- domain: probe.domain,
1029
- operation: probe.operation,
1030
- status: 'pass',
1031
- timeMs: elapsed,
1032
- });
1033
- }
1034
- else {
1035
- // Structured error responses that are domain-specific (like "no session") are still valid
1036
- // operational results — the dispatch pipeline worked. Only treat E_INTERNAL / E_NO_HANDLER as failures.
1037
- const code = response.error?.code ?? '';
1038
- const isCrash = code === 'E_INTERNAL' || code === 'E_NO_HANDLER';
1039
- probes.push({
1040
- domain: probe.domain,
1041
- operation: probe.operation,
1042
- status: isCrash ? 'fail' : 'pass',
1043
- timeMs: elapsed,
1044
- ...(isCrash ? { error: response.error?.message } : {}),
1045
- });
1046
- }
1047
- }
1048
- catch (err) {
1049
- const elapsed = Date.now() - start;
1050
- probes.push({
1051
- domain: probe.domain,
1052
- operation: probe.operation,
1053
- status: 'fail',
1054
- timeMs: elapsed,
1055
- error: err instanceof Error ? `${err.constructor.name}: ${err.message}` : String(err),
1056
- });
1057
- }
1058
- }
1059
- // --- DB connectivity and migration state checks ---
1060
- const dbChecks = [];
1061
- // tasks.db connectivity + integrity
1062
- {
1063
- const start = Date.now();
1064
- try {
1065
- const { getDb, getNativeDb } = await import('@cleocode/core/internal');
1066
- const projectRoot = (await import('@cleocode/core/internal')).getProjectRoot();
1067
- await getDb(projectRoot);
1068
- const nativeDb = getNativeDb();
1069
- if (nativeDb) {
1070
- const result = nativeDb.prepare('PRAGMA integrity_check').get();
1071
- const ok = result?.integrity_check === 'ok';
1072
- dbChecks.push({
1073
- domain: 'db',
1074
- operation: 'tasks.db',
1075
- status: ok ? 'pass' : 'fail',
1076
- timeMs: Date.now() - start,
1077
- ...(!ok ? { error: 'SQLite integrity check failed' } : {}),
1078
- });
1079
- }
1080
- else {
1081
- dbChecks.push({
1082
- domain: 'db',
1083
- operation: 'tasks.db',
1084
- status: 'fail',
1085
- timeMs: Date.now() - start,
1086
- error: 'Native DB handle unavailable',
1087
- });
1088
- }
1089
- }
1090
- catch (err) {
1091
- dbChecks.push({
1092
- domain: 'db',
1093
- operation: 'tasks.db',
1094
- status: 'fail',
1095
- timeMs: Date.now() - start,
1096
- error: err instanceof Error ? err.message : String(err),
1097
- });
1098
- }
1099
- }
1100
- // brain.db connectivity
1101
- {
1102
- const start = Date.now();
1103
- try {
1104
- const { getBrainDb } = await import('@cleocode/core/internal');
1105
- const projectRoot = (await import('@cleocode/core/internal')).getProjectRoot();
1106
- const brainDb = await getBrainDb(projectRoot);
1107
- if (brainDb) {
1108
- dbChecks.push({
1109
- domain: 'db',
1110
- operation: 'brain.db',
1111
- status: 'pass',
1112
- timeMs: Date.now() - start,
1113
- });
1114
- }
1115
- else {
1116
- dbChecks.push({
1117
- domain: 'db',
1118
- operation: 'brain.db',
1119
- status: 'fail',
1120
- timeMs: Date.now() - start,
1121
- error: 'brain.db not initialized',
1122
- });
1123
- }
1124
- }
1125
- catch (err) {
1126
- dbChecks.push({
1127
- domain: 'db',
1128
- operation: 'brain.db',
1129
- status: 'fail',
1130
- timeMs: Date.now() - start,
1131
- error: err instanceof Error ? err.message : String(err),
1132
- });
1133
- }
1134
- }
1135
- // Migration state validation (detect stale journals)
1136
- {
1137
- const start = Date.now();
1138
- try {
1139
- const migrationStatus = await getMigrationStatus((await import('@cleocode/core/internal')).getProjectRoot());
1140
- const hasPending = migrationStatus.migrations.some((m) => !m.applied);
1141
- dbChecks.push({
1142
- domain: 'db',
1143
- operation: 'migrations',
1144
- status: hasPending ? 'fail' : 'pass',
1145
- timeMs: Date.now() - start,
1146
- ...(hasPending
1147
- ? { error: `Unapplied migrations detected (${migrationStatus.from} → ${migrationStatus.to}). Run: cleo upgrade` }
1148
- : {}),
1149
- });
1150
- }
1151
- catch (err) {
1152
- dbChecks.push({
1153
- domain: 'db',
1154
- operation: 'migrations',
1155
- status: 'fail',
1156
- timeMs: Date.now() - start,
1157
- error: err instanceof Error ? err.message : String(err),
1158
- });
1159
- }
1160
- }
1161
- const allProbes = [...probes, ...dbChecks];
1162
- const totalMs = Date.now() - totalStart;
1163
- const passed = allProbes.filter((p) => p.status === 'pass').length;
1164
- const failed = allProbes.filter((p) => p.status === 'fail').length;
1165
- const skipped = allProbes.filter((p) => p.status === 'skip').length;
1166
- return {
1167
- success: failed === 0,
1168
- data: { probes, dbChecks, passed, failed, skipped, totalMs },
1169
- ...(failed > 0
1170
- ? {
1171
- error: {
1172
- code: 'E_SMOKE_FAILURES',
1173
- message: `${failed} probe(s) failed smoke test`,
1174
- exitCode: 1,
1175
- },
1176
- }
1177
- : {}),
1178
- };
1179
- }
1180
- //# sourceMappingURL=system-engine.js.map