@cleocode/core 2026.3.58 → 2026.3.59

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 (857) hide show
  1. package/dist/agents/agent-registry.d.ts +206 -0
  2. package/dist/agents/agent-registry.d.ts.map +1 -0
  3. package/dist/agents/health-monitor.d.ts +161 -0
  4. package/dist/agents/health-monitor.d.ts.map +1 -0
  5. package/dist/agents/index.d.ts +3 -1
  6. package/dist/agents/index.d.ts.map +1 -1
  7. package/dist/agents/retry.d.ts +57 -4
  8. package/dist/agents/retry.d.ts.map +1 -1
  9. package/dist/backfill/index.d.ts +27 -0
  10. package/dist/backfill/index.d.ts.map +1 -1
  11. package/dist/index.d.ts +1 -0
  12. package/dist/index.d.ts.map +1 -1
  13. package/dist/index.js +880 -506
  14. package/dist/index.js.map +4 -4
  15. package/dist/intelligence/impact.d.ts +34 -1
  16. package/dist/intelligence/impact.d.ts.map +1 -1
  17. package/dist/intelligence/index.d.ts +2 -2
  18. package/dist/intelligence/index.d.ts.map +1 -1
  19. package/dist/intelligence/types.d.ts +60 -0
  20. package/dist/intelligence/types.d.ts.map +1 -1
  21. package/dist/internal.d.ts +5 -4
  22. package/dist/internal.d.ts.map +1 -1
  23. package/dist/lib/index.d.ts +10 -0
  24. package/dist/lib/index.d.ts.map +1 -0
  25. package/dist/lib/retry.d.ts +128 -0
  26. package/dist/lib/retry.d.ts.map +1 -0
  27. package/dist/nexus/sharing/index.d.ts +48 -2
  28. package/dist/nexus/sharing/index.d.ts.map +1 -1
  29. package/dist/stats/workflow-telemetry.d.ts +15 -0
  30. package/dist/stats/workflow-telemetry.d.ts.map +1 -1
  31. package/dist/store/cross-db-cleanup.d.ts +35 -0
  32. package/dist/store/cross-db-cleanup.d.ts.map +1 -1
  33. package/dist/tasks/complete.d.ts.map +1 -1
  34. package/dist/tasks/enforcement.d.ts.map +1 -1
  35. package/dist/tasks/epic-enforcement.d.ts +61 -0
  36. package/dist/tasks/epic-enforcement.d.ts.map +1 -1
  37. package/dist/tasks/pipeline-stage.d.ts +70 -1
  38. package/dist/tasks/pipeline-stage.d.ts.map +1 -1
  39. package/package.json +5 -5
  40. package/schemas/config.schema.json +37 -1547
  41. package/src/__tests__/sharing.test.ts +24 -0
  42. package/src/agents/__tests__/agent-registry.test.ts +351 -0
  43. package/src/agents/__tests__/health-monitor.test.ts +332 -0
  44. package/src/agents/agent-registry.ts +394 -0
  45. package/src/agents/health-monitor.ts +279 -0
  46. package/src/agents/index.ts +24 -1
  47. package/src/agents/retry.ts +57 -4
  48. package/src/backfill/index.ts +27 -0
  49. package/src/config.ts +3 -3
  50. package/src/index.ts +1 -0
  51. package/src/intelligence/__tests__/impact.test.ts +165 -1
  52. package/src/intelligence/impact.ts +203 -0
  53. package/src/intelligence/index.ts +3 -0
  54. package/src/intelligence/types.ts +76 -0
  55. package/src/internal.ts +20 -0
  56. package/src/lib/__tests__/retry.test.ts +321 -0
  57. package/src/lib/index.ts +16 -0
  58. package/src/lib/retry.ts +224 -0
  59. package/src/nexus/sharing/index.ts +142 -2
  60. package/src/stats/workflow-telemetry.ts +15 -0
  61. package/src/store/__tests__/session-store.test.ts +43 -7
  62. package/src/store/__tests__/task-store.test.ts +1 -1
  63. package/src/store/__tests__/test-db-helper.ts +7 -3
  64. package/src/store/cross-db-cleanup.ts +35 -0
  65. package/src/tasks/__tests__/epic-enforcement.test.ts +9 -4
  66. package/src/tasks/__tests__/minimal-test.test.ts +2 -2
  67. package/src/tasks/__tests__/update.test.ts +25 -25
  68. package/src/tasks/complete.ts +11 -6
  69. package/src/tasks/enforcement.ts +6 -3
  70. package/src/tasks/epic-enforcement.ts +61 -0
  71. package/src/tasks/pipeline-stage.ts +70 -1
  72. package/templates/config.template.json +5 -116
  73. package/templates/global-config.template.json +2 -44
  74. package/dist/adapters/adapter-registry.js +0 -64
  75. package/dist/adapters/adapter-registry.js.map +0 -1
  76. package/dist/adapters/discovery.js +0 -83
  77. package/dist/adapters/discovery.js.map +0 -1
  78. package/dist/adapters/index.js +0 -9
  79. package/dist/adapters/index.js.map +0 -1
  80. package/dist/adapters/manager.js +0 -260
  81. package/dist/adapters/manager.js.map +0 -1
  82. package/dist/admin/export-tasks.js +0 -171
  83. package/dist/admin/export-tasks.js.map +0 -1
  84. package/dist/admin/export.js +0 -103
  85. package/dist/admin/export.js.map +0 -1
  86. package/dist/admin/help.js +0 -106
  87. package/dist/admin/help.js.map +0 -1
  88. package/dist/admin/import-tasks.js +0 -182
  89. package/dist/admin/import-tasks.js.map +0 -1
  90. package/dist/admin/import.js +0 -129
  91. package/dist/admin/import.js.map +0 -1
  92. package/dist/admin/index.js +0 -13
  93. package/dist/admin/index.js.map +0 -1
  94. package/dist/adrs/find.js +0 -134
  95. package/dist/adrs/find.js.map +0 -1
  96. package/dist/adrs/index.js +0 -15
  97. package/dist/adrs/index.js.map +0 -1
  98. package/dist/adrs/link-pipeline.js +0 -160
  99. package/dist/adrs/link-pipeline.js.map +0 -1
  100. package/dist/adrs/list.js +0 -43
  101. package/dist/adrs/list.js.map +0 -1
  102. package/dist/adrs/parse.js +0 -51
  103. package/dist/adrs/parse.js.map +0 -1
  104. package/dist/adrs/show.js +0 -22
  105. package/dist/adrs/show.js.map +0 -1
  106. package/dist/adrs/sync.js +0 -188
  107. package/dist/adrs/sync.js.map +0 -1
  108. package/dist/adrs/types.js +0 -9
  109. package/dist/adrs/types.js.map +0 -1
  110. package/dist/adrs/validate.js +0 -57
  111. package/dist/adrs/validate.js.map +0 -1
  112. package/dist/agents/agent-schema.js +0 -80
  113. package/dist/agents/agent-schema.js.map +0 -1
  114. package/dist/agents/capacity.js +0 -116
  115. package/dist/agents/capacity.js.map +0 -1
  116. package/dist/agents/index.js +0 -21
  117. package/dist/agents/index.js.map +0 -1
  118. package/dist/agents/registry.js +0 -314
  119. package/dist/agents/registry.js.map +0 -1
  120. package/dist/agents/retry.js +0 -176
  121. package/dist/agents/retry.js.map +0 -1
  122. package/dist/audit-prune.js +0 -94
  123. package/dist/audit-prune.js.map +0 -1
  124. package/dist/audit.js +0 -68
  125. package/dist/audit.js.map +0 -1
  126. package/dist/bootstrap.js +0 -260
  127. package/dist/bootstrap.js.map +0 -1
  128. package/dist/caamp/adapter.js +0 -434
  129. package/dist/caamp/adapter.js.map +0 -1
  130. package/dist/caamp/capability-check.js +0 -38
  131. package/dist/caamp/capability-check.js.map +0 -1
  132. package/dist/caamp/index.js +0 -23
  133. package/dist/caamp/index.js.map +0 -1
  134. package/dist/caamp-init.js +0 -16
  135. package/dist/caamp-init.js.map +0 -1
  136. package/dist/cleo.js +0 -267
  137. package/dist/cleo.js.map +0 -1
  138. package/dist/codebase-map/analyzers/architecture.js +0 -130
  139. package/dist/codebase-map/analyzers/architecture.js.map +0 -1
  140. package/dist/codebase-map/analyzers/concerns.js +0 -122
  141. package/dist/codebase-map/analyzers/concerns.js.map +0 -1
  142. package/dist/codebase-map/analyzers/conventions.js +0 -149
  143. package/dist/codebase-map/analyzers/conventions.js.map +0 -1
  144. package/dist/codebase-map/analyzers/integrations.js +0 -108
  145. package/dist/codebase-map/analyzers/integrations.js.map +0 -1
  146. package/dist/codebase-map/analyzers/stack.js +0 -117
  147. package/dist/codebase-map/analyzers/stack.js.map +0 -1
  148. package/dist/codebase-map/analyzers/structure.js +0 -137
  149. package/dist/codebase-map/analyzers/structure.js.map +0 -1
  150. package/dist/codebase-map/analyzers/testing.js +0 -118
  151. package/dist/codebase-map/analyzers/testing.js.map +0 -1
  152. package/dist/codebase-map/index.js +0 -57
  153. package/dist/codebase-map/index.js.map +0 -1
  154. package/dist/codebase-map/store.js +0 -122
  155. package/dist/codebase-map/store.js.map +0 -1
  156. package/dist/codebase-map/summary.js +0 -152
  157. package/dist/codebase-map/summary.js.map +0 -1
  158. package/dist/compliance/index.js +0 -288
  159. package/dist/compliance/index.js.map +0 -1
  160. package/dist/compliance/protocol-enforcement.js +0 -332
  161. package/dist/compliance/protocol-enforcement.js.map +0 -1
  162. package/dist/compliance/protocol-rules.js +0 -786
  163. package/dist/compliance/protocol-rules.js.map +0 -1
  164. package/dist/compliance/protocol-types.js +0 -80
  165. package/dist/compliance/protocol-types.js.map +0 -1
  166. package/dist/compliance/store.js +0 -53
  167. package/dist/compliance/store.js.map +0 -1
  168. package/dist/config/build-config.js +0 -29
  169. package/dist/config/build-config.js.map +0 -1
  170. package/dist/config.js +0 -287
  171. package/dist/config.js.map +0 -1
  172. package/dist/constants.js +0 -18
  173. package/dist/constants.js.map +0 -1
  174. package/dist/context/index.js +0 -137
  175. package/dist/context/index.js.map +0 -1
  176. package/dist/engine-result.js +0 -12
  177. package/dist/engine-result.js.map +0 -1
  178. package/dist/error-catalog.js +0 -404
  179. package/dist/error-catalog.js.map +0 -1
  180. package/dist/error-registry.js +0 -393
  181. package/dist/error-registry.js.map +0 -1
  182. package/dist/errors.js +0 -167
  183. package/dist/errors.js.map +0 -1
  184. package/dist/hooks/handlers/error-hooks.js +0 -43
  185. package/dist/hooks/handlers/error-hooks.js.map +0 -1
  186. package/dist/hooks/handlers/file-hooks.js +0 -80
  187. package/dist/hooks/handlers/file-hooks.js.map +0 -1
  188. package/dist/hooks/handlers/index.js +0 -19
  189. package/dist/hooks/handlers/index.js.map +0 -1
  190. package/dist/hooks/handlers/mcp-hooks.js +0 -80
  191. package/dist/hooks/handlers/mcp-hooks.js.map +0 -1
  192. package/dist/hooks/handlers/session-hooks.js +0 -73
  193. package/dist/hooks/handlers/session-hooks.js.map +0 -1
  194. package/dist/hooks/handlers/task-hooks.js +0 -63
  195. package/dist/hooks/handlers/task-hooks.js.map +0 -1
  196. package/dist/hooks/index.js +0 -13
  197. package/dist/hooks/index.js.map +0 -1
  198. package/dist/hooks/payload-schemas.js +0 -163
  199. package/dist/hooks/payload-schemas.js.map +0 -1
  200. package/dist/hooks/provider-hooks.js +0 -34
  201. package/dist/hooks/provider-hooks.js.map +0 -1
  202. package/dist/hooks/registry.js +0 -176
  203. package/dist/hooks/registry.js.map +0 -1
  204. package/dist/hooks/types.js +0 -62
  205. package/dist/hooks/types.js.map +0 -1
  206. package/dist/hooks.js +0 -136
  207. package/dist/hooks.js.map +0 -1
  208. package/dist/init.js +0 -711
  209. package/dist/init.js.map +0 -1
  210. package/dist/inject/index.js +0 -82
  211. package/dist/inject/index.js.map +0 -1
  212. package/dist/injection.js +0 -343
  213. package/dist/injection.js.map +0 -1
  214. package/dist/intelligence/impact.js +0 -499
  215. package/dist/intelligence/impact.js.map +0 -1
  216. package/dist/intelligence/index.js +0 -17
  217. package/dist/intelligence/index.js.map +0 -1
  218. package/dist/intelligence/patterns.js +0 -492
  219. package/dist/intelligence/patterns.js.map +0 -1
  220. package/dist/intelligence/prediction.js +0 -499
  221. package/dist/intelligence/prediction.js.map +0 -1
  222. package/dist/intelligence/types.js +0 -13
  223. package/dist/intelligence/types.js.map +0 -1
  224. package/dist/internal.js +0 -258
  225. package/dist/internal.js.map +0 -1
  226. package/dist/issue/create.js +0 -121
  227. package/dist/issue/create.js.map +0 -1
  228. package/dist/issue/diagnostics.js +0 -59
  229. package/dist/issue/diagnostics.js.map +0 -1
  230. package/dist/issue/index.js +0 -10
  231. package/dist/issue/index.js.map +0 -1
  232. package/dist/issue/template-parser.js +0 -267
  233. package/dist/issue/template-parser.js.map +0 -1
  234. package/dist/json-schema-validator.js +0 -76
  235. package/dist/json-schema-validator.js.map +0 -1
  236. package/dist/lifecycle/chain-composition.js +0 -152
  237. package/dist/lifecycle/chain-composition.js.map +0 -1
  238. package/dist/lifecycle/chain-store.js +0 -246
  239. package/dist/lifecycle/chain-store.js.map +0 -1
  240. package/dist/lifecycle/consolidate-rcasd.js +0 -352
  241. package/dist/lifecycle/consolidate-rcasd.js.map +0 -1
  242. package/dist/lifecycle/default-chain.js +0 -167
  243. package/dist/lifecycle/default-chain.js.map +0 -1
  244. package/dist/lifecycle/evidence.js +0 -180
  245. package/dist/lifecycle/evidence.js.map +0 -1
  246. package/dist/lifecycle/frontmatter.js +0 -363
  247. package/dist/lifecycle/frontmatter.js.map +0 -1
  248. package/dist/lifecycle/index.js +0 -753
  249. package/dist/lifecycle/index.js.map +0 -1
  250. package/dist/lifecycle/pipeline.js +0 -656
  251. package/dist/lifecycle/pipeline.js.map +0 -1
  252. package/dist/lifecycle/rcasd-index.js +0 -326
  253. package/dist/lifecycle/rcasd-index.js.map +0 -1
  254. package/dist/lifecycle/rcasd-paths.js +0 -220
  255. package/dist/lifecycle/rcasd-paths.js.map +0 -1
  256. package/dist/lifecycle/resume.js +0 -864
  257. package/dist/lifecycle/resume.js.map +0 -1
  258. package/dist/lifecycle/stage-artifacts.js +0 -94
  259. package/dist/lifecycle/stage-artifacts.js.map +0 -1
  260. package/dist/lifecycle/stages.js +0 -534
  261. package/dist/lifecycle/stages.js.map +0 -1
  262. package/dist/lifecycle/state-machine.js +0 -516
  263. package/dist/lifecycle/state-machine.js.map +0 -1
  264. package/dist/lifecycle/tessera-engine.js +0 -249
  265. package/dist/lifecycle/tessera-engine.js.map +0 -1
  266. package/dist/logger.js +0 -140
  267. package/dist/logger.js.map +0 -1
  268. package/dist/mcp/index.js +0 -146
  269. package/dist/mcp/index.js.map +0 -1
  270. package/dist/memory/auto-extract.js +0 -143
  271. package/dist/memory/auto-extract.js.map +0 -1
  272. package/dist/memory/brain-embedding.js +0 -49
  273. package/dist/memory/brain-embedding.js.map +0 -1
  274. package/dist/memory/brain-lifecycle.js +0 -298
  275. package/dist/memory/brain-lifecycle.js.map +0 -1
  276. package/dist/memory/brain-links.js +0 -148
  277. package/dist/memory/brain-links.js.map +0 -1
  278. package/dist/memory/brain-migration.js +0 -149
  279. package/dist/memory/brain-migration.js.map +0 -1
  280. package/dist/memory/brain-reasoning.js +0 -215
  281. package/dist/memory/brain-reasoning.js.map +0 -1
  282. package/dist/memory/brain-retrieval.js +0 -474
  283. package/dist/memory/brain-retrieval.js.map +0 -1
  284. package/dist/memory/brain-row-types.js +0 -10
  285. package/dist/memory/brain-row-types.js.map +0 -1
  286. package/dist/memory/brain-search.js +0 -519
  287. package/dist/memory/brain-search.js.map +0 -1
  288. package/dist/memory/brain-similarity.js +0 -145
  289. package/dist/memory/brain-similarity.js.map +0 -1
  290. package/dist/memory/claude-mem-migration.js +0 -277
  291. package/dist/memory/claude-mem-migration.js.map +0 -1
  292. package/dist/memory/decisions.js +0 -148
  293. package/dist/memory/decisions.js.map +0 -1
  294. package/dist/memory/engine-compat.js +0 -1030
  295. package/dist/memory/engine-compat.js.map +0 -1
  296. package/dist/memory/index.js +0 -773
  297. package/dist/memory/index.js.map +0 -1
  298. package/dist/memory/learnings.js +0 -121
  299. package/dist/memory/learnings.js.map +0 -1
  300. package/dist/memory/memory-bridge.js +0 -289
  301. package/dist/memory/memory-bridge.js.map +0 -1
  302. package/dist/memory/patterns.js +0 -122
  303. package/dist/memory/patterns.js.map +0 -1
  304. package/dist/memory/pipeline-manifest-sqlite.js +0 -975
  305. package/dist/memory/pipeline-manifest-sqlite.js.map +0 -1
  306. package/dist/memory/session-memory.js +0 -226
  307. package/dist/memory/session-memory.js.map +0 -1
  308. package/dist/metrics/ab-test.js +0 -260
  309. package/dist/metrics/ab-test.js.map +0 -1
  310. package/dist/metrics/aggregation.js +0 -363
  311. package/dist/metrics/aggregation.js.map +0 -1
  312. package/dist/metrics/common.js +0 -64
  313. package/dist/metrics/common.js.map +0 -1
  314. package/dist/metrics/enums.js +0 -78
  315. package/dist/metrics/enums.js.map +0 -1
  316. package/dist/metrics/index.js +0 -19
  317. package/dist/metrics/index.js.map +0 -1
  318. package/dist/metrics/model-provider-registry.js +0 -88
  319. package/dist/metrics/model-provider-registry.js.map +0 -1
  320. package/dist/metrics/otel-integration.js +0 -263
  321. package/dist/metrics/otel-integration.js.map +0 -1
  322. package/dist/metrics/provider-detection.js +0 -103
  323. package/dist/metrics/provider-detection.js.map +0 -1
  324. package/dist/metrics/token-estimation.js +0 -253
  325. package/dist/metrics/token-estimation.js.map +0 -1
  326. package/dist/metrics/token-service.js +0 -450
  327. package/dist/metrics/token-service.js.map +0 -1
  328. package/dist/migration/agent-outputs.js +0 -316
  329. package/dist/migration/agent-outputs.js.map +0 -1
  330. package/dist/migration/checksum.js +0 -92
  331. package/dist/migration/checksum.js.map +0 -1
  332. package/dist/migration/index.js +0 -282
  333. package/dist/migration/index.js.map +0 -1
  334. package/dist/migration/logger.js +0 -360
  335. package/dist/migration/logger.js.map +0 -1
  336. package/dist/migration/preflight.js +0 -9
  337. package/dist/migration/preflight.js.map +0 -1
  338. package/dist/migration/state.js +0 -421
  339. package/dist/migration/state.js.map +0 -1
  340. package/dist/migration/validate.js +0 -241
  341. package/dist/migration/validate.js.map +0 -1
  342. package/dist/nexus/deps.js +0 -375
  343. package/dist/nexus/deps.js.map +0 -1
  344. package/dist/nexus/discover.js +0 -288
  345. package/dist/nexus/discover.js.map +0 -1
  346. package/dist/nexus/hash.js +0 -10
  347. package/dist/nexus/hash.js.map +0 -1
  348. package/dist/nexus/index.js +0 -38
  349. package/dist/nexus/index.js.map +0 -1
  350. package/dist/nexus/migrate-json-to-sqlite.js +0 -115
  351. package/dist/nexus/migrate-json-to-sqlite.js.map +0 -1
  352. package/dist/nexus/permissions.js +0 -105
  353. package/dist/nexus/permissions.js.map +0 -1
  354. package/dist/nexus/query.js +0 -175
  355. package/dist/nexus/query.js.map +0 -1
  356. package/dist/nexus/registry.js +0 -584
  357. package/dist/nexus/registry.js.map +0 -1
  358. package/dist/nexus/sharing/index.js +0 -179
  359. package/dist/nexus/sharing/index.js.map +0 -1
  360. package/dist/nexus/transfer-types.js +0 -8
  361. package/dist/nexus/transfer-types.js.map +0 -1
  362. package/dist/nexus/transfer.js +0 -263
  363. package/dist/nexus/transfer.js.map +0 -1
  364. package/dist/observability/index.js +0 -103
  365. package/dist/observability/index.js.map +0 -1
  366. package/dist/observability/log-filter.js +0 -63
  367. package/dist/observability/log-filter.js.map +0 -1
  368. package/dist/observability/log-parser.js +0 -99
  369. package/dist/observability/log-parser.js.map +0 -1
  370. package/dist/observability/log-reader.js +0 -139
  371. package/dist/observability/log-reader.js.map +0 -1
  372. package/dist/observability/types.js +0 -19
  373. package/dist/observability/types.js.map +0 -1
  374. package/dist/orchestration/analyze.js +0 -107
  375. package/dist/orchestration/analyze.js.map +0 -1
  376. package/dist/orchestration/bootstrap.js +0 -132
  377. package/dist/orchestration/bootstrap.js.map +0 -1
  378. package/dist/orchestration/context.js +0 -56
  379. package/dist/orchestration/context.js.map +0 -1
  380. package/dist/orchestration/critical-path.js +0 -100
  381. package/dist/orchestration/critical-path.js.map +0 -1
  382. package/dist/orchestration/index.js +0 -286
  383. package/dist/orchestration/index.js.map +0 -1
  384. package/dist/orchestration/parallel.js +0 -89
  385. package/dist/orchestration/parallel.js.map +0 -1
  386. package/dist/orchestration/protocol-validators.js +0 -524
  387. package/dist/orchestration/protocol-validators.js.map +0 -1
  388. package/dist/orchestration/skill-ops.js +0 -98
  389. package/dist/orchestration/skill-ops.js.map +0 -1
  390. package/dist/orchestration/status.js +0 -107
  391. package/dist/orchestration/status.js.map +0 -1
  392. package/dist/orchestration/unblock.js +0 -103
  393. package/dist/orchestration/unblock.js.map +0 -1
  394. package/dist/orchestration/validate-spawn.js +0 -67
  395. package/dist/orchestration/validate-spawn.js.map +0 -1
  396. package/dist/orchestration/waves.js +0 -86
  397. package/dist/orchestration/waves.js.map +0 -1
  398. package/dist/otel/index.js +0 -163
  399. package/dist/otel/index.js.map +0 -1
  400. package/dist/output.js +0 -132
  401. package/dist/output.js.map +0 -1
  402. package/dist/pagination.js +0 -61
  403. package/dist/pagination.js.map +0 -1
  404. package/dist/paths.js +0 -337
  405. package/dist/paths.js.map +0 -1
  406. package/dist/phases/deps.js +0 -369
  407. package/dist/phases/deps.js.map +0 -1
  408. package/dist/phases/index.js +0 -349
  409. package/dist/phases/index.js.map +0 -1
  410. package/dist/pipeline/index.js +0 -10
  411. package/dist/pipeline/index.js.map +0 -1
  412. package/dist/pipeline/phase.js +0 -45
  413. package/dist/pipeline/phase.js.map +0 -1
  414. package/dist/platform.js +0 -211
  415. package/dist/platform.js.map +0 -1
  416. package/dist/project-info.js +0 -84
  417. package/dist/project-info.js.map +0 -1
  418. package/dist/reconciliation/index.js +0 -10
  419. package/dist/reconciliation/index.js.map +0 -1
  420. package/dist/reconciliation/link-store.js +0 -129
  421. package/dist/reconciliation/link-store.js.map +0 -1
  422. package/dist/reconciliation/reconciliation-engine.js +0 -298
  423. package/dist/reconciliation/reconciliation-engine.js.map +0 -1
  424. package/dist/release/artifacts.js +0 -427
  425. package/dist/release/artifacts.js.map +0 -1
  426. package/dist/release/changelog-writer.js +0 -151
  427. package/dist/release/changelog-writer.js.map +0 -1
  428. package/dist/release/channel.js +0 -144
  429. package/dist/release/channel.js.map +0 -1
  430. package/dist/release/ci.js +0 -166
  431. package/dist/release/ci.js.map +0 -1
  432. package/dist/release/github-pr.js +0 -225
  433. package/dist/release/github-pr.js.map +0 -1
  434. package/dist/release/guards.js +0 -116
  435. package/dist/release/guards.js.map +0 -1
  436. package/dist/release/index.js +0 -22
  437. package/dist/release/index.js.map +0 -1
  438. package/dist/release/release-config.js +0 -158
  439. package/dist/release/release-config.js.map +0 -1
  440. package/dist/release/release-manifest.js +0 -1019
  441. package/dist/release/release-manifest.js.map +0 -1
  442. package/dist/release/version-bump.js +0 -255
  443. package/dist/release/version-bump.js.map +0 -1
  444. package/dist/remote/index.js +0 -257
  445. package/dist/remote/index.js.map +0 -1
  446. package/dist/repair.js +0 -89
  447. package/dist/repair.js.map +0 -1
  448. package/dist/research/index.js +0 -2
  449. package/dist/research/index.js.map +0 -1
  450. package/dist/roadmap/index.js +0 -59
  451. package/dist/roadmap/index.js.map +0 -1
  452. package/dist/routing/capability-matrix.js +0 -1550
  453. package/dist/routing/capability-matrix.js.map +0 -1
  454. package/dist/routing/index.js +0 -9
  455. package/dist/routing/index.js.map +0 -1
  456. package/dist/scaffold.js +0 -1158
  457. package/dist/scaffold.js.map +0 -1
  458. package/dist/schema-management.js +0 -295
  459. package/dist/schema-management.js.map +0 -1
  460. package/dist/security/index.js +0 -9
  461. package/dist/security/index.js.map +0 -1
  462. package/dist/security/input-sanitization.js +0 -321
  463. package/dist/security/input-sanitization.js.map +0 -1
  464. package/dist/sequence/index.js +0 -295
  465. package/dist/sequence/index.js.map +0 -1
  466. package/dist/sessions/assumptions.js +0 -54
  467. package/dist/sessions/assumptions.js.map +0 -1
  468. package/dist/sessions/briefing.js +0 -377
  469. package/dist/sessions/briefing.js.map +0 -1
  470. package/dist/sessions/context-alert.js +0 -222
  471. package/dist/sessions/context-alert.js.map +0 -1
  472. package/dist/sessions/context-inject.js +0 -61
  473. package/dist/sessions/context-inject.js.map +0 -1
  474. package/dist/sessions/context-monitor.js +0 -98
  475. package/dist/sessions/context-monitor.js.map +0 -1
  476. package/dist/sessions/decisions.js +0 -65
  477. package/dist/sessions/decisions.js.map +0 -1
  478. package/dist/sessions/find.js +0 -63
  479. package/dist/sessions/find.js.map +0 -1
  480. package/dist/sessions/handoff.js +0 -328
  481. package/dist/sessions/handoff.js.map +0 -1
  482. package/dist/sessions/hitl-warnings.js +0 -254
  483. package/dist/sessions/hitl-warnings.js.map +0 -1
  484. package/dist/sessions/index.js +0 -318
  485. package/dist/sessions/index.js.map +0 -1
  486. package/dist/sessions/session-archive.js +0 -40
  487. package/dist/sessions/session-archive.js.map +0 -1
  488. package/dist/sessions/session-cleanup.js +0 -59
  489. package/dist/sessions/session-cleanup.js.map +0 -1
  490. package/dist/sessions/session-drift.js +0 -134
  491. package/dist/sessions/session-drift.js.map +0 -1
  492. package/dist/sessions/session-enforcement.js +0 -140
  493. package/dist/sessions/session-enforcement.js.map +0 -1
  494. package/dist/sessions/session-grade.js +0 -253
  495. package/dist/sessions/session-grade.js.map +0 -1
  496. package/dist/sessions/session-history.js +0 -42
  497. package/dist/sessions/session-history.js.map +0 -1
  498. package/dist/sessions/session-id.js +0 -81
  499. package/dist/sessions/session-id.js.map +0 -1
  500. package/dist/sessions/session-memory-bridge.js +0 -52
  501. package/dist/sessions/session-memory-bridge.js.map +0 -1
  502. package/dist/sessions/session-show.js +0 -24
  503. package/dist/sessions/session-show.js.map +0 -1
  504. package/dist/sessions/session-stats.js +0 -69
  505. package/dist/sessions/session-stats.js.map +0 -1
  506. package/dist/sessions/session-suspend.js +0 -39
  507. package/dist/sessions/session-suspend.js.map +0 -1
  508. package/dist/sessions/session-switch.js +0 -51
  509. package/dist/sessions/session-switch.js.map +0 -1
  510. package/dist/sessions/session-view.js +0 -76
  511. package/dist/sessions/session-view.js.map +0 -1
  512. package/dist/sessions/statusline-setup.js +0 -85
  513. package/dist/sessions/statusline-setup.js.map +0 -1
  514. package/dist/sessions/types.js +0 -8
  515. package/dist/sessions/types.js.map +0 -1
  516. package/dist/signaldock/claude-code-transport.js +0 -107
  517. package/dist/signaldock/claude-code-transport.js.map +0 -1
  518. package/dist/signaldock/factory.js +0 -25
  519. package/dist/signaldock/factory.js.map +0 -1
  520. package/dist/signaldock/index.js +0 -9
  521. package/dist/signaldock/index.js.map +0 -1
  522. package/dist/signaldock/signaldock-transport.js +0 -122
  523. package/dist/signaldock/signaldock-transport.js.map +0 -1
  524. package/dist/signaldock/transport.js +0 -11
  525. package/dist/signaldock/transport.js.map +0 -1
  526. package/dist/signaldock/types.js +0 -11
  527. package/dist/signaldock/types.js.map +0 -1
  528. package/dist/skills/agents/config.js +0 -94
  529. package/dist/skills/agents/config.js.map +0 -1
  530. package/dist/skills/agents/install.js +0 -116
  531. package/dist/skills/agents/install.js.map +0 -1
  532. package/dist/skills/agents/registry.js +0 -161
  533. package/dist/skills/agents/registry.js.map +0 -1
  534. package/dist/skills/discovery.js +0 -333
  535. package/dist/skills/discovery.js.map +0 -1
  536. package/dist/skills/dispatch.js +0 -347
  537. package/dist/skills/dispatch.js.map +0 -1
  538. package/dist/skills/dynamic-skill-generator.js +0 -100
  539. package/dist/skills/dynamic-skill-generator.js.map +0 -1
  540. package/dist/skills/index.js +0 -44
  541. package/dist/skills/index.js.map +0 -1
  542. package/dist/skills/injection/subagent.js +0 -195
  543. package/dist/skills/injection/subagent.js.map +0 -1
  544. package/dist/skills/injection/token.js +0 -260
  545. package/dist/skills/injection/token.js.map +0 -1
  546. package/dist/skills/install.js +0 -40
  547. package/dist/skills/install.js.map +0 -1
  548. package/dist/skills/manifests/contribution.js +0 -175
  549. package/dist/skills/manifests/contribution.js.map +0 -1
  550. package/dist/skills/manifests/research.js +0 -281
  551. package/dist/skills/manifests/research.js.map +0 -1
  552. package/dist/skills/manifests/resolver.js +0 -146
  553. package/dist/skills/manifests/resolver.js.map +0 -1
  554. package/dist/skills/marketplace.js +0 -90
  555. package/dist/skills/marketplace.js.map +0 -1
  556. package/dist/skills/orchestrator/spawn.js +0 -178
  557. package/dist/skills/orchestrator/spawn.js.map +0 -1
  558. package/dist/skills/orchestrator/startup.js +0 -451
  559. package/dist/skills/orchestrator/startup.js.map +0 -1
  560. package/dist/skills/orchestrator/validator.js +0 -301
  561. package/dist/skills/orchestrator/validator.js.map +0 -1
  562. package/dist/skills/precedence-integration.js +0 -73
  563. package/dist/skills/precedence-integration.js.map +0 -1
  564. package/dist/skills/precedence-types.js +0 -16
  565. package/dist/skills/precedence-types.js.map +0 -1
  566. package/dist/skills/routing-table.js +0 -63
  567. package/dist/skills/routing-table.js.map +0 -1
  568. package/dist/skills/skill-paths.js +0 -220
  569. package/dist/skills/skill-paths.js.map +0 -1
  570. package/dist/skills/test-utility.js +0 -55
  571. package/dist/skills/test-utility.js.map +0 -1
  572. package/dist/skills/types.js +0 -118
  573. package/dist/skills/types.js.map +0 -1
  574. package/dist/skills/validation.js +0 -183
  575. package/dist/skills/validation.js.map +0 -1
  576. package/dist/skills/version.js +0 -57
  577. package/dist/skills/version.js.map +0 -1
  578. package/dist/snapshot/index.js +0 -188
  579. package/dist/snapshot/index.js.map +0 -1
  580. package/dist/spawn/adapter-registry.js +0 -246
  581. package/dist/spawn/adapter-registry.js.map +0 -1
  582. package/dist/spawn/index.js +0 -10
  583. package/dist/spawn/index.js.map +0 -1
  584. package/dist/stats/index.js +0 -339
  585. package/dist/stats/index.js.map +0 -1
  586. package/dist/sticky/archive.js +0 -47
  587. package/dist/sticky/archive.js.map +0 -1
  588. package/dist/sticky/convert.js +0 -235
  589. package/dist/sticky/convert.js.map +0 -1
  590. package/dist/sticky/create.js +0 -48
  591. package/dist/sticky/create.js.map +0 -1
  592. package/dist/sticky/id.js +0 -35
  593. package/dist/sticky/id.js.map +0 -1
  594. package/dist/sticky/index.js +0 -16
  595. package/dist/sticky/index.js.map +0 -1
  596. package/dist/sticky/list.js +0 -44
  597. package/dist/sticky/list.js.map +0 -1
  598. package/dist/sticky/purge.js +0 -45
  599. package/dist/sticky/purge.js.map +0 -1
  600. package/dist/sticky/show.js +0 -42
  601. package/dist/sticky/show.js.map +0 -1
  602. package/dist/sticky/types.js +0 -10
  603. package/dist/sticky/types.js.map +0 -1
  604. package/dist/store/atomic.js +0 -167
  605. package/dist/store/atomic.js.map +0 -1
  606. package/dist/store/backup.js +0 -94
  607. package/dist/store/backup.js.map +0 -1
  608. package/dist/store/brain-accessor.js +0 -397
  609. package/dist/store/brain-accessor.js.map +0 -1
  610. package/dist/store/brain-schema.js +0 -212
  611. package/dist/store/brain-schema.js.map +0 -1
  612. package/dist/store/brain-sqlite.js +0 -271
  613. package/dist/store/brain-sqlite.js.map +0 -1
  614. package/dist/store/cache.js +0 -168
  615. package/dist/store/cache.js.map +0 -1
  616. package/dist/store/chain-schema.js +0 -51
  617. package/dist/store/chain-schema.js.map +0 -1
  618. package/dist/store/converters.js +0 -120
  619. package/dist/store/converters.js.map +0 -1
  620. package/dist/store/data-accessor.js +0 -26
  621. package/dist/store/data-accessor.js.map +0 -1
  622. package/dist/store/data-safety-central.js +0 -269
  623. package/dist/store/data-safety-central.js.map +0 -1
  624. package/dist/store/data-safety.js +0 -274
  625. package/dist/store/data-safety.js.map +0 -1
  626. package/dist/store/db-helpers.js +0 -221
  627. package/dist/store/db-helpers.js.map +0 -1
  628. package/dist/store/export.js +0 -155
  629. package/dist/store/export.js.map +0 -1
  630. package/dist/store/file-utils.js +0 -270
  631. package/dist/store/file-utils.js.map +0 -1
  632. package/dist/store/git-checkpoint.js +0 -365
  633. package/dist/store/git-checkpoint.js.map +0 -1
  634. package/dist/store/import-logging.js +0 -139
  635. package/dist/store/import-logging.js.map +0 -1
  636. package/dist/store/import-remap.js +0 -145
  637. package/dist/store/import-remap.js.map +0 -1
  638. package/dist/store/import-sort.js +0 -121
  639. package/dist/store/import-sort.js.map +0 -1
  640. package/dist/store/index.js +0 -28
  641. package/dist/store/index.js.map +0 -1
  642. package/dist/store/json.js +0 -208
  643. package/dist/store/json.js.map +0 -1
  644. package/dist/store/lifecycle-store.js +0 -249
  645. package/dist/store/lifecycle-store.js.map +0 -1
  646. package/dist/store/lock.js +0 -70
  647. package/dist/store/lock.js.map +0 -1
  648. package/dist/store/migration-sqlite.js +0 -671
  649. package/dist/store/migration-sqlite.js.map +0 -1
  650. package/dist/store/nexus-schema.js +0 -62
  651. package/dist/store/nexus-schema.js.map +0 -1
  652. package/dist/store/nexus-sqlite.js +0 -217
  653. package/dist/store/nexus-sqlite.js.map +0 -1
  654. package/dist/store/nexus-validation-schemas.js +0 -40
  655. package/dist/store/nexus-validation-schemas.js.map +0 -1
  656. package/dist/store/parsers.js +0 -37
  657. package/dist/store/parsers.js.map +0 -1
  658. package/dist/store/project-detect.js +0 -457
  659. package/dist/store/project-detect.js.map +0 -1
  660. package/dist/store/provider.js +0 -101
  661. package/dist/store/provider.js.map +0 -1
  662. package/dist/store/safety-data-accessor.js +0 -243
  663. package/dist/store/safety-data-accessor.js.map +0 -1
  664. package/dist/store/schema.js +0 -7
  665. package/dist/store/schema.js.map +0 -1
  666. package/dist/store/session-store.js +0 -219
  667. package/dist/store/session-store.js.map +0 -1
  668. package/dist/store/sqlite-backup.js +0 -105
  669. package/dist/store/sqlite-backup.js.map +0 -1
  670. package/dist/store/sqlite-data-accessor.js +0 -742
  671. package/dist/store/sqlite-data-accessor.js.map +0 -1
  672. package/dist/store/sqlite.js +0 -489
  673. package/dist/store/sqlite.js.map +0 -1
  674. package/dist/store/status-registry.js +0 -8
  675. package/dist/store/status-registry.js.map +0 -1
  676. package/dist/store/task-store.js +0 -344
  677. package/dist/store/task-store.js.map +0 -1
  678. package/dist/store/tasks-schema.js +0 -574
  679. package/dist/store/tasks-schema.js.map +0 -1
  680. package/dist/store/typed-query.js +0 -15
  681. package/dist/store/typed-query.js.map +0 -1
  682. package/dist/store/validation-schemas.js +0 -278
  683. package/dist/store/validation-schemas.js.map +0 -1
  684. package/dist/system/archive-analytics.js +0 -277
  685. package/dist/system/archive-analytics.js.map +0 -1
  686. package/dist/system/archive-stats.js +0 -64
  687. package/dist/system/archive-stats.js.map +0 -1
  688. package/dist/system/audit.js +0 -145
  689. package/dist/system/audit.js.map +0 -1
  690. package/dist/system/backup.js +0 -99
  691. package/dist/system/backup.js.map +0 -1
  692. package/dist/system/cleanup.js +0 -134
  693. package/dist/system/cleanup.js.map +0 -1
  694. package/dist/system/health.js +0 -1054
  695. package/dist/system/health.js.map +0 -1
  696. package/dist/system/index.js +0 -18
  697. package/dist/system/index.js.map +0 -1
  698. package/dist/system/inject-generate.js +0 -122
  699. package/dist/system/inject-generate.js.map +0 -1
  700. package/dist/system/labels.js +0 -38
  701. package/dist/system/labels.js.map +0 -1
  702. package/dist/system/metrics.js +0 -61
  703. package/dist/system/metrics.js.map +0 -1
  704. package/dist/system/migrate.js +0 -43
  705. package/dist/system/migrate.js.map +0 -1
  706. package/dist/system/platform-paths.js +0 -80
  707. package/dist/system/platform-paths.js.map +0 -1
  708. package/dist/system/runtime.js +0 -161
  709. package/dist/system/runtime.js.map +0 -1
  710. package/dist/system/safestop.js +0 -99
  711. package/dist/system/safestop.js.map +0 -1
  712. package/dist/system/storage-preflight.js +0 -123
  713. package/dist/system/storage-preflight.js.map +0 -1
  714. package/dist/task-work/index.js +0 -155
  715. package/dist/task-work/index.js.map +0 -1
  716. package/dist/tasks/add.js +0 -510
  717. package/dist/tasks/add.js.map +0 -1
  718. package/dist/tasks/analyze.js +0 -85
  719. package/dist/tasks/analyze.js.map +0 -1
  720. package/dist/tasks/archive.js +0 -90
  721. package/dist/tasks/archive.js.map +0 -1
  722. package/dist/tasks/atomicity.js +0 -83
  723. package/dist/tasks/atomicity.js.map +0 -1
  724. package/dist/tasks/cancel-ops.js +0 -83
  725. package/dist/tasks/cancel-ops.js.map +0 -1
  726. package/dist/tasks/complete.js +0 -224
  727. package/dist/tasks/complete.js.map +0 -1
  728. package/dist/tasks/crossref-extract.js +0 -73
  729. package/dist/tasks/crossref-extract.js.map +0 -1
  730. package/dist/tasks/delete-preview.js +0 -192
  731. package/dist/tasks/delete-preview.js.map +0 -1
  732. package/dist/tasks/delete.js +0 -120
  733. package/dist/tasks/delete.js.map +0 -1
  734. package/dist/tasks/deletion-strategy.js +0 -200
  735. package/dist/tasks/deletion-strategy.js.map +0 -1
  736. package/dist/tasks/dependency-check.js +0 -278
  737. package/dist/tasks/dependency-check.js.map +0 -1
  738. package/dist/tasks/deps-ready.js +0 -32
  739. package/dist/tasks/deps-ready.js.map +0 -1
  740. package/dist/tasks/enforcement.js +0 -82
  741. package/dist/tasks/enforcement.js.map +0 -1
  742. package/dist/tasks/find.js +0 -148
  743. package/dist/tasks/find.js.map +0 -1
  744. package/dist/tasks/graph-cache.js +0 -127
  745. package/dist/tasks/graph-cache.js.map +0 -1
  746. package/dist/tasks/graph-ops.js +0 -171
  747. package/dist/tasks/graph-ops.js.map +0 -1
  748. package/dist/tasks/graph-rag.js +0 -328
  749. package/dist/tasks/graph-rag.js.map +0 -1
  750. package/dist/tasks/hierarchy-policy.js +0 -149
  751. package/dist/tasks/hierarchy-policy.js.map +0 -1
  752. package/dist/tasks/hierarchy.js +0 -185
  753. package/dist/tasks/hierarchy.js.map +0 -1
  754. package/dist/tasks/id-generator.js +0 -65
  755. package/dist/tasks/id-generator.js.map +0 -1
  756. package/dist/tasks/index.js +0 -14
  757. package/dist/tasks/index.js.map +0 -1
  758. package/dist/tasks/labels.js +0 -52
  759. package/dist/tasks/labels.js.map +0 -1
  760. package/dist/tasks/list.js +0 -68
  761. package/dist/tasks/list.js.map +0 -1
  762. package/dist/tasks/phase-tracking.js +0 -133
  763. package/dist/tasks/phase-tracking.js.map +0 -1
  764. package/dist/tasks/plan.js +0 -268
  765. package/dist/tasks/plan.js.map +0 -1
  766. package/dist/tasks/relates.js +0 -89
  767. package/dist/tasks/relates.js.map +0 -1
  768. package/dist/tasks/reparent.d.ts +0 -38
  769. package/dist/tasks/reparent.d.ts.map +0 -1
  770. package/dist/tasks/show.js +0 -78
  771. package/dist/tasks/show.js.map +0 -1
  772. package/dist/tasks/size-weighting.js +0 -86
  773. package/dist/tasks/size-weighting.js.map +0 -1
  774. package/dist/tasks/staleness.js +0 -86
  775. package/dist/tasks/staleness.js.map +0 -1
  776. package/dist/tasks/task-ops.js +0 -1340
  777. package/dist/tasks/task-ops.js.map +0 -1
  778. package/dist/tasks/update.js +0 -243
  779. package/dist/tasks/update.js.map +0 -1
  780. package/dist/templates/index.js +0 -10
  781. package/dist/templates/index.js.map +0 -1
  782. package/dist/templates/parser.js +0 -254
  783. package/dist/templates/parser.js.map +0 -1
  784. package/dist/ui/aliases.js +0 -153
  785. package/dist/ui/aliases.js.map +0 -1
  786. package/dist/ui/changelog.js +0 -184
  787. package/dist/ui/changelog.js.map +0 -1
  788. package/dist/ui/command-registry.js +0 -168
  789. package/dist/ui/command-registry.js.map +0 -1
  790. package/dist/ui/flags.js +0 -94
  791. package/dist/ui/flags.js.map +0 -1
  792. package/dist/ui/index.js +0 -24
  793. package/dist/ui/index.js.map +0 -1
  794. package/dist/ui/injection-legacy.d.ts +0 -26
  795. package/dist/ui/injection-legacy.d.ts.map +0 -1
  796. package/dist/ui/injection-legacy.js +0 -42
  797. package/dist/ui/injection-legacy.js.map +0 -1
  798. package/dist/upgrade.js +0 -901
  799. package/dist/upgrade.js.map +0 -1
  800. package/dist/validation/chain-validation.js +0 -146
  801. package/dist/validation/chain-validation.js.map +0 -1
  802. package/dist/validation/compliance.js +0 -155
  803. package/dist/validation/compliance.js.map +0 -1
  804. package/dist/validation/docs-sync.js +0 -212
  805. package/dist/validation/docs-sync.js.map +0 -1
  806. package/dist/validation/doctor/checks.js +0 -1069
  807. package/dist/validation/doctor/checks.js.map +0 -1
  808. package/dist/validation/doctor/index.js +0 -9
  809. package/dist/validation/doctor/index.js.map +0 -1
  810. package/dist/validation/doctor/project-cache.js +0 -160
  811. package/dist/validation/doctor/project-cache.js.map +0 -1
  812. package/dist/validation/doctor/utils.js +0 -155
  813. package/dist/validation/doctor/utils.js.map +0 -1
  814. package/dist/validation/engine.js +0 -902
  815. package/dist/validation/engine.js.map +0 -1
  816. package/dist/validation/gap-check.js +0 -175
  817. package/dist/validation/gap-check.js.map +0 -1
  818. package/dist/validation/index.js +0 -40
  819. package/dist/validation/index.js.map +0 -1
  820. package/dist/validation/manifest.js +0 -237
  821. package/dist/validation/manifest.js.map +0 -1
  822. package/dist/validation/operation-gate-validators.js +0 -724
  823. package/dist/validation/operation-gate-validators.js.map +0 -1
  824. package/dist/validation/operation-verification-gates.js +0 -532
  825. package/dist/validation/operation-verification-gates.js.map +0 -1
  826. package/dist/validation/param-utils.js +0 -139
  827. package/dist/validation/param-utils.js.map +0 -1
  828. package/dist/validation/protocol-common.js +0 -300
  829. package/dist/validation/protocol-common.js.map +0 -1
  830. package/dist/validation/protocols/consensus.js +0 -71
  831. package/dist/validation/protocols/consensus.js.map +0 -1
  832. package/dist/validation/protocols/contribution.js +0 -59
  833. package/dist/validation/protocols/contribution.js.map +0 -1
  834. package/dist/validation/protocols/decomposition.js +0 -59
  835. package/dist/validation/protocols/decomposition.js.map +0 -1
  836. package/dist/validation/protocols/implementation.js +0 -59
  837. package/dist/validation/protocols/implementation.js.map +0 -1
  838. package/dist/validation/protocols/release-protocol.js +0 -60
  839. package/dist/validation/protocols/release-protocol.js.map +0 -1
  840. package/dist/validation/protocols/research.js +0 -77
  841. package/dist/validation/protocols/research.js.map +0 -1
  842. package/dist/validation/protocols/specification.js +0 -84
  843. package/dist/validation/protocols/specification.js.map +0 -1
  844. package/dist/validation/protocols/testing-protocol.js +0 -70
  845. package/dist/validation/protocols/testing-protocol.js.map +0 -1
  846. package/dist/validation/protocols/validation-protocol.js +0 -70
  847. package/dist/validation/protocols/validation-protocol.js.map +0 -1
  848. package/dist/validation/schema-integrity.js +0 -170
  849. package/dist/validation/schema-integrity.js.map +0 -1
  850. package/dist/validation/schema-validator.js +0 -176
  851. package/dist/validation/schema-validator.js.map +0 -1
  852. package/dist/validation/validate-ops.js +0 -937
  853. package/dist/validation/validate-ops.js.map +0 -1
  854. package/dist/validation/validation-rules.js +0 -226
  855. package/dist/validation/validation-rules.js.map +0 -1
  856. package/dist/validation/verification.js +0 -321
  857. package/dist/validation/verification.js.map +0 -1
