@cleocode/core 2026.3.64 → 2026.3.66

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 (823) hide show
  1. package/dist/agents/retry.d.ts.map +1 -1
  2. package/dist/cleo.d.ts +2 -2
  3. package/dist/config.d.ts.map +1 -1
  4. package/dist/index.d.ts +3 -3
  5. package/dist/index.d.ts.map +1 -1
  6. package/dist/index.js +128 -116
  7. package/dist/index.js.map +4 -4
  8. package/dist/tasks/complete.d.ts.map +1 -1
  9. package/dist/tasks/enforcement.d.ts.map +1 -1
  10. package/package.json +5 -5
  11. package/src/agents/retry.ts +18 -46
  12. package/src/cleo.ts +2 -2
  13. package/src/config.ts +13 -0
  14. package/src/index.ts +4 -1
  15. package/src/tasks/add.ts +5 -5
  16. package/src/tasks/complete.ts +14 -48
  17. package/src/tasks/enforcement.ts +12 -24
  18. package/dist/adapters/adapter-registry.js +0 -64
  19. package/dist/adapters/adapter-registry.js.map +0 -1
  20. package/dist/adapters/discovery.js +0 -83
  21. package/dist/adapters/discovery.js.map +0 -1
  22. package/dist/adapters/index.js +0 -9
  23. package/dist/adapters/index.js.map +0 -1
  24. package/dist/adapters/manager.js +0 -260
  25. package/dist/adapters/manager.js.map +0 -1
  26. package/dist/admin/export-tasks.js +0 -171
  27. package/dist/admin/export-tasks.js.map +0 -1
  28. package/dist/admin/export.js +0 -103
  29. package/dist/admin/export.js.map +0 -1
  30. package/dist/admin/help.js +0 -106
  31. package/dist/admin/help.js.map +0 -1
  32. package/dist/admin/import-tasks.js +0 -182
  33. package/dist/admin/import-tasks.js.map +0 -1
  34. package/dist/admin/import.js +0 -129
  35. package/dist/admin/import.js.map +0 -1
  36. package/dist/admin/index.js +0 -13
  37. package/dist/admin/index.js.map +0 -1
  38. package/dist/adrs/find.js +0 -134
  39. package/dist/adrs/find.js.map +0 -1
  40. package/dist/adrs/index.js +0 -15
  41. package/dist/adrs/index.js.map +0 -1
  42. package/dist/adrs/link-pipeline.js +0 -160
  43. package/dist/adrs/link-pipeline.js.map +0 -1
  44. package/dist/adrs/list.js +0 -43
  45. package/dist/adrs/list.js.map +0 -1
  46. package/dist/adrs/parse.js +0 -51
  47. package/dist/adrs/parse.js.map +0 -1
  48. package/dist/adrs/show.js +0 -22
  49. package/dist/adrs/show.js.map +0 -1
  50. package/dist/adrs/sync.js +0 -188
  51. package/dist/adrs/sync.js.map +0 -1
  52. package/dist/adrs/types.js +0 -9
  53. package/dist/adrs/types.js.map +0 -1
  54. package/dist/adrs/validate.js +0 -57
  55. package/dist/adrs/validate.js.map +0 -1
  56. package/dist/agents/agent-registry.js +0 -288
  57. package/dist/agents/agent-registry.js.map +0 -1
  58. package/dist/agents/agent-schema.js +0 -85
  59. package/dist/agents/agent-schema.js.map +0 -1
  60. package/dist/agents/capacity.js +0 -116
  61. package/dist/agents/capacity.js.map +0 -1
  62. package/dist/agents/execution-learning.js +0 -474
  63. package/dist/agents/execution-learning.js.map +0 -1
  64. package/dist/agents/health-monitor.js +0 -217
  65. package/dist/agents/health-monitor.js.map +0 -1
  66. package/dist/agents/index.js +0 -29
  67. package/dist/agents/index.js.map +0 -1
  68. package/dist/agents/registry.js +0 -314
  69. package/dist/agents/registry.js.map +0 -1
  70. package/dist/agents/retry.js +0 -229
  71. package/dist/agents/retry.js.map +0 -1
  72. package/dist/audit-prune.js +0 -94
  73. package/dist/audit-prune.js.map +0 -1
  74. package/dist/audit.js +0 -68
  75. package/dist/audit.js.map +0 -1
  76. package/dist/backfill/index.js +0 -229
  77. package/dist/backfill/index.js.map +0 -1
  78. package/dist/bootstrap.js +0 -367
  79. package/dist/bootstrap.js.map +0 -1
  80. package/dist/caamp/adapter.js +0 -434
  81. package/dist/caamp/adapter.js.map +0 -1
  82. package/dist/caamp/capability-check.js +0 -38
  83. package/dist/caamp/capability-check.js.map +0 -1
  84. package/dist/caamp/index.js +0 -23
  85. package/dist/caamp/index.js.map +0 -1
  86. package/dist/caamp-init.js +0 -16
  87. package/dist/caamp-init.js.map +0 -1
  88. package/dist/cleo.js +0 -302
  89. package/dist/cleo.js.map +0 -1
  90. package/dist/codebase-map/analyzers/architecture.js +0 -130
  91. package/dist/codebase-map/analyzers/architecture.js.map +0 -1
  92. package/dist/codebase-map/analyzers/concerns.js +0 -122
  93. package/dist/codebase-map/analyzers/concerns.js.map +0 -1
  94. package/dist/codebase-map/analyzers/conventions.js +0 -149
  95. package/dist/codebase-map/analyzers/conventions.js.map +0 -1
  96. package/dist/codebase-map/analyzers/integrations.js +0 -108
  97. package/dist/codebase-map/analyzers/integrations.js.map +0 -1
  98. package/dist/codebase-map/analyzers/stack.js +0 -117
  99. package/dist/codebase-map/analyzers/stack.js.map +0 -1
  100. package/dist/codebase-map/analyzers/structure.js +0 -137
  101. package/dist/codebase-map/analyzers/structure.js.map +0 -1
  102. package/dist/codebase-map/analyzers/testing.js +0 -118
  103. package/dist/codebase-map/analyzers/testing.js.map +0 -1
  104. package/dist/codebase-map/index.js +0 -57
  105. package/dist/codebase-map/index.js.map +0 -1
  106. package/dist/codebase-map/store.js +0 -122
  107. package/dist/codebase-map/store.js.map +0 -1
  108. package/dist/codebase-map/summary.js +0 -152
  109. package/dist/codebase-map/summary.js.map +0 -1
  110. package/dist/compliance/index.js +0 -288
  111. package/dist/compliance/index.js.map +0 -1
  112. package/dist/compliance/protocol-enforcement.js +0 -332
  113. package/dist/compliance/protocol-enforcement.js.map +0 -1
  114. package/dist/compliance/protocol-rules.js +0 -786
  115. package/dist/compliance/protocol-rules.js.map +0 -1
  116. package/dist/compliance/protocol-types.js +0 -80
  117. package/dist/compliance/protocol-types.js.map +0 -1
  118. package/dist/compliance/store.js +0 -53
  119. package/dist/compliance/store.js.map +0 -1
  120. package/dist/config/build-config.js +0 -29
  121. package/dist/config/build-config.js.map +0 -1
  122. package/dist/config.js +0 -370
  123. package/dist/config.js.map +0 -1
  124. package/dist/constants.js +0 -18
  125. package/dist/constants.js.map +0 -1
  126. package/dist/context/index.js +0 -137
  127. package/dist/context/index.js.map +0 -1
  128. package/dist/engine-result.js +0 -12
  129. package/dist/engine-result.js.map +0 -1
  130. package/dist/error-catalog.js +0 -404
  131. package/dist/error-catalog.js.map +0 -1
  132. package/dist/error-registry.js +0 -393
  133. package/dist/error-registry.js.map +0 -1
  134. package/dist/errors.js +0 -167
  135. package/dist/errors.js.map +0 -1
  136. package/dist/hooks/handlers/error-hooks.js +0 -43
  137. package/dist/hooks/handlers/error-hooks.js.map +0 -1
  138. package/dist/hooks/handlers/file-hooks.js +0 -80
  139. package/dist/hooks/handlers/file-hooks.js.map +0 -1
  140. package/dist/hooks/handlers/index.js +0 -19
  141. package/dist/hooks/handlers/index.js.map +0 -1
  142. package/dist/hooks/handlers/mcp-hooks.js +0 -80
  143. package/dist/hooks/handlers/mcp-hooks.js.map +0 -1
  144. package/dist/hooks/handlers/session-hooks.js +0 -73
  145. package/dist/hooks/handlers/session-hooks.js.map +0 -1
  146. package/dist/hooks/handlers/task-hooks.js +0 -63
  147. package/dist/hooks/handlers/task-hooks.js.map +0 -1
  148. package/dist/hooks/index.js +0 -13
  149. package/dist/hooks/index.js.map +0 -1
  150. package/dist/hooks/payload-schemas.js +0 -163
  151. package/dist/hooks/payload-schemas.js.map +0 -1
  152. package/dist/hooks/provider-hooks.js +0 -34
  153. package/dist/hooks/provider-hooks.js.map +0 -1
  154. package/dist/hooks/registry.js +0 -176
  155. package/dist/hooks/registry.js.map +0 -1
  156. package/dist/hooks/types.js +0 -62
  157. package/dist/hooks/types.js.map +0 -1
  158. package/dist/hooks.js +0 -136
  159. package/dist/hooks.js.map +0 -1
  160. package/dist/init.js +0 -711
  161. package/dist/init.js.map +0 -1
  162. package/dist/inject/index.js +0 -82
  163. package/dist/inject/index.js.map +0 -1
  164. package/dist/injection.js +0 -343
  165. package/dist/injection.js.map +0 -1
  166. package/dist/intelligence/adaptive-validation.js +0 -497
  167. package/dist/intelligence/adaptive-validation.js.map +0 -1
  168. package/dist/intelligence/impact.js +0 -675
  169. package/dist/intelligence/impact.js.map +0 -1
  170. package/dist/intelligence/index.js +0 -22
  171. package/dist/intelligence/index.js.map +0 -1
  172. package/dist/intelligence/patterns.js +0 -492
  173. package/dist/intelligence/patterns.js.map +0 -1
  174. package/dist/intelligence/prediction.js +0 -499
  175. package/dist/intelligence/prediction.js.map +0 -1
  176. package/dist/intelligence/types.js +0 -13
  177. package/dist/intelligence/types.js.map +0 -1
  178. package/dist/internal.js +0 -269
  179. package/dist/internal.js.map +0 -1
  180. package/dist/issue/create.js +0 -121
  181. package/dist/issue/create.js.map +0 -1
  182. package/dist/issue/diagnostics.js +0 -59
  183. package/dist/issue/diagnostics.js.map +0 -1
  184. package/dist/issue/index.js +0 -10
  185. package/dist/issue/index.js.map +0 -1
  186. package/dist/issue/template-parser.js +0 -267
  187. package/dist/issue/template-parser.js.map +0 -1
  188. package/dist/json-schema-validator.js +0 -76
  189. package/dist/json-schema-validator.js.map +0 -1
  190. package/dist/lib/index.js +0 -10
  191. package/dist/lib/index.js.map +0 -1
  192. package/dist/lib/retry.js +0 -152
  193. package/dist/lib/retry.js.map +0 -1
  194. package/dist/lifecycle/chain-composition.js +0 -152
  195. package/dist/lifecycle/chain-composition.js.map +0 -1
  196. package/dist/lifecycle/chain-store.js +0 -246
  197. package/dist/lifecycle/chain-store.js.map +0 -1
  198. package/dist/lifecycle/consolidate-rcasd.js +0 -352
  199. package/dist/lifecycle/consolidate-rcasd.js.map +0 -1
  200. package/dist/lifecycle/default-chain.js +0 -167
  201. package/dist/lifecycle/default-chain.js.map +0 -1
  202. package/dist/lifecycle/evidence.js +0 -180
  203. package/dist/lifecycle/evidence.js.map +0 -1
  204. package/dist/lifecycle/frontmatter.js +0 -363
  205. package/dist/lifecycle/frontmatter.js.map +0 -1
  206. package/dist/lifecycle/index.js +0 -753
  207. package/dist/lifecycle/index.js.map +0 -1
  208. package/dist/lifecycle/pipeline.js +0 -656
  209. package/dist/lifecycle/pipeline.js.map +0 -1
  210. package/dist/lifecycle/rcasd-index.js +0 -326
  211. package/dist/lifecycle/rcasd-index.js.map +0 -1
  212. package/dist/lifecycle/rcasd-paths.js +0 -220
  213. package/dist/lifecycle/rcasd-paths.js.map +0 -1
  214. package/dist/lifecycle/resume.js +0 -864
  215. package/dist/lifecycle/resume.js.map +0 -1
  216. package/dist/lifecycle/stage-artifacts.js +0 -94
  217. package/dist/lifecycle/stage-artifacts.js.map +0 -1
  218. package/dist/lifecycle/stages.js +0 -534
  219. package/dist/lifecycle/stages.js.map +0 -1
  220. package/dist/lifecycle/state-machine.js +0 -516
  221. package/dist/lifecycle/state-machine.js.map +0 -1
  222. package/dist/lifecycle/tessera-engine.js +0 -249
  223. package/dist/lifecycle/tessera-engine.js.map +0 -1
  224. package/dist/logger.js +0 -140
  225. package/dist/logger.js.map +0 -1
  226. package/dist/mcp/index.js +0 -146
  227. package/dist/mcp/index.js.map +0 -1
  228. package/dist/memory/auto-extract.js +0 -143
  229. package/dist/memory/auto-extract.js.map +0 -1
  230. package/dist/memory/brain-embedding.js +0 -49
  231. package/dist/memory/brain-embedding.js.map +0 -1
  232. package/dist/memory/brain-lifecycle.js +0 -298
  233. package/dist/memory/brain-lifecycle.js.map +0 -1
  234. package/dist/memory/brain-links.js +0 -148
  235. package/dist/memory/brain-links.js.map +0 -1
  236. package/dist/memory/brain-migration.js +0 -149
  237. package/dist/memory/brain-migration.js.map +0 -1
  238. package/dist/memory/brain-reasoning.js +0 -215
  239. package/dist/memory/brain-reasoning.js.map +0 -1
  240. package/dist/memory/brain-retrieval.js +0 -474
  241. package/dist/memory/brain-retrieval.js.map +0 -1
  242. package/dist/memory/brain-row-types.js +0 -10
  243. package/dist/memory/brain-row-types.js.map +0 -1
  244. package/dist/memory/brain-search.js +0 -519
  245. package/dist/memory/brain-search.js.map +0 -1
  246. package/dist/memory/brain-similarity.js +0 -145
  247. package/dist/memory/brain-similarity.js.map +0 -1
  248. package/dist/memory/claude-mem-migration.js +0 -277
  249. package/dist/memory/claude-mem-migration.js.map +0 -1
  250. package/dist/memory/decisions.js +0 -148
  251. package/dist/memory/decisions.js.map +0 -1
  252. package/dist/memory/engine-compat.js +0 -1030
  253. package/dist/memory/engine-compat.js.map +0 -1
  254. package/dist/memory/index.js +0 -773
  255. package/dist/memory/index.js.map +0 -1
  256. package/dist/memory/learnings.js +0 -121
  257. package/dist/memory/learnings.js.map +0 -1
  258. package/dist/memory/memory-bridge.js +0 -289
  259. package/dist/memory/memory-bridge.js.map +0 -1
  260. package/dist/memory/patterns.js +0 -122
  261. package/dist/memory/patterns.js.map +0 -1
  262. package/dist/memory/pipeline-manifest-sqlite.js +0 -975
  263. package/dist/memory/pipeline-manifest-sqlite.js.map +0 -1
  264. package/dist/memory/session-memory.js +0 -226
  265. package/dist/memory/session-memory.js.map +0 -1
  266. package/dist/metrics/ab-test.js +0 -260
  267. package/dist/metrics/ab-test.js.map +0 -1
  268. package/dist/metrics/aggregation.js +0 -363
  269. package/dist/metrics/aggregation.js.map +0 -1
  270. package/dist/metrics/common.js +0 -64
  271. package/dist/metrics/common.js.map +0 -1
  272. package/dist/metrics/enums.js +0 -78
  273. package/dist/metrics/enums.js.map +0 -1
  274. package/dist/metrics/index.js +0 -19
  275. package/dist/metrics/index.js.map +0 -1
  276. package/dist/metrics/model-provider-registry.js +0 -88
  277. package/dist/metrics/model-provider-registry.js.map +0 -1
  278. package/dist/metrics/otel-integration.js +0 -263
  279. package/dist/metrics/otel-integration.js.map +0 -1
  280. package/dist/metrics/provider-detection.js +0 -103
  281. package/dist/metrics/provider-detection.js.map +0 -1
  282. package/dist/metrics/token-estimation.js +0 -253
  283. package/dist/metrics/token-estimation.js.map +0 -1
  284. package/dist/metrics/token-service.js +0 -450
  285. package/dist/metrics/token-service.js.map +0 -1
  286. package/dist/migration/agent-outputs.js +0 -316
  287. package/dist/migration/agent-outputs.js.map +0 -1
  288. package/dist/migration/checksum.js +0 -92
  289. package/dist/migration/checksum.js.map +0 -1
  290. package/dist/migration/index.js +0 -282
  291. package/dist/migration/index.js.map +0 -1
  292. package/dist/migration/logger.js +0 -360
  293. package/dist/migration/logger.js.map +0 -1
  294. package/dist/migration/preflight.js +0 -9
  295. package/dist/migration/preflight.js.map +0 -1
  296. package/dist/migration/state.js +0 -421
  297. package/dist/migration/state.js.map +0 -1
  298. package/dist/migration/validate.js +0 -241
  299. package/dist/migration/validate.js.map +0 -1
  300. package/dist/nexus/deps.js +0 -375
  301. package/dist/nexus/deps.js.map +0 -1
  302. package/dist/nexus/discover.js +0 -288
  303. package/dist/nexus/discover.js.map +0 -1
  304. package/dist/nexus/hash.js +0 -10
  305. package/dist/nexus/hash.js.map +0 -1
  306. package/dist/nexus/index.js +0 -38
  307. package/dist/nexus/index.js.map +0 -1
  308. package/dist/nexus/migrate-json-to-sqlite.js +0 -115
  309. package/dist/nexus/migrate-json-to-sqlite.js.map +0 -1
  310. package/dist/nexus/permissions.js +0 -105
  311. package/dist/nexus/permissions.js.map +0 -1
  312. package/dist/nexus/query.js +0 -175
  313. package/dist/nexus/query.js.map +0 -1
  314. package/dist/nexus/registry.js +0 -584
  315. package/dist/nexus/registry.js.map +0 -1
  316. package/dist/nexus/sharing/index.js +0 -288
  317. package/dist/nexus/sharing/index.js.map +0 -1
  318. package/dist/nexus/transfer-types.js +0 -8
  319. package/dist/nexus/transfer-types.js.map +0 -1
  320. package/dist/nexus/transfer.js +0 -263
  321. package/dist/nexus/transfer.js.map +0 -1
  322. package/dist/observability/index.js +0 -103
  323. package/dist/observability/index.js.map +0 -1
  324. package/dist/observability/log-filter.js +0 -63
  325. package/dist/observability/log-filter.js.map +0 -1
  326. package/dist/observability/log-parser.js +0 -99
  327. package/dist/observability/log-parser.js.map +0 -1
  328. package/dist/observability/log-reader.js +0 -139
  329. package/dist/observability/log-reader.js.map +0 -1
  330. package/dist/observability/types.js +0 -19
  331. package/dist/observability/types.js.map +0 -1
  332. package/dist/orchestration/analyze.js +0 -107
  333. package/dist/orchestration/analyze.js.map +0 -1
  334. package/dist/orchestration/bootstrap.js +0 -132
  335. package/dist/orchestration/bootstrap.js.map +0 -1
  336. package/dist/orchestration/context.js +0 -56
  337. package/dist/orchestration/context.js.map +0 -1
  338. package/dist/orchestration/critical-path.js +0 -100
  339. package/dist/orchestration/critical-path.js.map +0 -1
  340. package/dist/orchestration/index.js +0 -286
  341. package/dist/orchestration/index.js.map +0 -1
  342. package/dist/orchestration/parallel.js +0 -89
  343. package/dist/orchestration/parallel.js.map +0 -1
  344. package/dist/orchestration/protocol-validators.js +0 -524
  345. package/dist/orchestration/protocol-validators.js.map +0 -1
  346. package/dist/orchestration/skill-ops.js +0 -98
  347. package/dist/orchestration/skill-ops.js.map +0 -1
  348. package/dist/orchestration/status.js +0 -107
  349. package/dist/orchestration/status.js.map +0 -1
  350. package/dist/orchestration/unblock.js +0 -103
  351. package/dist/orchestration/unblock.js.map +0 -1
  352. package/dist/orchestration/validate-spawn.js +0 -67
  353. package/dist/orchestration/validate-spawn.js.map +0 -1
  354. package/dist/orchestration/waves.js +0 -86
  355. package/dist/orchestration/waves.js.map +0 -1
  356. package/dist/otel/index.js +0 -163
  357. package/dist/otel/index.js.map +0 -1
  358. package/dist/output.js +0 -132
  359. package/dist/output.js.map +0 -1
  360. package/dist/pagination.js +0 -61
  361. package/dist/pagination.js.map +0 -1
  362. package/dist/paths.js +0 -337
  363. package/dist/paths.js.map +0 -1
  364. package/dist/phases/deps.js +0 -372
  365. package/dist/phases/deps.js.map +0 -1
  366. package/dist/phases/index.js +0 -349
  367. package/dist/phases/index.js.map +0 -1
  368. package/dist/pipeline/index.js +0 -10
  369. package/dist/pipeline/index.js.map +0 -1
  370. package/dist/pipeline/phase.js +0 -45
  371. package/dist/pipeline/phase.js.map +0 -1
  372. package/dist/platform.js +0 -211
  373. package/dist/platform.js.map +0 -1
  374. package/dist/project-info.js +0 -84
  375. package/dist/project-info.js.map +0 -1
  376. package/dist/reconciliation/index.js +0 -10
  377. package/dist/reconciliation/index.js.map +0 -1
  378. package/dist/reconciliation/link-store.js +0 -129
  379. package/dist/reconciliation/link-store.js.map +0 -1
  380. package/dist/reconciliation/reconciliation-engine.js +0 -298
  381. package/dist/reconciliation/reconciliation-engine.js.map +0 -1
  382. package/dist/release/artifacts.js +0 -427
  383. package/dist/release/artifacts.js.map +0 -1
  384. package/dist/release/changelog-writer.js +0 -151
  385. package/dist/release/changelog-writer.js.map +0 -1
  386. package/dist/release/channel.js +0 -144
  387. package/dist/release/channel.js.map +0 -1
  388. package/dist/release/ci.js +0 -166
  389. package/dist/release/ci.js.map +0 -1
  390. package/dist/release/github-pr.js +0 -225
  391. package/dist/release/github-pr.js.map +0 -1
  392. package/dist/release/guards.js +0 -116
  393. package/dist/release/guards.js.map +0 -1
  394. package/dist/release/index.js +0 -22
  395. package/dist/release/index.js.map +0 -1
  396. package/dist/release/release-config.js +0 -158
  397. package/dist/release/release-config.js.map +0 -1
  398. package/dist/release/release-manifest.js +0 -1019
  399. package/dist/release/release-manifest.js.map +0 -1
  400. package/dist/release/version-bump.js +0 -255
  401. package/dist/release/version-bump.js.map +0 -1
  402. package/dist/remote/index.js +0 -257
  403. package/dist/remote/index.js.map +0 -1
  404. package/dist/repair.js +0 -130
  405. package/dist/repair.js.map +0 -1
  406. package/dist/research/index.js +0 -2
  407. package/dist/research/index.js.map +0 -1
  408. package/dist/roadmap/index.js +0 -59
  409. package/dist/roadmap/index.js.map +0 -1
  410. package/dist/routing/capability-matrix.js +0 -1557
  411. package/dist/routing/capability-matrix.js.map +0 -1
  412. package/dist/routing/index.js +0 -9
  413. package/dist/routing/index.js.map +0 -1
  414. package/dist/scaffold.js +0 -1178
  415. package/dist/scaffold.js.map +0 -1
  416. package/dist/schema-management.js +0 -295
  417. package/dist/schema-management.js.map +0 -1
  418. package/dist/security/index.js +0 -9
  419. package/dist/security/index.js.map +0 -1
  420. package/dist/security/input-sanitization.js +0 -321
  421. package/dist/security/input-sanitization.js.map +0 -1
  422. package/dist/sequence/index.js +0 -295
  423. package/dist/sequence/index.js.map +0 -1
  424. package/dist/sessions/assumptions.js +0 -54
  425. package/dist/sessions/assumptions.js.map +0 -1
  426. package/dist/sessions/briefing.js +0 -377
  427. package/dist/sessions/briefing.js.map +0 -1
  428. package/dist/sessions/context-alert.js +0 -222
  429. package/dist/sessions/context-alert.js.map +0 -1
  430. package/dist/sessions/context-inject.js +0 -61
  431. package/dist/sessions/context-inject.js.map +0 -1
  432. package/dist/sessions/context-monitor.js +0 -98
  433. package/dist/sessions/context-monitor.js.map +0 -1
  434. package/dist/sessions/decisions.js +0 -65
  435. package/dist/sessions/decisions.js.map +0 -1
  436. package/dist/sessions/find.js +0 -63
  437. package/dist/sessions/find.js.map +0 -1
  438. package/dist/sessions/handoff.js +0 -328
  439. package/dist/sessions/handoff.js.map +0 -1
  440. package/dist/sessions/hitl-warnings.js +0 -254
  441. package/dist/sessions/hitl-warnings.js.map +0 -1
  442. package/dist/sessions/index.js +0 -318
  443. package/dist/sessions/index.js.map +0 -1
  444. package/dist/sessions/session-archive.js +0 -40
  445. package/dist/sessions/session-archive.js.map +0 -1
  446. package/dist/sessions/session-cleanup.js +0 -59
  447. package/dist/sessions/session-cleanup.js.map +0 -1
  448. package/dist/sessions/session-drift.js +0 -134
  449. package/dist/sessions/session-drift.js.map +0 -1
  450. package/dist/sessions/session-enforcement.js +0 -144
  451. package/dist/sessions/session-enforcement.js.map +0 -1
  452. package/dist/sessions/session-grade.js +0 -253
  453. package/dist/sessions/session-grade.js.map +0 -1
  454. package/dist/sessions/session-history.js +0 -42
  455. package/dist/sessions/session-history.js.map +0 -1
  456. package/dist/sessions/session-id.js +0 -81
  457. package/dist/sessions/session-id.js.map +0 -1
  458. package/dist/sessions/session-memory-bridge.js +0 -52
  459. package/dist/sessions/session-memory-bridge.js.map +0 -1
  460. package/dist/sessions/session-show.js +0 -24
  461. package/dist/sessions/session-show.js.map +0 -1
  462. package/dist/sessions/session-stats.js +0 -69
  463. package/dist/sessions/session-stats.js.map +0 -1
  464. package/dist/sessions/session-suspend.js +0 -39
  465. package/dist/sessions/session-suspend.js.map +0 -1
  466. package/dist/sessions/session-switch.js +0 -51
  467. package/dist/sessions/session-switch.js.map +0 -1
  468. package/dist/sessions/session-view.js +0 -76
  469. package/dist/sessions/session-view.js.map +0 -1
  470. package/dist/sessions/statusline-setup.js +0 -85
  471. package/dist/sessions/statusline-setup.js.map +0 -1
  472. package/dist/sessions/types.js +0 -8
  473. package/dist/sessions/types.js.map +0 -1
  474. package/dist/signaldock/claude-code-transport.js +0 -107
  475. package/dist/signaldock/claude-code-transport.js.map +0 -1
  476. package/dist/signaldock/factory.js +0 -25
  477. package/dist/signaldock/factory.js.map +0 -1
  478. package/dist/signaldock/index.js +0 -9
  479. package/dist/signaldock/index.js.map +0 -1
  480. package/dist/signaldock/signaldock-transport.js +0 -122
  481. package/dist/signaldock/signaldock-transport.js.map +0 -1
  482. package/dist/signaldock/transport.js +0 -11
  483. package/dist/signaldock/transport.js.map +0 -1
  484. package/dist/signaldock/types.js +0 -11
  485. package/dist/signaldock/types.js.map +0 -1
  486. package/dist/skills/agents/config.js +0 -94
  487. package/dist/skills/agents/config.js.map +0 -1
  488. package/dist/skills/agents/install.js +0 -116
  489. package/dist/skills/agents/install.js.map +0 -1
  490. package/dist/skills/agents/registry.js +0 -161
  491. package/dist/skills/agents/registry.js.map +0 -1
  492. package/dist/skills/discovery.js +0 -333
  493. package/dist/skills/discovery.js.map +0 -1
  494. package/dist/skills/dispatch.js +0 -347
  495. package/dist/skills/dispatch.js.map +0 -1
  496. package/dist/skills/dynamic-skill-generator.js +0 -100
  497. package/dist/skills/dynamic-skill-generator.js.map +0 -1
  498. package/dist/skills/index.js +0 -44
  499. package/dist/skills/index.js.map +0 -1
  500. package/dist/skills/injection/subagent.js +0 -195
  501. package/dist/skills/injection/subagent.js.map +0 -1
  502. package/dist/skills/injection/token.js +0 -260
  503. package/dist/skills/injection/token.js.map +0 -1
  504. package/dist/skills/install.js +0 -40
  505. package/dist/skills/install.js.map +0 -1
  506. package/dist/skills/manifests/contribution.js +0 -175
  507. package/dist/skills/manifests/contribution.js.map +0 -1
  508. package/dist/skills/manifests/research.js +0 -281
  509. package/dist/skills/manifests/research.js.map +0 -1
  510. package/dist/skills/manifests/resolver.js +0 -146
  511. package/dist/skills/manifests/resolver.js.map +0 -1
  512. package/dist/skills/marketplace.js +0 -90
  513. package/dist/skills/marketplace.js.map +0 -1
  514. package/dist/skills/orchestrator/spawn.js +0 -178
  515. package/dist/skills/orchestrator/spawn.js.map +0 -1
  516. package/dist/skills/orchestrator/startup.js +0 -451
  517. package/dist/skills/orchestrator/startup.js.map +0 -1
  518. package/dist/skills/orchestrator/validator.js +0 -301
  519. package/dist/skills/orchestrator/validator.js.map +0 -1
  520. package/dist/skills/precedence-integration.js +0 -73
  521. package/dist/skills/precedence-integration.js.map +0 -1
  522. package/dist/skills/precedence-types.js +0 -16
  523. package/dist/skills/precedence-types.js.map +0 -1
  524. package/dist/skills/routing-table.js +0 -63
  525. package/dist/skills/routing-table.js.map +0 -1
  526. package/dist/skills/skill-paths.js +0 -220
  527. package/dist/skills/skill-paths.js.map +0 -1
  528. package/dist/skills/test-utility.js +0 -55
  529. package/dist/skills/test-utility.js.map +0 -1
  530. package/dist/skills/types.js +0 -118
  531. package/dist/skills/types.js.map +0 -1
  532. package/dist/skills/validation.js +0 -183
  533. package/dist/skills/validation.js.map +0 -1
  534. package/dist/skills/version.js +0 -57
  535. package/dist/skills/version.js.map +0 -1
  536. package/dist/snapshot/index.js +0 -188
  537. package/dist/snapshot/index.js.map +0 -1
  538. package/dist/spawn/adapter-registry.js +0 -246
  539. package/dist/spawn/adapter-registry.js.map +0 -1
  540. package/dist/spawn/index.js +0 -10
  541. package/dist/spawn/index.js.map +0 -1
  542. package/dist/stats/index.js +0 -343
  543. package/dist/stats/index.js.map +0 -1
  544. package/dist/stats/workflow-telemetry.js +0 -400
  545. package/dist/stats/workflow-telemetry.js.map +0 -1
  546. package/dist/sticky/archive.js +0 -47
  547. package/dist/sticky/archive.js.map +0 -1
  548. package/dist/sticky/convert.js +0 -235
  549. package/dist/sticky/convert.js.map +0 -1
  550. package/dist/sticky/create.js +0 -48
  551. package/dist/sticky/create.js.map +0 -1
  552. package/dist/sticky/id.js +0 -35
  553. package/dist/sticky/id.js.map +0 -1
  554. package/dist/sticky/index.js +0 -16
  555. package/dist/sticky/index.js.map +0 -1
  556. package/dist/sticky/list.js +0 -44
  557. package/dist/sticky/list.js.map +0 -1
  558. package/dist/sticky/purge.js +0 -45
  559. package/dist/sticky/purge.js.map +0 -1
  560. package/dist/sticky/show.js +0 -42
  561. package/dist/sticky/show.js.map +0 -1
  562. package/dist/sticky/types.js +0 -10
  563. package/dist/sticky/types.js.map +0 -1
  564. package/dist/store/atomic.js +0 -167
  565. package/dist/store/atomic.js.map +0 -1
  566. package/dist/store/backup.js +0 -94
  567. package/dist/store/backup.js.map +0 -1
  568. package/dist/store/brain-accessor.js +0 -397
  569. package/dist/store/brain-accessor.js.map +0 -1
  570. package/dist/store/brain-schema.js +0 -215
  571. package/dist/store/brain-schema.js.map +0 -1
  572. package/dist/store/brain-sqlite.js +0 -271
  573. package/dist/store/brain-sqlite.js.map +0 -1
  574. package/dist/store/cache.js +0 -168
  575. package/dist/store/cache.js.map +0 -1
  576. package/dist/store/chain-schema.js +0 -51
  577. package/dist/store/chain-schema.js.map +0 -1
  578. package/dist/store/converters.js +0 -122
  579. package/dist/store/converters.js.map +0 -1
  580. package/dist/store/cross-db-cleanup.js +0 -169
  581. package/dist/store/cross-db-cleanup.js.map +0 -1
  582. package/dist/store/data-accessor.js +0 -26
  583. package/dist/store/data-accessor.js.map +0 -1
  584. package/dist/store/data-safety-central.js +0 -269
  585. package/dist/store/data-safety-central.js.map +0 -1
  586. package/dist/store/data-safety.js +0 -274
  587. package/dist/store/data-safety.js.map +0 -1
  588. package/dist/store/db-helpers.js +0 -223
  589. package/dist/store/db-helpers.js.map +0 -1
  590. package/dist/store/export.js +0 -155
  591. package/dist/store/export.js.map +0 -1
  592. package/dist/store/file-utils.js +0 -270
  593. package/dist/store/file-utils.js.map +0 -1
  594. package/dist/store/git-checkpoint.js +0 -365
  595. package/dist/store/git-checkpoint.js.map +0 -1
  596. package/dist/store/import-logging.js +0 -139
  597. package/dist/store/import-logging.js.map +0 -1
  598. package/dist/store/import-remap.js +0 -145
  599. package/dist/store/import-remap.js.map +0 -1
  600. package/dist/store/import-sort.js +0 -121
  601. package/dist/store/import-sort.js.map +0 -1
  602. package/dist/store/index.js +0 -28
  603. package/dist/store/index.js.map +0 -1
  604. package/dist/store/json.js +0 -208
  605. package/dist/store/json.js.map +0 -1
  606. package/dist/store/lifecycle-store.js +0 -249
  607. package/dist/store/lifecycle-store.js.map +0 -1
  608. package/dist/store/lock.js +0 -70
  609. package/dist/store/lock.js.map +0 -1
  610. package/dist/store/migration-sqlite.js +0 -676
  611. package/dist/store/migration-sqlite.js.map +0 -1
  612. package/dist/store/nexus-schema.js +0 -62
  613. package/dist/store/nexus-schema.js.map +0 -1
  614. package/dist/store/nexus-sqlite.js +0 -217
  615. package/dist/store/nexus-sqlite.js.map +0 -1
  616. package/dist/store/nexus-validation-schemas.js +0 -40
  617. package/dist/store/nexus-validation-schemas.js.map +0 -1
  618. package/dist/store/parsers.js +0 -37
  619. package/dist/store/parsers.js.map +0 -1
  620. package/dist/store/project-detect.js +0 -457
  621. package/dist/store/project-detect.js.map +0 -1
  622. package/dist/store/provider.js +0 -101
  623. package/dist/store/provider.js.map +0 -1
  624. package/dist/store/safety-data-accessor.js +0 -243
  625. package/dist/store/safety-data-accessor.js.map +0 -1
  626. package/dist/store/schema.js +0 -7
  627. package/dist/store/schema.js.map +0 -1
  628. package/dist/store/session-store.js +0 -219
  629. package/dist/store/session-store.js.map +0 -1
  630. package/dist/store/sqlite-backup.js +0 -105
  631. package/dist/store/sqlite-backup.js.map +0 -1
  632. package/dist/store/sqlite-data-accessor.js +0 -734
  633. package/dist/store/sqlite-data-accessor.js.map +0 -1
  634. package/dist/store/sqlite.js +0 -554
  635. package/dist/store/sqlite.js.map +0 -1
  636. package/dist/store/status-registry.js +0 -8
  637. package/dist/store/status-registry.js.map +0 -1
  638. package/dist/store/task-store.js +0 -348
  639. package/dist/store/task-store.js.map +0 -1
  640. package/dist/store/tasks-schema.js +0 -604
  641. package/dist/store/tasks-schema.js.map +0 -1
  642. package/dist/store/typed-query.js +0 -15
  643. package/dist/store/typed-query.js.map +0 -1
  644. package/dist/store/validation-schemas.js +0 -278
  645. package/dist/store/validation-schemas.js.map +0 -1
  646. package/dist/system/archive-analytics.js +0 -277
  647. package/dist/system/archive-analytics.js.map +0 -1
  648. package/dist/system/archive-stats.js +0 -64
  649. package/dist/system/archive-stats.js.map +0 -1
  650. package/dist/system/audit.js +0 -145
  651. package/dist/system/audit.js.map +0 -1
  652. package/dist/system/backup.js +0 -141
  653. package/dist/system/backup.js.map +0 -1
  654. package/dist/system/cleanup.js +0 -134
  655. package/dist/system/cleanup.js.map +0 -1
  656. package/dist/system/health.js +0 -1054
  657. package/dist/system/health.js.map +0 -1
  658. package/dist/system/index.js +0 -18
  659. package/dist/system/index.js.map +0 -1
  660. package/dist/system/inject-generate.js +0 -122
  661. package/dist/system/inject-generate.js.map +0 -1
  662. package/dist/system/labels.js +0 -38
  663. package/dist/system/labels.js.map +0 -1
  664. package/dist/system/metrics.js +0 -61
  665. package/dist/system/metrics.js.map +0 -1
  666. package/dist/system/migrate.js +0 -43
  667. package/dist/system/migrate.js.map +0 -1
  668. package/dist/system/platform-paths.js +0 -80
  669. package/dist/system/platform-paths.js.map +0 -1
  670. package/dist/system/runtime.js +0 -161
  671. package/dist/system/runtime.js.map +0 -1
  672. package/dist/system/safestop.js +0 -99
  673. package/dist/system/safestop.js.map +0 -1
  674. package/dist/system/storage-preflight.js +0 -123
  675. package/dist/system/storage-preflight.js.map +0 -1
  676. package/dist/task-work/index.js +0 -155
  677. package/dist/task-work/index.js.map +0 -1
  678. package/dist/tasks/add.js +0 -656
  679. package/dist/tasks/add.js.map +0 -1
  680. package/dist/tasks/analyze.js +0 -85
  681. package/dist/tasks/analyze.js.map +0 -1
  682. package/dist/tasks/archive.js +0 -90
  683. package/dist/tasks/archive.js.map +0 -1
  684. package/dist/tasks/atomicity.js +0 -83
  685. package/dist/tasks/atomicity.js.map +0 -1
  686. package/dist/tasks/cancel-ops.js +0 -83
  687. package/dist/tasks/cancel-ops.js.map +0 -1
  688. package/dist/tasks/complete.js +0 -235
  689. package/dist/tasks/complete.js.map +0 -1
  690. package/dist/tasks/crossref-extract.js +0 -73
  691. package/dist/tasks/crossref-extract.js.map +0 -1
  692. package/dist/tasks/delete-preview.js +0 -192
  693. package/dist/tasks/delete-preview.js.map +0 -1
  694. package/dist/tasks/delete.js +0 -120
  695. package/dist/tasks/delete.js.map +0 -1
  696. package/dist/tasks/deletion-strategy.js +0 -200
  697. package/dist/tasks/deletion-strategy.js.map +0 -1
  698. package/dist/tasks/dependency-check.js +0 -278
  699. package/dist/tasks/dependency-check.js.map +0 -1
  700. package/dist/tasks/deps-ready.js +0 -32
  701. package/dist/tasks/deps-ready.js.map +0 -1
  702. package/dist/tasks/enforcement.js +0 -89
  703. package/dist/tasks/enforcement.js.map +0 -1
  704. package/dist/tasks/epic-enforcement.js +0 -294
  705. package/dist/tasks/epic-enforcement.js.map +0 -1
  706. package/dist/tasks/find.js +0 -148
  707. package/dist/tasks/find.js.map +0 -1
  708. package/dist/tasks/graph-cache.js +0 -127
  709. package/dist/tasks/graph-cache.js.map +0 -1
  710. package/dist/tasks/graph-ops.js +0 -171
  711. package/dist/tasks/graph-ops.js.map +0 -1
  712. package/dist/tasks/graph-rag.js +0 -328
  713. package/dist/tasks/graph-rag.js.map +0 -1
  714. package/dist/tasks/hierarchy-policy.js +0 -149
  715. package/dist/tasks/hierarchy-policy.js.map +0 -1
  716. package/dist/tasks/hierarchy.js +0 -185
  717. package/dist/tasks/hierarchy.js.map +0 -1
  718. package/dist/tasks/id-generator.js +0 -65
  719. package/dist/tasks/id-generator.js.map +0 -1
  720. package/dist/tasks/index.js +0 -14
  721. package/dist/tasks/index.js.map +0 -1
  722. package/dist/tasks/labels.js +0 -52
  723. package/dist/tasks/labels.js.map +0 -1
  724. package/dist/tasks/list.js +0 -68
  725. package/dist/tasks/list.js.map +0 -1
  726. package/dist/tasks/phase-tracking.js +0 -133
  727. package/dist/tasks/phase-tracking.js.map +0 -1
  728. package/dist/tasks/pipeline-stage.js +0 -248
  729. package/dist/tasks/pipeline-stage.js.map +0 -1
  730. package/dist/tasks/plan.js +0 -268
  731. package/dist/tasks/plan.js.map +0 -1
  732. package/dist/tasks/relates.js +0 -89
  733. package/dist/tasks/relates.js.map +0 -1
  734. package/dist/tasks/reparent.d.ts +0 -38
  735. package/dist/tasks/reparent.d.ts.map +0 -1
  736. package/dist/tasks/show.js +0 -78
  737. package/dist/tasks/show.js.map +0 -1
  738. package/dist/tasks/size-weighting.js +0 -86
  739. package/dist/tasks/size-weighting.js.map +0 -1
  740. package/dist/tasks/staleness.js +0 -86
  741. package/dist/tasks/staleness.js.map +0 -1
  742. package/dist/tasks/task-ops.js +0 -1340
  743. package/dist/tasks/task-ops.js.map +0 -1
  744. package/dist/tasks/update.js +0 -271
  745. package/dist/tasks/update.js.map +0 -1
  746. package/dist/templates/index.js +0 -10
  747. package/dist/templates/index.js.map +0 -1
  748. package/dist/templates/parser.js +0 -254
  749. package/dist/templates/parser.js.map +0 -1
  750. package/dist/ui/aliases.js +0 -153
  751. package/dist/ui/aliases.js.map +0 -1
  752. package/dist/ui/changelog.js +0 -184
  753. package/dist/ui/changelog.js.map +0 -1
  754. package/dist/ui/command-registry.js +0 -168
  755. package/dist/ui/command-registry.js.map +0 -1
  756. package/dist/ui/flags.js +0 -94
  757. package/dist/ui/flags.js.map +0 -1
  758. package/dist/ui/index.js +0 -24
  759. package/dist/ui/index.js.map +0 -1
  760. package/dist/ui/injection-legacy.d.ts +0 -26
  761. package/dist/ui/injection-legacy.d.ts.map +0 -1
  762. package/dist/ui/injection-legacy.js +0 -42
  763. package/dist/ui/injection-legacy.js.map +0 -1
  764. package/dist/upgrade.js +0 -901
  765. package/dist/upgrade.js.map +0 -1
  766. package/dist/validation/chain-validation.js +0 -146
  767. package/dist/validation/chain-validation.js.map +0 -1
  768. package/dist/validation/compliance.js +0 -155
  769. package/dist/validation/compliance.js.map +0 -1
  770. package/dist/validation/docs-sync.js +0 -212
  771. package/dist/validation/docs-sync.js.map +0 -1
  772. package/dist/validation/doctor/checks.js +0 -1069
  773. package/dist/validation/doctor/checks.js.map +0 -1
  774. package/dist/validation/doctor/index.js +0 -9
  775. package/dist/validation/doctor/index.js.map +0 -1
  776. package/dist/validation/doctor/project-cache.js +0 -160
  777. package/dist/validation/doctor/project-cache.js.map +0 -1
  778. package/dist/validation/doctor/utils.js +0 -155
  779. package/dist/validation/doctor/utils.js.map +0 -1
  780. package/dist/validation/engine.js +0 -902
  781. package/dist/validation/engine.js.map +0 -1
  782. package/dist/validation/gap-check.js +0 -175
  783. package/dist/validation/gap-check.js.map +0 -1
  784. package/dist/validation/index.js +0 -40
  785. package/dist/validation/index.js.map +0 -1
  786. package/dist/validation/manifest.js +0 -237
  787. package/dist/validation/manifest.js.map +0 -1
  788. package/dist/validation/operation-gate-validators.js +0 -724
  789. package/dist/validation/operation-gate-validators.js.map +0 -1
  790. package/dist/validation/operation-verification-gates.js +0 -532
  791. package/dist/validation/operation-verification-gates.js.map +0 -1
  792. package/dist/validation/param-utils.js +0 -139
  793. package/dist/validation/param-utils.js.map +0 -1
  794. package/dist/validation/protocol-common.js +0 -300
  795. package/dist/validation/protocol-common.js.map +0 -1
  796. package/dist/validation/protocols/consensus.js +0 -71
  797. package/dist/validation/protocols/consensus.js.map +0 -1
  798. package/dist/validation/protocols/contribution.js +0 -59
  799. package/dist/validation/protocols/contribution.js.map +0 -1
  800. package/dist/validation/protocols/decomposition.js +0 -59
  801. package/dist/validation/protocols/decomposition.js.map +0 -1
  802. package/dist/validation/protocols/implementation.js +0 -59
  803. package/dist/validation/protocols/implementation.js.map +0 -1
  804. package/dist/validation/protocols/release-protocol.js +0 -60
  805. package/dist/validation/protocols/release-protocol.js.map +0 -1
  806. package/dist/validation/protocols/research.js +0 -77
  807. package/dist/validation/protocols/research.js.map +0 -1
  808. package/dist/validation/protocols/specification.js +0 -84
  809. package/dist/validation/protocols/specification.js.map +0 -1
  810. package/dist/validation/protocols/testing-protocol.js +0 -70
  811. package/dist/validation/protocols/testing-protocol.js.map +0 -1
  812. package/dist/validation/protocols/validation-protocol.js +0 -70
  813. package/dist/validation/protocols/validation-protocol.js.map +0 -1
  814. package/dist/validation/schema-integrity.js +0 -170
  815. package/dist/validation/schema-integrity.js.map +0 -1
  816. package/dist/validation/schema-validator.js +0 -176
  817. package/dist/validation/schema-validator.js.map +0 -1
  818. package/dist/validation/validate-ops.js +0 -937
  819. package/dist/validation/validate-ops.js.map +0 -1
  820. package/dist/validation/validation-rules.js +0 -226
  821. package/dist/validation/validation-rules.js.map +0 -1
  822. package/dist/validation/verification.js +0 -321
  823. package/dist/validation/verification.js.map +0 -1
