@cleocode/core 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 (1087) hide show
  1. package/README.md +1 -1
  2. package/dist/cant/approval.d.ts +110 -0
  3. package/dist/cant/approval.d.ts.map +1 -0
  4. package/dist/cant/context-builder.d.ts +79 -0
  5. package/dist/cant/context-builder.d.ts.map +1 -0
  6. package/dist/cant/discretion.d.ts +95 -0
  7. package/dist/cant/discretion.d.ts.map +1 -0
  8. package/dist/cant/index.d.ts +25 -0
  9. package/dist/cant/index.d.ts.map +1 -0
  10. package/dist/cant/parallel-runner.d.ts +38 -0
  11. package/dist/cant/parallel-runner.d.ts.map +1 -0
  12. package/dist/cant/types.d.ts +127 -0
  13. package/dist/cant/types.d.ts.map +1 -0
  14. package/dist/cant/workflow-executor.d.ts +105 -0
  15. package/dist/cant/workflow-executor.d.ts.map +1 -0
  16. package/dist/conduit/conduit-client.d.ts +26 -0
  17. package/dist/conduit/conduit-client.d.ts.map +1 -0
  18. package/dist/conduit/factory.d.ts +13 -0
  19. package/dist/conduit/factory.d.ts.map +1 -0
  20. package/dist/conduit/http-transport.d.ts +32 -0
  21. package/dist/conduit/http-transport.d.ts.map +1 -0
  22. package/dist/conduit/index.d.ts +12 -0
  23. package/dist/conduit/index.d.ts.map +1 -0
  24. package/dist/crypto/credentials.d.ts +40 -0
  25. package/dist/crypto/credentials.d.ts.map +1 -0
  26. package/dist/engine-result.d.ts +1 -1
  27. package/dist/engine-result.d.ts.map +1 -1
  28. package/dist/error-catalog.d.ts +1 -1
  29. package/dist/error-catalog.d.ts.map +1 -1
  30. package/dist/error-registry.d.ts +1 -1
  31. package/dist/error-registry.d.ts.map +1 -1
  32. package/dist/errors.d.ts +1 -1
  33. package/dist/errors.d.ts.map +1 -1
  34. package/dist/hooks/handlers/agent-hooks.d.ts.map +1 -1
  35. package/dist/hooks/handlers/context-hooks.d.ts.map +1 -1
  36. package/dist/hooks/handlers/error-hooks.d.ts +14 -5
  37. package/dist/hooks/handlers/error-hooks.d.ts.map +1 -1
  38. package/dist/hooks/handlers/file-hooks.d.ts.map +1 -1
  39. package/dist/hooks/handlers/handler-helpers.d.ts +41 -0
  40. package/dist/hooks/handlers/handler-helpers.d.ts.map +1 -0
  41. package/dist/hooks/handlers/mcp-hooks.d.ts.map +1 -1
  42. package/dist/hooks/handlers/session-hooks.d.ts.map +1 -1
  43. package/dist/hooks/handlers/task-hooks.d.ts.map +1 -1
  44. package/dist/hooks/handlers/work-capture-hooks.d.ts.map +1 -1
  45. package/dist/index.d.ts +3 -1
  46. package/dist/index.d.ts.map +1 -1
  47. package/dist/index.js +2285 -767
  48. package/dist/index.js.map +4 -4
  49. package/dist/init.d.ts.map +1 -1
  50. package/dist/internal.d.ts +7 -0
  51. package/dist/internal.d.ts.map +1 -1
  52. package/dist/memory/brain-retrieval.d.ts +3 -0
  53. package/dist/memory/brain-retrieval.d.ts.map +1 -1
  54. package/dist/mvi-helpers.d.ts +52 -0
  55. package/dist/mvi-helpers.d.ts.map +1 -0
  56. package/dist/nexus/workspace.d.ts.map +1 -1
  57. package/dist/output.d.ts +2 -2
  58. package/dist/output.d.ts.map +1 -1
  59. package/dist/pagination.d.ts +1 -1
  60. package/dist/pagination.d.ts.map +1 -1
  61. package/dist/sessions/find.d.ts +3 -0
  62. package/dist/sessions/find.d.ts.map +1 -1
  63. package/dist/sessions/index.d.ts.map +1 -1
  64. package/dist/store/agent-registry-accessor.d.ts +454 -0
  65. package/dist/store/agent-registry-accessor.d.ts.map +1 -0
  66. package/dist/store/converters.d.ts.map +1 -1
  67. package/dist/store/db-helpers.d.ts.map +1 -1
  68. package/dist/store/safety-data-accessor.d.ts +7 -0
  69. package/dist/store/safety-data-accessor.d.ts.map +1 -1
  70. package/dist/store/signaldock-sqlite.d.ts +48 -0
  71. package/dist/store/signaldock-sqlite.d.ts.map +1 -0
  72. package/dist/store/sqlite-data-accessor.d.ts.map +1 -1
  73. package/dist/store/sqlite.d.ts.map +1 -1
  74. package/dist/store/task-store.d.ts.map +1 -1
  75. package/dist/store/tasks-schema.d.ts +240 -0
  76. package/dist/store/tasks-schema.d.ts.map +1 -1
  77. package/dist/store/validation-schemas.d.ts +32 -0
  78. package/dist/store/validation-schemas.d.ts.map +1 -1
  79. package/dist/system/health.d.ts.map +1 -1
  80. package/dist/task-work/index.d.ts.map +1 -1
  81. package/dist/tasks/find.d.ts +3 -0
  82. package/dist/tasks/find.d.ts.map +1 -1
  83. package/dist/tasks/list.d.ts +5 -2
  84. package/dist/tasks/list.d.ts.map +1 -1
  85. package/dist/tasks/show.d.ts +3 -0
  86. package/dist/tasks/show.d.ts.map +1 -1
  87. package/dist/upgrade.d.ts.map +1 -1
  88. package/migrations/drizzle-tasks/20260324000000_assignee-column/migration.sql +6 -0
  89. package/migrations/drizzle-tasks/20260324000000_assignee-column/snapshot.json +9 -0
  90. package/migrations/drizzle-tasks/20260327000000_agent-credentials/migration.sql +23 -0
  91. package/package.json +7 -7
  92. package/src/__tests__/cli-parity.test.js +11 -1
  93. package/src/__tests__/cli-parity.test.js.map +1 -1
  94. package/src/__tests__/cli-parity.test.ts +17 -1
  95. package/src/__tests__/human-output.test.js +11 -1
  96. package/src/__tests__/human-output.test.js.map +1 -1
  97. package/src/__tests__/human-output.test.ts +18 -1
  98. package/src/__tests__/injection-chain.test.js +3 -2
  99. package/src/__tests__/injection-chain.test.js.map +1 -1
  100. package/src/__tests__/injection-mvi-tiers.test.d.ts +2 -2
  101. package/src/__tests__/injection-mvi-tiers.test.js +15 -15
  102. package/src/__tests__/injection-mvi-tiers.test.js.map +1 -1
  103. package/src/__tests__/lafs-conformance.test.d.ts +1 -1
  104. package/src/__tests__/lafs-conformance.test.js +2 -2
  105. package/src/__tests__/sharing.test.js +19 -0
  106. package/src/__tests__/sharing.test.js.map +1 -1
  107. package/src/agents/__tests__/agent-registry.test.d.ts +12 -0
  108. package/src/agents/__tests__/agent-registry.test.d.ts.map +1 -0
  109. package/src/agents/__tests__/agent-registry.test.js +262 -0
  110. package/src/agents/__tests__/agent-registry.test.js.map +1 -0
  111. package/src/agents/__tests__/execution-learning.test.d.ts +14 -0
  112. package/src/agents/__tests__/execution-learning.test.d.ts.map +1 -0
  113. package/src/agents/__tests__/execution-learning.test.js +533 -0
  114. package/src/agents/__tests__/execution-learning.test.js.map +1 -0
  115. package/src/agents/__tests__/health-monitor.test.d.ts +10 -0
  116. package/src/agents/__tests__/health-monitor.test.d.ts.map +1 -0
  117. package/src/agents/__tests__/health-monitor.test.js +259 -0
  118. package/src/agents/__tests__/health-monitor.test.js.map +1 -0
  119. package/src/agents/__tests__/registry.test.js +27 -2
  120. package/src/agents/__tests__/registry.test.js.map +1 -1
  121. package/src/cant/__tests__/cant-agent-parse.test.ts +94 -0
  122. package/src/cant/approval.ts +218 -0
  123. package/src/cant/context-builder.ts +135 -0
  124. package/src/cant/discretion.ts +149 -0
  125. package/src/cant/index.ts +58 -0
  126. package/src/cant/parallel-runner.ts +205 -0
  127. package/src/cant/types.ts +158 -0
  128. package/src/cant/workflow-executor.ts +618 -0
  129. package/src/conduit/conduit-client.ts +114 -0
  130. package/src/conduit/factory.ts +45 -0
  131. package/src/conduit/http-transport.ts +140 -0
  132. package/src/conduit/index.ts +12 -0
  133. package/src/crypto/credentials.ts +166 -0
  134. package/src/engine-result.ts +1 -1
  135. package/src/error-catalog.ts +1 -1
  136. package/src/error-registry.ts +1 -1
  137. package/src/errors.ts +1 -1
  138. package/src/hooks/handlers/__tests__/hook-automation-e2e.test.d.ts +13 -0
  139. package/src/hooks/handlers/__tests__/hook-automation-e2e.test.d.ts.map +1 -0
  140. package/src/hooks/handlers/__tests__/hook-automation-e2e.test.js +501 -0
  141. package/src/hooks/handlers/__tests__/hook-automation-e2e.test.js.map +1 -0
  142. package/src/hooks/handlers/agent-hooks.ts +1 -30
  143. package/src/hooks/handlers/context-hooks.ts +1 -30
  144. package/src/hooks/handlers/error-hooks.ts +14 -5
  145. package/src/hooks/handlers/file-hooks.ts +1 -6
  146. package/src/hooks/handlers/handler-helpers.ts +62 -0
  147. package/src/hooks/handlers/mcp-hooks.ts +2 -14
  148. package/src/hooks/handlers/session-hooks.ts +1 -6
  149. package/src/hooks/handlers/task-hooks.ts +1 -6
  150. package/src/hooks/handlers/work-capture-hooks.ts +1 -10
  151. package/src/index.ts +11 -1
  152. package/src/init.ts +12 -0
  153. package/src/intelligence/__tests__/adaptive-validation.test.d.ts +11 -0
  154. package/src/intelligence/__tests__/adaptive-validation.test.d.ts.map +1 -0
  155. package/src/intelligence/__tests__/adaptive-validation.test.js +517 -0
  156. package/src/intelligence/__tests__/adaptive-validation.test.js.map +1 -0
  157. package/src/intelligence/__tests__/impact.test.d.ts +1 -0
  158. package/src/intelligence/__tests__/impact.test.d.ts.map +1 -1
  159. package/src/intelligence/__tests__/impact.test.js +132 -1
  160. package/src/intelligence/__tests__/impact.test.js.map +1 -1
  161. package/src/internal.ts +17 -0
  162. package/src/lib/__tests__/retry.test.d.ts +7 -0
  163. package/src/lib/__tests__/retry.test.d.ts.map +1 -0
  164. package/src/lib/__tests__/retry.test.js +225 -0
  165. package/src/lib/__tests__/retry.test.js.map +1 -0
  166. package/src/lifecycle/__tests__/chain-store.test.js +6 -0
  167. package/src/lifecycle/__tests__/chain-store.test.js.map +1 -1
  168. package/src/lifecycle/__tests__/tessera-engine.test.js +52 -0
  169. package/src/lifecycle/__tests__/tessera-engine.test.js.map +1 -1
  170. package/src/memory/__tests__/brain-automation.test.d.ts +11 -0
  171. package/src/memory/__tests__/brain-automation.test.d.ts.map +1 -0
  172. package/src/memory/__tests__/brain-automation.test.js +730 -0
  173. package/src/memory/__tests__/brain-automation.test.js.map +1 -0
  174. package/src/memory/brain-retrieval.ts +9 -0
  175. package/src/mvi-helpers.ts +81 -0
  176. package/src/nexus/workspace.ts +19 -7
  177. package/src/output.ts +43 -10
  178. package/src/pagination.ts +1 -1
  179. package/src/sessions/__tests__/session-edge-cases.test.js +20 -1
  180. package/src/sessions/__tests__/session-edge-cases.test.js.map +1 -1
  181. package/src/sessions/__tests__/session-find.test.js +1 -1
  182. package/src/sessions/__tests__/session-find.test.js.map +1 -1
  183. package/src/sessions/__tests__/session-find.test.ts +1 -1
  184. package/src/sessions/find.ts +6 -1
  185. package/src/sessions/index.ts +9 -0
  186. package/src/store/__tests__/migration-safety.test.js +3 -0
  187. package/src/store/__tests__/migration-safety.test.js.map +1 -1
  188. package/src/store/__tests__/session-store.test.js +128 -1
  189. package/src/store/__tests__/session-store.test.js.map +1 -1
  190. package/src/store/__tests__/task-store.test.js +18 -1
  191. package/src/store/__tests__/task-store.test.js.map +1 -1
  192. package/src/store/__tests__/test-db-helper.d.ts.map +1 -1
  193. package/src/store/__tests__/test-db-helper.js +12 -0
  194. package/src/store/__tests__/test-db-helper.js.map +1 -1
  195. package/src/store/agent-registry-accessor.ts +199 -0
  196. package/src/store/converters.ts +2 -0
  197. package/src/store/db-helpers.ts +1 -0
  198. package/src/store/safety-data-accessor.ts +23 -0
  199. package/src/store/signaldock-sqlite.ts +227 -0
  200. package/src/store/sqlite-data-accessor.ts +69 -0
  201. package/src/store/sqlite.ts +4 -1
  202. package/src/store/task-store.ts +1 -0
  203. package/src/store/tasks-schema.ts +42 -0
  204. package/src/system/health.ts +33 -0
  205. package/src/task-work/index.ts +5 -0
  206. package/src/tasks/__tests__/add.test.js +19 -1
  207. package/src/tasks/__tests__/add.test.js.map +1 -1
  208. package/src/tasks/__tests__/assignee.test.d.ts +14 -0
  209. package/src/tasks/__tests__/assignee.test.d.ts.map +1 -0
  210. package/src/tasks/__tests__/assignee.test.js +125 -0
  211. package/src/tasks/__tests__/assignee.test.js.map +1 -0
  212. package/src/tasks/__tests__/assignee.test.ts +162 -0
  213. package/src/tasks/__tests__/complete-unblocks.test.js +13 -1
  214. package/src/tasks/__tests__/complete-unblocks.test.js.map +1 -1
  215. package/src/tasks/__tests__/complete.test.js +28 -7
  216. package/src/tasks/__tests__/complete.test.js.map +1 -1
  217. package/src/tasks/__tests__/epic-enforcement.test.d.ts +15 -0
  218. package/src/tasks/__tests__/epic-enforcement.test.d.ts.map +1 -0
  219. package/src/tasks/__tests__/epic-enforcement.test.js +669 -0
  220. package/src/tasks/__tests__/epic-enforcement.test.js.map +1 -0
  221. package/src/tasks/__tests__/hierarchy-policy.test.js +5 -0
  222. package/src/tasks/__tests__/hierarchy-policy.test.js.map +1 -1
  223. package/src/tasks/__tests__/minimal-test.test.d.ts +2 -0
  224. package/src/tasks/__tests__/minimal-test.test.d.ts.map +1 -0
  225. package/src/tasks/__tests__/minimal-test.test.js +25 -0
  226. package/src/tasks/__tests__/minimal-test.test.js.map +1 -0
  227. package/src/tasks/__tests__/pipeline-stage.test.d.ts +14 -0
  228. package/src/tasks/__tests__/pipeline-stage.test.d.ts.map +1 -0
  229. package/src/tasks/__tests__/pipeline-stage.test.js +277 -0
  230. package/src/tasks/__tests__/pipeline-stage.test.js.map +1 -0
  231. package/src/tasks/__tests__/update.test.js +43 -6
  232. package/src/tasks/__tests__/update.test.js.map +1 -1
  233. package/src/tasks/find.ts +11 -1
  234. package/src/tasks/list.ts +14 -3
  235. package/src/tasks/show.ts +6 -0
  236. package/src/upgrade.ts +16 -0
  237. package/dist/adapters/adapter-registry.js +0 -64
  238. package/dist/adapters/adapter-registry.js.map +0 -1
  239. package/dist/adapters/discovery.js +0 -83
  240. package/dist/adapters/discovery.js.map +0 -1
  241. package/dist/adapters/index.js +0 -9
  242. package/dist/adapters/index.js.map +0 -1
  243. package/dist/adapters/manager.js +0 -260
  244. package/dist/adapters/manager.js.map +0 -1
  245. package/dist/admin/export-tasks.js +0 -171
  246. package/dist/admin/export-tasks.js.map +0 -1
  247. package/dist/admin/export.js +0 -103
  248. package/dist/admin/export.js.map +0 -1
  249. package/dist/admin/help.js +0 -106
  250. package/dist/admin/help.js.map +0 -1
  251. package/dist/admin/import-tasks.js +0 -182
  252. package/dist/admin/import-tasks.js.map +0 -1
  253. package/dist/admin/import.js +0 -129
  254. package/dist/admin/import.js.map +0 -1
  255. package/dist/admin/index.js +0 -13
  256. package/dist/admin/index.js.map +0 -1
  257. package/dist/adrs/find.js +0 -134
  258. package/dist/adrs/find.js.map +0 -1
  259. package/dist/adrs/index.js +0 -15
  260. package/dist/adrs/index.js.map +0 -1
  261. package/dist/adrs/link-pipeline.js +0 -160
  262. package/dist/adrs/link-pipeline.js.map +0 -1
  263. package/dist/adrs/list.js +0 -43
  264. package/dist/adrs/list.js.map +0 -1
  265. package/dist/adrs/parse.js +0 -51
  266. package/dist/adrs/parse.js.map +0 -1
  267. package/dist/adrs/show.js +0 -22
  268. package/dist/adrs/show.js.map +0 -1
  269. package/dist/adrs/sync.js +0 -188
  270. package/dist/adrs/sync.js.map +0 -1
  271. package/dist/adrs/types.js +0 -9
  272. package/dist/adrs/types.js.map +0 -1
  273. package/dist/adrs/validate.js +0 -57
  274. package/dist/adrs/validate.js.map +0 -1
  275. package/dist/agents/agent-registry.js +0 -288
  276. package/dist/agents/agent-registry.js.map +0 -1
  277. package/dist/agents/agent-schema.js +0 -85
  278. package/dist/agents/agent-schema.js.map +0 -1
  279. package/dist/agents/capacity.js +0 -116
  280. package/dist/agents/capacity.js.map +0 -1
  281. package/dist/agents/execution-learning.js +0 -474
  282. package/dist/agents/execution-learning.js.map +0 -1
  283. package/dist/agents/health-monitor.js +0 -217
  284. package/dist/agents/health-monitor.js.map +0 -1
  285. package/dist/agents/index.js +0 -29
  286. package/dist/agents/index.js.map +0 -1
  287. package/dist/agents/registry.js +0 -314
  288. package/dist/agents/registry.js.map +0 -1
  289. package/dist/agents/retry.js +0 -210
  290. package/dist/agents/retry.js.map +0 -1
  291. package/dist/audit-prune.js +0 -94
  292. package/dist/audit-prune.js.map +0 -1
  293. package/dist/audit.js +0 -68
  294. package/dist/audit.js.map +0 -1
  295. package/dist/backfill/index.js +0 -229
  296. package/dist/backfill/index.js.map +0 -1
  297. package/dist/bootstrap.js +0 -367
  298. package/dist/bootstrap.js.map +0 -1
  299. package/dist/caamp/adapter.js +0 -434
  300. package/dist/caamp/adapter.js.map +0 -1
  301. package/dist/caamp/capability-check.js +0 -38
  302. package/dist/caamp/capability-check.js.map +0 -1
  303. package/dist/caamp/index.js +0 -23
  304. package/dist/caamp/index.js.map +0 -1
  305. package/dist/caamp-init.js +0 -16
  306. package/dist/caamp-init.js.map +0 -1
  307. package/dist/cleo.js +0 -302
  308. package/dist/cleo.js.map +0 -1
  309. package/dist/codebase-map/analyzers/architecture.js +0 -130
  310. package/dist/codebase-map/analyzers/architecture.js.map +0 -1
  311. package/dist/codebase-map/analyzers/concerns.js +0 -122
  312. package/dist/codebase-map/analyzers/concerns.js.map +0 -1
  313. package/dist/codebase-map/analyzers/conventions.js +0 -149
  314. package/dist/codebase-map/analyzers/conventions.js.map +0 -1
  315. package/dist/codebase-map/analyzers/integrations.js +0 -108
  316. package/dist/codebase-map/analyzers/integrations.js.map +0 -1
  317. package/dist/codebase-map/analyzers/stack.js +0 -117
  318. package/dist/codebase-map/analyzers/stack.js.map +0 -1
  319. package/dist/codebase-map/analyzers/structure.js +0 -137
  320. package/dist/codebase-map/analyzers/structure.js.map +0 -1
  321. package/dist/codebase-map/analyzers/testing.js +0 -118
  322. package/dist/codebase-map/analyzers/testing.js.map +0 -1
  323. package/dist/codebase-map/index.js +0 -57
  324. package/dist/codebase-map/index.js.map +0 -1
  325. package/dist/codebase-map/store.js +0 -122
  326. package/dist/codebase-map/store.js.map +0 -1
  327. package/dist/codebase-map/summary.js +0 -152
  328. package/dist/codebase-map/summary.js.map +0 -1
  329. package/dist/compliance/index.js +0 -288
  330. package/dist/compliance/index.js.map +0 -1
  331. package/dist/compliance/protocol-enforcement.js +0 -332
  332. package/dist/compliance/protocol-enforcement.js.map +0 -1
  333. package/dist/compliance/protocol-rules.js +0 -786
  334. package/dist/compliance/protocol-rules.js.map +0 -1
  335. package/dist/compliance/protocol-types.js +0 -80
  336. package/dist/compliance/protocol-types.js.map +0 -1
  337. package/dist/compliance/store.js +0 -53
  338. package/dist/compliance/store.js.map +0 -1
  339. package/dist/config/build-config.js +0 -29
  340. package/dist/config/build-config.js.map +0 -1
  341. package/dist/config.js +0 -400
  342. package/dist/config.js.map +0 -1
  343. package/dist/constants.js +0 -18
  344. package/dist/constants.js.map +0 -1
  345. package/dist/context/index.js +0 -137
  346. package/dist/context/index.js.map +0 -1
  347. package/dist/engine-result.js +0 -12
  348. package/dist/engine-result.js.map +0 -1
  349. package/dist/error-catalog.js +0 -404
  350. package/dist/error-catalog.js.map +0 -1
  351. package/dist/error-registry.js +0 -393
  352. package/dist/error-registry.js.map +0 -1
  353. package/dist/errors.js +0 -167
  354. package/dist/errors.js.map +0 -1
  355. package/dist/hooks/handlers/error-hooks.js +0 -43
  356. package/dist/hooks/handlers/error-hooks.js.map +0 -1
  357. package/dist/hooks/handlers/file-hooks.js +0 -80
  358. package/dist/hooks/handlers/file-hooks.js.map +0 -1
  359. package/dist/hooks/handlers/index.js +0 -19
  360. package/dist/hooks/handlers/index.js.map +0 -1
  361. package/dist/hooks/handlers/mcp-hooks.js +0 -80
  362. package/dist/hooks/handlers/mcp-hooks.js.map +0 -1
  363. package/dist/hooks/handlers/memory-bridge-refresh.js +0 -42
  364. package/dist/hooks/handlers/memory-bridge-refresh.js.map +0 -1
  365. package/dist/hooks/handlers/session-hooks.js +0 -109
  366. package/dist/hooks/handlers/session-hooks.js.map +0 -1
  367. package/dist/hooks/handlers/task-hooks.js +0 -70
  368. package/dist/hooks/handlers/task-hooks.js.map +0 -1
  369. package/dist/hooks/index.js +0 -13
  370. package/dist/hooks/index.js.map +0 -1
  371. package/dist/hooks/payload-schemas.js +0 -163
  372. package/dist/hooks/payload-schemas.js.map +0 -1
  373. package/dist/hooks/provider-hooks.js +0 -34
  374. package/dist/hooks/provider-hooks.js.map +0 -1
  375. package/dist/hooks/registry.js +0 -176
  376. package/dist/hooks/registry.js.map +0 -1
  377. package/dist/hooks/types.js +0 -62
  378. package/dist/hooks/types.js.map +0 -1
  379. package/dist/hooks.js +0 -136
  380. package/dist/hooks.js.map +0 -1
  381. package/dist/init.js +0 -711
  382. package/dist/init.js.map +0 -1
  383. package/dist/inject/index.js +0 -82
  384. package/dist/inject/index.js.map +0 -1
  385. package/dist/injection.js +0 -343
  386. package/dist/injection.js.map +0 -1
  387. package/dist/intelligence/adaptive-validation.js +0 -497
  388. package/dist/intelligence/adaptive-validation.js.map +0 -1
  389. package/dist/intelligence/impact.js +0 -675
  390. package/dist/intelligence/impact.js.map +0 -1
  391. package/dist/intelligence/index.js +0 -22
  392. package/dist/intelligence/index.js.map +0 -1
  393. package/dist/intelligence/patterns.js +0 -492
  394. package/dist/intelligence/patterns.js.map +0 -1
  395. package/dist/intelligence/prediction.js +0 -499
  396. package/dist/intelligence/prediction.js.map +0 -1
  397. package/dist/intelligence/types.js +0 -13
  398. package/dist/intelligence/types.js.map +0 -1
  399. package/dist/internal.js +0 -276
  400. package/dist/internal.js.map +0 -1
  401. package/dist/issue/create.js +0 -121
  402. package/dist/issue/create.js.map +0 -1
  403. package/dist/issue/diagnostics.js +0 -59
  404. package/dist/issue/diagnostics.js.map +0 -1
  405. package/dist/issue/index.js +0 -10
  406. package/dist/issue/index.js.map +0 -1
  407. package/dist/issue/template-parser.js +0 -267
  408. package/dist/issue/template-parser.js.map +0 -1
  409. package/dist/json-schema-validator.js +0 -76
  410. package/dist/json-schema-validator.js.map +0 -1
  411. package/dist/lib/index.js +0 -10
  412. package/dist/lib/index.js.map +0 -1
  413. package/dist/lib/retry.js +0 -152
  414. package/dist/lib/retry.js.map +0 -1
  415. package/dist/lifecycle/chain-composition.js +0 -152
  416. package/dist/lifecycle/chain-composition.js.map +0 -1
  417. package/dist/lifecycle/chain-store.js +0 -246
  418. package/dist/lifecycle/chain-store.js.map +0 -1
  419. package/dist/lifecycle/consolidate-rcasd.js +0 -352
  420. package/dist/lifecycle/consolidate-rcasd.js.map +0 -1
  421. package/dist/lifecycle/default-chain.js +0 -167
  422. package/dist/lifecycle/default-chain.js.map +0 -1
  423. package/dist/lifecycle/evidence.js +0 -180
  424. package/dist/lifecycle/evidence.js.map +0 -1
  425. package/dist/lifecycle/frontmatter.js +0 -363
  426. package/dist/lifecycle/frontmatter.js.map +0 -1
  427. package/dist/lifecycle/index.js +0 -753
  428. package/dist/lifecycle/index.js.map +0 -1
  429. package/dist/lifecycle/pipeline.js +0 -656
  430. package/dist/lifecycle/pipeline.js.map +0 -1
  431. package/dist/lifecycle/rcasd-index.js +0 -326
  432. package/dist/lifecycle/rcasd-index.js.map +0 -1
  433. package/dist/lifecycle/rcasd-paths.js +0 -220
  434. package/dist/lifecycle/rcasd-paths.js.map +0 -1
  435. package/dist/lifecycle/resume.js +0 -864
  436. package/dist/lifecycle/resume.js.map +0 -1
  437. package/dist/lifecycle/stage-artifacts.js +0 -94
  438. package/dist/lifecycle/stage-artifacts.js.map +0 -1
  439. package/dist/lifecycle/stages.js +0 -534
  440. package/dist/lifecycle/stages.js.map +0 -1
  441. package/dist/lifecycle/state-machine.js +0 -516
  442. package/dist/lifecycle/state-machine.js.map +0 -1
  443. package/dist/lifecycle/tessera-engine.js +0 -249
  444. package/dist/lifecycle/tessera-engine.js.map +0 -1
  445. package/dist/logger.js +0 -140
  446. package/dist/logger.js.map +0 -1
  447. package/dist/mcp/index.js +0 -146
  448. package/dist/mcp/index.js.map +0 -1
  449. package/dist/memory/auto-extract.js +0 -177
  450. package/dist/memory/auto-extract.js.map +0 -1
  451. package/dist/memory/brain-embedding.js +0 -66
  452. package/dist/memory/brain-embedding.js.map +0 -1
  453. package/dist/memory/brain-lifecycle.js +0 -298
  454. package/dist/memory/brain-lifecycle.js.map +0 -1
  455. package/dist/memory/brain-links.js +0 -148
  456. package/dist/memory/brain-links.js.map +0 -1
  457. package/dist/memory/brain-maintenance.js +0 -98
  458. package/dist/memory/brain-maintenance.js.map +0 -1
  459. package/dist/memory/brain-migration.js +0 -149
  460. package/dist/memory/brain-migration.js.map +0 -1
  461. package/dist/memory/brain-reasoning.js +0 -215
  462. package/dist/memory/brain-reasoning.js.map +0 -1
  463. package/dist/memory/brain-retrieval.js +0 -521
  464. package/dist/memory/brain-retrieval.js.map +0 -1
  465. package/dist/memory/brain-row-types.js +0 -10
  466. package/dist/memory/brain-row-types.js.map +0 -1
  467. package/dist/memory/brain-search.js +0 -519
  468. package/dist/memory/brain-search.js.map +0 -1
  469. package/dist/memory/brain-similarity.js +0 -145
  470. package/dist/memory/brain-similarity.js.map +0 -1
  471. package/dist/memory/claude-mem-migration.js +0 -277
  472. package/dist/memory/claude-mem-migration.js.map +0 -1
  473. package/dist/memory/decisions.js +0 -148
  474. package/dist/memory/decisions.js.map +0 -1
  475. package/dist/memory/embedding-local.js +0 -97
  476. package/dist/memory/embedding-local.js.map +0 -1
  477. package/dist/memory/embedding-queue.js +0 -271
  478. package/dist/memory/embedding-queue.js.map +0 -1
  479. package/dist/memory/embedding-worker.js +0 -58
  480. package/dist/memory/embedding-worker.js.map +0 -1
  481. package/dist/memory/engine-compat.js +0 -1030
  482. package/dist/memory/engine-compat.js.map +0 -1
  483. package/dist/memory/index.js +0 -773
  484. package/dist/memory/index.js.map +0 -1
  485. package/dist/memory/learnings.js +0 -121
  486. package/dist/memory/learnings.js.map +0 -1
  487. package/dist/memory/memory-bridge.js +0 -370
  488. package/dist/memory/memory-bridge.js.map +0 -1
  489. package/dist/memory/patterns.js +0 -122
  490. package/dist/memory/patterns.js.map +0 -1
  491. package/dist/memory/pipeline-manifest-sqlite.js +0 -975
  492. package/dist/memory/pipeline-manifest-sqlite.js.map +0 -1
  493. package/dist/memory/session-memory.js +0 -331
  494. package/dist/memory/session-memory.js.map +0 -1
  495. package/dist/metrics/ab-test.js +0 -260
  496. package/dist/metrics/ab-test.js.map +0 -1
  497. package/dist/metrics/aggregation.js +0 -363
  498. package/dist/metrics/aggregation.js.map +0 -1
  499. package/dist/metrics/common.js +0 -64
  500. package/dist/metrics/common.js.map +0 -1
  501. package/dist/metrics/enums.js +0 -78
  502. package/dist/metrics/enums.js.map +0 -1
  503. package/dist/metrics/index.js +0 -19
  504. package/dist/metrics/index.js.map +0 -1
  505. package/dist/metrics/model-provider-registry.js +0 -88
  506. package/dist/metrics/model-provider-registry.js.map +0 -1
  507. package/dist/metrics/otel-integration.js +0 -263
  508. package/dist/metrics/otel-integration.js.map +0 -1
  509. package/dist/metrics/provider-detection.js +0 -103
  510. package/dist/metrics/provider-detection.js.map +0 -1
  511. package/dist/metrics/token-estimation.js +0 -253
  512. package/dist/metrics/token-estimation.js.map +0 -1
  513. package/dist/metrics/token-service.js +0 -450
  514. package/dist/metrics/token-service.js.map +0 -1
  515. package/dist/migration/agent-outputs.js +0 -316
  516. package/dist/migration/agent-outputs.js.map +0 -1
  517. package/dist/migration/checksum.js +0 -92
  518. package/dist/migration/checksum.js.map +0 -1
  519. package/dist/migration/index.js +0 -282
  520. package/dist/migration/index.js.map +0 -1
  521. package/dist/migration/logger.js +0 -360
  522. package/dist/migration/logger.js.map +0 -1
  523. package/dist/migration/preflight.js +0 -9
  524. package/dist/migration/preflight.js.map +0 -1
  525. package/dist/migration/state.js +0 -421
  526. package/dist/migration/state.js.map +0 -1
  527. package/dist/migration/validate.js +0 -241
  528. package/dist/migration/validate.js.map +0 -1
  529. package/dist/nexus/deps.js +0 -375
  530. package/dist/nexus/deps.js.map +0 -1
  531. package/dist/nexus/discover.js +0 -288
  532. package/dist/nexus/discover.js.map +0 -1
  533. package/dist/nexus/hash.js +0 -10
  534. package/dist/nexus/hash.js.map +0 -1
  535. package/dist/nexus/index.js +0 -38
  536. package/dist/nexus/index.js.map +0 -1
  537. package/dist/nexus/migrate-json-to-sqlite.js +0 -115
  538. package/dist/nexus/migrate-json-to-sqlite.js.map +0 -1
  539. package/dist/nexus/permissions.js +0 -105
  540. package/dist/nexus/permissions.js.map +0 -1
  541. package/dist/nexus/query.js +0 -175
  542. package/dist/nexus/query.js.map +0 -1
  543. package/dist/nexus/registry.js +0 -584
  544. package/dist/nexus/registry.js.map +0 -1
  545. package/dist/nexus/sharing/index.js +0 -288
  546. package/dist/nexus/sharing/index.js.map +0 -1
  547. package/dist/nexus/transfer-types.js +0 -8
  548. package/dist/nexus/transfer-types.js.map +0 -1
  549. package/dist/nexus/transfer.js +0 -263
  550. package/dist/nexus/transfer.js.map +0 -1
  551. package/dist/observability/index.js +0 -103
  552. package/dist/observability/index.js.map +0 -1
  553. package/dist/observability/log-filter.js +0 -63
  554. package/dist/observability/log-filter.js.map +0 -1
  555. package/dist/observability/log-parser.js +0 -99
  556. package/dist/observability/log-parser.js.map +0 -1
  557. package/dist/observability/log-reader.js +0 -139
  558. package/dist/observability/log-reader.js.map +0 -1
  559. package/dist/observability/types.js +0 -19
  560. package/dist/observability/types.js.map +0 -1
  561. package/dist/orchestration/analyze.js +0 -107
  562. package/dist/orchestration/analyze.js.map +0 -1
  563. package/dist/orchestration/bootstrap.js +0 -132
  564. package/dist/orchestration/bootstrap.js.map +0 -1
  565. package/dist/orchestration/context.js +0 -56
  566. package/dist/orchestration/context.js.map +0 -1
  567. package/dist/orchestration/critical-path.js +0 -100
  568. package/dist/orchestration/critical-path.js.map +0 -1
  569. package/dist/orchestration/index.js +0 -286
  570. package/dist/orchestration/index.js.map +0 -1
  571. package/dist/orchestration/parallel.js +0 -89
  572. package/dist/orchestration/parallel.js.map +0 -1
  573. package/dist/orchestration/protocol-validators.js +0 -524
  574. package/dist/orchestration/protocol-validators.js.map +0 -1
  575. package/dist/orchestration/skill-ops.js +0 -98
  576. package/dist/orchestration/skill-ops.js.map +0 -1
  577. package/dist/orchestration/status.js +0 -107
  578. package/dist/orchestration/status.js.map +0 -1
  579. package/dist/orchestration/unblock.js +0 -103
  580. package/dist/orchestration/unblock.js.map +0 -1
  581. package/dist/orchestration/validate-spawn.js +0 -67
  582. package/dist/orchestration/validate-spawn.js.map +0 -1
  583. package/dist/orchestration/waves.js +0 -86
  584. package/dist/orchestration/waves.js.map +0 -1
  585. package/dist/otel/index.js +0 -163
  586. package/dist/otel/index.js.map +0 -1
  587. package/dist/output.js +0 -132
  588. package/dist/output.js.map +0 -1
  589. package/dist/pagination.js +0 -64
  590. package/dist/pagination.js.map +0 -1
  591. package/dist/paths.js +0 -337
  592. package/dist/paths.js.map +0 -1
  593. package/dist/phases/deps.js +0 -372
  594. package/dist/phases/deps.js.map +0 -1
  595. package/dist/phases/index.js +0 -349
  596. package/dist/phases/index.js.map +0 -1
  597. package/dist/pipeline/index.js +0 -10
  598. package/dist/pipeline/index.js.map +0 -1
  599. package/dist/pipeline/phase.js +0 -45
  600. package/dist/pipeline/phase.js.map +0 -1
  601. package/dist/platform.js +0 -211
  602. package/dist/platform.js.map +0 -1
  603. package/dist/project-info.js +0 -84
  604. package/dist/project-info.js.map +0 -1
  605. package/dist/reconciliation/index.js +0 -10
  606. package/dist/reconciliation/index.js.map +0 -1
  607. package/dist/reconciliation/link-store.js +0 -129
  608. package/dist/reconciliation/link-store.js.map +0 -1
  609. package/dist/reconciliation/reconciliation-engine.js +0 -298
  610. package/dist/reconciliation/reconciliation-engine.js.map +0 -1
  611. package/dist/release/artifacts.js +0 -427
  612. package/dist/release/artifacts.js.map +0 -1
  613. package/dist/release/changelog-writer.js +0 -151
  614. package/dist/release/changelog-writer.js.map +0 -1
  615. package/dist/release/channel.js +0 -144
  616. package/dist/release/channel.js.map +0 -1
  617. package/dist/release/ci.js +0 -166
  618. package/dist/release/ci.js.map +0 -1
  619. package/dist/release/github-pr.js +0 -225
  620. package/dist/release/github-pr.js.map +0 -1
  621. package/dist/release/guards.js +0 -116
  622. package/dist/release/guards.js.map +0 -1
  623. package/dist/release/index.js +0 -22
  624. package/dist/release/index.js.map +0 -1
  625. package/dist/release/release-config.js +0 -158
  626. package/dist/release/release-config.js.map +0 -1
  627. package/dist/release/release-manifest.js +0 -1019
  628. package/dist/release/release-manifest.js.map +0 -1
  629. package/dist/release/version-bump.js +0 -255
  630. package/dist/release/version-bump.js.map +0 -1
  631. package/dist/remote/index.js +0 -257
  632. package/dist/remote/index.js.map +0 -1
  633. package/dist/repair.js +0 -130
  634. package/dist/repair.js.map +0 -1
  635. package/dist/research/index.js +0 -2
  636. package/dist/research/index.js.map +0 -1
  637. package/dist/roadmap/index.js +0 -59
  638. package/dist/roadmap/index.js.map +0 -1
  639. package/dist/routing/capability-matrix.js +0 -1557
  640. package/dist/routing/capability-matrix.js.map +0 -1
  641. package/dist/routing/index.js +0 -9
  642. package/dist/routing/index.js.map +0 -1
  643. package/dist/scaffold.js +0 -1178
  644. package/dist/scaffold.js.map +0 -1
  645. package/dist/schema-management.js +0 -295
  646. package/dist/schema-management.js.map +0 -1
  647. package/dist/security/index.js +0 -9
  648. package/dist/security/index.js.map +0 -1
  649. package/dist/security/input-sanitization.js +0 -321
  650. package/dist/security/input-sanitization.js.map +0 -1
  651. package/dist/sequence/index.js +0 -295
  652. package/dist/sequence/index.js.map +0 -1
  653. package/dist/sessions/assumptions.js +0 -54
  654. package/dist/sessions/assumptions.js.map +0 -1
  655. package/dist/sessions/briefing.js +0 -377
  656. package/dist/sessions/briefing.js.map +0 -1
  657. package/dist/sessions/context-alert.js +0 -222
  658. package/dist/sessions/context-alert.js.map +0 -1
  659. package/dist/sessions/context-inject.js +0 -61
  660. package/dist/sessions/context-inject.js.map +0 -1
  661. package/dist/sessions/context-monitor.js +0 -98
  662. package/dist/sessions/context-monitor.js.map +0 -1
  663. package/dist/sessions/decisions.js +0 -65
  664. package/dist/sessions/decisions.js.map +0 -1
  665. package/dist/sessions/find.js +0 -63
  666. package/dist/sessions/find.js.map +0 -1
  667. package/dist/sessions/handoff.js +0 -328
  668. package/dist/sessions/handoff.js.map +0 -1
  669. package/dist/sessions/hitl-warnings.js +0 -254
  670. package/dist/sessions/hitl-warnings.js.map +0 -1
  671. package/dist/sessions/index.js +0 -314
  672. package/dist/sessions/index.js.map +0 -1
  673. package/dist/sessions/session-archive.js +0 -40
  674. package/dist/sessions/session-archive.js.map +0 -1
  675. package/dist/sessions/session-cleanup.js +0 -59
  676. package/dist/sessions/session-cleanup.js.map +0 -1
  677. package/dist/sessions/session-drift.js +0 -134
  678. package/dist/sessions/session-drift.js.map +0 -1
  679. package/dist/sessions/session-enforcement.js +0 -144
  680. package/dist/sessions/session-enforcement.js.map +0 -1
  681. package/dist/sessions/session-grade.js +0 -253
  682. package/dist/sessions/session-grade.js.map +0 -1
  683. package/dist/sessions/session-history.js +0 -42
  684. package/dist/sessions/session-history.js.map +0 -1
  685. package/dist/sessions/session-id.js +0 -81
  686. package/dist/sessions/session-id.js.map +0 -1
  687. package/dist/sessions/session-memory-bridge.js +0 -52
  688. package/dist/sessions/session-memory-bridge.js.map +0 -1
  689. package/dist/sessions/session-show.js +0 -24
  690. package/dist/sessions/session-show.js.map +0 -1
  691. package/dist/sessions/session-stats.js +0 -69
  692. package/dist/sessions/session-stats.js.map +0 -1
  693. package/dist/sessions/session-suspend.js +0 -39
  694. package/dist/sessions/session-suspend.js.map +0 -1
  695. package/dist/sessions/session-switch.js +0 -51
  696. package/dist/sessions/session-switch.js.map +0 -1
  697. package/dist/sessions/session-view.js +0 -76
  698. package/dist/sessions/session-view.js.map +0 -1
  699. package/dist/sessions/statusline-setup.js +0 -85
  700. package/dist/sessions/statusline-setup.js.map +0 -1
  701. package/dist/sessions/types.js +0 -8
  702. package/dist/sessions/types.js.map +0 -1
  703. package/dist/signaldock/claude-code-transport.d.ts +0 -34
  704. package/dist/signaldock/claude-code-transport.d.ts.map +0 -1
  705. package/dist/signaldock/claude-code-transport.js +0 -107
  706. package/dist/signaldock/claude-code-transport.js.map +0 -1
  707. package/dist/signaldock/factory.d.ts +0 -22
  708. package/dist/signaldock/factory.d.ts.map +0 -1
  709. package/dist/signaldock/factory.js +0 -25
  710. package/dist/signaldock/factory.js.map +0 -1
  711. package/dist/signaldock/index.d.ts +0 -13
  712. package/dist/signaldock/index.d.ts.map +0 -1
  713. package/dist/signaldock/index.js +0 -9
  714. package/dist/signaldock/index.js.map +0 -1
  715. package/dist/signaldock/signaldock-transport.d.ts +0 -45
  716. package/dist/signaldock/signaldock-transport.d.ts.map +0 -1
  717. package/dist/signaldock/signaldock-transport.js +0 -122
  718. package/dist/signaldock/signaldock-transport.js.map +0 -1
  719. package/dist/signaldock/transport.d.ts +0 -49
  720. package/dist/signaldock/transport.d.ts.map +0 -1
  721. package/dist/signaldock/transport.js +0 -11
  722. package/dist/signaldock/transport.js.map +0 -1
  723. package/dist/signaldock/types.d.ts +0 -88
  724. package/dist/signaldock/types.d.ts.map +0 -1
  725. package/dist/signaldock/types.js +0 -11
  726. package/dist/signaldock/types.js.map +0 -1
  727. package/dist/skills/agents/config.js +0 -94
  728. package/dist/skills/agents/config.js.map +0 -1
  729. package/dist/skills/agents/install.js +0 -116
  730. package/dist/skills/agents/install.js.map +0 -1
  731. package/dist/skills/agents/registry.js +0 -161
  732. package/dist/skills/agents/registry.js.map +0 -1
  733. package/dist/skills/discovery.js +0 -333
  734. package/dist/skills/discovery.js.map +0 -1
  735. package/dist/skills/dispatch.js +0 -347
  736. package/dist/skills/dispatch.js.map +0 -1
  737. package/dist/skills/dynamic-skill-generator.js +0 -100
  738. package/dist/skills/dynamic-skill-generator.js.map +0 -1
  739. package/dist/skills/index.js +0 -44
  740. package/dist/skills/index.js.map +0 -1
  741. package/dist/skills/injection/subagent.js +0 -195
  742. package/dist/skills/injection/subagent.js.map +0 -1
  743. package/dist/skills/injection/token.js +0 -260
  744. package/dist/skills/injection/token.js.map +0 -1
  745. package/dist/skills/install.js +0 -40
  746. package/dist/skills/install.js.map +0 -1
  747. package/dist/skills/manifests/contribution.js +0 -175
  748. package/dist/skills/manifests/contribution.js.map +0 -1
  749. package/dist/skills/manifests/research.js +0 -281
  750. package/dist/skills/manifests/research.js.map +0 -1
  751. package/dist/skills/manifests/resolver.js +0 -146
  752. package/dist/skills/manifests/resolver.js.map +0 -1
  753. package/dist/skills/marketplace.js +0 -90
  754. package/dist/skills/marketplace.js.map +0 -1
  755. package/dist/skills/orchestrator/spawn.js +0 -178
  756. package/dist/skills/orchestrator/spawn.js.map +0 -1
  757. package/dist/skills/orchestrator/startup.js +0 -451
  758. package/dist/skills/orchestrator/startup.js.map +0 -1
  759. package/dist/skills/orchestrator/validator.js +0 -301
  760. package/dist/skills/orchestrator/validator.js.map +0 -1
  761. package/dist/skills/precedence-integration.js +0 -73
  762. package/dist/skills/precedence-integration.js.map +0 -1
  763. package/dist/skills/precedence-types.js +0 -16
  764. package/dist/skills/precedence-types.js.map +0 -1
  765. package/dist/skills/routing-table.js +0 -63
  766. package/dist/skills/routing-table.js.map +0 -1
  767. package/dist/skills/skill-paths.js +0 -220
  768. package/dist/skills/skill-paths.js.map +0 -1
  769. package/dist/skills/test-utility.js +0 -55
  770. package/dist/skills/test-utility.js.map +0 -1
  771. package/dist/skills/types.js +0 -118
  772. package/dist/skills/types.js.map +0 -1
  773. package/dist/skills/validation.js +0 -183
  774. package/dist/skills/validation.js.map +0 -1
  775. package/dist/skills/version.js +0 -57
  776. package/dist/skills/version.js.map +0 -1
  777. package/dist/snapshot/index.js +0 -188
  778. package/dist/snapshot/index.js.map +0 -1
  779. package/dist/spawn/adapter-registry.js +0 -246
  780. package/dist/spawn/adapter-registry.js.map +0 -1
  781. package/dist/spawn/index.js +0 -10
  782. package/dist/spawn/index.js.map +0 -1
  783. package/dist/stats/index.js +0 -343
  784. package/dist/stats/index.js.map +0 -1
  785. package/dist/stats/workflow-telemetry.js +0 -400
  786. package/dist/stats/workflow-telemetry.js.map +0 -1
  787. package/dist/sticky/archive.js +0 -47
  788. package/dist/sticky/archive.js.map +0 -1
  789. package/dist/sticky/convert.js +0 -235
  790. package/dist/sticky/convert.js.map +0 -1
  791. package/dist/sticky/create.js +0 -48
  792. package/dist/sticky/create.js.map +0 -1
  793. package/dist/sticky/id.js +0 -35
  794. package/dist/sticky/id.js.map +0 -1
  795. package/dist/sticky/index.js +0 -16
  796. package/dist/sticky/index.js.map +0 -1
  797. package/dist/sticky/list.js +0 -44
  798. package/dist/sticky/list.js.map +0 -1
  799. package/dist/sticky/purge.js +0 -45
  800. package/dist/sticky/purge.js.map +0 -1
  801. package/dist/sticky/show.js +0 -42
  802. package/dist/sticky/show.js.map +0 -1
  803. package/dist/sticky/types.js +0 -10
  804. package/dist/sticky/types.js.map +0 -1
  805. package/dist/store/atomic.js +0 -167
  806. package/dist/store/atomic.js.map +0 -1
  807. package/dist/store/backup.js +0 -94
  808. package/dist/store/backup.js.map +0 -1
  809. package/dist/store/brain-accessor.js +0 -397
  810. package/dist/store/brain-accessor.js.map +0 -1
  811. package/dist/store/brain-schema.js +0 -215
  812. package/dist/store/brain-schema.js.map +0 -1
  813. package/dist/store/brain-sqlite.js +0 -222
  814. package/dist/store/brain-sqlite.js.map +0 -1
  815. package/dist/store/cache.js +0 -168
  816. package/dist/store/cache.js.map +0 -1
  817. package/dist/store/chain-schema.js +0 -51
  818. package/dist/store/chain-schema.js.map +0 -1
  819. package/dist/store/converters.js +0 -122
  820. package/dist/store/converters.js.map +0 -1
  821. package/dist/store/cross-db-cleanup.js +0 -169
  822. package/dist/store/cross-db-cleanup.js.map +0 -1
  823. package/dist/store/data-accessor.js +0 -26
  824. package/dist/store/data-accessor.js.map +0 -1
  825. package/dist/store/data-safety-central.js +0 -269
  826. package/dist/store/data-safety-central.js.map +0 -1
  827. package/dist/store/data-safety.js +0 -274
  828. package/dist/store/data-safety.js.map +0 -1
  829. package/dist/store/db-helpers.js +0 -223
  830. package/dist/store/db-helpers.js.map +0 -1
  831. package/dist/store/export.js +0 -155
  832. package/dist/store/export.js.map +0 -1
  833. package/dist/store/file-utils.js +0 -270
  834. package/dist/store/file-utils.js.map +0 -1
  835. package/dist/store/git-checkpoint.js +0 -365
  836. package/dist/store/git-checkpoint.js.map +0 -1
  837. package/dist/store/import-logging.js +0 -139
  838. package/dist/store/import-logging.js.map +0 -1
  839. package/dist/store/import-remap.js +0 -145
  840. package/dist/store/import-remap.js.map +0 -1
  841. package/dist/store/import-sort.js +0 -121
  842. package/dist/store/import-sort.js.map +0 -1
  843. package/dist/store/index.js +0 -28
  844. package/dist/store/index.js.map +0 -1
  845. package/dist/store/json.js +0 -208
  846. package/dist/store/json.js.map +0 -1
  847. package/dist/store/lifecycle-store.js +0 -249
  848. package/dist/store/lifecycle-store.js.map +0 -1
  849. package/dist/store/lock.js +0 -70
  850. package/dist/store/lock.js.map +0 -1
  851. package/dist/store/migration-manager.js +0 -151
  852. package/dist/store/migration-manager.js.map +0 -1
  853. package/dist/store/migration-sqlite.js +0 -676
  854. package/dist/store/migration-sqlite.js.map +0 -1
  855. package/dist/store/nexus-schema.js +0 -62
  856. package/dist/store/nexus-schema.js.map +0 -1
  857. package/dist/store/nexus-sqlite.js +0 -217
  858. package/dist/store/nexus-sqlite.js.map +0 -1
  859. package/dist/store/nexus-validation-schemas.js +0 -40
  860. package/dist/store/nexus-validation-schemas.js.map +0 -1
  861. package/dist/store/parsers.js +0 -37
  862. package/dist/store/parsers.js.map +0 -1
  863. package/dist/store/project-detect.js +0 -457
  864. package/dist/store/project-detect.js.map +0 -1
  865. package/dist/store/provider.js +0 -101
  866. package/dist/store/provider.js.map +0 -1
  867. package/dist/store/safety-data-accessor.js +0 -243
  868. package/dist/store/safety-data-accessor.js.map +0 -1
  869. package/dist/store/schema.js +0 -7
  870. package/dist/store/schema.js.map +0 -1
  871. package/dist/store/session-store.js +0 -219
  872. package/dist/store/session-store.js.map +0 -1
  873. package/dist/store/sqlite-backup.js +0 -105
  874. package/dist/store/sqlite-backup.js.map +0 -1
  875. package/dist/store/sqlite-data-accessor.js +0 -734
  876. package/dist/store/sqlite-data-accessor.js.map +0 -1
  877. package/dist/store/sqlite.js +0 -436
  878. package/dist/store/sqlite.js.map +0 -1
  879. package/dist/store/status-registry.js +0 -8
  880. package/dist/store/status-registry.js.map +0 -1
  881. package/dist/store/task-store.js +0 -348
  882. package/dist/store/task-store.js.map +0 -1
  883. package/dist/store/tasks-schema.js +0 -604
  884. package/dist/store/tasks-schema.js.map +0 -1
  885. package/dist/store/typed-query.js +0 -15
  886. package/dist/store/typed-query.js.map +0 -1
  887. package/dist/store/validation-schemas.js +0 -278
  888. package/dist/store/validation-schemas.js.map +0 -1
  889. package/dist/system/archive-analytics.js +0 -277
  890. package/dist/system/archive-analytics.js.map +0 -1
  891. package/dist/system/archive-stats.js +0 -64
  892. package/dist/system/archive-stats.js.map +0 -1
  893. package/dist/system/audit.js +0 -145
  894. package/dist/system/audit.js.map +0 -1
  895. package/dist/system/backup.js +0 -141
  896. package/dist/system/backup.js.map +0 -1
  897. package/dist/system/cleanup.js +0 -134
  898. package/dist/system/cleanup.js.map +0 -1
  899. package/dist/system/health.js +0 -1054
  900. package/dist/system/health.js.map +0 -1
  901. package/dist/system/index.js +0 -18
  902. package/dist/system/index.js.map +0 -1
  903. package/dist/system/inject-generate.js +0 -122
  904. package/dist/system/inject-generate.js.map +0 -1
  905. package/dist/system/labels.js +0 -38
  906. package/dist/system/labels.js.map +0 -1
  907. package/dist/system/metrics.js +0 -61
  908. package/dist/system/metrics.js.map +0 -1
  909. package/dist/system/migrate.js +0 -43
  910. package/dist/system/migrate.js.map +0 -1
  911. package/dist/system/platform-paths.js +0 -80
  912. package/dist/system/platform-paths.js.map +0 -1
  913. package/dist/system/runtime.js +0 -161
  914. package/dist/system/runtime.js.map +0 -1
  915. package/dist/system/safestop.js +0 -99
  916. package/dist/system/safestop.js.map +0 -1
  917. package/dist/system/storage-preflight.js +0 -123
  918. package/dist/system/storage-preflight.js.map +0 -1
  919. package/dist/task-work/index.js +0 -155
  920. package/dist/task-work/index.js.map +0 -1
  921. package/dist/tasks/add.js +0 -661
  922. package/dist/tasks/add.js.map +0 -1
  923. package/dist/tasks/analyze.js +0 -85
  924. package/dist/tasks/analyze.js.map +0 -1
  925. package/dist/tasks/archive.js +0 -90
  926. package/dist/tasks/archive.js.map +0 -1
  927. package/dist/tasks/atomicity.js +0 -83
  928. package/dist/tasks/atomicity.js.map +0 -1
  929. package/dist/tasks/cancel-ops.js +0 -83
  930. package/dist/tasks/cancel-ops.js.map +0 -1
  931. package/dist/tasks/complete.js +0 -208
  932. package/dist/tasks/complete.js.map +0 -1
  933. package/dist/tasks/crossref-extract.js +0 -73
  934. package/dist/tasks/crossref-extract.js.map +0 -1
  935. package/dist/tasks/delete-preview.js +0 -192
  936. package/dist/tasks/delete-preview.js.map +0 -1
  937. package/dist/tasks/delete.js +0 -120
  938. package/dist/tasks/delete.js.map +0 -1
  939. package/dist/tasks/deletion-strategy.js +0 -200
  940. package/dist/tasks/deletion-strategy.js.map +0 -1
  941. package/dist/tasks/dependency-check.js +0 -278
  942. package/dist/tasks/dependency-check.js.map +0 -1
  943. package/dist/tasks/deps-ready.js +0 -32
  944. package/dist/tasks/deps-ready.js.map +0 -1
  945. package/dist/tasks/enforcement.js +0 -86
  946. package/dist/tasks/enforcement.js.map +0 -1
  947. package/dist/tasks/epic-enforcement.js +0 -294
  948. package/dist/tasks/epic-enforcement.js.map +0 -1
  949. package/dist/tasks/find.js +0 -148
  950. package/dist/tasks/find.js.map +0 -1
  951. package/dist/tasks/graph-cache.js +0 -127
  952. package/dist/tasks/graph-cache.js.map +0 -1
  953. package/dist/tasks/graph-ops.js +0 -171
  954. package/dist/tasks/graph-ops.js.map +0 -1
  955. package/dist/tasks/graph-rag.js +0 -328
  956. package/dist/tasks/graph-rag.js.map +0 -1
  957. package/dist/tasks/hierarchy-policy.js +0 -149
  958. package/dist/tasks/hierarchy-policy.js.map +0 -1
  959. package/dist/tasks/hierarchy.js +0 -185
  960. package/dist/tasks/hierarchy.js.map +0 -1
  961. package/dist/tasks/id-generator.js +0 -65
  962. package/dist/tasks/id-generator.js.map +0 -1
  963. package/dist/tasks/index.js +0 -14
  964. package/dist/tasks/index.js.map +0 -1
  965. package/dist/tasks/labels.js +0 -52
  966. package/dist/tasks/labels.js.map +0 -1
  967. package/dist/tasks/list.js +0 -68
  968. package/dist/tasks/list.js.map +0 -1
  969. package/dist/tasks/phase-tracking.js +0 -133
  970. package/dist/tasks/phase-tracking.js.map +0 -1
  971. package/dist/tasks/pipeline-stage.js +0 -248
  972. package/dist/tasks/pipeline-stage.js.map +0 -1
  973. package/dist/tasks/plan.js +0 -268
  974. package/dist/tasks/plan.js.map +0 -1
  975. package/dist/tasks/relates.js +0 -89
  976. package/dist/tasks/relates.js.map +0 -1
  977. package/dist/tasks/reparent.d.ts +0 -38
  978. package/dist/tasks/reparent.d.ts.map +0 -1
  979. package/dist/tasks/show.js +0 -78
  980. package/dist/tasks/show.js.map +0 -1
  981. package/dist/tasks/size-weighting.js +0 -86
  982. package/dist/tasks/size-weighting.js.map +0 -1
  983. package/dist/tasks/staleness.js +0 -86
  984. package/dist/tasks/staleness.js.map +0 -1
  985. package/dist/tasks/task-ops.js +0 -1340
  986. package/dist/tasks/task-ops.js.map +0 -1
  987. package/dist/tasks/update.js +0 -271
  988. package/dist/tasks/update.js.map +0 -1
  989. package/dist/templates/index.js +0 -10
  990. package/dist/templates/index.js.map +0 -1
  991. package/dist/templates/parser.js +0 -254
  992. package/dist/templates/parser.js.map +0 -1
  993. package/dist/ui/aliases.js +0 -153
  994. package/dist/ui/aliases.js.map +0 -1
  995. package/dist/ui/changelog.js +0 -184
  996. package/dist/ui/changelog.js.map +0 -1
  997. package/dist/ui/command-registry.js +0 -168
  998. package/dist/ui/command-registry.js.map +0 -1
  999. package/dist/ui/flags.js +0 -94
  1000. package/dist/ui/flags.js.map +0 -1
  1001. package/dist/ui/index.js +0 -24
  1002. package/dist/ui/index.js.map +0 -1
  1003. package/dist/ui/injection-legacy.d.ts +0 -26
  1004. package/dist/ui/injection-legacy.d.ts.map +0 -1
  1005. package/dist/ui/injection-legacy.js +0 -42
  1006. package/dist/ui/injection-legacy.js.map +0 -1
  1007. package/dist/upgrade.js +0 -1144
  1008. package/dist/upgrade.js.map +0 -1
  1009. package/dist/validation/chain-validation.js +0 -146
  1010. package/dist/validation/chain-validation.js.map +0 -1
  1011. package/dist/validation/compliance.js +0 -155
  1012. package/dist/validation/compliance.js.map +0 -1
  1013. package/dist/validation/docs-sync.js +0 -212
  1014. package/dist/validation/docs-sync.js.map +0 -1
  1015. package/dist/validation/doctor/checks.js +0 -1069
  1016. package/dist/validation/doctor/checks.js.map +0 -1
  1017. package/dist/validation/doctor/index.js +0 -9
  1018. package/dist/validation/doctor/index.js.map +0 -1
  1019. package/dist/validation/doctor/project-cache.js +0 -160
  1020. package/dist/validation/doctor/project-cache.js.map +0 -1
  1021. package/dist/validation/doctor/utils.js +0 -155
  1022. package/dist/validation/doctor/utils.js.map +0 -1
  1023. package/dist/validation/engine.js +0 -902
  1024. package/dist/validation/engine.js.map +0 -1
  1025. package/dist/validation/gap-check.js +0 -175
  1026. package/dist/validation/gap-check.js.map +0 -1
  1027. package/dist/validation/index.js +0 -40
  1028. package/dist/validation/index.js.map +0 -1
  1029. package/dist/validation/manifest.js +0 -237
  1030. package/dist/validation/manifest.js.map +0 -1
  1031. package/dist/validation/operation-gate-validators.js +0 -724
  1032. package/dist/validation/operation-gate-validators.js.map +0 -1
  1033. package/dist/validation/operation-verification-gates.js +0 -532
  1034. package/dist/validation/operation-verification-gates.js.map +0 -1
  1035. package/dist/validation/param-utils.js +0 -139
  1036. package/dist/validation/param-utils.js.map +0 -1
  1037. package/dist/validation/protocol-common.js +0 -300
  1038. package/dist/validation/protocol-common.js.map +0 -1
  1039. package/dist/validation/protocols/consensus.js +0 -71
  1040. package/dist/validation/protocols/consensus.js.map +0 -1
  1041. package/dist/validation/protocols/contribution.js +0 -59
  1042. package/dist/validation/protocols/contribution.js.map +0 -1
  1043. package/dist/validation/protocols/decomposition.js +0 -59
  1044. package/dist/validation/protocols/decomposition.js.map +0 -1
  1045. package/dist/validation/protocols/implementation.js +0 -59
  1046. package/dist/validation/protocols/implementation.js.map +0 -1
  1047. package/dist/validation/protocols/release-protocol.js +0 -60
  1048. package/dist/validation/protocols/release-protocol.js.map +0 -1
  1049. package/dist/validation/protocols/research.js +0 -77
  1050. package/dist/validation/protocols/research.js.map +0 -1
  1051. package/dist/validation/protocols/specification.js +0 -84
  1052. package/dist/validation/protocols/specification.js.map +0 -1
  1053. package/dist/validation/protocols/testing-protocol.js +0 -70
  1054. package/dist/validation/protocols/testing-protocol.js.map +0 -1
  1055. package/dist/validation/protocols/validation-protocol.js +0 -70
  1056. package/dist/validation/protocols/validation-protocol.js.map +0 -1
  1057. package/dist/validation/schema-integrity.js +0 -170
  1058. package/dist/validation/schema-integrity.js.map +0 -1
  1059. package/dist/validation/schema-validator.js +0 -176
  1060. package/dist/validation/schema-validator.js.map +0 -1
  1061. package/dist/validation/validate-ops.js +0 -937
  1062. package/dist/validation/validate-ops.js.map +0 -1
  1063. package/dist/validation/validation-rules.js +0 -226
  1064. package/dist/validation/validation-rules.js.map +0 -1
  1065. package/dist/validation/verification.js +0 -321
  1066. package/dist/validation/verification.js.map +0 -1
  1067. package/src/signaldock/__tests__/claude-code-transport.test.d.ts +0 -7
  1068. package/src/signaldock/__tests__/claude-code-transport.test.d.ts.map +0 -1
  1069. package/src/signaldock/__tests__/claude-code-transport.test.js +0 -147
  1070. package/src/signaldock/__tests__/claude-code-transport.test.js.map +0 -1
  1071. package/src/signaldock/__tests__/claude-code-transport.test.ts +0 -180
  1072. package/src/signaldock/__tests__/factory.test.d.ts +0 -7
  1073. package/src/signaldock/__tests__/factory.test.d.ts.map +0 -1
  1074. package/src/signaldock/__tests__/factory.test.js +0 -55
  1075. package/src/signaldock/__tests__/factory.test.js.map +0 -1
  1076. package/src/signaldock/__tests__/factory.test.ts +0 -61
  1077. package/src/signaldock/__tests__/signaldock-transport.test.d.ts +0 -9
  1078. package/src/signaldock/__tests__/signaldock-transport.test.d.ts.map +0 -1
  1079. package/src/signaldock/__tests__/signaldock-transport.test.js +0 -321
  1080. package/src/signaldock/__tests__/signaldock-transport.test.js.map +0 -1
  1081. package/src/signaldock/__tests__/signaldock-transport.test.ts +0 -421
  1082. package/src/signaldock/claude-code-transport.ts +0 -137
  1083. package/src/signaldock/factory.ts +0 -39
  1084. package/src/signaldock/index.ts +0 -28
  1085. package/src/signaldock/signaldock-transport.ts +0 -194
  1086. package/src/signaldock/transport.ts +0 -78
  1087. package/src/signaldock/types.ts +0 -100