@@ -1,742 +0,0 @@
1
- /**
2
- * SQLite-based implementation of the DataAccessor interface.
3
- *
4
- * Materializes TaskFile/ArchiveFile/SessionsFile from SQLite tables,
5
- * allowing core modules to continue using whole-file data structures
6
- * while storage is backed by the relational database.
7
- *
8
- * Uses existing sqlite.ts engine (node:sqlite / drizzle-orm) and
9
- * task-store.ts / session-store.ts for row-level operations.
10
- *
11
- * @epic T4454
12
- */
13
- import { and, eq, inArray, isNull, like, ne, notInArray, or, sql } from 'drizzle-orm';
14
- import { archivedTaskToRow, rowToSession, rowToTask, taskToRow } from './converters.js';
15
- import { batchUpdateDependencies, loadDependenciesForTasks, loadRelationsForTasks, updateDependencies, upsertSession, upsertTask, } from './db-helpers.js';
16
- import { closeDb, getDb, getNativeTasksDb } from './sqlite.js';
17
- import { TERMINAL_TASK_STATUSES } from './status-registry.js';
18
- import * as schema from './tasks-schema.js';
19
- /**
20
- * Generate a unique audit log entry ID.
21
- * @task T4837
22
- */
23
- function generateAuditLogId() {
24
- const epoch = Math.floor(Date.now() / 1000);
25
- const rand = Math.random().toString(36).slice(2, 8);
26
- return `log-${epoch}-${rand}`;
27
- }
28
- // ---- Schema meta helpers ----
29
- /** Read a JSON blob from the schema_meta table by key. */
30
- async function getMetaValue(cwd, key) {
31
- const db = await getDb(cwd);
32
- const rows = await db
33
- .select()
34
- .from(schema.schemaMeta)
35
- .where(eq(schema.schemaMeta.key, key))
36
- .all();
37
- if (rows.length === 0 || !rows[0])
38
- return null;
39
- try {
40
- return JSON.parse(rows[0].value);
41
- }
42
- catch {
43
- return null;
44
- }
45
- }
46
- /** Write a JSON blob to the schema_meta table by key. */
47
- export async function setMetaValue(cwd, key, value) {
48
- const db = await getDb(cwd);
49
- const json = JSON.stringify(value);
50
- await db
51
- .insert(schema.schemaMeta)
52
- .values({ key, value: json })
53
- .onConflictDoUpdate({
54
- target: schema.schemaMeta.key,
55
- set: { value: json },
56
- })
57
- .run();
58
- }
59
- // ---- Accessor factory ----
60
- /**
61
- * Create a SQLite-backed DataAccessor.
62
- *
63
- * Opens (or creates) the SQLite database at `.cleo/tasks.db` and returns
64
- * a DataAccessor that materializes/dematerializes whole-file structures
65
- * from the relational tables.
66
- *
67
- * @param cwd - Working directory for path resolution (defaults to process.cwd())
68
- */
69
- export async function createSqliteDataAccessor(cwd) {
70
- // Eagerly initialize the database to ensure tables exist
71
- await getDb(cwd);
72
- /** Load all task IDs for cross-task dependency validation. */
73
- async function getAllTaskIds() {
74
- const db = await getDb(cwd);
75
- const rows = await db.select({ id: schema.tasks.id }).from(schema.tasks).all();
76
- return new Set(rows.map((r) => r.id));
77
- }
78
- const accessor = {
79
- engine: 'sqlite',
80
- // ---- loadArchive ----
81
- async loadArchive() {
82
- const db = await getDb(cwd);
83
- // Query tasks where status = 'archived'
84
- const archivedRows = await db
85
- .select()
86
- .from(schema.tasks)
87
- .where(eq(schema.tasks.status, 'archived'))
88
- .all();
89
- if (archivedRows.length === 0)
90
- return null;
91
- const archivedTasks = archivedRows.map((row) => {
92
- const task = rowToTask(row);
93
- // Restore the original terminal status for the archive representation
94
- // but keep the archived metadata accessible
95
- return {
96
- ...task,
97
- // In archive files, tasks retain their pre-archive status if available,
98
- // but since we store as 'archived' in DB, use the archived info
99
- archivedAt: row.archivedAt ?? undefined,
100
- archiveReason: row.archiveReason ?? undefined,
101
- cycleTimeDays: row.cycleTimeDays ?? undefined,
102
- };
103
- });
104
- // Load dependencies and relations for archived tasks, filtering orphaned refs
105
- if (archivedTasks.length > 0) {
106
- // Also load all active task IDs so we can validate cross-references
107
- const activeRows = await db
108
- .select({ id: schema.tasks.id })
109
- .from(schema.tasks)
110
- .where(ne(schema.tasks.status, 'archived'))
111
- .all();
112
- const allKnownIds = new Set([
113
- ...archivedTasks.map((t) => t.id),
114
- ...activeRows.map((r) => r.id),
115
- ]);
116
- await loadDependenciesForTasks(db, archivedTasks, allKnownIds);
117
- await loadRelationsForTasks(db, archivedTasks);
118
- }
119
- return {
120
- archivedTasks,
121
- version: '1.0.0',
122
- };
123
- },
124
- // ---- saveArchive ----
125
- async saveArchive(data) {
126
- const db = await getDb(cwd);
127
- // Pre-compute archive IDs + active task IDs for dependency validation
128
- const archiveIds = new Set(data.archivedTasks.map((t) => t.id));
129
- const activeRows = await db
130
- .select({ id: schema.tasks.id })
131
- .from(schema.tasks)
132
- .where(ne(schema.tasks.status, 'archived'))
133
- .all();
134
- const validDepIds = new Set([...archiveIds, ...activeRows.map((r) => r.id)]);
135
- // Wrap all upserts + dependency updates in a single transaction
136
- const nativeDb = getNativeTasksDb();
137
- if (!nativeDb) {
138
- throw new Error('Native database not initialized');
139
- }
140
- nativeDb.prepare('BEGIN IMMEDIATE').run();
141
- try {
142
- // Collect dependency data for batch update
143
- const depBatch = [];
144
- for (const task of data.archivedTasks) {
145
- const row = archivedTaskToRow(task);
146
- // Extract archive-specific fields if they exist on the task object
147
- const taskAny = task;
148
- const archiveFields = {
149
- archivedAt: taskAny.archivedAt ?? row.completedAt ?? new Date().toISOString(),
150
- archiveReason: taskAny.archiveReason ?? 'completed',
151
- cycleTimeDays: taskAny.cycleTimeDays ?? null,
152
- };
153
- await upsertTask(db, row, archiveFields);
154
- depBatch.push({ taskId: task.id, deps: task.depends ?? [] });
155
- }
156
- // Single batch operation for all dependency updates
157
- await batchUpdateDependencies(db, depBatch, validDepIds);
158
- nativeDb.prepare('COMMIT').run();
159
- }
160
- catch (err) {
161
- nativeDb.prepare('ROLLBACK').run();
162
- throw err;
163
- }
164
- },
165
- // ---- loadSessions ----
166
- async loadSessions() {
167
- const db = await getDb(cwd);
168
- const sessionRows = await db.select().from(schema.sessions).all();
169
- return sessionRows.map(rowToSession);
170
- },
171
- // ---- saveSessions ----
172
- async saveSessions(sessions) {
173
- const db = await getDb(cwd);
174
- // Get existing session IDs
175
- const existingRows = await db.select({ id: schema.sessions.id }).from(schema.sessions).all();
176
- const existingIds = new Set(existingRows.map((r) => r.id));
177
- const incomingIds = new Set(sessions.map((s) => s.id));
178
- // Delete sessions that are no longer in the data
179
- for (const eid of existingIds) {
180
- if (!incomingIds.has(eid)) {
181
- await db.delete(schema.sessions).where(eq(schema.sessions.id, eid)).run();
182
- }
183
- }
184
- // Upsert all sessions
185
- for (const session of sessions) {
186
- await upsertSession(db, session);
187
- }
188
- },
189
- // ---- appendLog ----
190
- async appendLog(entry) {
191
- const db = await getDb(cwd);
192
- await db
193
- .insert(schema.auditLog)
194
- .values({
195
- id: entry.id ?? generateAuditLogId(),
196
- timestamp: entry.timestamp ?? new Date().toISOString(),
197
- action: entry.action ?? entry.operation ?? 'unknown',
198
- taskId: entry.taskId ?? 'unknown',
199
- actor: entry.actor ?? 'system',
200
- detailsJson: entry.details ? JSON.stringify(entry.details) : '{}',
201
- beforeJson: entry.before ? JSON.stringify(entry.before) : null,
202
- afterJson: entry.after ? JSON.stringify(entry.after) : null,
203
- })
204
- .run();
205
- },
206
- // ---- Fine-grained task operations (T5034) ----
207
- async upsertSingleTask(task) {
208
- const db = await getDb(cwd);
209
- const row = taskToRow(task);
210
- await upsertTask(db, row);
211
- await updateDependencies(db, task.id, task.depends ?? []);
212
- },
213
- async addRelation(taskId, relatedTo, relationType, reason) {
214
- const db = await getDb(cwd);
215
- // Validate relation type - throw on invalid (T5168)
216
- const validTypes = [
217
- 'related',
218
- 'blocks',
219
- 'duplicates',
220
- 'absorbs',
221
- 'fixes',
222
- 'extends',
223
- 'supersedes',
224
- ];
225
- if (!validTypes.includes(relationType)) {
226
- throw new Error(`Invalid relation type: ${relationType}. Valid types: ${validTypes.join(', ')}`);
227
- }
228
- await db
229
- .insert(schema.taskRelations)
230
- .values({
231
- taskId,
232
- relatedTo,
233
- relationType: relationType,
234
- reason: reason ?? null,
235
- })
236
- .onConflictDoNothing()
237
- .run();
238
- },
239
- async archiveSingleTask(taskId, fields) {
240
- const db = await getDb(cwd);
241
- // Verify the task exists before archiving
242
- const rows = await db
243
- .select({ id: schema.tasks.id })
244
- .from(schema.tasks)
245
- .where(eq(schema.tasks.id, taskId))
246
- .all();
247
- if (rows.length === 0)
248
- return;
249
- await db
250
- .update(schema.tasks)
251
- .set({
252
- status: 'archived',
253
- archivedAt: fields.archivedAt ?? new Date().toISOString(),
254
- archiveReason: fields.archiveReason ?? 'completed',
255
- cycleTimeDays: fields.cycleTimeDays ?? null,
256
- updatedAt: new Date().toISOString(),
257
- })
258
- .where(eq(schema.tasks.id, taskId))
259
- .run();
260
- },
261
- async removeSingleTask(taskId) {
262
- const db = await getDb(cwd);
263
- // Delete dependencies first (both directions)
264
- await db
265
- .delete(schema.taskDependencies)
266
- .where(eq(schema.taskDependencies.taskId, taskId))
267
- .run();
268
- await db
269
- .delete(schema.taskDependencies)
270
- .where(eq(schema.taskDependencies.dependsOn, taskId))
271
- .run();
272
- // Delete the task itself
273
- await db.delete(schema.tasks).where(eq(schema.tasks.id, taskId)).run();
274
- },
275
- async loadSingleTask(taskId) {
276
- const db = await getDb(cwd);
277
- const rows = await db
278
- .select()
279
- .from(schema.tasks)
280
- .where(eq(schema.tasks.id, taskId))
281
- .limit(1)
282
- .all();
283
- if (rows.length === 0 || !rows[0])
284
- return null;
285
- const task = rowToTask(rows[0]);
286
- // Load all task IDs so dependency validation doesn't filter out cross-task refs
287
- const allIdRows = await db.select({ id: schema.tasks.id }).from(schema.tasks).all();
288
- const allIds = new Set(allIdRows.map((r) => r.id));
289
- await loadDependenciesForTasks(db, [task], allIds);
290
- await loadRelationsForTasks(db, [task]);
291
- return task;
292
- },
293
- async getActiveSession() {
294
- const db = await getDb(cwd);
295
- const rows = await db
296
- .select()
297
- .from(schema.sessions)
298
- .where(eq(schema.sessions.status, 'active'))
299
- .orderBy(sql `${schema.sessions.startedAt} DESC`)
300
- .limit(1)
301
- .all();
302
- if (rows.length === 0 || !rows[0])
303
- return null;
304
- return rowToSession(rows[0]);
305
- },
306
- async upsertSingleSession(session) {
307
- const db = await getDb(cwd);
308
- await upsertSession(db, session);
309
- },
310
- async removeSingleSession(sessionId) {
311
- const db = await getDb(cwd);
312
- await db.delete(schema.sessions).where(eq(schema.sessions.id, sessionId)).run();
313
- },
314
- // ---- Targeted query methods (Phase 2 modernization) ----
315
- async queryTasks(filters) {
316
- const db = await getDb(cwd);
317
- const conditions = [];
318
- // Exclude archived by default unless explicitly requested
319
- if (filters.status) {
320
- const statuses = Array.isArray(filters.status) ? filters.status : [filters.status];
321
- if (!statuses.includes('archived')) {
322
- conditions.push(ne(schema.tasks.status, 'archived'));
323
- }
324
- conditions.push(inArray(schema.tasks.status, statuses));
325
- }
326
- else if (filters.excludeStatus) {
327
- const excluded = Array.isArray(filters.excludeStatus)
328
- ? filters.excludeStatus
329
- : [filters.excludeStatus];
330
- for (const s of excluded) {
331
- conditions.push(ne(schema.tasks.status, s));
332
- }
333
- }
334
- else {
335
- conditions.push(ne(schema.tasks.status, 'archived'));
336
- }
337
- if (filters.priority)
338
- conditions.push(eq(schema.tasks.priority, filters.priority));
339
- if (filters.type)
340
- conditions.push(eq(schema.tasks.type, filters.type));
341
- if (filters.phase)
342
- conditions.push(eq(schema.tasks.phase, filters.phase));
343
- if (filters.parentId !== undefined) {
344
- if (filters.parentId === null) {
345
- conditions.push(isNull(schema.tasks.parentId));
346
- }
347
- else {
348
- conditions.push(eq(schema.tasks.parentId, filters.parentId));
349
- }
350
- }
351
- if (filters.search) {
352
- const pattern = `%${filters.search}%`;
353
- conditions.push(or(like(schema.tasks.title, pattern), like(schema.tasks.description, pattern), like(schema.tasks.id, pattern)));
354
- }
355
- if (filters.label) {
356
- // label stored in JSON array — use LIKE on the serialized column
357
- conditions.push(like(schema.tasks.labelsJson, `%${JSON.stringify(filters.label)}%`));
358
- }
359
- const where = conditions.length > 0 ? and(...conditions) : undefined;
360
- // Count total matching rows (before pagination)
361
- const countResult = await db
362
- .select({ count: sql `count(*)` })
363
- .from(schema.tasks)
364
- .where(where)
365
- .get();
366
- const total = countResult?.count ?? 0;
367
- // Build ordered query
368
- let orderClause;
369
- switch (filters.orderBy) {
370
- case 'createdAt':
371
- orderClause = sql `${schema.tasks.createdAt} ASC`;
372
- break;
373
- case 'updatedAt':
374
- orderClause = sql `${schema.tasks.updatedAt} DESC NULLS LAST`;
375
- break;
376
- case 'priority': {
377
- // Map priority to numeric sort: critical=0, high=1, medium=2, low=3
378
- orderClause = sql `CASE ${schema.tasks.priority}
379
- WHEN 'critical' THEN 0 WHEN 'high' THEN 1
380
- WHEN 'medium' THEN 2 WHEN 'low' THEN 3 ELSE 4 END ASC`;
381
- break;
382
- }
383
- default:
384
- // position ASC, createdAt ASC (default)
385
- orderClause = sql `${schema.tasks.position} ASC, ${schema.tasks.createdAt} ASC`;
386
- }
387
- let query = db.select().from(schema.tasks).where(where).orderBy(orderClause);
388
- if (filters.limit !== undefined) {
389
- query = query.limit(filters.limit);
390
- }
391
- if (filters.offset !== undefined) {
392
- query = query.offset(filters.offset);
393
- }
394
- const rows = await query.all();
395
- const tasks = rows.map(rowToTask);
396
- // Load dependencies and relations with full ID set for cross-task refs
397
- if (tasks.length > 0) {
398
- const allIds = await getAllTaskIds();
399
- await loadDependenciesForTasks(db, tasks, allIds);
400
- await loadRelationsForTasks(db, tasks);
401
- }
402
- return { tasks, total };
403
- },
404
- async countTasks(filters) {
405
- const db = await getDb(cwd);
406
- const conditions = [];
407
- if (filters?.status) {
408
- const statuses = Array.isArray(filters.status) ? filters.status : [filters.status];
409
- conditions.push(inArray(schema.tasks.status, statuses));
410
- }
411
- else {
412
- conditions.push(ne(schema.tasks.status, 'archived'));
413
- }
414
- if (filters?.parentId) {
415
- conditions.push(eq(schema.tasks.parentId, filters.parentId));
416
- }
417
- const where = conditions.length > 0 ? and(...conditions) : undefined;
418
- const result = await db
419
- .select({ count: sql `count(*)` })
420
- .from(schema.tasks)
421
- .where(where)
422
- .get();
423
- return result?.count ?? 0;
424
- },
425
- async getChildren(parentId) {
426
- const db = await getDb(cwd);
427
- const rows = await db
428
- .select()
429
- .from(schema.tasks)
430
- .where(and(eq(schema.tasks.parentId, parentId), ne(schema.tasks.status, 'archived')))
431
- .orderBy(sql `${schema.tasks.position} ASC, ${schema.tasks.createdAt} ASC`)
432
- .all();
433
- const tasks = rows.map(rowToTask);
434
- if (tasks.length > 0) {
435
- const allIds = await getAllTaskIds();
436
- await loadDependenciesForTasks(db, tasks, allIds);
437
- await loadRelationsForTasks(db, tasks);
438
- }
439
- return tasks;
440
- },
441
- async countChildren(parentId) {
442
- const db = await getDb(cwd);
443
- const result = await db
444
- .select({ count: sql `count(*)` })
445
- .from(schema.tasks)
446
- .where(and(eq(schema.tasks.parentId, parentId), ne(schema.tasks.status, 'archived')))
447
- .get();
448
- return result?.count ?? 0;
449
- },
450
- async countActiveChildren(parentId) {
451
- const db = await getDb(cwd);
452
- const result = await db
453
- .select({ count: sql `count(*)` })
454
- .from(schema.tasks)
455
- .where(and(eq(schema.tasks.parentId, parentId), notInArray(schema.tasks.status, [...TERMINAL_TASK_STATUSES])))
456
- .get();
457
- return result?.count ?? 0;
458
- },
459
- async getAncestorChain(taskId) {
460
- const nativeDb = getNativeTasksDb();
461
- if (!nativeDb)
462
- return [];
463
- const rows = nativeDb
464
- .prepare(`WITH RECURSIVE ancestors(id, title, description, status, priority, type, parent_id,
465
- phase, size, position, position_version, labels_json, notes_json, acceptance_json,
466
- files_json, origin, blocked_by, epic_lifecycle, no_auto_complete, created_at,
467
- updated_at, completed_at, cancelled_at, cancellation_reason, archived_at,
468
- archive_reason, cycle_time_days, verification_json, created_by, modified_by,
469
- session_id, depth) AS (
470
- SELECT *, 0 FROM tasks WHERE id = ?
471
- UNION ALL
472
- SELECT t.*, a.depth + 1 FROM tasks t
473
- JOIN ancestors a ON t.id = a.parent_id
474
- WHERE a.parent_id IS NOT NULL
475
- )
476
- SELECT * FROM ancestors WHERE id != ? ORDER BY depth DESC`)
477
- .all(taskId, taskId);
478
- // Convert raw rows — they have snake_case column names from native SQLite
479
- const db = await getDb(cwd);
480
- const tasks = [];
481
- for (const raw of rows) {
482
- const id = raw.id;
483
- // Use Drizzle for proper conversion
484
- const drizzleRows = await db
485
- .select()
486
- .from(schema.tasks)
487
- .where(eq(schema.tasks.id, id))
488
- .limit(1)
489
- .all();
490
- if (drizzleRows[0]) {
491
- tasks.push(rowToTask(drizzleRows[0]));
492
- }
493
- }
494
- if (tasks.length > 0) {
495
- const allIds = await getAllTaskIds();
496
- await loadDependenciesForTasks(db, tasks, allIds);
497
- await loadRelationsForTasks(db, tasks);
498
- }
499
- return tasks;
500
- },
501
- async getSubtree(rootId) {
502
- const nativeDb = getNativeTasksDb();
503
- if (!nativeDb)
504
- return [];
505
- // Get IDs from the CTE, then load via Drizzle for proper conversion
506
- const idRows = nativeDb
507
- .prepare(`WITH RECURSIVE subtree AS (
508
- SELECT id FROM tasks WHERE id = ?
509
- UNION ALL
510
- SELECT t.id FROM tasks t
511
- JOIN subtree s ON t.parent_id = s.id
512
- )
513
- SELECT id FROM subtree`)
514
- .all(rootId);
515
- if (idRows.length === 0)
516
- return [];
517
- const db = await getDb(cwd);
518
- const ids = idRows.map((r) => r.id);
519
- const rows = await db.select().from(schema.tasks).where(inArray(schema.tasks.id, ids)).all();
520
- const tasks = rows.map(rowToTask);
521
- if (tasks.length > 0) {
522
- const allIds = await getAllTaskIds();
523
- await loadDependenciesForTasks(db, tasks, allIds);
524
- await loadRelationsForTasks(db, tasks);
525
- }
526
- return tasks;
527
- },
528
- async getDependents(taskId) {
529
- const db = await getDb(cwd);
530
- // Find tasks whose depends list includes taskId (reverse lookup)
531
- const depRows = await db
532
- .select()
533
- .from(schema.taskDependencies)
534
- .where(eq(schema.taskDependencies.dependsOn, taskId))
535
- .all();
536
- if (depRows.length === 0)
537
- return [];
538
- const dependentIds = depRows.map((r) => r.taskId);
539
- const rows = await db
540
- .select()
541
- .from(schema.tasks)
542
- .where(inArray(schema.tasks.id, dependentIds))
543
- .all();
544
- const tasks = rows.map(rowToTask);
545
- if (tasks.length > 0) {
546
- const allIds = await getAllTaskIds();
547
- await loadDependenciesForTasks(db, tasks, allIds);
548
- await loadRelationsForTasks(db, tasks);
549
- }
550
- return tasks;
551
- },
552
- async getDependencyChain(taskId) {
553
- const nativeDb = getNativeTasksDb();
554
- if (!nativeDb)
555
- return [];
556
- const rows = nativeDb
557
- .prepare(`WITH RECURSIVE dep_chain(id) AS (
558
- SELECT depends_on FROM task_dependencies WHERE task_id = ?
559
- UNION
560
- SELECT td.depends_on FROM task_dependencies td
561
- JOIN dep_chain dc ON td.task_id = dc.id
562
- )
563
- SELECT id FROM dep_chain`)
564
- .all(taskId);
565
- return rows.map((r) => r.id);
566
- },
567
- async taskExists(taskId) {
568
- const db = await getDb(cwd);
569
- const result = await db
570
- .select({ id: schema.tasks.id })
571
- .from(schema.tasks)
572
- .where(eq(schema.tasks.id, taskId))
573
- .limit(1)
574
- .get();
575
- return !!result;
576
- },
577
- async loadTasks(taskIds) {
578
- if (taskIds.length === 0)
579
- return [];
580
- const db = await getDb(cwd);
581
- const rows = await db
582
- .select()
583
- .from(schema.tasks)
584
- .where(inArray(schema.tasks.id, taskIds))
585
- .all();
586
- const tasks = rows.map(rowToTask);
587
- if (tasks.length > 0) {
588
- const allIds = await getAllTaskIds();
589
- await loadDependenciesForTasks(db, tasks, allIds);
590
- await loadRelationsForTasks(db, tasks);
591
- }
592
- return tasks;
593
- },
594
- // ---- Position helpers (T024/T025) ----
595
- async getNextPosition(parentId) {
596
- const nativeDb = getNativeTasksDb();
597
- if (!nativeDb) {
598
- throw new Error('Native database not initialized');
599
- }
600
- const row = parentId === null
601
- ? nativeDb
602
- .prepare(`SELECT COALESCE(MAX(position), 0) + 1 AS next_pos FROM tasks WHERE parent_id IS NULL AND status != 'archived'`)
603
- .get()
604
- : nativeDb
605
- .prepare(`SELECT COALESCE(MAX(position), 0) + 1 AS next_pos FROM tasks WHERE parent_id = ? AND status != 'archived'`)
606
- .get(parentId);
607
- return row?.next_pos ?? 1;
608
- },
609
- async shiftPositions(parentId, fromPosition, delta) {
610
- const nativeDb = getNativeTasksDb();
611
- if (!nativeDb) {
612
- throw new Error('Native database not initialized');
613
- }
614
- if (parentId === null) {
615
- nativeDb
616
- .prepare(`UPDATE tasks SET position = position + ?, position_version = position_version + 1, updated_at = ? WHERE parent_id IS NULL AND position >= ? AND status != 'archived'`)
617
- .run(delta, new Date().toISOString(), fromPosition);
618
- }
619
- else {
620
- nativeDb
621
- .prepare(`UPDATE tasks SET position = position + ?, position_version = position_version + 1, updated_at = ? WHERE parent_id = ? AND position >= ? AND status != 'archived'`)
622
- .run(delta, new Date().toISOString(), parentId, fromPosition);
623
- }
624
- },
625
- // ---- Targeted write methods ----
626
- async updateTaskFields(taskId, fields) {
627
- const db = await getDb(cwd);
628
- const updateRow = {
629
- updatedAt: fields.updatedAt ?? new Date().toISOString(),
630
- };
631
- // Copy only provided fields
632
- const fieldMap = [
633
- ['title', 'title'],
634
- ['description', 'description'],
635
- ['status', 'status'],
636
- ['priority', 'priority'],
637
- ['type', 'type'],
638
- ['parentId', 'parentId'],
639
- ['phase', 'phase'],
640
- ['size', 'size'],
641
- ['position', 'position'],
642
- ['positionVersion', 'positionVersion'],
643
- ['labelsJson', 'labelsJson'],
644
- ['notesJson', 'notesJson'],
645
- ['acceptanceJson', 'acceptanceJson'],
646
- ['filesJson', 'filesJson'],
647
- ['origin', 'origin'],
648
- ['blockedBy', 'blockedBy'],
649
- ['epicLifecycle', 'epicLifecycle'],
650
- ['noAutoComplete', 'noAutoComplete'],
651
- ['completedAt', 'completedAt'],
652
- ['cancelledAt', 'cancelledAt'],
653
- ['cancellationReason', 'cancellationReason'],
654
- ['verificationJson', 'verificationJson'],
655
- ['createdBy', 'createdBy'],
656
- ['modifiedBy', 'modifiedBy'],
657
- ['sessionId', 'sessionId'],
658
- ];
659
- for (const [key, col] of fieldMap) {
660
- if (fields[key] !== undefined) {
661
- updateRow[col] = fields[key];
662
- }
663
- }
664
- await db.update(schema.tasks).set(updateRow).where(eq(schema.tasks.id, taskId)).run();
665
- },
666
- async transaction(fn) {
667
- const nativeDb = getNativeTasksDb();
668
- if (!nativeDb) {
669
- throw new Error('Native database not initialized');
670
- }
671
- const db = await getDb(cwd);
672
- nativeDb.prepare('BEGIN IMMEDIATE').run();
673
- try {
674
- const tx = {
675
- async upsertSingleTask(task) {
676
- const row = taskToRow(task);
677
- await upsertTask(db, row);
678
- await updateDependencies(db, task.id, task.depends ?? []);
679
- },
680
- async archiveSingleTask(taskId, fields) {
681
- await db
682
- .update(schema.tasks)
683
- .set({
684
- status: 'archived',
685
- archivedAt: fields.archivedAt ?? new Date().toISOString(),
686
- archiveReason: fields.archiveReason ?? 'completed',
687
- cycleTimeDays: fields.cycleTimeDays ?? null,
688
- updatedAt: new Date().toISOString(),
689
- })
690
- .where(eq(schema.tasks.id, taskId))
691
- .run();
692
- },
693
- async removeSingleTask(taskId) {
694
- await db
695
- .delete(schema.taskDependencies)
696
- .where(eq(schema.taskDependencies.taskId, taskId))
697
- .run();
698
- await db
699
- .delete(schema.taskDependencies)
700
- .where(eq(schema.taskDependencies.dependsOn, taskId))
701
- .run();
702
- await db.delete(schema.tasks).where(eq(schema.tasks.id, taskId)).run();
703
- },
704
- async setMetaValue(key, value) {
705
- await setMetaValue(cwd, key, value);
706
- },
707
- async updateTaskFields(taskId, flds) {
708
- // Delegate to the outer accessor's implementation
709
- await accessor.updateTaskFields(taskId, flds);
710
- },
711
- async appendLog(entry) {
712
- await accessor.appendLog(entry);
713
- },
714
- };
715
- const result = await fn(tx);
716
- nativeDb.prepare('COMMIT').run();
717
- return result;
718
- }
719
- catch (err) {
720
- nativeDb.prepare('ROLLBACK').run();
721
- throw err;
722
- }
723
- },
724
- // ---- close ----
725
- async close() {
726
- closeDb();
727
- },
728
- // ---- Metadata ----
729
- async getMetaValue(key) {
730
- return getMetaValue(cwd, key);
731
- },
732
- async setMetaValue(key, value) {
733
- return setMetaValue(cwd, key, value);
734
- },
735
- async getSchemaVersion() {
736
- const meta = await getMetaValue(cwd, 'file_meta');
737
- return meta?.schemaVersion ?? null;
738
- },
739
- };
740
- return accessor;
741
- }
742
- //# sourceMappingURL=sqlite-data-accessor.js.map