@@ -1,734 +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 idRows = nativeDb
464
- .prepare(`WITH RECURSIVE ancestor_ids(id, depth) AS (
465
- SELECT parent_id, 0 FROM tasks WHERE id = ? AND parent_id IS NOT NULL
466
- UNION ALL
467
- SELECT t.parent_id, a.depth + 1 FROM tasks t
468
- JOIN ancestor_ids a ON t.id = a.id
469
- WHERE t.parent_id IS NOT NULL
470
- )
471
- SELECT id FROM ancestor_ids ORDER BY depth DESC`)
472
- .all(taskId);
473
- if (idRows.length === 0)
474
- return [];
475
- const db = await getDb(cwd);
476
- const ids = idRows.map((r) => r.id);
477
- const taskRows = await db
478
- .select()
479
- .from(schema.tasks)
480
- .where(inArray(schema.tasks.id, ids))
481
- .all();
482
- const tasks = taskRows.map(rowToTask);
483
- if (tasks.length > 0) {
484
- const allIds = await getAllTaskIds();
485
- await loadDependenciesForTasks(db, tasks, allIds);
486
- await loadRelationsForTasks(db, tasks);
487
- }
488
- // Preserve depth order (ancestors from root down)
489
- const orderMap = new Map(ids.map((id, i) => [id, i]));
490
- tasks.sort((a, b) => (orderMap.get(a.id) ?? 0) - (orderMap.get(b.id) ?? 0));
491
- return tasks;
492
- },
493
- async getSubtree(rootId) {
494
- const nativeDb = getNativeTasksDb();
495
- if (!nativeDb)
496
- return [];
497
- // Get IDs from the CTE, then load via Drizzle for proper conversion
498
- const idRows = nativeDb
499
- .prepare(`WITH RECURSIVE subtree AS (
500
- SELECT id FROM tasks WHERE id = ?
501
- UNION ALL
502
- SELECT t.id FROM tasks t
503
- JOIN subtree s ON t.parent_id = s.id
504
- )
505
- SELECT id FROM subtree`)
506
- .all(rootId);
507
- if (idRows.length === 0)
508
- return [];
509
- const db = await getDb(cwd);
510
- const ids = idRows.map((r) => r.id);
511
- const rows = await db.select().from(schema.tasks).where(inArray(schema.tasks.id, ids)).all();
512
- const tasks = rows.map(rowToTask);
513
- if (tasks.length > 0) {
514
- const allIds = await getAllTaskIds();
515
- await loadDependenciesForTasks(db, tasks, allIds);
516
- await loadRelationsForTasks(db, tasks);
517
- }
518
- return tasks;
519
- },
520
- async getDependents(taskId) {
521
- const db = await getDb(cwd);
522
- // Find tasks whose depends list includes taskId (reverse lookup)
523
- const depRows = await db
524
- .select()
525
- .from(schema.taskDependencies)
526
- .where(eq(schema.taskDependencies.dependsOn, taskId))
527
- .all();
528
- if (depRows.length === 0)
529
- return [];
530
- const dependentIds = depRows.map((r) => r.taskId);
531
- const rows = await db
532
- .select()
533
- .from(schema.tasks)
534
- .where(inArray(schema.tasks.id, dependentIds))
535
- .all();
536
- const tasks = rows.map(rowToTask);
537
- if (tasks.length > 0) {
538
- const allIds = await getAllTaskIds();
539
- await loadDependenciesForTasks(db, tasks, allIds);
540
- await loadRelationsForTasks(db, tasks);
541
- }
542
- return tasks;
543
- },
544
- async getDependencyChain(taskId) {
545
- const nativeDb = getNativeTasksDb();
546
- if (!nativeDb)
547
- return [];
548
- const rows = nativeDb
549
- .prepare(`WITH RECURSIVE dep_chain(id) AS (
550
- SELECT depends_on FROM task_dependencies WHERE task_id = ?
551
- UNION
552
- SELECT td.depends_on FROM task_dependencies td
553
- JOIN dep_chain dc ON td.task_id = dc.id
554
- )
555
- SELECT id FROM dep_chain`)
556
- .all(taskId);
557
- return rows.map((r) => r.id);
558
- },
559
- async taskExists(taskId) {
560
- const db = await getDb(cwd);
561
- const result = await db
562
- .select({ id: schema.tasks.id })
563
- .from(schema.tasks)
564
- .where(eq(schema.tasks.id, taskId))
565
- .limit(1)
566
- .get();
567
- return !!result;
568
- },
569
- async loadTasks(taskIds) {
570
- if (taskIds.length === 0)
571
- return [];
572
- const db = await getDb(cwd);
573
- const rows = await db
574
- .select()
575
- .from(schema.tasks)
576
- .where(inArray(schema.tasks.id, taskIds))
577
- .all();
578
- const tasks = rows.map(rowToTask);
579
- if (tasks.length > 0) {
580
- const allIds = await getAllTaskIds();
581
- await loadDependenciesForTasks(db, tasks, allIds);
582
- await loadRelationsForTasks(db, tasks);
583
- }
584
- return tasks;
585
- },
586
- // ---- Position helpers (T024/T025) ----
587
- async getNextPosition(parentId) {
588
- const nativeDb = getNativeTasksDb();
589
- if (!nativeDb) {
590
- throw new Error('Native database not initialized');
591
- }
592
- const row = parentId === null
593
- ? nativeDb
594
- .prepare(`SELECT COALESCE(MAX(position), 0) + 1 AS next_pos FROM tasks WHERE parent_id IS NULL AND status != 'archived'`)
595
- .get()
596
- : nativeDb
597
- .prepare(`SELECT COALESCE(MAX(position), 0) + 1 AS next_pos FROM tasks WHERE parent_id = ? AND status != 'archived'`)
598
- .get(parentId);
599
- return row?.next_pos ?? 1;
600
- },
601
- async shiftPositions(parentId, fromPosition, delta) {
602
- const nativeDb = getNativeTasksDb();
603
- if (!nativeDb) {
604
- throw new Error('Native database not initialized');
605
- }
606
- if (parentId === null) {
607
- nativeDb
608
- .prepare(`UPDATE tasks SET position = position + ?, position_version = position_version + 1, updated_at = ? WHERE parent_id IS NULL AND position >= ? AND status != 'archived'`)
609
- .run(delta, new Date().toISOString(), fromPosition);
610
- }
611
- else {
612
- nativeDb
613
- .prepare(`UPDATE tasks SET position = position + ?, position_version = position_version + 1, updated_at = ? WHERE parent_id = ? AND position >= ? AND status != 'archived'`)
614
- .run(delta, new Date().toISOString(), parentId, fromPosition);
615
- }
616
- },
617
- // ---- Targeted write methods ----
618
- async updateTaskFields(taskId, fields) {
619
- const db = await getDb(cwd);
620
- const updateRow = {
621
- updatedAt: fields.updatedAt ?? new Date().toISOString(),
622
- };
623
- // Copy only provided fields
624
- const fieldMap = [
625
- ['title', 'title'],
626
- ['description', 'description'],
627
- ['status', 'status'],
628
- ['priority', 'priority'],
629
- ['type', 'type'],
630
- ['parentId', 'parentId'],
631
- ['phase', 'phase'],
632
- ['size', 'size'],
633
- ['position', 'position'],
634
- ['positionVersion', 'positionVersion'],
635
- ['labelsJson', 'labelsJson'],
636
- ['notesJson', 'notesJson'],
637
- ['acceptanceJson', 'acceptanceJson'],
638
- ['filesJson', 'filesJson'],
639
- ['origin', 'origin'],
640
- ['blockedBy', 'blockedBy'],
641
- ['epicLifecycle', 'epicLifecycle'],
642
- ['noAutoComplete', 'noAutoComplete'],
643
- ['completedAt', 'completedAt'],
644
- ['cancelledAt', 'cancelledAt'],
645
- ['cancellationReason', 'cancellationReason'],
646
- ['verificationJson', 'verificationJson'],
647
- ['createdBy', 'createdBy'],
648
- ['modifiedBy', 'modifiedBy'],
649
- ['sessionId', 'sessionId'],
650
- ];
651
- for (const [key, col] of fieldMap) {
652
- if (fields[key] !== undefined) {
653
- updateRow[col] = fields[key];
654
- }
655
- }
656
- await db.update(schema.tasks).set(updateRow).where(eq(schema.tasks.id, taskId)).run();
657
- },
658
- async transaction(fn) {
659
- const nativeDb = getNativeTasksDb();
660
- if (!nativeDb) {
661
- throw new Error('Native database not initialized');
662
- }
663
- const db = await getDb(cwd);
664
- nativeDb.prepare('BEGIN IMMEDIATE').run();
665
- try {
666
- const tx = {
667
- async upsertSingleTask(task) {
668
- const row = taskToRow(task);
669
- await upsertTask(db, row);
670
- await updateDependencies(db, task.id, task.depends ?? []);
671
- },
672
- async archiveSingleTask(taskId, fields) {
673
- await db
674
- .update(schema.tasks)
675
- .set({
676
- status: 'archived',
677
- archivedAt: fields.archivedAt ?? new Date().toISOString(),
678
- archiveReason: fields.archiveReason ?? 'completed',
679
- cycleTimeDays: fields.cycleTimeDays ?? null,
680
- updatedAt: new Date().toISOString(),
681
- })
682
- .where(eq(schema.tasks.id, taskId))
683
- .run();
684
- },
685
- async removeSingleTask(taskId) {
686
- await db
687
- .delete(schema.taskDependencies)
688
- .where(eq(schema.taskDependencies.taskId, taskId))
689
- .run();
690
- await db
691
- .delete(schema.taskDependencies)
692
- .where(eq(schema.taskDependencies.dependsOn, taskId))
693
- .run();
694
- await db.delete(schema.tasks).where(eq(schema.tasks.id, taskId)).run();
695
- },
696
- async setMetaValue(key, value) {
697
- await setMetaValue(cwd, key, value);
698
- },
699
- async updateTaskFields(taskId, flds) {
700
- // Delegate to the outer accessor's implementation
701
- await accessor.updateTaskFields(taskId, flds);
702
- },
703
- async appendLog(entry) {
704
- await accessor.appendLog(entry);
705
- },
706
- };
707
- const result = await fn(tx);
708
- nativeDb.prepare('COMMIT').run();
709
- return result;
710
- }
711
- catch (err) {
712
- nativeDb.prepare('ROLLBACK').run();
713
- throw err;
714
- }
715
- },
716
- // ---- close ----
717
- async close() {
718
- closeDb();
719
- },
720
- // ---- Metadata ----
721
- async getMetaValue(key) {
722
- return getMetaValue(cwd, key);
723
- },
724
- async setMetaValue(key, value) {
725
- return setMetaValue(cwd, key, value);
726
- },
727
- async getSchemaVersion() {
728
- const meta = await getMetaValue(cwd, 'file_meta');
729
- return meta?.schemaVersion ?? null;
730
- },
731
- };
732
- return accessor;
733
- }
734
- //# sourceMappingURL=sqlite-data-accessor.js.map