@cleocode/core 2026.4.12 → 2026.4.14

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