@cleocode/core 2026.3.73 → 2026.3.76

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1093) 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/cleo.d.ts.map +1 -1
  17. package/dist/conduit/conduit-client.d.ts +26 -0
  18. package/dist/conduit/conduit-client.d.ts.map +1 -0
  19. package/dist/conduit/factory.d.ts +13 -0
  20. package/dist/conduit/factory.d.ts.map +1 -0
  21. package/dist/conduit/http-transport.d.ts +32 -0
  22. package/dist/conduit/http-transport.d.ts.map +1 -0
  23. package/dist/conduit/index.d.ts +12 -0
  24. package/dist/conduit/index.d.ts.map +1 -0
  25. package/dist/crypto/credentials.d.ts +40 -0
  26. package/dist/crypto/credentials.d.ts.map +1 -0
  27. package/dist/engine-result.d.ts +1 -1
  28. package/dist/engine-result.d.ts.map +1 -1
  29. package/dist/error-catalog.d.ts +1 -1
  30. package/dist/error-catalog.d.ts.map +1 -1
  31. package/dist/error-registry.d.ts +1 -1
  32. package/dist/error-registry.d.ts.map +1 -1
  33. package/dist/errors.d.ts +1 -1
  34. package/dist/errors.d.ts.map +1 -1
  35. package/dist/hooks/handlers/agent-hooks.d.ts.map +1 -1
  36. package/dist/hooks/handlers/context-hooks.d.ts.map +1 -1
  37. package/dist/hooks/handlers/error-hooks.d.ts +14 -5
  38. package/dist/hooks/handlers/error-hooks.d.ts.map +1 -1
  39. package/dist/hooks/handlers/file-hooks.d.ts.map +1 -1
  40. package/dist/hooks/handlers/handler-helpers.d.ts +41 -0
  41. package/dist/hooks/handlers/handler-helpers.d.ts.map +1 -0
  42. package/dist/hooks/handlers/mcp-hooks.d.ts.map +1 -1
  43. package/dist/hooks/handlers/session-hooks.d.ts.map +1 -1
  44. package/dist/hooks/handlers/task-hooks.d.ts.map +1 -1
  45. package/dist/hooks/handlers/work-capture-hooks.d.ts.map +1 -1
  46. package/dist/index.d.ts +3 -1
  47. package/dist/index.d.ts.map +1 -1
  48. package/dist/index.js +2766 -939
  49. package/dist/index.js.map +4 -4
  50. package/dist/init.d.ts.map +1 -1
  51. package/dist/internal.d.ts +7 -0
  52. package/dist/internal.d.ts.map +1 -1
  53. package/dist/memory/brain-retrieval.d.ts +3 -0
  54. package/dist/memory/brain-retrieval.d.ts.map +1 -1
  55. package/dist/mvi-helpers.d.ts +52 -0
  56. package/dist/mvi-helpers.d.ts.map +1 -0
  57. package/dist/nexus/index.d.ts +2 -0
  58. package/dist/nexus/index.d.ts.map +1 -1
  59. package/dist/nexus/workspace.d.ts +128 -0
  60. package/dist/nexus/workspace.d.ts.map +1 -0
  61. package/dist/output.d.ts +2 -2
  62. package/dist/output.d.ts.map +1 -1
  63. package/dist/pagination.d.ts +1 -1
  64. package/dist/pagination.d.ts.map +1 -1
  65. package/dist/sessions/find.d.ts +3 -0
  66. package/dist/sessions/find.d.ts.map +1 -1
  67. package/dist/sessions/index.d.ts.map +1 -1
  68. package/dist/store/agent-registry-accessor.d.ts +454 -0
  69. package/dist/store/agent-registry-accessor.d.ts.map +1 -0
  70. package/dist/store/converters.d.ts.map +1 -1
  71. package/dist/store/db-helpers.d.ts.map +1 -1
  72. package/dist/store/safety-data-accessor.d.ts +7 -0
  73. package/dist/store/safety-data-accessor.d.ts.map +1 -1
  74. package/dist/store/signaldock-sqlite.d.ts +48 -0
  75. package/dist/store/signaldock-sqlite.d.ts.map +1 -0
  76. package/dist/store/sqlite-data-accessor.d.ts.map +1 -1
  77. package/dist/store/sqlite.d.ts.map +1 -1
  78. package/dist/store/task-store.d.ts.map +1 -1
  79. package/dist/store/tasks-schema.d.ts +240 -0
  80. package/dist/store/tasks-schema.d.ts.map +1 -1
  81. package/dist/store/validation-schemas.d.ts +32 -0
  82. package/dist/store/validation-schemas.d.ts.map +1 -1
  83. package/dist/system/health.d.ts.map +1 -1
  84. package/dist/task-work/index.d.ts.map +1 -1
  85. package/dist/tasks/find.d.ts +3 -0
  86. package/dist/tasks/find.d.ts.map +1 -1
  87. package/dist/tasks/list.d.ts +5 -2
  88. package/dist/tasks/list.d.ts.map +1 -1
  89. package/dist/tasks/show.d.ts +3 -0
  90. package/dist/tasks/show.d.ts.map +1 -1
  91. package/dist/upgrade.d.ts.map +1 -1
  92. package/migrations/drizzle-tasks/20260324000000_assignee-column/migration.sql +6 -0
  93. package/migrations/drizzle-tasks/20260324000000_assignee-column/snapshot.json +9 -0
  94. package/migrations/drizzle-tasks/20260327000000_agent-credentials/migration.sql +23 -0
  95. package/package.json +7 -7
  96. package/src/__tests__/cli-parity.test.js +11 -1
  97. package/src/__tests__/cli-parity.test.js.map +1 -1
  98. package/src/__tests__/cli-parity.test.ts +17 -1
  99. package/src/__tests__/human-output.test.js +11 -1
  100. package/src/__tests__/human-output.test.js.map +1 -1
  101. package/src/__tests__/human-output.test.ts +18 -1
  102. package/src/__tests__/injection-chain.test.js +3 -2
  103. package/src/__tests__/injection-chain.test.js.map +1 -1
  104. package/src/__tests__/injection-mvi-tiers.test.d.ts +2 -2
  105. package/src/__tests__/injection-mvi-tiers.test.js +15 -15
  106. package/src/__tests__/injection-mvi-tiers.test.js.map +1 -1
  107. package/src/__tests__/lafs-conformance.test.d.ts +1 -1
  108. package/src/__tests__/lafs-conformance.test.js +2 -2
  109. package/src/__tests__/sharing.test.js +19 -0
  110. package/src/__tests__/sharing.test.js.map +1 -1
  111. package/src/agents/__tests__/agent-registry.test.d.ts +12 -0
  112. package/src/agents/__tests__/agent-registry.test.d.ts.map +1 -0
  113. package/src/agents/__tests__/agent-registry.test.js +262 -0
  114. package/src/agents/__tests__/agent-registry.test.js.map +1 -0
  115. package/src/agents/__tests__/execution-learning.test.d.ts +14 -0
  116. package/src/agents/__tests__/execution-learning.test.d.ts.map +1 -0
  117. package/src/agents/__tests__/execution-learning.test.js +533 -0
  118. package/src/agents/__tests__/execution-learning.test.js.map +1 -0
  119. package/src/agents/__tests__/health-monitor.test.d.ts +10 -0
  120. package/src/agents/__tests__/health-monitor.test.d.ts.map +1 -0
  121. package/src/agents/__tests__/health-monitor.test.js +259 -0
  122. package/src/agents/__tests__/health-monitor.test.js.map +1 -0
  123. package/src/agents/__tests__/registry.test.js +27 -2
  124. package/src/agents/__tests__/registry.test.js.map +1 -1
  125. package/src/cant/__tests__/cant-agent-parse.test.ts +94 -0
  126. package/src/cant/approval.ts +218 -0
  127. package/src/cant/context-builder.ts +135 -0
  128. package/src/cant/discretion.ts +149 -0
  129. package/src/cant/index.ts +58 -0
  130. package/src/cant/parallel-runner.ts +205 -0
  131. package/src/cant/types.ts +158 -0
  132. package/src/cant/workflow-executor.ts +618 -0
  133. package/src/cleo.ts +14 -0
  134. package/src/conduit/conduit-client.ts +114 -0
  135. package/src/conduit/factory.ts +45 -0
  136. package/src/conduit/http-transport.ts +140 -0
  137. package/src/conduit/index.ts +12 -0
  138. package/src/crypto/credentials.ts +166 -0
  139. package/src/engine-result.ts +1 -1
  140. package/src/error-catalog.ts +1 -1
  141. package/src/error-registry.ts +1 -1
  142. package/src/errors.ts +1 -1
  143. package/src/hooks/handlers/__tests__/hook-automation-e2e.test.d.ts +13 -0
  144. package/src/hooks/handlers/__tests__/hook-automation-e2e.test.d.ts.map +1 -0
  145. package/src/hooks/handlers/__tests__/hook-automation-e2e.test.js +501 -0
  146. package/src/hooks/handlers/__tests__/hook-automation-e2e.test.js.map +1 -0
  147. package/src/hooks/handlers/agent-hooks.ts +1 -30
  148. package/src/hooks/handlers/context-hooks.ts +1 -30
  149. package/src/hooks/handlers/error-hooks.ts +14 -5
  150. package/src/hooks/handlers/file-hooks.ts +1 -6
  151. package/src/hooks/handlers/handler-helpers.ts +62 -0
  152. package/src/hooks/handlers/mcp-hooks.ts +2 -14
  153. package/src/hooks/handlers/session-hooks.ts +1 -6
  154. package/src/hooks/handlers/task-hooks.ts +1 -6
  155. package/src/hooks/handlers/work-capture-hooks.ts +1 -10
  156. package/src/index.ts +11 -1
  157. package/src/init.ts +12 -0
  158. package/src/intelligence/__tests__/adaptive-validation.test.d.ts +11 -0
  159. package/src/intelligence/__tests__/adaptive-validation.test.d.ts.map +1 -0
  160. package/src/intelligence/__tests__/adaptive-validation.test.js +517 -0
  161. package/src/intelligence/__tests__/adaptive-validation.test.js.map +1 -0
  162. package/src/intelligence/__tests__/impact.test.d.ts +1 -0
  163. package/src/intelligence/__tests__/impact.test.d.ts.map +1 -1
  164. package/src/intelligence/__tests__/impact.test.js +132 -1
  165. package/src/intelligence/__tests__/impact.test.js.map +1 -1
  166. package/src/internal.ts +17 -0
  167. package/src/lib/__tests__/retry.test.d.ts +7 -0
  168. package/src/lib/__tests__/retry.test.d.ts.map +1 -0
  169. package/src/lib/__tests__/retry.test.js +225 -0
  170. package/src/lib/__tests__/retry.test.js.map +1 -0
  171. package/src/lifecycle/__tests__/chain-store.test.js +6 -0
  172. package/src/lifecycle/__tests__/chain-store.test.js.map +1 -1
  173. package/src/lifecycle/__tests__/tessera-engine.test.js +52 -0
  174. package/src/lifecycle/__tests__/tessera-engine.test.js.map +1 -1
  175. package/src/memory/__tests__/brain-automation.test.d.ts +11 -0
  176. package/src/memory/__tests__/brain-automation.test.d.ts.map +1 -0
  177. package/src/memory/__tests__/brain-automation.test.js +730 -0
  178. package/src/memory/__tests__/brain-automation.test.js.map +1 -0
  179. package/src/memory/brain-retrieval.ts +9 -0
  180. package/src/mvi-helpers.ts +81 -0
  181. package/src/nexus/index.ts +15 -0
  182. package/src/nexus/workspace.ts +520 -0
  183. package/src/output.ts +43 -10
  184. package/src/pagination.ts +1 -1
  185. package/src/sessions/__tests__/session-edge-cases.test.js +20 -1
  186. package/src/sessions/__tests__/session-edge-cases.test.js.map +1 -1
  187. package/src/sessions/__tests__/session-find.test.js +1 -1
  188. package/src/sessions/__tests__/session-find.test.js.map +1 -1
  189. package/src/sessions/__tests__/session-find.test.ts +1 -1
  190. package/src/sessions/find.ts +6 -1
  191. package/src/sessions/index.ts +9 -0
  192. package/src/store/__tests__/migration-safety.test.js +3 -0
  193. package/src/store/__tests__/migration-safety.test.js.map +1 -1
  194. package/src/store/__tests__/session-store.test.js +128 -1
  195. package/src/store/__tests__/session-store.test.js.map +1 -1
  196. package/src/store/__tests__/task-store.test.js +18 -1
  197. package/src/store/__tests__/task-store.test.js.map +1 -1
  198. package/src/store/__tests__/test-db-helper.d.ts.map +1 -1
  199. package/src/store/__tests__/test-db-helper.js +12 -0
  200. package/src/store/__tests__/test-db-helper.js.map +1 -1
  201. package/src/store/agent-registry-accessor.ts +199 -0
  202. package/src/store/converters.ts +2 -0
  203. package/src/store/db-helpers.ts +1 -0
  204. package/src/store/safety-data-accessor.ts +23 -0
  205. package/src/store/signaldock-sqlite.ts +227 -0
  206. package/src/store/sqlite-data-accessor.ts +69 -0
  207. package/src/store/sqlite.ts +4 -1
  208. package/src/store/task-store.ts +1 -0
  209. package/src/store/tasks-schema.ts +42 -0
  210. package/src/system/health.ts +33 -0
  211. package/src/task-work/index.ts +5 -0
  212. package/src/tasks/__tests__/add.test.js +19 -1
  213. package/src/tasks/__tests__/add.test.js.map +1 -1
  214. package/src/tasks/__tests__/assignee.test.d.ts +14 -0
  215. package/src/tasks/__tests__/assignee.test.d.ts.map +1 -0
  216. package/src/tasks/__tests__/assignee.test.js +125 -0
  217. package/src/tasks/__tests__/assignee.test.js.map +1 -0
  218. package/src/tasks/__tests__/assignee.test.ts +162 -0
  219. package/src/tasks/__tests__/complete-unblocks.test.js +13 -1
  220. package/src/tasks/__tests__/complete-unblocks.test.js.map +1 -1
  221. package/src/tasks/__tests__/complete.test.js +28 -7
  222. package/src/tasks/__tests__/complete.test.js.map +1 -1
  223. package/src/tasks/__tests__/epic-enforcement.test.d.ts +15 -0
  224. package/src/tasks/__tests__/epic-enforcement.test.d.ts.map +1 -0
  225. package/src/tasks/__tests__/epic-enforcement.test.js +669 -0
  226. package/src/tasks/__tests__/epic-enforcement.test.js.map +1 -0
  227. package/src/tasks/__tests__/hierarchy-policy.test.js +5 -0
  228. package/src/tasks/__tests__/hierarchy-policy.test.js.map +1 -1
  229. package/src/tasks/__tests__/minimal-test.test.d.ts +2 -0
  230. package/src/tasks/__tests__/minimal-test.test.d.ts.map +1 -0
  231. package/src/tasks/__tests__/minimal-test.test.js +25 -0
  232. package/src/tasks/__tests__/minimal-test.test.js.map +1 -0
  233. package/src/tasks/__tests__/pipeline-stage.test.d.ts +14 -0
  234. package/src/tasks/__tests__/pipeline-stage.test.d.ts.map +1 -0
  235. package/src/tasks/__tests__/pipeline-stage.test.js +277 -0
  236. package/src/tasks/__tests__/pipeline-stage.test.js.map +1 -0
  237. package/src/tasks/__tests__/update.test.js +43 -6
  238. package/src/tasks/__tests__/update.test.js.map +1 -1
  239. package/src/tasks/find.ts +11 -1
  240. package/src/tasks/list.ts +14 -3
  241. package/src/tasks/show.ts +6 -0
  242. package/src/upgrade.ts +16 -0
  243. package/dist/adapters/adapter-registry.js +0 -64
  244. package/dist/adapters/adapter-registry.js.map +0 -1
  245. package/dist/adapters/discovery.js +0 -83
  246. package/dist/adapters/discovery.js.map +0 -1
  247. package/dist/adapters/index.js +0 -9
  248. package/dist/adapters/index.js.map +0 -1
  249. package/dist/adapters/manager.js +0 -260
  250. package/dist/adapters/manager.js.map +0 -1
  251. package/dist/admin/export-tasks.js +0 -171
  252. package/dist/admin/export-tasks.js.map +0 -1
  253. package/dist/admin/export.js +0 -103
  254. package/dist/admin/export.js.map +0 -1
  255. package/dist/admin/help.js +0 -106
  256. package/dist/admin/help.js.map +0 -1
  257. package/dist/admin/import-tasks.js +0 -182
  258. package/dist/admin/import-tasks.js.map +0 -1
  259. package/dist/admin/import.js +0 -129
  260. package/dist/admin/import.js.map +0 -1
  261. package/dist/admin/index.js +0 -13
  262. package/dist/admin/index.js.map +0 -1
  263. package/dist/adrs/find.js +0 -134
  264. package/dist/adrs/find.js.map +0 -1
  265. package/dist/adrs/index.js +0 -15
  266. package/dist/adrs/index.js.map +0 -1
  267. package/dist/adrs/link-pipeline.js +0 -160
  268. package/dist/adrs/link-pipeline.js.map +0 -1
  269. package/dist/adrs/list.js +0 -43
  270. package/dist/adrs/list.js.map +0 -1
  271. package/dist/adrs/parse.js +0 -51
  272. package/dist/adrs/parse.js.map +0 -1
  273. package/dist/adrs/show.js +0 -22
  274. package/dist/adrs/show.js.map +0 -1
  275. package/dist/adrs/sync.js +0 -188
  276. package/dist/adrs/sync.js.map +0 -1
  277. package/dist/adrs/types.js +0 -9
  278. package/dist/adrs/types.js.map +0 -1
  279. package/dist/adrs/validate.js +0 -57
  280. package/dist/adrs/validate.js.map +0 -1
  281. package/dist/agents/agent-registry.js +0 -288
  282. package/dist/agents/agent-registry.js.map +0 -1
  283. package/dist/agents/agent-schema.js +0 -85
  284. package/dist/agents/agent-schema.js.map +0 -1
  285. package/dist/agents/capacity.js +0 -116
  286. package/dist/agents/capacity.js.map +0 -1
  287. package/dist/agents/execution-learning.js +0 -474
  288. package/dist/agents/execution-learning.js.map +0 -1
  289. package/dist/agents/health-monitor.js +0 -217
  290. package/dist/agents/health-monitor.js.map +0 -1
  291. package/dist/agents/index.js +0 -29
  292. package/dist/agents/index.js.map +0 -1
  293. package/dist/agents/registry.js +0 -314
  294. package/dist/agents/registry.js.map +0 -1
  295. package/dist/agents/retry.js +0 -210
  296. package/dist/agents/retry.js.map +0 -1
  297. package/dist/audit-prune.js +0 -94
  298. package/dist/audit-prune.js.map +0 -1
  299. package/dist/audit.js +0 -68
  300. package/dist/audit.js.map +0 -1
  301. package/dist/backfill/index.js +0 -229
  302. package/dist/backfill/index.js.map +0 -1
  303. package/dist/bootstrap.js +0 -367
  304. package/dist/bootstrap.js.map +0 -1
  305. package/dist/caamp/adapter.js +0 -434
  306. package/dist/caamp/adapter.js.map +0 -1
  307. package/dist/caamp/capability-check.js +0 -38
  308. package/dist/caamp/capability-check.js.map +0 -1
  309. package/dist/caamp/index.js +0 -23
  310. package/dist/caamp/index.js.map +0 -1
  311. package/dist/caamp-init.js +0 -16
  312. package/dist/caamp-init.js.map +0 -1
  313. package/dist/cleo.js +0 -302
  314. package/dist/cleo.js.map +0 -1
  315. package/dist/codebase-map/analyzers/architecture.js +0 -130
  316. package/dist/codebase-map/analyzers/architecture.js.map +0 -1
  317. package/dist/codebase-map/analyzers/concerns.js +0 -122
  318. package/dist/codebase-map/analyzers/concerns.js.map +0 -1
  319. package/dist/codebase-map/analyzers/conventions.js +0 -149
  320. package/dist/codebase-map/analyzers/conventions.js.map +0 -1
  321. package/dist/codebase-map/analyzers/integrations.js +0 -108
  322. package/dist/codebase-map/analyzers/integrations.js.map +0 -1
  323. package/dist/codebase-map/analyzers/stack.js +0 -117
  324. package/dist/codebase-map/analyzers/stack.js.map +0 -1
  325. package/dist/codebase-map/analyzers/structure.js +0 -137
  326. package/dist/codebase-map/analyzers/structure.js.map +0 -1
  327. package/dist/codebase-map/analyzers/testing.js +0 -118
  328. package/dist/codebase-map/analyzers/testing.js.map +0 -1
  329. package/dist/codebase-map/index.js +0 -57
  330. package/dist/codebase-map/index.js.map +0 -1
  331. package/dist/codebase-map/store.js +0 -122
  332. package/dist/codebase-map/store.js.map +0 -1
  333. package/dist/codebase-map/summary.js +0 -152
  334. package/dist/codebase-map/summary.js.map +0 -1
  335. package/dist/compliance/index.js +0 -288
  336. package/dist/compliance/index.js.map +0 -1
  337. package/dist/compliance/protocol-enforcement.js +0 -332
  338. package/dist/compliance/protocol-enforcement.js.map +0 -1
  339. package/dist/compliance/protocol-rules.js +0 -786
  340. package/dist/compliance/protocol-rules.js.map +0 -1
  341. package/dist/compliance/protocol-types.js +0 -80
  342. package/dist/compliance/protocol-types.js.map +0 -1
  343. package/dist/compliance/store.js +0 -53
  344. package/dist/compliance/store.js.map +0 -1
  345. package/dist/config/build-config.js +0 -29
  346. package/dist/config/build-config.js.map +0 -1
  347. package/dist/config.js +0 -400
  348. package/dist/config.js.map +0 -1
  349. package/dist/constants.js +0 -18
  350. package/dist/constants.js.map +0 -1
  351. package/dist/context/index.js +0 -137
  352. package/dist/context/index.js.map +0 -1
  353. package/dist/engine-result.js +0 -12
  354. package/dist/engine-result.js.map +0 -1
  355. package/dist/error-catalog.js +0 -404
  356. package/dist/error-catalog.js.map +0 -1
  357. package/dist/error-registry.js +0 -393
  358. package/dist/error-registry.js.map +0 -1
  359. package/dist/errors.js +0 -167
  360. package/dist/errors.js.map +0 -1
  361. package/dist/hooks/handlers/error-hooks.js +0 -43
  362. package/dist/hooks/handlers/error-hooks.js.map +0 -1
  363. package/dist/hooks/handlers/file-hooks.js +0 -80
  364. package/dist/hooks/handlers/file-hooks.js.map +0 -1
  365. package/dist/hooks/handlers/index.js +0 -19
  366. package/dist/hooks/handlers/index.js.map +0 -1
  367. package/dist/hooks/handlers/mcp-hooks.js +0 -80
  368. package/dist/hooks/handlers/mcp-hooks.js.map +0 -1
  369. package/dist/hooks/handlers/memory-bridge-refresh.js +0 -42
  370. package/dist/hooks/handlers/memory-bridge-refresh.js.map +0 -1
  371. package/dist/hooks/handlers/session-hooks.js +0 -109
  372. package/dist/hooks/handlers/session-hooks.js.map +0 -1
  373. package/dist/hooks/handlers/task-hooks.js +0 -70
  374. package/dist/hooks/handlers/task-hooks.js.map +0 -1
  375. package/dist/hooks/index.js +0 -13
  376. package/dist/hooks/index.js.map +0 -1
  377. package/dist/hooks/payload-schemas.js +0 -163
  378. package/dist/hooks/payload-schemas.js.map +0 -1
  379. package/dist/hooks/provider-hooks.js +0 -34
  380. package/dist/hooks/provider-hooks.js.map +0 -1
  381. package/dist/hooks/registry.js +0 -176
  382. package/dist/hooks/registry.js.map +0 -1
  383. package/dist/hooks/types.js +0 -62
  384. package/dist/hooks/types.js.map +0 -1
  385. package/dist/hooks.js +0 -136
  386. package/dist/hooks.js.map +0 -1
  387. package/dist/init.js +0 -711
  388. package/dist/init.js.map +0 -1
  389. package/dist/inject/index.js +0 -82
  390. package/dist/inject/index.js.map +0 -1
  391. package/dist/injection.js +0 -343
  392. package/dist/injection.js.map +0 -1
  393. package/dist/intelligence/adaptive-validation.js +0 -497
  394. package/dist/intelligence/adaptive-validation.js.map +0 -1
  395. package/dist/intelligence/impact.js +0 -675
  396. package/dist/intelligence/impact.js.map +0 -1
  397. package/dist/intelligence/index.js +0 -22
  398. package/dist/intelligence/index.js.map +0 -1
  399. package/dist/intelligence/patterns.js +0 -492
  400. package/dist/intelligence/patterns.js.map +0 -1
  401. package/dist/intelligence/prediction.js +0 -499
  402. package/dist/intelligence/prediction.js.map +0 -1
  403. package/dist/intelligence/types.js +0 -13
  404. package/dist/intelligence/types.js.map +0 -1
  405. package/dist/internal.js +0 -276
  406. package/dist/internal.js.map +0 -1
  407. package/dist/issue/create.js +0 -121
  408. package/dist/issue/create.js.map +0 -1
  409. package/dist/issue/diagnostics.js +0 -59
  410. package/dist/issue/diagnostics.js.map +0 -1
  411. package/dist/issue/index.js +0 -10
  412. package/dist/issue/index.js.map +0 -1
  413. package/dist/issue/template-parser.js +0 -267
  414. package/dist/issue/template-parser.js.map +0 -1
  415. package/dist/json-schema-validator.js +0 -76
  416. package/dist/json-schema-validator.js.map +0 -1
  417. package/dist/lib/index.js +0 -10
  418. package/dist/lib/index.js.map +0 -1
  419. package/dist/lib/retry.js +0 -152
  420. package/dist/lib/retry.js.map +0 -1
  421. package/dist/lifecycle/chain-composition.js +0 -152
  422. package/dist/lifecycle/chain-composition.js.map +0 -1
  423. package/dist/lifecycle/chain-store.js +0 -246
  424. package/dist/lifecycle/chain-store.js.map +0 -1
  425. package/dist/lifecycle/consolidate-rcasd.js +0 -352
  426. package/dist/lifecycle/consolidate-rcasd.js.map +0 -1
  427. package/dist/lifecycle/default-chain.js +0 -167
  428. package/dist/lifecycle/default-chain.js.map +0 -1
  429. package/dist/lifecycle/evidence.js +0 -180
  430. package/dist/lifecycle/evidence.js.map +0 -1
  431. package/dist/lifecycle/frontmatter.js +0 -363
  432. package/dist/lifecycle/frontmatter.js.map +0 -1
  433. package/dist/lifecycle/index.js +0 -753
  434. package/dist/lifecycle/index.js.map +0 -1
  435. package/dist/lifecycle/pipeline.js +0 -656
  436. package/dist/lifecycle/pipeline.js.map +0 -1
  437. package/dist/lifecycle/rcasd-index.js +0 -326
  438. package/dist/lifecycle/rcasd-index.js.map +0 -1
  439. package/dist/lifecycle/rcasd-paths.js +0 -220
  440. package/dist/lifecycle/rcasd-paths.js.map +0 -1
  441. package/dist/lifecycle/resume.js +0 -864
  442. package/dist/lifecycle/resume.js.map +0 -1
  443. package/dist/lifecycle/stage-artifacts.js +0 -94
  444. package/dist/lifecycle/stage-artifacts.js.map +0 -1
  445. package/dist/lifecycle/stages.js +0 -534
  446. package/dist/lifecycle/stages.js.map +0 -1
  447. package/dist/lifecycle/state-machine.js +0 -516
  448. package/dist/lifecycle/state-machine.js.map +0 -1
  449. package/dist/lifecycle/tessera-engine.js +0 -249
  450. package/dist/lifecycle/tessera-engine.js.map +0 -1
  451. package/dist/logger.js +0 -140
  452. package/dist/logger.js.map +0 -1
  453. package/dist/mcp/index.js +0 -146
  454. package/dist/mcp/index.js.map +0 -1
  455. package/dist/memory/auto-extract.js +0 -177
  456. package/dist/memory/auto-extract.js.map +0 -1
  457. package/dist/memory/brain-embedding.js +0 -66
  458. package/dist/memory/brain-embedding.js.map +0 -1
  459. package/dist/memory/brain-lifecycle.js +0 -298
  460. package/dist/memory/brain-lifecycle.js.map +0 -1
  461. package/dist/memory/brain-links.js +0 -148
  462. package/dist/memory/brain-links.js.map +0 -1
  463. package/dist/memory/brain-maintenance.js +0 -98
  464. package/dist/memory/brain-maintenance.js.map +0 -1
  465. package/dist/memory/brain-migration.js +0 -149
  466. package/dist/memory/brain-migration.js.map +0 -1
  467. package/dist/memory/brain-reasoning.js +0 -215
  468. package/dist/memory/brain-reasoning.js.map +0 -1
  469. package/dist/memory/brain-retrieval.js +0 -521
  470. package/dist/memory/brain-retrieval.js.map +0 -1
  471. package/dist/memory/brain-row-types.js +0 -10
  472. package/dist/memory/brain-row-types.js.map +0 -1
  473. package/dist/memory/brain-search.js +0 -519
  474. package/dist/memory/brain-search.js.map +0 -1
  475. package/dist/memory/brain-similarity.js +0 -145
  476. package/dist/memory/brain-similarity.js.map +0 -1
  477. package/dist/memory/claude-mem-migration.js +0 -277
  478. package/dist/memory/claude-mem-migration.js.map +0 -1
  479. package/dist/memory/decisions.js +0 -148
  480. package/dist/memory/decisions.js.map +0 -1
  481. package/dist/memory/embedding-local.js +0 -97
  482. package/dist/memory/embedding-local.js.map +0 -1
  483. package/dist/memory/embedding-queue.js +0 -271
  484. package/dist/memory/embedding-queue.js.map +0 -1
  485. package/dist/memory/embedding-worker.js +0 -58
  486. package/dist/memory/embedding-worker.js.map +0 -1
  487. package/dist/memory/engine-compat.js +0 -1030
  488. package/dist/memory/engine-compat.js.map +0 -1
  489. package/dist/memory/index.js +0 -773
  490. package/dist/memory/index.js.map +0 -1
  491. package/dist/memory/learnings.js +0 -121
  492. package/dist/memory/learnings.js.map +0 -1
  493. package/dist/memory/memory-bridge.js +0 -370
  494. package/dist/memory/memory-bridge.js.map +0 -1
  495. package/dist/memory/patterns.js +0 -122
  496. package/dist/memory/patterns.js.map +0 -1
  497. package/dist/memory/pipeline-manifest-sqlite.js +0 -975
  498. package/dist/memory/pipeline-manifest-sqlite.js.map +0 -1
  499. package/dist/memory/session-memory.js +0 -331
  500. package/dist/memory/session-memory.js.map +0 -1
  501. package/dist/metrics/ab-test.js +0 -260
  502. package/dist/metrics/ab-test.js.map +0 -1
  503. package/dist/metrics/aggregation.js +0 -363
  504. package/dist/metrics/aggregation.js.map +0 -1
  505. package/dist/metrics/common.js +0 -64
  506. package/dist/metrics/common.js.map +0 -1
  507. package/dist/metrics/enums.js +0 -78
  508. package/dist/metrics/enums.js.map +0 -1
  509. package/dist/metrics/index.js +0 -19
  510. package/dist/metrics/index.js.map +0 -1
  511. package/dist/metrics/model-provider-registry.js +0 -88
  512. package/dist/metrics/model-provider-registry.js.map +0 -1
  513. package/dist/metrics/otel-integration.js +0 -263
  514. package/dist/metrics/otel-integration.js.map +0 -1
  515. package/dist/metrics/provider-detection.js +0 -103
  516. package/dist/metrics/provider-detection.js.map +0 -1
  517. package/dist/metrics/token-estimation.js +0 -253
  518. package/dist/metrics/token-estimation.js.map +0 -1
  519. package/dist/metrics/token-service.js +0 -450
  520. package/dist/metrics/token-service.js.map +0 -1
  521. package/dist/migration/agent-outputs.js +0 -316
  522. package/dist/migration/agent-outputs.js.map +0 -1
  523. package/dist/migration/checksum.js +0 -92
  524. package/dist/migration/checksum.js.map +0 -1
  525. package/dist/migration/index.js +0 -282
  526. package/dist/migration/index.js.map +0 -1
  527. package/dist/migration/logger.js +0 -360
  528. package/dist/migration/logger.js.map +0 -1
  529. package/dist/migration/preflight.js +0 -9
  530. package/dist/migration/preflight.js.map +0 -1
  531. package/dist/migration/state.js +0 -421
  532. package/dist/migration/state.js.map +0 -1
  533. package/dist/migration/validate.js +0 -241
  534. package/dist/migration/validate.js.map +0 -1
  535. package/dist/nexus/deps.js +0 -375
  536. package/dist/nexus/deps.js.map +0 -1
  537. package/dist/nexus/discover.js +0 -288
  538. package/dist/nexus/discover.js.map +0 -1
  539. package/dist/nexus/hash.js +0 -10
  540. package/dist/nexus/hash.js.map +0 -1
  541. package/dist/nexus/index.js +0 -38
  542. package/dist/nexus/index.js.map +0 -1
  543. package/dist/nexus/migrate-json-to-sqlite.js +0 -115
  544. package/dist/nexus/migrate-json-to-sqlite.js.map +0 -1
  545. package/dist/nexus/permissions.js +0 -105
  546. package/dist/nexus/permissions.js.map +0 -1
  547. package/dist/nexus/query.js +0 -175
  548. package/dist/nexus/query.js.map +0 -1
  549. package/dist/nexus/registry.js +0 -584
  550. package/dist/nexus/registry.js.map +0 -1
  551. package/dist/nexus/sharing/index.js +0 -288
  552. package/dist/nexus/sharing/index.js.map +0 -1
  553. package/dist/nexus/transfer-types.js +0 -8
  554. package/dist/nexus/transfer-types.js.map +0 -1
  555. package/dist/nexus/transfer.js +0 -263
  556. package/dist/nexus/transfer.js.map +0 -1
  557. package/dist/observability/index.js +0 -103
  558. package/dist/observability/index.js.map +0 -1
  559. package/dist/observability/log-filter.js +0 -63
  560. package/dist/observability/log-filter.js.map +0 -1
  561. package/dist/observability/log-parser.js +0 -99
  562. package/dist/observability/log-parser.js.map +0 -1
  563. package/dist/observability/log-reader.js +0 -139
  564. package/dist/observability/log-reader.js.map +0 -1
  565. package/dist/observability/types.js +0 -19
  566. package/dist/observability/types.js.map +0 -1
  567. package/dist/orchestration/analyze.js +0 -107
  568. package/dist/orchestration/analyze.js.map +0 -1
  569. package/dist/orchestration/bootstrap.js +0 -132
  570. package/dist/orchestration/bootstrap.js.map +0 -1
  571. package/dist/orchestration/context.js +0 -56
  572. package/dist/orchestration/context.js.map +0 -1
  573. package/dist/orchestration/critical-path.js +0 -100
  574. package/dist/orchestration/critical-path.js.map +0 -1
  575. package/dist/orchestration/index.js +0 -286
  576. package/dist/orchestration/index.js.map +0 -1
  577. package/dist/orchestration/parallel.js +0 -89
  578. package/dist/orchestration/parallel.js.map +0 -1
  579. package/dist/orchestration/protocol-validators.js +0 -524
  580. package/dist/orchestration/protocol-validators.js.map +0 -1
  581. package/dist/orchestration/skill-ops.js +0 -98
  582. package/dist/orchestration/skill-ops.js.map +0 -1
  583. package/dist/orchestration/status.js +0 -107
  584. package/dist/orchestration/status.js.map +0 -1
  585. package/dist/orchestration/unblock.js +0 -103
  586. package/dist/orchestration/unblock.js.map +0 -1
  587. package/dist/orchestration/validate-spawn.js +0 -67
  588. package/dist/orchestration/validate-spawn.js.map +0 -1
  589. package/dist/orchestration/waves.js +0 -86
  590. package/dist/orchestration/waves.js.map +0 -1
  591. package/dist/otel/index.js +0 -163
  592. package/dist/otel/index.js.map +0 -1
  593. package/dist/output.js +0 -132
  594. package/dist/output.js.map +0 -1
  595. package/dist/pagination.js +0 -64
  596. package/dist/pagination.js.map +0 -1
  597. package/dist/paths.js +0 -337
  598. package/dist/paths.js.map +0 -1
  599. package/dist/phases/deps.js +0 -372
  600. package/dist/phases/deps.js.map +0 -1
  601. package/dist/phases/index.js +0 -349
  602. package/dist/phases/index.js.map +0 -1
  603. package/dist/pipeline/index.js +0 -10
  604. package/dist/pipeline/index.js.map +0 -1
  605. package/dist/pipeline/phase.js +0 -45
  606. package/dist/pipeline/phase.js.map +0 -1
  607. package/dist/platform.js +0 -211
  608. package/dist/platform.js.map +0 -1
  609. package/dist/project-info.js +0 -84
  610. package/dist/project-info.js.map +0 -1
  611. package/dist/reconciliation/index.js +0 -10
  612. package/dist/reconciliation/index.js.map +0 -1
  613. package/dist/reconciliation/link-store.js +0 -129
  614. package/dist/reconciliation/link-store.js.map +0 -1
  615. package/dist/reconciliation/reconciliation-engine.js +0 -298
  616. package/dist/reconciliation/reconciliation-engine.js.map +0 -1
  617. package/dist/release/artifacts.js +0 -427
  618. package/dist/release/artifacts.js.map +0 -1
  619. package/dist/release/changelog-writer.js +0 -151
  620. package/dist/release/changelog-writer.js.map +0 -1
  621. package/dist/release/channel.js +0 -144
  622. package/dist/release/channel.js.map +0 -1
  623. package/dist/release/ci.js +0 -166
  624. package/dist/release/ci.js.map +0 -1
  625. package/dist/release/github-pr.js +0 -225
  626. package/dist/release/github-pr.js.map +0 -1
  627. package/dist/release/guards.js +0 -116
  628. package/dist/release/guards.js.map +0 -1
  629. package/dist/release/index.js +0 -22
  630. package/dist/release/index.js.map +0 -1
  631. package/dist/release/release-config.js +0 -158
  632. package/dist/release/release-config.js.map +0 -1
  633. package/dist/release/release-manifest.js +0 -1019
  634. package/dist/release/release-manifest.js.map +0 -1
  635. package/dist/release/version-bump.js +0 -255
  636. package/dist/release/version-bump.js.map +0 -1
  637. package/dist/remote/index.js +0 -257
  638. package/dist/remote/index.js.map +0 -1
  639. package/dist/repair.js +0 -130
  640. package/dist/repair.js.map +0 -1
  641. package/dist/research/index.js +0 -2
  642. package/dist/research/index.js.map +0 -1
  643. package/dist/roadmap/index.js +0 -59
  644. package/dist/roadmap/index.js.map +0 -1
  645. package/dist/routing/capability-matrix.js +0 -1557
  646. package/dist/routing/capability-matrix.js.map +0 -1
  647. package/dist/routing/index.js +0 -9
  648. package/dist/routing/index.js.map +0 -1
  649. package/dist/scaffold.js +0 -1178
  650. package/dist/scaffold.js.map +0 -1
  651. package/dist/schema-management.js +0 -295
  652. package/dist/schema-management.js.map +0 -1
  653. package/dist/security/index.js +0 -9
  654. package/dist/security/index.js.map +0 -1
  655. package/dist/security/input-sanitization.js +0 -321
  656. package/dist/security/input-sanitization.js.map +0 -1
  657. package/dist/sequence/index.js +0 -295
  658. package/dist/sequence/index.js.map +0 -1
  659. package/dist/sessions/assumptions.js +0 -54
  660. package/dist/sessions/assumptions.js.map +0 -1
  661. package/dist/sessions/briefing.js +0 -377
  662. package/dist/sessions/briefing.js.map +0 -1
  663. package/dist/sessions/context-alert.js +0 -222
  664. package/dist/sessions/context-alert.js.map +0 -1
  665. package/dist/sessions/context-inject.js +0 -61
  666. package/dist/sessions/context-inject.js.map +0 -1
  667. package/dist/sessions/context-monitor.js +0 -98
  668. package/dist/sessions/context-monitor.js.map +0 -1
  669. package/dist/sessions/decisions.js +0 -65
  670. package/dist/sessions/decisions.js.map +0 -1
  671. package/dist/sessions/find.js +0 -63
  672. package/dist/sessions/find.js.map +0 -1
  673. package/dist/sessions/handoff.js +0 -328
  674. package/dist/sessions/handoff.js.map +0 -1
  675. package/dist/sessions/hitl-warnings.js +0 -254
  676. package/dist/sessions/hitl-warnings.js.map +0 -1
  677. package/dist/sessions/index.js +0 -314
  678. package/dist/sessions/index.js.map +0 -1
  679. package/dist/sessions/session-archive.js +0 -40
  680. package/dist/sessions/session-archive.js.map +0 -1
  681. package/dist/sessions/session-cleanup.js +0 -59
  682. package/dist/sessions/session-cleanup.js.map +0 -1
  683. package/dist/sessions/session-drift.js +0 -134
  684. package/dist/sessions/session-drift.js.map +0 -1
  685. package/dist/sessions/session-enforcement.js +0 -144
  686. package/dist/sessions/session-enforcement.js.map +0 -1
  687. package/dist/sessions/session-grade.js +0 -253
  688. package/dist/sessions/session-grade.js.map +0 -1
  689. package/dist/sessions/session-history.js +0 -42
  690. package/dist/sessions/session-history.js.map +0 -1
  691. package/dist/sessions/session-id.js +0 -81
  692. package/dist/sessions/session-id.js.map +0 -1
  693. package/dist/sessions/session-memory-bridge.js +0 -52
  694. package/dist/sessions/session-memory-bridge.js.map +0 -1
  695. package/dist/sessions/session-show.js +0 -24
  696. package/dist/sessions/session-show.js.map +0 -1
  697. package/dist/sessions/session-stats.js +0 -69
  698. package/dist/sessions/session-stats.js.map +0 -1
  699. package/dist/sessions/session-suspend.js +0 -39
  700. package/dist/sessions/session-suspend.js.map +0 -1
  701. package/dist/sessions/session-switch.js +0 -51
  702. package/dist/sessions/session-switch.js.map +0 -1
  703. package/dist/sessions/session-view.js +0 -76
  704. package/dist/sessions/session-view.js.map +0 -1
  705. package/dist/sessions/statusline-setup.js +0 -85
  706. package/dist/sessions/statusline-setup.js.map +0 -1
  707. package/dist/sessions/types.js +0 -8
  708. package/dist/sessions/types.js.map +0 -1
  709. package/dist/signaldock/claude-code-transport.d.ts +0 -34
  710. package/dist/signaldock/claude-code-transport.d.ts.map +0 -1
  711. package/dist/signaldock/claude-code-transport.js +0 -107
  712. package/dist/signaldock/claude-code-transport.js.map +0 -1
  713. package/dist/signaldock/factory.d.ts +0 -22
  714. package/dist/signaldock/factory.d.ts.map +0 -1
  715. package/dist/signaldock/factory.js +0 -25
  716. package/dist/signaldock/factory.js.map +0 -1
  717. package/dist/signaldock/index.d.ts +0 -13
  718. package/dist/signaldock/index.d.ts.map +0 -1
  719. package/dist/signaldock/index.js +0 -9
  720. package/dist/signaldock/index.js.map +0 -1
  721. package/dist/signaldock/signaldock-transport.d.ts +0 -45
  722. package/dist/signaldock/signaldock-transport.d.ts.map +0 -1
  723. package/dist/signaldock/signaldock-transport.js +0 -122
  724. package/dist/signaldock/signaldock-transport.js.map +0 -1
  725. package/dist/signaldock/transport.d.ts +0 -49
  726. package/dist/signaldock/transport.d.ts.map +0 -1
  727. package/dist/signaldock/transport.js +0 -11
  728. package/dist/signaldock/transport.js.map +0 -1
  729. package/dist/signaldock/types.d.ts +0 -88
  730. package/dist/signaldock/types.d.ts.map +0 -1
  731. package/dist/signaldock/types.js +0 -11
  732. package/dist/signaldock/types.js.map +0 -1
  733. package/dist/skills/agents/config.js +0 -94
  734. package/dist/skills/agents/config.js.map +0 -1
  735. package/dist/skills/agents/install.js +0 -116
  736. package/dist/skills/agents/install.js.map +0 -1
  737. package/dist/skills/agents/registry.js +0 -161
  738. package/dist/skills/agents/registry.js.map +0 -1
  739. package/dist/skills/discovery.js +0 -333
  740. package/dist/skills/discovery.js.map +0 -1
  741. package/dist/skills/dispatch.js +0 -347
  742. package/dist/skills/dispatch.js.map +0 -1
  743. package/dist/skills/dynamic-skill-generator.js +0 -100
  744. package/dist/skills/dynamic-skill-generator.js.map +0 -1
  745. package/dist/skills/index.js +0 -44
  746. package/dist/skills/index.js.map +0 -1
  747. package/dist/skills/injection/subagent.js +0 -195
  748. package/dist/skills/injection/subagent.js.map +0 -1
  749. package/dist/skills/injection/token.js +0 -260
  750. package/dist/skills/injection/token.js.map +0 -1
  751. package/dist/skills/install.js +0 -40
  752. package/dist/skills/install.js.map +0 -1
  753. package/dist/skills/manifests/contribution.js +0 -175
  754. package/dist/skills/manifests/contribution.js.map +0 -1
  755. package/dist/skills/manifests/research.js +0 -281
  756. package/dist/skills/manifests/research.js.map +0 -1
  757. package/dist/skills/manifests/resolver.js +0 -146
  758. package/dist/skills/manifests/resolver.js.map +0 -1
  759. package/dist/skills/marketplace.js +0 -90
  760. package/dist/skills/marketplace.js.map +0 -1
  761. package/dist/skills/orchestrator/spawn.js +0 -178
  762. package/dist/skills/orchestrator/spawn.js.map +0 -1
  763. package/dist/skills/orchestrator/startup.js +0 -451
  764. package/dist/skills/orchestrator/startup.js.map +0 -1
  765. package/dist/skills/orchestrator/validator.js +0 -301
  766. package/dist/skills/orchestrator/validator.js.map +0 -1
  767. package/dist/skills/precedence-integration.js +0 -73
  768. package/dist/skills/precedence-integration.js.map +0 -1
  769. package/dist/skills/precedence-types.js +0 -16
  770. package/dist/skills/precedence-types.js.map +0 -1
  771. package/dist/skills/routing-table.js +0 -63
  772. package/dist/skills/routing-table.js.map +0 -1
  773. package/dist/skills/skill-paths.js +0 -220
  774. package/dist/skills/skill-paths.js.map +0 -1
  775. package/dist/skills/test-utility.js +0 -55
  776. package/dist/skills/test-utility.js.map +0 -1
  777. package/dist/skills/types.js +0 -118
  778. package/dist/skills/types.js.map +0 -1
  779. package/dist/skills/validation.js +0 -183
  780. package/dist/skills/validation.js.map +0 -1
  781. package/dist/skills/version.js +0 -57
  782. package/dist/skills/version.js.map +0 -1
  783. package/dist/snapshot/index.js +0 -188
  784. package/dist/snapshot/index.js.map +0 -1
  785. package/dist/spawn/adapter-registry.js +0 -246
  786. package/dist/spawn/adapter-registry.js.map +0 -1
  787. package/dist/spawn/index.js +0 -10
  788. package/dist/spawn/index.js.map +0 -1
  789. package/dist/stats/index.js +0 -343
  790. package/dist/stats/index.js.map +0 -1
  791. package/dist/stats/workflow-telemetry.js +0 -400
  792. package/dist/stats/workflow-telemetry.js.map +0 -1
  793. package/dist/sticky/archive.js +0 -47
  794. package/dist/sticky/archive.js.map +0 -1
  795. package/dist/sticky/convert.js +0 -235
  796. package/dist/sticky/convert.js.map +0 -1
  797. package/dist/sticky/create.js +0 -48
  798. package/dist/sticky/create.js.map +0 -1
  799. package/dist/sticky/id.js +0 -35
  800. package/dist/sticky/id.js.map +0 -1
  801. package/dist/sticky/index.js +0 -16
  802. package/dist/sticky/index.js.map +0 -1
  803. package/dist/sticky/list.js +0 -44
  804. package/dist/sticky/list.js.map +0 -1
  805. package/dist/sticky/purge.js +0 -45
  806. package/dist/sticky/purge.js.map +0 -1
  807. package/dist/sticky/show.js +0 -42
  808. package/dist/sticky/show.js.map +0 -1
  809. package/dist/sticky/types.js +0 -10
  810. package/dist/sticky/types.js.map +0 -1
  811. package/dist/store/atomic.js +0 -167
  812. package/dist/store/atomic.js.map +0 -1
  813. package/dist/store/backup.js +0 -94
  814. package/dist/store/backup.js.map +0 -1
  815. package/dist/store/brain-accessor.js +0 -397
  816. package/dist/store/brain-accessor.js.map +0 -1
  817. package/dist/store/brain-schema.js +0 -215
  818. package/dist/store/brain-schema.js.map +0 -1
  819. package/dist/store/brain-sqlite.js +0 -222
  820. package/dist/store/brain-sqlite.js.map +0 -1
  821. package/dist/store/cache.js +0 -168
  822. package/dist/store/cache.js.map +0 -1
  823. package/dist/store/chain-schema.js +0 -51
  824. package/dist/store/chain-schema.js.map +0 -1
  825. package/dist/store/converters.js +0 -122
  826. package/dist/store/converters.js.map +0 -1
  827. package/dist/store/cross-db-cleanup.js +0 -169
  828. package/dist/store/cross-db-cleanup.js.map +0 -1
  829. package/dist/store/data-accessor.js +0 -26
  830. package/dist/store/data-accessor.js.map +0 -1
  831. package/dist/store/data-safety-central.js +0 -269
  832. package/dist/store/data-safety-central.js.map +0 -1
  833. package/dist/store/data-safety.js +0 -274
  834. package/dist/store/data-safety.js.map +0 -1
  835. package/dist/store/db-helpers.js +0 -223
  836. package/dist/store/db-helpers.js.map +0 -1
  837. package/dist/store/export.js +0 -155
  838. package/dist/store/export.js.map +0 -1
  839. package/dist/store/file-utils.js +0 -270
  840. package/dist/store/file-utils.js.map +0 -1
  841. package/dist/store/git-checkpoint.js +0 -365
  842. package/dist/store/git-checkpoint.js.map +0 -1
  843. package/dist/store/import-logging.js +0 -139
  844. package/dist/store/import-logging.js.map +0 -1
  845. package/dist/store/import-remap.js +0 -145
  846. package/dist/store/import-remap.js.map +0 -1
  847. package/dist/store/import-sort.js +0 -121
  848. package/dist/store/import-sort.js.map +0 -1
  849. package/dist/store/index.js +0 -28
  850. package/dist/store/index.js.map +0 -1
  851. package/dist/store/json.js +0 -208
  852. package/dist/store/json.js.map +0 -1
  853. package/dist/store/lifecycle-store.js +0 -249
  854. package/dist/store/lifecycle-store.js.map +0 -1
  855. package/dist/store/lock.js +0 -70
  856. package/dist/store/lock.js.map +0 -1
  857. package/dist/store/migration-manager.js +0 -151
  858. package/dist/store/migration-manager.js.map +0 -1
  859. package/dist/store/migration-sqlite.js +0 -676
  860. package/dist/store/migration-sqlite.js.map +0 -1
  861. package/dist/store/nexus-schema.js +0 -62
  862. package/dist/store/nexus-schema.js.map +0 -1
  863. package/dist/store/nexus-sqlite.js +0 -217
  864. package/dist/store/nexus-sqlite.js.map +0 -1
  865. package/dist/store/nexus-validation-schemas.js +0 -40
  866. package/dist/store/nexus-validation-schemas.js.map +0 -1
  867. package/dist/store/parsers.js +0 -37
  868. package/dist/store/parsers.js.map +0 -1
  869. package/dist/store/project-detect.js +0 -457
  870. package/dist/store/project-detect.js.map +0 -1
  871. package/dist/store/provider.js +0 -101
  872. package/dist/store/provider.js.map +0 -1
  873. package/dist/store/safety-data-accessor.js +0 -243
  874. package/dist/store/safety-data-accessor.js.map +0 -1
  875. package/dist/store/schema.js +0 -7
  876. package/dist/store/schema.js.map +0 -1
  877. package/dist/store/session-store.js +0 -219
  878. package/dist/store/session-store.js.map +0 -1
  879. package/dist/store/sqlite-backup.js +0 -105
  880. package/dist/store/sqlite-backup.js.map +0 -1
  881. package/dist/store/sqlite-data-accessor.js +0 -734
  882. package/dist/store/sqlite-data-accessor.js.map +0 -1
  883. package/dist/store/sqlite.js +0 -436
  884. package/dist/store/sqlite.js.map +0 -1
  885. package/dist/store/status-registry.js +0 -8
  886. package/dist/store/status-registry.js.map +0 -1
  887. package/dist/store/task-store.js +0 -348
  888. package/dist/store/task-store.js.map +0 -1
  889. package/dist/store/tasks-schema.js +0 -604
  890. package/dist/store/tasks-schema.js.map +0 -1
  891. package/dist/store/typed-query.js +0 -15
  892. package/dist/store/typed-query.js.map +0 -1
  893. package/dist/store/validation-schemas.js +0 -278
  894. package/dist/store/validation-schemas.js.map +0 -1
  895. package/dist/system/archive-analytics.js +0 -277
  896. package/dist/system/archive-analytics.js.map +0 -1
  897. package/dist/system/archive-stats.js +0 -64
  898. package/dist/system/archive-stats.js.map +0 -1
  899. package/dist/system/audit.js +0 -145
  900. package/dist/system/audit.js.map +0 -1
  901. package/dist/system/backup.js +0 -141
  902. package/dist/system/backup.js.map +0 -1
  903. package/dist/system/cleanup.js +0 -134
  904. package/dist/system/cleanup.js.map +0 -1
  905. package/dist/system/health.js +0 -1054
  906. package/dist/system/health.js.map +0 -1
  907. package/dist/system/index.js +0 -18
  908. package/dist/system/index.js.map +0 -1
  909. package/dist/system/inject-generate.js +0 -122
  910. package/dist/system/inject-generate.js.map +0 -1
  911. package/dist/system/labels.js +0 -38
  912. package/dist/system/labels.js.map +0 -1
  913. package/dist/system/metrics.js +0 -61
  914. package/dist/system/metrics.js.map +0 -1
  915. package/dist/system/migrate.js +0 -43
  916. package/dist/system/migrate.js.map +0 -1
  917. package/dist/system/platform-paths.js +0 -80
  918. package/dist/system/platform-paths.js.map +0 -1
  919. package/dist/system/runtime.js +0 -161
  920. package/dist/system/runtime.js.map +0 -1
  921. package/dist/system/safestop.js +0 -99
  922. package/dist/system/safestop.js.map +0 -1
  923. package/dist/system/storage-preflight.js +0 -123
  924. package/dist/system/storage-preflight.js.map +0 -1
  925. package/dist/task-work/index.js +0 -155
  926. package/dist/task-work/index.js.map +0 -1
  927. package/dist/tasks/add.js +0 -661
  928. package/dist/tasks/add.js.map +0 -1
  929. package/dist/tasks/analyze.js +0 -85
  930. package/dist/tasks/analyze.js.map +0 -1
  931. package/dist/tasks/archive.js +0 -90
  932. package/dist/tasks/archive.js.map +0 -1
  933. package/dist/tasks/atomicity.js +0 -83
  934. package/dist/tasks/atomicity.js.map +0 -1
  935. package/dist/tasks/cancel-ops.js +0 -83
  936. package/dist/tasks/cancel-ops.js.map +0 -1
  937. package/dist/tasks/complete.js +0 -208
  938. package/dist/tasks/complete.js.map +0 -1
  939. package/dist/tasks/crossref-extract.js +0 -73
  940. package/dist/tasks/crossref-extract.js.map +0 -1
  941. package/dist/tasks/delete-preview.js +0 -192
  942. package/dist/tasks/delete-preview.js.map +0 -1
  943. package/dist/tasks/delete.js +0 -120
  944. package/dist/tasks/delete.js.map +0 -1
  945. package/dist/tasks/deletion-strategy.js +0 -200
  946. package/dist/tasks/deletion-strategy.js.map +0 -1
  947. package/dist/tasks/dependency-check.js +0 -278
  948. package/dist/tasks/dependency-check.js.map +0 -1
  949. package/dist/tasks/deps-ready.js +0 -32
  950. package/dist/tasks/deps-ready.js.map +0 -1
  951. package/dist/tasks/enforcement.js +0 -86
  952. package/dist/tasks/enforcement.js.map +0 -1
  953. package/dist/tasks/epic-enforcement.js +0 -294
  954. package/dist/tasks/epic-enforcement.js.map +0 -1
  955. package/dist/tasks/find.js +0 -148
  956. package/dist/tasks/find.js.map +0 -1
  957. package/dist/tasks/graph-cache.js +0 -127
  958. package/dist/tasks/graph-cache.js.map +0 -1
  959. package/dist/tasks/graph-ops.js +0 -171
  960. package/dist/tasks/graph-ops.js.map +0 -1
  961. package/dist/tasks/graph-rag.js +0 -328
  962. package/dist/tasks/graph-rag.js.map +0 -1
  963. package/dist/tasks/hierarchy-policy.js +0 -149
  964. package/dist/tasks/hierarchy-policy.js.map +0 -1
  965. package/dist/tasks/hierarchy.js +0 -185
  966. package/dist/tasks/hierarchy.js.map +0 -1
  967. package/dist/tasks/id-generator.js +0 -65
  968. package/dist/tasks/id-generator.js.map +0 -1
  969. package/dist/tasks/index.js +0 -14
  970. package/dist/tasks/index.js.map +0 -1
  971. package/dist/tasks/labels.js +0 -52
  972. package/dist/tasks/labels.js.map +0 -1
  973. package/dist/tasks/list.js +0 -68
  974. package/dist/tasks/list.js.map +0 -1
  975. package/dist/tasks/phase-tracking.js +0 -133
  976. package/dist/tasks/phase-tracking.js.map +0 -1
  977. package/dist/tasks/pipeline-stage.js +0 -248
  978. package/dist/tasks/pipeline-stage.js.map +0 -1
  979. package/dist/tasks/plan.js +0 -268
  980. package/dist/tasks/plan.js.map +0 -1
  981. package/dist/tasks/relates.js +0 -89
  982. package/dist/tasks/relates.js.map +0 -1
  983. package/dist/tasks/reparent.d.ts +0 -38
  984. package/dist/tasks/reparent.d.ts.map +0 -1
  985. package/dist/tasks/show.js +0 -78
  986. package/dist/tasks/show.js.map +0 -1
  987. package/dist/tasks/size-weighting.js +0 -86
  988. package/dist/tasks/size-weighting.js.map +0 -1
  989. package/dist/tasks/staleness.js +0 -86
  990. package/dist/tasks/staleness.js.map +0 -1
  991. package/dist/tasks/task-ops.js +0 -1340
  992. package/dist/tasks/task-ops.js.map +0 -1
  993. package/dist/tasks/update.js +0 -271
  994. package/dist/tasks/update.js.map +0 -1
  995. package/dist/templates/index.js +0 -10
  996. package/dist/templates/index.js.map +0 -1
  997. package/dist/templates/parser.js +0 -254
  998. package/dist/templates/parser.js.map +0 -1
  999. package/dist/ui/aliases.js +0 -153
  1000. package/dist/ui/aliases.js.map +0 -1
  1001. package/dist/ui/changelog.js +0 -184
  1002. package/dist/ui/changelog.js.map +0 -1
  1003. package/dist/ui/command-registry.js +0 -168
  1004. package/dist/ui/command-registry.js.map +0 -1
  1005. package/dist/ui/flags.js +0 -94
  1006. package/dist/ui/flags.js.map +0 -1
  1007. package/dist/ui/index.js +0 -24
  1008. package/dist/ui/index.js.map +0 -1
  1009. package/dist/ui/injection-legacy.d.ts +0 -26
  1010. package/dist/ui/injection-legacy.d.ts.map +0 -1
  1011. package/dist/ui/injection-legacy.js +0 -42
  1012. package/dist/ui/injection-legacy.js.map +0 -1
  1013. package/dist/upgrade.js +0 -1144
  1014. package/dist/upgrade.js.map +0 -1
  1015. package/dist/validation/chain-validation.js +0 -146
  1016. package/dist/validation/chain-validation.js.map +0 -1
  1017. package/dist/validation/compliance.js +0 -155
  1018. package/dist/validation/compliance.js.map +0 -1
  1019. package/dist/validation/docs-sync.js +0 -212
  1020. package/dist/validation/docs-sync.js.map +0 -1
  1021. package/dist/validation/doctor/checks.js +0 -1069
  1022. package/dist/validation/doctor/checks.js.map +0 -1
  1023. package/dist/validation/doctor/index.js +0 -9
  1024. package/dist/validation/doctor/index.js.map +0 -1
  1025. package/dist/validation/doctor/project-cache.js +0 -160
  1026. package/dist/validation/doctor/project-cache.js.map +0 -1
  1027. package/dist/validation/doctor/utils.js +0 -155
  1028. package/dist/validation/doctor/utils.js.map +0 -1
  1029. package/dist/validation/engine.js +0 -902
  1030. package/dist/validation/engine.js.map +0 -1
  1031. package/dist/validation/gap-check.js +0 -175
  1032. package/dist/validation/gap-check.js.map +0 -1
  1033. package/dist/validation/index.js +0 -40
  1034. package/dist/validation/index.js.map +0 -1
  1035. package/dist/validation/manifest.js +0 -237
  1036. package/dist/validation/manifest.js.map +0 -1
  1037. package/dist/validation/operation-gate-validators.js +0 -724
  1038. package/dist/validation/operation-gate-validators.js.map +0 -1
  1039. package/dist/validation/operation-verification-gates.js +0 -532
  1040. package/dist/validation/operation-verification-gates.js.map +0 -1
  1041. package/dist/validation/param-utils.js +0 -139
  1042. package/dist/validation/param-utils.js.map +0 -1
  1043. package/dist/validation/protocol-common.js +0 -300
  1044. package/dist/validation/protocol-common.js.map +0 -1
  1045. package/dist/validation/protocols/consensus.js +0 -71
  1046. package/dist/validation/protocols/consensus.js.map +0 -1
  1047. package/dist/validation/protocols/contribution.js +0 -59
  1048. package/dist/validation/protocols/contribution.js.map +0 -1
  1049. package/dist/validation/protocols/decomposition.js +0 -59
  1050. package/dist/validation/protocols/decomposition.js.map +0 -1
  1051. package/dist/validation/protocols/implementation.js +0 -59
  1052. package/dist/validation/protocols/implementation.js.map +0 -1
  1053. package/dist/validation/protocols/release-protocol.js +0 -60
  1054. package/dist/validation/protocols/release-protocol.js.map +0 -1
  1055. package/dist/validation/protocols/research.js +0 -77
  1056. package/dist/validation/protocols/research.js.map +0 -1
  1057. package/dist/validation/protocols/specification.js +0 -84
  1058. package/dist/validation/protocols/specification.js.map +0 -1
  1059. package/dist/validation/protocols/testing-protocol.js +0 -70
  1060. package/dist/validation/protocols/testing-protocol.js.map +0 -1
  1061. package/dist/validation/protocols/validation-protocol.js +0 -70
  1062. package/dist/validation/protocols/validation-protocol.js.map +0 -1
  1063. package/dist/validation/schema-integrity.js +0 -170
  1064. package/dist/validation/schema-integrity.js.map +0 -1
  1065. package/dist/validation/schema-validator.js +0 -176
  1066. package/dist/validation/schema-validator.js.map +0 -1
  1067. package/dist/validation/validate-ops.js +0 -937
  1068. package/dist/validation/validate-ops.js.map +0 -1
  1069. package/dist/validation/validation-rules.js +0 -226
  1070. package/dist/validation/validation-rules.js.map +0 -1
  1071. package/dist/validation/verification.js +0 -321
  1072. package/dist/validation/verification.js.map +0 -1
  1073. package/src/signaldock/__tests__/claude-code-transport.test.d.ts +0 -7
  1074. package/src/signaldock/__tests__/claude-code-transport.test.d.ts.map +0 -1
  1075. package/src/signaldock/__tests__/claude-code-transport.test.js +0 -147
  1076. package/src/signaldock/__tests__/claude-code-transport.test.js.map +0 -1
  1077. package/src/signaldock/__tests__/claude-code-transport.test.ts +0 -180
  1078. package/src/signaldock/__tests__/factory.test.d.ts +0 -7
  1079. package/src/signaldock/__tests__/factory.test.d.ts.map +0 -1
  1080. package/src/signaldock/__tests__/factory.test.js +0 -55
  1081. package/src/signaldock/__tests__/factory.test.js.map +0 -1
  1082. package/src/signaldock/__tests__/factory.test.ts +0 -61
  1083. package/src/signaldock/__tests__/signaldock-transport.test.d.ts +0 -9
  1084. package/src/signaldock/__tests__/signaldock-transport.test.d.ts.map +0 -1
  1085. package/src/signaldock/__tests__/signaldock-transport.test.js +0 -321
  1086. package/src/signaldock/__tests__/signaldock-transport.test.js.map +0 -1
  1087. package/src/signaldock/__tests__/signaldock-transport.test.ts +0 -421
  1088. package/src/signaldock/claude-code-transport.ts +0 -137
  1089. package/src/signaldock/factory.ts +0 -39
  1090. package/src/signaldock/index.ts +0 -28
  1091. package/src/signaldock/signaldock-transport.ts +0 -194
  1092. package/src/signaldock/transport.ts +0 -78
  1093. 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