@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,975 +0,0 @@
1
- /**
2
- * Pipeline Manifest SQLite Implementation
3
- *
4
- * Reimplements all 14 pipeline manifest operations using Drizzle ORM +
5
- * SQLite (tasks.db pipeline_manifest table) instead of JSONL file I/O.
6
- *
7
- * Provides a one-time migration function to import existing MANIFEST.jsonl
8
- * entries into the new table.
9
- *
10
- * @task T5581
11
- * @epic T5576
12
- */
13
- import { createHash } from 'node:crypto';
14
- import { existsSync, readFileSync, renameSync } from 'node:fs';
15
- import { join } from 'node:path';
16
- import { and, count, desc, eq, gte, isNull, like, lte, or } from 'drizzle-orm';
17
- import { pipelineManifest } from '../store/tasks-schema.js';
18
- async function getDb(cwd) {
19
- const { getDb: _getDb } = await import('../store/sqlite.js');
20
- return _getDb(cwd);
21
- }
22
- async function getNativeDb() {
23
- const { getNativeDb: _getNativeDb } = await import('../store/sqlite.js');
24
- return _getNativeDb();
25
- }
26
- import { createPage } from '../pagination.js';
27
- import { getCleoDirAbsolute, getProjectRoot } from '../paths.js';
28
- import { filterManifestEntries, } from './index.js';
29
- export { filterManifestEntries };
30
- function normalizeLimit(limit) {
31
- return typeof limit === 'number' && limit > 0 ? limit : undefined;
32
- }
33
- function normalizeOffset(offset) {
34
- return typeof offset === 'number' && offset > 0 ? offset : undefined;
35
- }
36
- function effectivePageLimit(limit, offset) {
37
- return limit ?? (offset !== undefined ? 50 : undefined);
38
- }
39
- function buildManifestSqlFilters(filter) {
40
- const conditions = [isNull(pipelineManifest.archivedAt)];
41
- if (filter.status) {
42
- const storedStatus = filter.status === 'completed' ? 'active' : filter.status;
43
- conditions.push(eq(pipelineManifest.status, storedStatus));
44
- }
45
- if (filter.agent_type) {
46
- conditions.push(eq(pipelineManifest.type, filter.agent_type));
47
- }
48
- if (filter.dateAfter) {
49
- conditions.push(gte(pipelineManifest.createdAt, `${filter.dateAfter} 00:00:00`));
50
- }
51
- if (filter.dateBefore) {
52
- conditions.push(lte(pipelineManifest.createdAt, `${filter.dateBefore} 23:59:59`));
53
- }
54
- return {
55
- conditions,
56
- requiresInMemoryFiltering: filter.taskId !== undefined || filter.topic !== undefined || filter.actionable !== undefined,
57
- };
58
- }
59
- function applyManifestMemoryOnlyFilters(entries, filter) {
60
- const inMemoryFilter = {
61
- taskId: filter.taskId,
62
- topic: filter.topic,
63
- actionable: filter.actionable,
64
- };
65
- return filterManifestEntries(entries, inMemoryFilter);
66
- }
67
- // ============================================================================
68
- // Internal helpers
69
- // ============================================================================
70
- function now() {
71
- return new Date().toISOString().replace('T', ' ').slice(0, 19);
72
- }
73
- function computeContentHash(content) {
74
- return createHash('sha256')
75
- .update(content || '')
76
- .digest('hex')
77
- .slice(0, 16);
78
- }
79
- /**
80
- * Convert a pipeline_manifest row back to ExtendedManifestEntry format
81
- * for backward-compatible output.
82
- */
83
- function rowToEntry(row) {
84
- let meta = {};
85
- if (row.metadataJson) {
86
- try {
87
- meta = JSON.parse(row.metadataJson);
88
- }
89
- catch {
90
- // ignore malformed JSON
91
- }
92
- }
93
- return {
94
- id: row.id,
95
- file: meta['file'] ?? row.sourceFile ?? '',
96
- title: meta['title'] ?? row.type,
97
- date: row.createdAt.slice(0, 10),
98
- status: (row.status === 'active' ? 'completed' : row.status),
99
- agent_type: row.type,
100
- topics: meta['topics'] ?? [],
101
- key_findings: meta['key_findings'] ?? [],
102
- actionable: meta['actionable'] ?? true,
103
- needs_followup: meta['needs_followup'] ?? [],
104
- linked_tasks: meta['linked_tasks'] ?? (row.taskId ? [row.taskId] : []),
105
- confidence: meta['confidence'],
106
- file_checksum: meta['file_checksum'],
107
- duration_seconds: meta['duration_seconds'],
108
- };
109
- }
110
- /**
111
- * Convert an ExtendedManifestEntry to a pipeline_manifest row for insertion.
112
- */
113
- function entryToRow(entry) {
114
- const serializedContent = JSON.stringify(entry);
115
- const contentHash = computeContentHash(serializedContent);
116
- // Extract the first linked task (primary association)
117
- const primaryTaskId = entry.linked_tasks?.[0] ?? null;
118
- // Store full entry in metadataJson for round-trip fidelity
119
- const metadataJson = JSON.stringify({
120
- file: entry.file,
121
- title: entry.title,
122
- topics: entry.topics ?? [],
123
- key_findings: entry.key_findings ?? [],
124
- actionable: entry.actionable,
125
- needs_followup: entry.needs_followup ?? [],
126
- linked_tasks: entry.linked_tasks ?? [],
127
- confidence: entry.confidence,
128
- file_checksum: entry.file_checksum,
129
- duration_seconds: entry.duration_seconds,
130
- });
131
- // Normalize status: completed → active for storage
132
- let storedStatus = entry.status;
133
- if (storedStatus === 'completed')
134
- storedStatus = 'active';
135
- return {
136
- id: entry.id,
137
- taskId: primaryTaskId,
138
- type: entry.agent_type,
139
- content: serializedContent,
140
- contentHash,
141
- status: storedStatus,
142
- distilled: false,
143
- sourceFile: entry.file || null,
144
- metadataJson,
145
- createdAt: entry.date + ' 00:00:00',
146
- archivedAt: null,
147
- };
148
- }
149
- // ============================================================================
150
- // EngineResult-wrapped functions
151
- // ============================================================================
152
- /** pipeline.manifest.show - Get manifest entry details by ID */
153
- export async function pipelineManifestShow(researchId, projectRoot) {
154
- if (!researchId) {
155
- return {
156
- success: false,
157
- error: { code: 'E_INVALID_INPUT', message: 'researchId is required' },
158
- };
159
- }
160
- try {
161
- const db = await getDb(projectRoot);
162
- const rows = await db
163
- .select()
164
- .from(pipelineManifest)
165
- .where(eq(pipelineManifest.id, researchId))
166
- .limit(1);
167
- if (rows.length === 0) {
168
- return {
169
- success: false,
170
- error: { code: 'E_NOT_FOUND', message: `Research entry '${researchId}' not found` },
171
- };
172
- }
173
- const entry = rowToEntry(rows[0]);
174
- const root = getProjectRoot(projectRoot);
175
- let fileContent = null;
176
- try {
177
- const filePath = join(root, entry.file);
178
- if (existsSync(filePath)) {
179
- fileContent = readFileSync(filePath, 'utf-8');
180
- }
181
- }
182
- catch {
183
- // File may not exist or be unreadable
184
- }
185
- return {
186
- success: true,
187
- data: { ...entry, fileContent, fileExists: fileContent !== null },
188
- };
189
- }
190
- catch (error) {
191
- return {
192
- success: false,
193
- error: {
194
- code: 'E_MANIFEST_SHOW',
195
- message: error instanceof Error ? error.message : String(error),
196
- },
197
- };
198
- }
199
- }
200
- /** pipeline.manifest.list - List manifest entries with filters */
201
- export async function pipelineManifestList(params, projectRoot) {
202
- try {
203
- const db = await getDb(projectRoot);
204
- const filter = { ...params };
205
- if (params.type) {
206
- filter.agent_type = params.type;
207
- }
208
- const limit = normalizeLimit(params.limit);
209
- const offset = normalizeOffset(params.offset);
210
- const pageLimit = effectivePageLimit(limit, offset);
211
- const { conditions, requiresInMemoryFiltering } = buildManifestSqlFilters(filter);
212
- const whereClause = and(...conditions);
213
- const totalRow = await db
214
- .select({ count: count() })
215
- .from(pipelineManifest)
216
- .where(isNull(pipelineManifest.archivedAt))
217
- .get();
218
- const total = totalRow?.count ?? 0;
219
- if (!requiresInMemoryFiltering) {
220
- const filteredRow = await db
221
- .select({ count: count() })
222
- .from(pipelineManifest)
223
- .where(whereClause)
224
- .get();
225
- const filtered = filteredRow?.count ?? 0;
226
- let query = db
227
- .select()
228
- .from(pipelineManifest)
229
- .where(whereClause)
230
- .orderBy(desc(pipelineManifest.createdAt));
231
- if (pageLimit !== undefined) {
232
- query = query.limit(pageLimit);
233
- }
234
- if (offset !== undefined) {
235
- query = query.offset(offset);
236
- }
237
- const rows = await query;
238
- return {
239
- success: true,
240
- data: { entries: rows.map(rowToEntry), total, filtered },
241
- page: createPage({ total: filtered, limit: pageLimit, offset }),
242
- };
243
- }
244
- const rows = await db
245
- .select()
246
- .from(pipelineManifest)
247
- .where(whereClause)
248
- .orderBy(desc(pipelineManifest.createdAt));
249
- const filteredEntries = applyManifestMemoryOnlyFilters(rows.map(rowToEntry), filter);
250
- const filtered = filteredEntries.length;
251
- const start = offset ?? 0;
252
- const pagedEntries = pageLimit !== undefined
253
- ? filteredEntries.slice(start, start + pageLimit)
254
- : filteredEntries.slice(start);
255
- return {
256
- success: true,
257
- data: { entries: pagedEntries, total, filtered },
258
- page: createPage({ total: filtered, limit: pageLimit, offset }),
259
- };
260
- }
261
- catch (error) {
262
- return {
263
- success: false,
264
- error: {
265
- code: 'E_MANIFEST_LIST',
266
- message: error instanceof Error ? error.message : String(error),
267
- },
268
- };
269
- }
270
- }
271
- /** pipeline.manifest.find - Find manifest entries by text (LIKE search on content + type) */
272
- export async function pipelineManifestFind(query, options, projectRoot) {
273
- if (!query) {
274
- return { success: false, error: { code: 'E_INVALID_INPUT', message: 'query is required' } };
275
- }
276
- try {
277
- const db = await getDb(projectRoot);
278
- const likePattern = `%${query}%`;
279
- const rows = await db
280
- .select()
281
- .from(pipelineManifest)
282
- .where(and(isNull(pipelineManifest.archivedAt), or(like(pipelineManifest.content, likePattern), like(pipelineManifest.type, likePattern))))
283
- .orderBy(desc(pipelineManifest.createdAt));
284
- const queryLower = query.toLowerCase();
285
- const entries = rows.map(rowToEntry);
286
- const scored = entries.map((entry) => {
287
- let score = 0;
288
- if (entry.title.toLowerCase().includes(queryLower))
289
- score += 0.5;
290
- if (entry.topics.some((t) => t.toLowerCase().includes(queryLower)))
291
- score += 0.3;
292
- if (entry.key_findings?.some((f) => f.toLowerCase().includes(queryLower)))
293
- score += 0.2;
294
- if (entry.id.toLowerCase().includes(queryLower))
295
- score += 0.1;
296
- return { entry, score };
297
- });
298
- const minConfidence = options?.confidence ?? 0.1;
299
- let results = scored.filter((s) => s.score >= minConfidence).sort((a, b) => b.score - a.score);
300
- if (options?.limit && options.limit > 0) {
301
- results = results.slice(0, options.limit);
302
- }
303
- return {
304
- success: true,
305
- data: {
306
- query,
307
- results: results.map((r) => ({
308
- ...r.entry,
309
- relevanceScore: Math.round(r.score * 100) / 100,
310
- })),
311
- total: results.length,
312
- },
313
- };
314
- }
315
- catch (error) {
316
- return {
317
- success: false,
318
- error: {
319
- code: 'E_MANIFEST_FIND',
320
- message: error instanceof Error ? error.message : String(error),
321
- },
322
- };
323
- }
324
- }
325
- /** pipeline.manifest.pending - Get pending manifest items */
326
- export async function pipelineManifestPending(epicId, projectRoot) {
327
- try {
328
- const db = await getDb(projectRoot);
329
- const rows = await db
330
- .select()
331
- .from(pipelineManifest)
332
- .where(isNull(pipelineManifest.archivedAt))
333
- .orderBy(desc(pipelineManifest.createdAt));
334
- const entries = rows.map(rowToEntry);
335
- let pending = entries.filter((e) => e.status === 'partial' ||
336
- e.status === 'blocked' ||
337
- (e.needs_followup && e.needs_followup.length > 0));
338
- if (epicId) {
339
- pending = pending.filter((e) => e.id.startsWith(epicId) || e.linked_tasks?.includes(epicId));
340
- }
341
- return {
342
- success: true,
343
- data: {
344
- entries: pending,
345
- total: pending.length,
346
- byStatus: {
347
- partial: pending.filter((e) => e.status === 'partial').length,
348
- blocked: pending.filter((e) => e.status === 'blocked').length,
349
- needsFollowup: pending.filter((e) => e.needs_followup && e.needs_followup.length > 0)
350
- .length,
351
- },
352
- },
353
- };
354
- }
355
- catch (error) {
356
- return {
357
- success: false,
358
- error: {
359
- code: 'E_MANIFEST_PENDING',
360
- message: error instanceof Error ? error.message : String(error),
361
- },
362
- };
363
- }
364
- }
365
- /** pipeline.manifest.stats - Manifest statistics */
366
- export async function pipelineManifestStats(epicId, projectRoot) {
367
- try {
368
- const db = await getDb(projectRoot);
369
- const rows = await db
370
- .select()
371
- .from(pipelineManifest)
372
- .where(isNull(pipelineManifest.archivedAt));
373
- const entries = rows.map(rowToEntry);
374
- let filtered = entries;
375
- if (epicId) {
376
- filtered = entries.filter((e) => e.id.startsWith(epicId) || e.linked_tasks?.includes(epicId));
377
- }
378
- const byStatus = {};
379
- const byType = {};
380
- let actionable = 0;
381
- let needsFollowup = 0;
382
- let totalFindings = 0;
383
- for (const entry of filtered) {
384
- byStatus[entry.status] = (byStatus[entry.status] || 0) + 1;
385
- byType[entry.agent_type] = (byType[entry.agent_type] || 0) + 1;
386
- if (entry.actionable)
387
- actionable++;
388
- if (entry.needs_followup && entry.needs_followup.length > 0)
389
- needsFollowup++;
390
- if (entry.key_findings)
391
- totalFindings += entry.key_findings.length;
392
- }
393
- return {
394
- success: true,
395
- data: {
396
- total: filtered.length,
397
- byStatus,
398
- byType,
399
- actionable,
400
- needsFollowup,
401
- averageFindings: filtered.length > 0 ? Math.round((totalFindings / filtered.length) * 10) / 10 : 0,
402
- },
403
- };
404
- }
405
- catch (error) {
406
- return {
407
- success: false,
408
- error: {
409
- code: 'E_MANIFEST_STATS',
410
- message: error instanceof Error ? error.message : String(error),
411
- },
412
- };
413
- }
414
- }
415
- /** pipeline.manifest.read - Read manifest entries with optional filter */
416
- export async function pipelineManifestRead(filter, projectRoot) {
417
- try {
418
- const db = await getDb(projectRoot);
419
- const rows = await db
420
- .select()
421
- .from(pipelineManifest)
422
- .where(isNull(pipelineManifest.archivedAt))
423
- .orderBy(desc(pipelineManifest.createdAt));
424
- const entries = rows.map(rowToEntry);
425
- const filtered = filter ? filterManifestEntries(entries, filter) : entries;
426
- return {
427
- success: true,
428
- data: { entries: filtered, total: filtered.length, filter: filter || {} },
429
- };
430
- }
431
- catch (error) {
432
- return {
433
- success: false,
434
- error: {
435
- code: 'E_MANIFEST_READ',
436
- message: error instanceof Error ? error.message : String(error),
437
- },
438
- };
439
- }
440
- }
441
- /** pipeline.manifest.append - Append entry to pipeline_manifest table */
442
- export async function pipelineManifestAppend(entry, projectRoot) {
443
- if (!entry) {
444
- return { success: false, error: { code: 'E_INVALID_INPUT', message: 'entry is required' } };
445
- }
446
- const errors = [];
447
- if (!entry.id)
448
- errors.push('id is required');
449
- if (!entry.file)
450
- errors.push('file is required');
451
- if (!entry.title)
452
- errors.push('title is required');
453
- if (!entry.date)
454
- errors.push('date is required');
455
- if (!entry.status)
456
- errors.push('status is required');
457
- if (!entry.agent_type)
458
- errors.push('agent_type is required');
459
- if (!entry.topics)
460
- errors.push('topics is required');
461
- if (entry.actionable === undefined)
462
- errors.push('actionable is required');
463
- if (errors.length > 0) {
464
- return {
465
- success: false,
466
- error: {
467
- code: 'E_VALIDATION_FAILED',
468
- message: `Invalid manifest entry: ${errors.join(', ')}`,
469
- },
470
- };
471
- }
472
- try {
473
- const db = await getDb(projectRoot);
474
- const row = entryToRow(entry);
475
- await db
476
- .insert(pipelineManifest)
477
- .values(row)
478
- .onConflictDoUpdate({
479
- target: pipelineManifest.id,
480
- set: {
481
- content: row.content,
482
- contentHash: row.contentHash,
483
- status: row.status,
484
- metadataJson: row.metadataJson,
485
- sourceFile: row.sourceFile,
486
- taskId: row.taskId,
487
- },
488
- });
489
- return { success: true, data: { appended: true, entryId: entry.id } };
490
- }
491
- catch (error) {
492
- return {
493
- success: false,
494
- error: {
495
- code: 'E_MANIFEST_APPEND',
496
- message: error instanceof Error ? error.message : String(error),
497
- },
498
- };
499
- }
500
- }
501
- /** pipeline.manifest.archive - Archive old manifest entries by date */
502
- export async function pipelineManifestArchive(beforeDate, projectRoot) {
503
- if (!beforeDate) {
504
- return {
505
- success: false,
506
- error: {
507
- code: 'E_INVALID_INPUT',
508
- message: 'beforeDate is required (ISO-8601 format: YYYY-MM-DD)',
509
- },
510
- };
511
- }
512
- try {
513
- const db = await getDb(projectRoot);
514
- const nativeDb = await getNativeDb();
515
- if (!nativeDb) {
516
- return {
517
- success: false,
518
- error: { code: 'E_DB_NOT_INITIALIZED', message: 'Database not initialized' },
519
- };
520
- }
521
- // Find entries to archive (before date, not already archived)
522
- const rows = await db
523
- .select()
524
- .from(pipelineManifest)
525
- .where(isNull(pipelineManifest.archivedAt));
526
- const toArchive = rows.filter((r) => r.createdAt.slice(0, 10) < beforeDate);
527
- if (toArchive.length === 0) {
528
- const remaining = rows.length;
529
- return {
530
- success: true,
531
- data: { archived: 0, remaining, message: 'No entries found before the specified date' },
532
- };
533
- }
534
- const archivedAt = now();
535
- for (const row of toArchive) {
536
- await db.update(pipelineManifest).set({ archivedAt }).where(eq(pipelineManifest.id, row.id));
537
- }
538
- const remaining = rows.length - toArchive.length;
539
- return { success: true, data: { archived: toArchive.length, remaining } };
540
- }
541
- catch (error) {
542
- return {
543
- success: false,
544
- error: {
545
- code: 'E_MANIFEST_ARCHIVE',
546
- message: error instanceof Error ? error.message : String(error),
547
- },
548
- };
549
- }
550
- }
551
- /** pipeline.manifest.compact - Dedup by contentHash (keep newest by createdAt) */
552
- export async function pipelineManifestCompact(projectRoot) {
553
- try {
554
- const db = await getDb(projectRoot);
555
- const rows = await db
556
- .select()
557
- .from(pipelineManifest)
558
- .where(isNull(pipelineManifest.archivedAt))
559
- .orderBy(desc(pipelineManifest.createdAt));
560
- const originalCount = rows.length;
561
- if (originalCount === 0) {
562
- return { success: true, data: { compacted: false, message: 'No entries found' } };
563
- }
564
- // Dedup by contentHash — keep newest (first seen due to DESC order)
565
- const seenHashes = new Set();
566
- const seenIds = new Set();
567
- const toDelete = [];
568
- for (const row of rows) {
569
- const hash = row.contentHash ?? computeContentHash(row.content);
570
- if (seenHashes.has(hash) || seenIds.has(row.id)) {
571
- toDelete.push(row.id);
572
- }
573
- else {
574
- seenHashes.add(hash);
575
- seenIds.add(row.id);
576
- }
577
- }
578
- for (const id of toDelete) {
579
- await db.delete(pipelineManifest).where(eq(pipelineManifest.id, id));
580
- }
581
- return {
582
- success: true,
583
- data: {
584
- compacted: true,
585
- originalLines: originalCount,
586
- malformedRemoved: 0,
587
- duplicatesRemoved: toDelete.length,
588
- remainingEntries: originalCount - toDelete.length,
589
- },
590
- };
591
- }
592
- catch (error) {
593
- return {
594
- success: false,
595
- error: {
596
- code: 'E_COMPACT_FAILED',
597
- message: error instanceof Error ? error.message : String(error),
598
- },
599
- };
600
- }
601
- }
602
- /** pipeline.manifest.validate - Validate manifest entries for a task */
603
- export async function pipelineManifestValidate(taskId, projectRoot) {
604
- if (!taskId) {
605
- return { success: false, error: { code: 'E_INVALID_INPUT', message: 'taskId is required' } };
606
- }
607
- try {
608
- const db = await getDb(projectRoot);
609
- const root = getProjectRoot(projectRoot);
610
- const rows = await db
611
- .select()
612
- .from(pipelineManifest)
613
- .where(isNull(pipelineManifest.archivedAt));
614
- const entries = rows.map(rowToEntry);
615
- const linked = entries.filter((e) => e.id.startsWith(taskId) || e.linked_tasks?.includes(taskId));
616
- if (linked.length === 0) {
617
- return {
618
- success: true,
619
- data: {
620
- taskId,
621
- valid: true,
622
- entriesFound: 0,
623
- message: `No research entries found for task ${taskId}`,
624
- issues: [],
625
- },
626
- };
627
- }
628
- const issues = [];
629
- for (const entry of linked) {
630
- if (!entry.id)
631
- issues.push({ entryId: entry.id || '(unknown)', issue: 'Missing id', severity: 'error' });
632
- if (!entry.file)
633
- issues.push({ entryId: entry.id, issue: 'Missing file path', severity: 'error' });
634
- if (!entry.title)
635
- issues.push({ entryId: entry.id, issue: 'Missing title', severity: 'error' });
636
- if (!entry.date)
637
- issues.push({ entryId: entry.id, issue: 'Missing date', severity: 'error' });
638
- if (!entry.status)
639
- issues.push({ entryId: entry.id, issue: 'Missing status', severity: 'error' });
640
- if (!entry.agent_type)
641
- issues.push({ entryId: entry.id, issue: 'Missing agent_type', severity: 'error' });
642
- if (entry.status && !['completed', 'partial', 'blocked'].includes(entry.status)) {
643
- issues.push({
644
- entryId: entry.id,
645
- issue: `Invalid status: ${entry.status}`,
646
- severity: 'error',
647
- });
648
- }
649
- if (entry.file) {
650
- const filePath = join(root, entry.file);
651
- if (!existsSync(filePath)) {
652
- issues.push({
653
- entryId: entry.id,
654
- issue: `Output file not found: ${entry.file}`,
655
- severity: 'warning',
656
- });
657
- }
658
- }
659
- if (entry.agent_type === 'research' &&
660
- (!entry.key_findings || entry.key_findings.length === 0)) {
661
- issues.push({
662
- entryId: entry.id,
663
- issue: 'Research entry missing key_findings',
664
- severity: 'warning',
665
- });
666
- }
667
- }
668
- return {
669
- success: true,
670
- data: {
671
- taskId,
672
- valid: issues.filter((i) => i.severity === 'error').length === 0,
673
- entriesFound: linked.length,
674
- issues,
675
- errorCount: issues.filter((i) => i.severity === 'error').length,
676
- warningCount: issues.filter((i) => i.severity === 'warning').length,
677
- },
678
- };
679
- }
680
- catch (error) {
681
- return {
682
- success: false,
683
- error: {
684
- code: 'E_MANIFEST_VALIDATE',
685
- message: error instanceof Error ? error.message : String(error),
686
- },
687
- };
688
- }
689
- }
690
- /** pipeline.manifest.contradictions - Find entries with overlapping topics but conflicting key_findings */
691
- export async function pipelineManifestContradictions(projectRoot, params) {
692
- try {
693
- const db = await getDb(projectRoot);
694
- const rows = await db
695
- .select()
696
- .from(pipelineManifest)
697
- .where(isNull(pipelineManifest.archivedAt));
698
- const entries = rows.map(rowToEntry);
699
- // In-memory negation pattern matching (same logic as compat layer)
700
- const byTopic = new Map();
701
- for (const entry of entries) {
702
- if (!entry.key_findings || entry.key_findings.length === 0)
703
- continue;
704
- for (const topic of entry.topics) {
705
- if (params?.topic && topic !== params.topic)
706
- continue;
707
- if (!byTopic.has(topic))
708
- byTopic.set(topic, []);
709
- byTopic.get(topic).push(entry);
710
- }
711
- }
712
- const negationPairs = [
713
- [/\bdoes NOT\b/i, /\bdoes\b(?!.*\bnot\b)/i],
714
- [/\bcannot\b/i, /\bcan\b(?!.*\bnot\b)/i],
715
- [/\bno\s+\w+\s+required\b/i, /\brequired\b(?!.*\bno\b)/i],
716
- [
717
- /\bnot\s+(?:available|supported|possible|recommended)\b/i,
718
- /\b(?:available|supported|possible|recommended)\b(?!.*\bnot\b)/i,
719
- ],
720
- [/\bwithout\b/i, /\brequires?\b/i],
721
- [/\bavoid\b/i, /\buse\b/i],
722
- [/\bdeprecated\b/i, /\brecommended\b/i],
723
- [/\banti-pattern\b/i, /\bbest practice\b/i],
724
- ];
725
- const contradictions = [];
726
- for (const [topic, topicEntries] of byTopic) {
727
- if (topicEntries.length < 2)
728
- continue;
729
- for (let i = 0; i < topicEntries.length; i++) {
730
- for (let j = i + 1; j < topicEntries.length; j++) {
731
- const a = topicEntries[i];
732
- const b = topicEntries[j];
733
- const conflicts = [];
734
- for (const findingA of a.key_findings) {
735
- for (const findingB of b.key_findings) {
736
- for (const [patternNeg, patternPos] of negationPairs) {
737
- if ((patternNeg.test(findingA) && patternPos.test(findingB)) ||
738
- (patternPos.test(findingA) && patternNeg.test(findingB))) {
739
- conflicts.push(`"${findingA}" vs "${findingB}"`);
740
- break;
741
- }
742
- }
743
- }
744
- }
745
- if (conflicts.length > 0) {
746
- contradictions.push({
747
- entryA: a,
748
- entryB: b,
749
- topic,
750
- conflictDetails: conflicts.join('; '),
751
- });
752
- }
753
- }
754
- }
755
- }
756
- return { success: true, data: { contradictions } };
757
- }
758
- catch (error) {
759
- return {
760
- success: false,
761
- error: {
762
- code: 'E_MANIFEST_CONTRADICTIONS',
763
- message: error instanceof Error ? error.message : String(error),
764
- },
765
- };
766
- }
767
- }
768
- /** pipeline.manifest.superseded - Identify entries replaced by newer work on same topic */
769
- export async function pipelineManifestSuperseded(projectRoot, params) {
770
- try {
771
- const db = await getDb(projectRoot);
772
- const rows = await db
773
- .select()
774
- .from(pipelineManifest)
775
- .where(isNull(pipelineManifest.archivedAt));
776
- const entries = rows.map(rowToEntry);
777
- const byTopicAndType = new Map();
778
- for (const entry of entries) {
779
- for (const topic of entry.topics) {
780
- if (params?.topic && topic !== params.topic)
781
- continue;
782
- const key = `${topic}::${entry.agent_type}`;
783
- if (!byTopicAndType.has(key))
784
- byTopicAndType.set(key, []);
785
- byTopicAndType.get(key).push(entry);
786
- }
787
- }
788
- const superseded = [];
789
- const seenPairs = new Set();
790
- for (const [key, groupEntries] of byTopicAndType) {
791
- if (groupEntries.length < 2)
792
- continue;
793
- const topic = key.split('::')[0];
794
- const sorted = [...groupEntries].sort((a, b) => a.date.localeCompare(b.date));
795
- for (let i = 0; i < sorted.length - 1; i++) {
796
- const pairKey = `${sorted[i].id}::${sorted[sorted.length - 1].id}::${topic}`;
797
- if (seenPairs.has(pairKey))
798
- continue;
799
- seenPairs.add(pairKey);
800
- superseded.push({ old: sorted[i], replacement: sorted[sorted.length - 1], topic });
801
- }
802
- }
803
- return { success: true, data: { superseded } };
804
- }
805
- catch (error) {
806
- return {
807
- success: false,
808
- error: {
809
- code: 'E_MANIFEST_SUPERSEDED',
810
- message: error instanceof Error ? error.message : String(error),
811
- },
812
- };
813
- }
814
- }
815
- /** pipeline.manifest.link - Link manifest entry to a task */
816
- export async function pipelineManifestLink(taskId, researchId, notes, projectRoot) {
817
- if (!taskId || !researchId) {
818
- return {
819
- success: false,
820
- error: { code: 'E_INVALID_INPUT', message: 'taskId and researchId are required' },
821
- };
822
- }
823
- try {
824
- const db = await getDb(projectRoot);
825
- const rows = await db
826
- .select()
827
- .from(pipelineManifest)
828
- .where(eq(pipelineManifest.id, researchId))
829
- .limit(1);
830
- if (rows.length === 0) {
831
- return {
832
- success: false,
833
- error: { code: 'E_NOT_FOUND', message: `Research entry '${researchId}' not found` },
834
- };
835
- }
836
- const row = rows[0];
837
- const entry = rowToEntry(row);
838
- if (entry.linked_tasks?.includes(taskId)) {
839
- return { success: true, data: { taskId, researchId, linked: true, alreadyLinked: true } };
840
- }
841
- // Update linked_tasks in metadataJson
842
- const updatedLinkedTasks = [...(entry.linked_tasks ?? []), taskId];
843
- let meta = {};
844
- try {
845
- meta = row.metadataJson ? JSON.parse(row.metadataJson) : {};
846
- }
847
- catch {
848
- // ignore
849
- }
850
- meta['linked_tasks'] = updatedLinkedTasks;
851
- await db
852
- .update(pipelineManifest)
853
- .set({
854
- taskId: row.taskId ?? taskId,
855
- metadataJson: JSON.stringify(meta),
856
- })
857
- .where(eq(pipelineManifest.id, researchId));
858
- return { success: true, data: { taskId, researchId, linked: true, notes: notes || null } };
859
- }
860
- catch (error) {
861
- return {
862
- success: false,
863
- error: {
864
- code: 'E_MANIFEST_LINK',
865
- message: error instanceof Error ? error.message : String(error),
866
- },
867
- };
868
- }
869
- }
870
- // ============================================================================
871
- // Helper exported for compat consumers
872
- // ============================================================================
873
- /**
874
- * Read all manifest entries from the pipeline_manifest table.
875
- * Replaces readManifestEntries() from pipeline-manifest-compat.
876
- */
877
- export async function readManifestEntries(projectRoot) {
878
- try {
879
- const db = await getDb(projectRoot);
880
- const rows = await db
881
- .select()
882
- .from(pipelineManifest)
883
- .where(isNull(pipelineManifest.archivedAt))
884
- .orderBy(desc(pipelineManifest.createdAt));
885
- return rows.map(rowToEntry);
886
- }
887
- catch {
888
- return [];
889
- }
890
- }
891
- /**
892
- * Filter manifest entries by criteria (alias for backward compatibility).
893
- */
894
- export function filterEntries(entries, filter) {
895
- return filterManifestEntries(entries, filter);
896
- }
897
- // ============================================================================
898
- // Distillation stub (Phase 3)
899
- // ============================================================================
900
- /**
901
- * Distill a manifest entry to brain.db observation (Phase 3, pending).
902
- */
903
- export async function distillManifestEntry(_entryId, _projectRoot) {
904
- return { success: true, data: { skipped: true, reason: 'distillation_pending_phase3' } };
905
- }
906
- // ============================================================================
907
- // One-time migration: MANIFEST.jsonl → SQLite
908
- // ============================================================================
909
- /**
910
- * Migrate existing .cleo/MANIFEST.jsonl entries into the pipeline_manifest table.
911
- * Skips entries that already exist (by id). Renames MANIFEST.jsonl to
912
- * MANIFEST.jsonl.migrated when done.
913
- *
914
- * @returns Count of migrated and skipped entries.
915
- */
916
- export async function migrateManifestJsonlToSqlite(projectRoot) {
917
- const root = getProjectRoot(projectRoot);
918
- const manifestPath = join(getCleoDirAbsolute(root), 'MANIFEST.jsonl');
919
- if (!existsSync(manifestPath)) {
920
- return { migrated: 0, skipped: 0 };
921
- }
922
- const content = readFileSync(manifestPath, 'utf-8');
923
- const lines = content.split('\n');
924
- const entries = [];
925
- for (const line of lines) {
926
- const trimmed = line.trim();
927
- if (!trimmed)
928
- continue;
929
- try {
930
- entries.push(JSON.parse(trimmed));
931
- }
932
- catch {
933
- // skip malformed lines
934
- }
935
- }
936
- if (entries.length === 0) {
937
- return { migrated: 0, skipped: 0 };
938
- }
939
- const db = await getDb(projectRoot);
940
- let migrated = 0;
941
- let skipped = 0;
942
- for (const entry of entries) {
943
- if (!entry.id) {
944
- skipped++;
945
- continue;
946
- }
947
- // Check if already exists
948
- const existing = await db
949
- .select({ id: pipelineManifest.id })
950
- .from(pipelineManifest)
951
- .where(eq(pipelineManifest.id, entry.id))
952
- .limit(1);
953
- if (existing.length > 0) {
954
- skipped++;
955
- continue;
956
- }
957
- try {
958
- const row = entryToRow(entry);
959
- await db.insert(pipelineManifest).values(row);
960
- migrated++;
961
- }
962
- catch {
963
- skipped++;
964
- }
965
- }
966
- // Rename MANIFEST.jsonl to MANIFEST.jsonl.migrated
967
- try {
968
- renameSync(manifestPath, manifestPath + '.migrated');
969
- }
970
- catch {
971
- // Non-fatal — file may already be renamed or locked
972
- }
973
- return { migrated, skipped };
974
- }
975
- //# sourceMappingURL=pipeline-manifest-sqlite.js.map