@@ -1,1019 +0,0 @@
1
- /**
2
- * Release manifest operations backed by the release_manifests SQLite table.
3
- *
4
- * Migrated from .cleo/releases.json to SQLite per T5580.
5
- * All reads/writes now go through Drizzle ORM via tasks.db.
6
- *
7
- * @task T5580
8
- * @task T4788
9
- */
10
- import { execFileSync } from 'node:child_process';
11
- import { existsSync, renameSync } from 'node:fs';
12
- import { readFile } from 'node:fs/promises';
13
- import { join } from 'node:path';
14
- import { and, count, desc, eq } from 'drizzle-orm';
15
- import { createPage } from '../pagination.js';
16
- import { getCleoDirAbsolute, getProjectRoot } from '../paths.js';
17
- import * as schema from '../store/tasks-schema.js';
18
- import { parseChangelogBlocks, writeChangelogSection } from './changelog-writer.js';
19
- import { resolveChannelFromBranch } from './channel.js';
20
- import { detectBranchProtection } from './github-pr.js';
21
- import { getChannelConfig, getGitFlowConfig, getPushMode, loadReleaseConfig, } from './release-config.js';
22
- import { getVersionBumpConfig } from './version-bump.js';
23
- async function getDb(cwd) {
24
- const { getDb: _getDb } = await import('../store/sqlite.js');
25
- return _getDb(cwd);
26
- }
27
- function normalizeLimit(limit) {
28
- return typeof limit === 'number' && limit > 0 ? limit : undefined;
29
- }
30
- function normalizeOffset(offset) {
31
- return typeof offset === 'number' && offset > 0 ? offset : undefined;
32
- }
33
- function effectivePageLimit(limit, offset) {
34
- return limit ?? (offset !== undefined ? 50 : undefined);
35
- }
36
- // ── Internal helpers ─────────────────────────────────────────────────
37
- function isValidVersion(version) {
38
- return /^v?\d+\.\d+\.\d+(-[\w.]+)?(\+[\w.]+)?$/.test(version);
39
- }
40
- function validateCalVerWindow(version, now = new Date()) {
41
- const normalized = version.startsWith('v') ? version.slice(1) : version;
42
- const base = normalized.split('-')[0] ?? normalized;
43
- const parts = base.split('.');
44
- if (parts.length !== 3) {
45
- return { valid: false, message: `Invalid CalVer format: ${version}` };
46
- }
47
- const tagYear = Number.parseInt(parts[0] ?? '', 10);
48
- const tagMonth = Number.parseInt(parts[1] ?? '', 10);
49
- if (!Number.isInteger(tagYear) || !Number.isInteger(tagMonth)) {
50
- return { valid: false, message: `Invalid CalVer date components: ${version}` };
51
- }
52
- const currentYear = now.getUTCFullYear();
53
- const currentMonth = now.getUTCMonth() + 1;
54
- const nextMonth = currentMonth === 12 ? 1 : currentMonth + 1;
55
- const nextYear = currentMonth === 12 ? currentYear + 1 : currentYear;
56
- const isPreRelease = normalized.includes('-');
57
- if (isPreRelease) {
58
- const valid = (tagYear === currentYear || tagYear === nextYear) &&
59
- (tagMonth === currentMonth || tagMonth === nextMonth);
60
- return {
61
- valid,
62
- message: valid
63
- ? `CalVer OK (pre-release): ${version}`
64
- : `Pre-release ${version} outside allowed CalVer range ${currentYear}.${currentMonth} or ${nextYear}.${nextMonth}`,
65
- };
66
- }
67
- const valid = tagYear === currentYear && tagMonth === currentMonth;
68
- return {
69
- valid,
70
- message: valid
71
- ? `CalVer OK (stable): ${version}`
72
- : `${version} does not match current CalVer ${currentYear}.${currentMonth}`,
73
- };
74
- }
75
- function normalizeVersion(version) {
76
- return version.startsWith('v') ? version : `v${version}`;
77
- }
78
- function rowToManifest(row) {
79
- return {
80
- version: row.version,
81
- status: row.status,
82
- createdAt: row.createdAt,
83
- preparedAt: row.preparedAt ?? undefined,
84
- committedAt: row.committedAt ?? undefined,
85
- taggedAt: row.taggedAt ?? undefined,
86
- pushedAt: row.pushedAt ?? undefined,
87
- tasks: JSON.parse(row.tasksJson),
88
- notes: row.notes ?? undefined,
89
- changelog: row.changelog ?? undefined,
90
- previousVersion: row.previousVersion ?? undefined,
91
- commitSha: row.commitSha ?? undefined,
92
- gitTag: row.gitTag ?? undefined,
93
- };
94
- }
95
- async function findLatestPushedVersion(cwd) {
96
- const db = await getDb(cwd);
97
- const rows = await db
98
- .select({ version: schema.releaseManifests.version })
99
- .from(schema.releaseManifests)
100
- .where(eq(schema.releaseManifests.status, 'pushed'))
101
- .orderBy(desc(schema.releaseManifests.pushedAt))
102
- .limit(1)
103
- .all();
104
- return rows[0]?.version;
105
- }
106
- // ── Public API ───────────────────────────────────────────────────────
107
- /**
108
- * Prepare a release (create a release manifest entry).
109
- * @task T4788
110
- */
111
- export async function prepareRelease(version, tasks, notes, loadTasksFn, cwd) {
112
- if (!version) {
113
- throw new Error('version is required');
114
- }
115
- if (!isValidVersion(version)) {
116
- throw new Error(`Invalid version format: ${version} (expected X.Y.Z or YYYY.M.patch)`);
117
- }
118
- const normalizedVersion = normalizeVersion(version);
119
- const db = await getDb(cwd);
120
- const existing = await db
121
- .select()
122
- .from(schema.releaseManifests)
123
- .where(eq(schema.releaseManifests.version, normalizedVersion))
124
- .limit(1)
125
- .all();
126
- if (existing.length > 0) {
127
- throw new Error(`Release ${normalizedVersion} already exists (status: ${existing[0].status})`);
128
- }
129
- let releaseTasks = tasks ?? [];
130
- if (releaseTasks.length === 0) {
131
- const allTasks = await loadTasksFn();
132
- releaseTasks = allTasks.filter((t) => t.status === 'done' && t.completedAt).map((t) => t.id);
133
- }
134
- // Filter out epic IDs
135
- const allTasks = await loadTasksFn();
136
- const epicIds = new Set(allTasks.filter((t) => allTasks.some((c) => c.parentId === t.id)).map((t) => t.id));
137
- releaseTasks = releaseTasks.filter((id) => !epicIds.has(id));
138
- const previousVersion = await findLatestPushedVersion(cwd);
139
- const now = new Date().toISOString();
140
- const id = `rel-${normalizedVersion.replace(/[^a-z0-9]/gi, '-')}`;
141
- await db
142
- .insert(schema.releaseManifests)
143
- .values({
144
- id,
145
- version: normalizedVersion,
146
- status: 'prepared',
147
- tasksJson: JSON.stringify(releaseTasks),
148
- notes: notes ?? null,
149
- previousVersion: previousVersion ?? null,
150
- createdAt: now,
151
- preparedAt: now,
152
- })
153
- .run();
154
- return {
155
- version: normalizedVersion,
156
- status: 'prepared',
157
- tasks: releaseTasks,
158
- taskCount: releaseTasks.length,
159
- };
160
- }
161
- /**
162
- * Generate changelog for a release.
163
- * @task T4788
164
- */
165
- export async function generateReleaseChangelog(version, loadTasksFn, cwd) {
166
- if (!version) {
167
- throw new Error('version is required');
168
- }
169
- const normalizedVersion = normalizeVersion(version);
170
- const db = await getDb(cwd);
171
- const rows = await db
172
- .select()
173
- .from(schema.releaseManifests)
174
- .where(eq(schema.releaseManifests.version, normalizedVersion))
175
- .limit(1)
176
- .all();
177
- if (rows.length === 0) {
178
- throw new Error(`Release ${normalizedVersion} not found`);
179
- }
180
- const row = rows[0];
181
- const releaseTasks = JSON.parse(row.tasksJson);
182
- const allTasks = await loadTasksFn();
183
- const taskMap = new Map(allTasks.map((t) => [t.id, t]));
184
- const features = [];
185
- const fixes = [];
186
- const chores = [];
187
- const docs = [];
188
- const tests = [];
189
- const changes = [];
190
- /**
191
- * Strip conventional commit prefixes from task titles.
192
- * e.g. "feat: add auth" → "Add auth", "fix(ui): button" → "Button"
193
- */
194
- function stripConventionalPrefix(title) {
195
- return title.replace(/^(feat|fix|docs?|test|chore|refactor|style|ci|build|perf)(\([^)]+\))?:\s*/i, '');
196
- }
197
- /**
198
- * Capitalize the first character of a string.
199
- */
200
- function capitalize(s) {
201
- return s.length === 0 ? s : s[0].toUpperCase() + s.slice(1);
202
- }
203
- /**
204
- * Build a changelog entry line for a task.
205
- * Uses description to enrich the entry when it's meaningfully different from the title.
206
- */
207
- function buildEntry(task) {
208
- const cleanTitle = capitalize(stripConventionalPrefix(task.title));
209
- // Strip newlines and collapse whitespace in description
210
- const safeDesc = task.description
211
- ?.replace(/\r?\n/g, ' ')
212
- .replace(/\s{2,}/g, ' ')
213
- .trim();
214
- const desc = safeDesc;
215
- // Include description only when it's non-trivial and adds information beyond the title.
216
- // Skip if: description is empty, identical to title, or a minor rephrasing (≤10% longer, no new words).
217
- const shouldIncludeDesc = (() => {
218
- if (!desc || desc.length === 0)
219
- return false;
220
- const titleNorm = cleanTitle
221
- .toLowerCase()
222
- .replace(/[^a-z0-9\s]/g, '')
223
- .trim();
224
- const descNorm = desc
225
- .toLowerCase()
226
- .replace(/[^a-z0-9\s]/g, '')
227
- .trim();
228
- if (titleNorm === descNorm)
229
- return false;
230
- if (descNorm.startsWith(titleNorm) && descNorm.length < titleNorm.length * 1.3)
231
- return false;
232
- // Require description to be at least 20 chars and contain different content
233
- return desc.length >= 20;
234
- })();
235
- if (shouldIncludeDesc) {
236
- // Truncate long descriptions to keep changelog readable
237
- const descDisplay = desc.length > 150 ? desc.slice(0, 147) + '...' : desc;
238
- return `- **${cleanTitle}**: ${descDisplay} (${task.id})`;
239
- }
240
- return `- ${cleanTitle} (${task.id})`;
241
- }
242
- /**
243
- * Categorize a task into a changelog section.
244
- * Priority order:
245
- * 1. task.type field ('epic' → skip, others are hints for 'task'/'subtask')
246
- * 2. task.labels array
247
- * 3. Title keyword scan (with conventional prefix stripped)
248
- */
249
- function categorizeTask(task) {
250
- // Fix A: Skip epics entirely — they are parent containers, not deliverables
251
- if (task.type === 'epic')
252
- return 'changes'; // Will be filtered out by the caller
253
- // Priority 1: task.type field is the most authoritative signal
254
- const taskType = (task.type ?? '').toLowerCase();
255
- if (taskType === 'test')
256
- return 'tests';
257
- if (taskType === 'fix' || taskType === 'bugfix')
258
- return 'fixes';
259
- if (taskType === 'feat' || taskType === 'feature')
260
- return 'features';
261
- if (taskType === 'docs' || taskType === 'doc')
262
- return 'docs';
263
- if (taskType === 'chore' || taskType === 'refactor')
264
- return 'chores';
265
- // Priority 2: conventional commit prefix in raw title
266
- if (/^feat(\([^)]+\))?:/.test(task.title.toLowerCase()))
267
- return 'features';
268
- if (/^fix(\([^)]+\))?:/.test(task.title.toLowerCase()))
269
- return 'fixes';
270
- if (/^docs?(\([^)]+\))?:/.test(task.title.toLowerCase()))
271
- return 'docs';
272
- if (/^test(\([^)]+\))?:/.test(task.title.toLowerCase()))
273
- return 'tests';
274
- if (/^(chore|refactor|style|ci|build|perf)(\([^)]+\))?:/.test(task.title.toLowerCase()))
275
- return 'chores';
276
- // Priority 3: labels for strong category signals
277
- const labels = task.labels ?? [];
278
- if (labels.some((l) => ['test', 'testing'].includes(l.toLowerCase())))
279
- return 'tests';
280
- if (labels.some((l) => ['fix', 'bug', 'bugfix', 'regression'].includes(l.toLowerCase())))
281
- return 'fixes';
282
- if (labels.some((l) => ['feat', 'feature', 'enhancement', 'add'].includes(l.toLowerCase())))
283
- return 'features';
284
- if (labels.some((l) => ['docs', 'documentation'].includes(l.toLowerCase())))
285
- return 'docs';
286
- if (labels.some((l) => ['chore', 'refactor', 'cleanup', 'maintenance'].includes(l.toLowerCase())))
287
- return 'chores';
288
- // Priority 4: keyword scan on the cleaned title
289
- const titleLower = stripConventionalPrefix(task.title).toLowerCase();
290
- const rawTitleLower = task.title.toLowerCase();
291
- if (titleLower.startsWith('test') ||
292
- (titleLower.includes('test') && titleLower.includes('add')))
293
- return 'tests';
294
- if (titleLower.includes('bug') ||
295
- titleLower.startsWith('fix') ||
296
- titleLower.includes('regression') ||
297
- titleLower.includes('broken'))
298
- return 'fixes';
299
- if (titleLower.startsWith('add ') ||
300
- titleLower.includes('implement') ||
301
- titleLower.startsWith('create ') ||
302
- titleLower.startsWith('introduce '))
303
- return 'features';
304
- if (titleLower.startsWith('doc') ||
305
- titleLower.includes('documentation') ||
306
- titleLower.includes('readme') ||
307
- titleLower.includes('changelog'))
308
- return 'docs';
309
- if (titleLower.startsWith('chore') ||
310
- titleLower.includes('refactor') ||
311
- titleLower.includes('cleanup') ||
312
- titleLower.includes('migrate') ||
313
- titleLower.includes('upgrade') ||
314
- titleLower.includes('remove ') ||
315
- titleLower.startsWith('audit'))
316
- return 'chores';
317
- // Raw title scan for backward compat
318
- if (rawTitleLower.startsWith('feat'))
319
- return 'features';
320
- return 'changes';
321
- }
322
- for (const taskId of releaseTasks) {
323
- const task = taskMap.get(taskId);
324
- if (!task)
325
- continue;
326
- // Fix A: Filter out epics — they are containers, not changelog entries
327
- if (task.type === 'epic')
328
- continue;
329
- // Also filter by label in case type field is not populated
330
- if (task.labels?.some((l) => l.toLowerCase() === 'epic'))
331
- continue;
332
- // Heuristic: titles starting with "EPIC:" are epics even without type field
333
- if (/^epic:/i.test(task.title.trim()))
334
- continue;
335
- // Filter out research/internal/spike/audit tasks — not user-facing deliverables
336
- const labelsLower = (task.labels ?? []).map((l) => l.toLowerCase());
337
- if (labelsLower.some((l) => ['research', 'internal', 'spike', 'audit'].includes(l)))
338
- continue;
339
- if (['spike', 'research'].includes((task.type ?? '').toLowerCase()))
340
- continue;
341
- if (/^(research|investigate|audit|spike)\s/i.test(task.title.trim()))
342
- continue;
343
- const category = categorizeTask(task);
344
- const entry = buildEntry(task);
345
- if (category === 'features')
346
- features.push(entry);
347
- else if (category === 'fixes')
348
- fixes.push(entry);
349
- else if (category === 'docs')
350
- docs.push(entry);
351
- else if (category === 'tests')
352
- tests.push(entry);
353
- else if (category === 'chores')
354
- chores.push(entry);
355
- else
356
- changes.push(entry);
357
- }
358
- const sections = [];
359
- const date = new Date().toISOString().split('T')[0];
360
- sections.push(`## ${normalizedVersion} (${date})`);
361
- sections.push('');
362
- if (row.notes) {
363
- sections.push(row.notes);
364
- sections.push('');
365
- }
366
- if (features.length > 0) {
367
- sections.push('### Features');
368
- sections.push(...features);
369
- sections.push('');
370
- }
371
- if (fixes.length > 0) {
372
- sections.push('### Bug Fixes');
373
- sections.push(...fixes);
374
- sections.push('');
375
- }
376
- if (docs.length > 0) {
377
- sections.push('### Documentation');
378
- sections.push(...docs);
379
- sections.push('');
380
- }
381
- if (tests.length > 0) {
382
- sections.push('### Tests');
383
- sections.push(...tests);
384
- sections.push('');
385
- }
386
- if (chores.length > 0) {
387
- sections.push('### Chores');
388
- sections.push(...chores);
389
- sections.push('');
390
- }
391
- if (changes.length > 0) {
392
- sections.push('### Changes');
393
- sections.push(...changes);
394
- sections.push('');
395
- }
396
- const changelog = sections.join('\n');
397
- await db
398
- .update(schema.releaseManifests)
399
- .set({ changelog })
400
- .where(eq(schema.releaseManifests.version, normalizedVersion))
401
- .run();
402
- // Write or update CHANGELOG.md with section-aware merge
403
- const changelogPath = join(cwd ?? process.cwd(), 'CHANGELOG.md');
404
- let existingChangelogContent = '';
405
- try {
406
- existingChangelogContent = await readFile(changelogPath, 'utf8');
407
- }
408
- catch {
409
- // File doesn't exist yet — start fresh
410
- }
411
- const { customBlocks } = parseChangelogBlocks(existingChangelogContent);
412
- // Build the changelog body (content after the ## header line)
413
- const changelogBody = sections.slice(2).join('\n'); // skip header + blank line
414
- await writeChangelogSection(normalizedVersion.replace(/^v/, ''), changelogBody, customBlocks, changelogPath);
415
- return {
416
- version: normalizedVersion,
417
- changelog,
418
- taskCount: releaseTasks.length,
419
- sections: {
420
- features: features.length,
421
- fixes: fixes.length,
422
- docs: docs.length,
423
- tests: tests.length,
424
- chores: chores.length,
425
- changes: changes.length,
426
- },
427
- };
428
- }
429
- /**
430
- * List all releases.
431
- * @task T4788
432
- */
433
- export async function listManifestReleases(optionsOrCwd, cwd) {
434
- const options = typeof optionsOrCwd === 'string' || optionsOrCwd === undefined ? {} : optionsOrCwd;
435
- const effectiveCwd = typeof optionsOrCwd === 'string' ? optionsOrCwd : cwd;
436
- const limit = normalizeLimit(options.limit);
437
- const offset = normalizeOffset(options.offset);
438
- const pageLimit = effectivePageLimit(limit, offset);
439
- const db = await getDb(effectiveCwd);
440
- const totalRow = await db.select({ count: count() }).from(schema.releaseManifests).get();
441
- const total = totalRow?.count ?? 0;
442
- const conditions = options.status ? [eq(schema.releaseManifests.status, options.status)] : [];
443
- const whereClause = conditions.length > 0 ? and(...conditions) : undefined;
444
- const filteredRow = await db
445
- .select({ count: count() })
446
- .from(schema.releaseManifests)
447
- .where(whereClause)
448
- .get();
449
- const filtered = filteredRow?.count ?? 0;
450
- let query = db
451
- .select()
452
- .from(schema.releaseManifests)
453
- .where(whereClause)
454
- .orderBy(desc(schema.releaseManifests.createdAt));
455
- if (pageLimit !== undefined) {
456
- query = query.limit(pageLimit);
457
- }
458
- if (offset !== undefined) {
459
- query = query.offset(offset);
460
- }
461
- const rows = await query.all();
462
- const latest = await findLatestPushedVersion(effectiveCwd);
463
- return {
464
- releases: rows.map((r) => ({
465
- version: r.version,
466
- status: r.status,
467
- createdAt: r.createdAt,
468
- taskCount: JSON.parse(r.tasksJson).length,
469
- })),
470
- total,
471
- filtered,
472
- latest,
473
- page: createPage({ total: filtered, limit: pageLimit, offset }),
474
- };
475
- }
476
- /**
477
- * Show release details.
478
- * @task T4788
479
- */
480
- export async function showManifestRelease(version, cwd) {
481
- if (!version) {
482
- throw new Error('version is required');
483
- }
484
- const normalizedVersion = normalizeVersion(version);
485
- const db = await getDb(cwd);
486
- const rows = await db
487
- .select()
488
- .from(schema.releaseManifests)
489
- .where(eq(schema.releaseManifests.version, normalizedVersion))
490
- .limit(1)
491
- .all();
492
- if (rows.length === 0) {
493
- throw new Error(`Release ${normalizedVersion} not found`);
494
- }
495
- return rowToManifest(rows[0]);
496
- }
497
- /**
498
- * Mark release as committed (metadata only).
499
- * @task T4788
500
- */
501
- export async function commitRelease(version, cwd) {
502
- if (!version) {
503
- throw new Error('version is required');
504
- }
505
- const normalizedVersion = normalizeVersion(version);
506
- const db = await getDb(cwd);
507
- const rows = await db
508
- .select()
509
- .from(schema.releaseManifests)
510
- .where(eq(schema.releaseManifests.version, normalizedVersion))
511
- .limit(1)
512
- .all();
513
- if (rows.length === 0) {
514
- throw new Error(`Release ${normalizedVersion} not found`);
515
- }
516
- if (rows[0].status !== 'prepared') {
517
- throw new Error(`Release ${normalizedVersion} is in state '${rows[0].status}', expected 'prepared'`);
518
- }
519
- const committedAt = new Date().toISOString();
520
- await db
521
- .update(schema.releaseManifests)
522
- .set({ status: 'committed', committedAt })
523
- .where(eq(schema.releaseManifests.version, normalizedVersion))
524
- .run();
525
- return { version: normalizedVersion, status: 'committed', committedAt };
526
- }
527
- /**
528
- * Mark release as tagged (metadata only).
529
- * @task T4788
530
- */
531
- export async function tagRelease(version, cwd) {
532
- if (!version) {
533
- throw new Error('version is required');
534
- }
535
- const normalizedVersion = normalizeVersion(version);
536
- const db = await getDb(cwd);
537
- const rows = await db
538
- .select()
539
- .from(schema.releaseManifests)
540
- .where(eq(schema.releaseManifests.version, normalizedVersion))
541
- .limit(1)
542
- .all();
543
- if (rows.length === 0) {
544
- throw new Error(`Release ${normalizedVersion} not found`);
545
- }
546
- const taggedAt = new Date().toISOString();
547
- await db
548
- .update(schema.releaseManifests)
549
- .set({ status: 'tagged', taggedAt })
550
- .where(eq(schema.releaseManifests.version, normalizedVersion))
551
- .run();
552
- return { version: normalizedVersion, status: 'tagged', taggedAt };
553
- }
554
- /**
555
- * Run release validation gates.
556
- * @task T4788
557
- * @task T5586
558
- */
559
- export async function runReleaseGates(version, loadTasksFn, cwd, opts) {
560
- if (!version) {
561
- throw new Error('version is required');
562
- }
563
- const normalizedVersion = normalizeVersion(version);
564
- const db = await getDb(cwd);
565
- const rows = await db
566
- .select()
567
- .from(schema.releaseManifests)
568
- .where(eq(schema.releaseManifests.version, normalizedVersion))
569
- .limit(1)
570
- .all();
571
- if (rows.length === 0) {
572
- throw new Error(`Release ${normalizedVersion} not found`);
573
- }
574
- const row = rows[0];
575
- const releaseTasks = JSON.parse(row.tasksJson);
576
- const gates = [];
577
- gates.push({
578
- name: 'version_valid',
579
- status: isValidVersion(normalizedVersion) ? 'passed' : 'failed',
580
- message: isValidVersion(normalizedVersion)
581
- ? 'Version format is valid'
582
- : 'Invalid version format',
583
- });
584
- const releaseConfig = loadReleaseConfig(cwd);
585
- if (releaseConfig.versioningScheme === 'calver') {
586
- const calver = validateCalVerWindow(normalizedVersion);
587
- gates.push({
588
- name: 'calver_window',
589
- status: calver.valid ? 'passed' : 'failed',
590
- message: calver.message,
591
- });
592
- }
593
- gates.push({
594
- name: 'has_tasks',
595
- status: releaseTasks.length > 0 ? 'passed' : 'failed',
596
- message: releaseTasks.length > 0 ? `${releaseTasks.length} tasks included` : 'No tasks in release',
597
- });
598
- gates.push({
599
- name: 'has_changelog',
600
- status: row.changelog ? 'passed' : 'failed',
601
- message: row.changelog
602
- ? 'Changelog generated'
603
- : 'No changelog generated. Run release.changelog first.',
604
- });
605
- const allTasks = await loadTasksFn();
606
- const incompleteTasks = releaseTasks.filter((id) => {
607
- const task = allTasks.find((t) => t.id === id);
608
- return task && task.status !== 'done';
609
- });
610
- gates.push({
611
- name: 'tasks_complete',
612
- status: incompleteTasks.length === 0 ? 'passed' : 'failed',
613
- message: incompleteTasks.length === 0
614
- ? 'All tasks completed'
615
- : `${incompleteTasks.length} tasks not completed: ${incompleteTasks.join(', ')}`,
616
- });
617
- // G2: Build artifact — dist/ must exist (Node projects only)
618
- // Monorepo-aware: checks packages/cleo/dist/ first, then root dist/
619
- const projectRoot = cwd ?? getProjectRoot();
620
- const monorepoDist = join(projectRoot, 'packages', 'cleo', 'dist', 'cli', 'index.js');
621
- const rootDist = join(projectRoot, 'dist', 'cli', 'index.js');
622
- const distExists = existsSync(monorepoDist) || existsSync(rootDist);
623
- const isNodeProject = existsSync(join(projectRoot, 'package.json'));
624
- if (isNodeProject) {
625
- gates.push({
626
- name: 'build_artifact',
627
- status: distExists ? 'passed' : 'failed',
628
- message: distExists ? 'Build artifacts present' : 'dist/ not built — run: pnpm run build',
629
- });
630
- }
631
- // GD1: Clean working tree (CHANGELOG.md and version bump targets are allowed to be dirty)
632
- // Skipped in dry-run mode — dry-run makes no commits so tree cleanliness is irrelevant.
633
- // Untracked files (?? lines) are excluded from the dirty check — they do not affect git
634
- // commit/tag operations and must not block releases.
635
- if (opts?.dryRun) {
636
- gates.push({
637
- name: 'clean_working_tree',
638
- status: 'passed',
639
- message: 'Skipped in dry-run mode',
640
- });
641
- }
642
- else {
643
- // Dynamically build exclusion set from configured version bump targets + CHANGELOG.md
644
- const bumpTargets = getVersionBumpConfig(cwd);
645
- const allowedDirty = new Set(['CHANGELOG.md', ...bumpTargets.map((t) => t.file)]);
646
- let workingTreeClean = true;
647
- let dirtyFiles = [];
648
- try {
649
- const porcelain = execFileSync('git', ['status', '--porcelain'], {
650
- cwd: projectRoot,
651
- encoding: 'utf-8',
652
- stdio: 'pipe',
653
- });
654
- dirtyFiles = porcelain
655
- .split('\n')
656
- .filter((l) => l.trim())
657
- // Exclude untracked files (?? prefix) — they don't affect commits or tags
658
- .filter((l) => !l.startsWith('?? '))
659
- .map((l) => l.slice(3).trim())
660
- .filter((f) => !allowedDirty.has(f));
661
- workingTreeClean = dirtyFiles.length === 0;
662
- }
663
- catch {
664
- /* git not available — skip */
665
- }
666
- const excludeList = [...allowedDirty].join(', ');
667
- gates.push({
668
- name: 'clean_working_tree',
669
- status: workingTreeClean ? 'passed' : 'failed',
670
- message: workingTreeClean
671
- ? `Working tree clean (excluding ${excludeList})`
672
- : `Uncommitted changes in: ${dirtyFiles.slice(0, 5).join(', ')}${dirtyFiles.length > 5 ? ` (+${dirtyFiles.length - 5} more)` : ''}`,
673
- });
674
- }
675
- // GD2: Branch target — use GitFlow config if available, else defaults
676
- const isPreRelease = normalizedVersion.includes('-');
677
- let currentBranch = '';
678
- try {
679
- currentBranch = execFileSync('git', ['rev-parse', '--abbrev-ref', 'HEAD'], {
680
- cwd: projectRoot,
681
- encoding: 'utf-8',
682
- stdio: 'pipe',
683
- }).trim();
684
- }
685
- catch {
686
- /* git not available — skip */
687
- }
688
- const gitFlowCfg = getGitFlowConfig(releaseConfig);
689
- const channelCfg = getChannelConfig(releaseConfig);
690
- const expectedBranch = isPreRelease ? gitFlowCfg.branches.develop : gitFlowCfg.branches.main;
691
- const isFeatureBranch = currentBranch.startsWith(gitFlowCfg.branches.featurePrefix) ||
692
- currentBranch.startsWith(gitFlowCfg.branches.hotfixPrefix) ||
693
- currentBranch.startsWith(gitFlowCfg.branches.releasePrefix);
694
- const branchOk = !currentBranch || // git unavailable → pass
695
- currentBranch === 'HEAD' || // detached HEAD → pass
696
- currentBranch === expectedBranch || // exactly right branch → pass
697
- (isPreRelease && isFeatureBranch); // feature/hotfix/release branch with pre-release → pass
698
- // Resolve channel from current branch
699
- const detectedChannel = currentBranch
700
- ? resolveChannelFromBranch(currentBranch, channelCfg)
701
- : isPreRelease
702
- ? 'beta'
703
- : 'latest';
704
- gates.push({
705
- name: 'branch_target',
706
- status: branchOk ? 'passed' : 'failed',
707
- message: branchOk
708
- ? `On correct branch: ${currentBranch} (channel: ${detectedChannel})`
709
- : `Expected branch '${expectedBranch}' for ${isPreRelease ? 'pre-release' : 'stable'} release, but on '${currentBranch}'`,
710
- });
711
- // GD3: Branch protection — detect if push requires a PR (informational, never fails)
712
- const pushMode = getPushMode(releaseConfig);
713
- let requiresPR = false;
714
- if (pushMode === 'pr') {
715
- requiresPR = true;
716
- }
717
- else if (pushMode === 'auto') {
718
- try {
719
- const protectionResult = await detectBranchProtection(expectedBranch, 'origin', projectRoot);
720
- requiresPR = protectionResult.protected;
721
- }
722
- catch {
723
- // Branch protection detection is best-effort; never block release
724
- requiresPR = false;
725
- }
726
- }
727
- gates.push({
728
- name: 'branch_protection',
729
- status: 'passed',
730
- message: requiresPR
731
- ? `Branch '${expectedBranch}' is protected — release.ship will create a PR`
732
- : `Branch '${expectedBranch}' allows direct push`,
733
- });
734
- const allPassed = gates.every((g) => g.status === 'passed');
735
- const metadata = {
736
- channel: detectedChannel,
737
- requiresPR,
738
- targetBranch: expectedBranch,
739
- currentBranch,
740
- };
741
- return {
742
- version: normalizedVersion,
743
- allPassed,
744
- gates,
745
- passedCount: gates.filter((g) => g.status === 'passed').length,
746
- failedCount: gates.filter((g) => g.status === 'failed').length,
747
- metadata,
748
- };
749
- }
750
- /**
751
- * Cancel and remove a release in draft or prepared state.
752
- * Only releases that have not yet been committed to git can be cancelled.
753
- * For committed/tagged/pushed releases, use rollbackRelease() instead.
754
- *
755
- * @task T5602
756
- */
757
- export async function cancelRelease(version, projectRoot) {
758
- if (!version) {
759
- throw new Error('version is required');
760
- }
761
- const normalizedVersion = normalizeVersion(version);
762
- const db = await getDb(projectRoot);
763
- const rows = await db
764
- .select()
765
- .from(schema.releaseManifests)
766
- .where(eq(schema.releaseManifests.version, normalizedVersion))
767
- .limit(1)
768
- .all();
769
- if (rows.length === 0) {
770
- return {
771
- success: false,
772
- message: `Release ${normalizedVersion} not found`,
773
- version: normalizedVersion,
774
- };
775
- }
776
- const status = rows[0].status;
777
- const cancellableStates = ['draft', 'prepared'];
778
- if (!cancellableStates.includes(status)) {
779
- return {
780
- success: false,
781
- message: `Cannot cancel a release in '${status}' state. Use 'release rollback' instead.`,
782
- version: normalizedVersion,
783
- };
784
- }
785
- await db
786
- .delete(schema.releaseManifests)
787
- .where(eq(schema.releaseManifests.version, normalizedVersion))
788
- .run();
789
- return {
790
- success: true,
791
- message: `Release ${normalizedVersion} cancelled and removed`,
792
- version: normalizedVersion,
793
- };
794
- }
795
- /**
796
- * Rollback a release.
797
- * @task T4788
798
- */
799
- export async function rollbackRelease(version, reason, cwd) {
800
- if (!version) {
801
- throw new Error('version is required');
802
- }
803
- const normalizedVersion = normalizeVersion(version);
804
- const db = await getDb(cwd);
805
- const rows = await db
806
- .select()
807
- .from(schema.releaseManifests)
808
- .where(eq(schema.releaseManifests.version, normalizedVersion))
809
- .limit(1)
810
- .all();
811
- if (rows.length === 0) {
812
- throw new Error(`Release ${normalizedVersion} not found`);
813
- }
814
- const previousStatus = rows[0].status;
815
- await db
816
- .update(schema.releaseManifests)
817
- .set({ status: 'rolled_back' })
818
- .where(eq(schema.releaseManifests.version, normalizedVersion))
819
- .run();
820
- return {
821
- version: normalizedVersion,
822
- previousStatus,
823
- status: 'rolled_back',
824
- reason: reason ?? 'No reason provided',
825
- };
826
- }
827
- /**
828
- * Read push policy from project config.
829
- * Returns undefined if no push config exists.
830
- */
831
- async function readPushPolicy(cwd) {
832
- const configPath = join(getCleoDirAbsolute(cwd), 'config.json');
833
- let config;
834
- try {
835
- const raw = await readFile(configPath, 'utf-8');
836
- config = JSON.parse(raw);
837
- }
838
- catch {
839
- return undefined;
840
- }
841
- if (!config)
842
- return undefined;
843
- const release = config.release;
844
- if (!release)
845
- return undefined;
846
- return release.push;
847
- }
848
- /**
849
- * Push release to remote via git.
850
- *
851
- * Respects config.release.push policy:
852
- * - remote: override default remote (fallback to 'origin')
853
- * - requireCleanTree: verify git working tree is clean before push
854
- * - allowedBranches: verify current branch is in the allowed list
855
- * - enabled: if false and no explicit push flag, caller should skip
856
- *
857
- * @task T4788
858
- * @task T4276
859
- */
860
- export async function pushRelease(version, remote, cwd, opts) {
861
- if (!version) {
862
- throw new Error('version is required');
863
- }
864
- const normalizedVersion = normalizeVersion(version);
865
- const projectRoot = getProjectRoot(cwd);
866
- const pushPolicy = await readPushPolicy(cwd);
867
- // Resolve effective push mode: opts.mode > pushPolicy.mode > config > 'direct'
868
- const configPushMode = getPushMode(loadReleaseConfig(cwd));
869
- const effectivePushMode = opts?.mode ?? pushPolicy?.mode ?? configPushMode;
870
- // If branch protection detected and mode allows PR creation, signal PR required
871
- if (effectivePushMode === 'pr' || effectivePushMode === 'auto') {
872
- const targetRemoteForCheck = remote ?? pushPolicy?.remote ?? 'origin';
873
- let branchIsProtected = effectivePushMode === 'pr'; // 'pr' always requires PR
874
- if (effectivePushMode === 'auto') {
875
- try {
876
- const protection = await detectBranchProtection(pushPolicy?.allowedBranches?.[0] ?? 'main', targetRemoteForCheck, projectRoot);
877
- branchIsProtected = protection.protected;
878
- }
879
- catch {
880
- // Best-effort; default to direct push if detection fails
881
- branchIsProtected = false;
882
- }
883
- }
884
- if (branchIsProtected) {
885
- return {
886
- version: normalizedVersion,
887
- status: 'requires_pr',
888
- remote: targetRemoteForCheck,
889
- pushedAt: new Date().toISOString(),
890
- requiresPR: true,
891
- };
892
- }
893
- }
894
- // If push policy says disabled and caller didn't explicitly pass --push, skip
895
- if (pushPolicy && pushPolicy.enabled === false && !opts?.explicitPush) {
896
- throw new Error('Push is disabled by config (release.push.enabled=false). Use --push to override.');
897
- }
898
- // Determine remote: explicit param > config > 'origin'
899
- const targetRemote = remote ?? pushPolicy?.remote ?? 'origin';
900
- // Check requireCleanTree
901
- // Untracked files (?? lines) are excluded — they do not affect push operations.
902
- if (pushPolicy?.requireCleanTree) {
903
- const statusOutput = execFileSync('git', ['status', '--porcelain'], {
904
- cwd: projectRoot,
905
- timeout: 10000,
906
- encoding: 'utf-8',
907
- stdio: ['pipe', 'pipe', 'pipe'],
908
- });
909
- const trackedDirty = statusOutput
910
- .split('\n')
911
- .filter((l) => l.trim() && !l.startsWith('?? '))
912
- .join('\n');
913
- if (trackedDirty.trim().length > 0) {
914
- throw new Error('Git working tree is not clean. Commit or stash changes before pushing (config: release.push.requireCleanTree=true).');
915
- }
916
- }
917
- // Check allowedBranches
918
- if (pushPolicy?.allowedBranches && pushPolicy.allowedBranches.length > 0) {
919
- const currentBranch = execFileSync('git', ['rev-parse', '--abbrev-ref', 'HEAD'], {
920
- cwd: projectRoot,
921
- timeout: 10000,
922
- encoding: 'utf-8',
923
- stdio: ['pipe', 'pipe', 'pipe'],
924
- }).trim();
925
- if (!pushPolicy.allowedBranches.includes(currentBranch)) {
926
- throw new Error(`Current branch '${currentBranch}' is not in allowed branches: ${pushPolicy.allowedBranches.join(', ')} (config: release.push.allowedBranches).`);
927
- }
928
- }
929
- execFileSync('git', ['push', targetRemote, '--follow-tags'], {
930
- cwd: projectRoot,
931
- timeout: 60000,
932
- encoding: 'utf-8',
933
- stdio: ['pipe', 'pipe', 'pipe'],
934
- });
935
- return {
936
- version: normalizedVersion,
937
- status: 'pushed',
938
- remote: targetRemote,
939
- pushedAt: new Date().toISOString(),
940
- };
941
- }
942
- /**
943
- * Update release status after push, with optional provenance fields.
944
- * @task T4788
945
- * @task T5580
946
- */
947
- export async function markReleasePushed(version, pushedAt, cwd, provenance) {
948
- const normalizedVersion = normalizeVersion(version);
949
- const db = await getDb(cwd);
950
- await db
951
- .update(schema.releaseManifests)
952
- .set({
953
- status: 'pushed',
954
- pushedAt,
955
- ...(provenance?.commitSha != null ? { commitSha: provenance.commitSha } : {}),
956
- ...(provenance?.gitTag != null ? { gitTag: provenance.gitTag } : {}),
957
- })
958
- .where(eq(schema.releaseManifests.version, normalizedVersion))
959
- .run();
960
- }
961
- /**
962
- * One-time migration: read .cleo/releases.json and insert each release into
963
- * the release_manifests table. Renames the file to releases.json.migrated on success.
964
- *
965
- * @task T5580
966
- */
967
- export async function migrateReleasesJsonToSqlite(projectRoot) {
968
- const releasesPath = join(getCleoDirAbsolute(projectRoot), 'releases.json');
969
- if (!existsSync(releasesPath)) {
970
- return { migrated: 0 };
971
- }
972
- let raw;
973
- try {
974
- const contents = await readFile(releasesPath, 'utf-8');
975
- raw = JSON.parse(contents);
976
- }
977
- catch {
978
- return { migrated: 0 };
979
- }
980
- if (!raw || !Array.isArray(raw.releases)) {
981
- return { migrated: 0 };
982
- }
983
- const db = await getDb(projectRoot);
984
- let migrated = 0;
985
- for (const r of raw.releases) {
986
- // Skip if already exists by version
987
- const existing = await db
988
- .select({ id: schema.releaseManifests.id })
989
- .from(schema.releaseManifests)
990
- .where(eq(schema.releaseManifests.version, r.version))
991
- .limit(1)
992
- .all();
993
- if (existing.length > 0)
994
- continue;
995
- const id = `rel-${r.version.replace(/[^a-z0-9]/gi, '-')}`;
996
- await db
997
- .insert(schema.releaseManifests)
998
- .values({
999
- id,
1000
- version: r.version,
1001
- status: r.status,
1002
- tasksJson: JSON.stringify(r.tasks ?? []),
1003
- notes: r.notes ?? null,
1004
- changelog: r.changelog ?? null,
1005
- previousVersion: r.previousVersion ?? null,
1006
- createdAt: r.createdAt,
1007
- preparedAt: r.preparedAt ?? null,
1008
- committedAt: r.committedAt ?? null,
1009
- taggedAt: r.taggedAt ?? null,
1010
- pushedAt: r.pushedAt ?? null,
1011
- })
1012
- .run();
1013
- migrated++;
1014
- }
1015
- // Rename legacy file on success
1016
- renameSync(releasesPath, releasesPath + '.migrated');
1017
- return { migrated };
1018
- }
1019
- //# sourceMappingURL=release-manifest.js.map