@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,1054 +0,0 @@
1
- /**
2
- * System health checks core module.
3
- * @task T4783
4
- * @task T4795
5
- */
6
- import { execFile, execFileSync } from 'node:child_process';
7
- import { existsSync, readFileSync, statSync } from 'node:fs';
8
- import { createRequire } from 'node:module';
9
- import { join } from 'node:path';
10
- import { promisify } from 'node:util';
11
- import { checkGitHooks } from '../hooks.js';
12
- import { checkInjection } from '../injection.js';
13
- import { getAgentsHome, isProjectInitialized } from '../paths.js';
14
- import { getSystemInfo } from '../platform.js';
15
- import { checkBrainDb, checkCleoStructure, checkConfig, checkGlobalHome, checkGlobalTemplates, checkLogDir, checkMemoryBridge, checkProjectContext, checkProjectInfo, checkSqliteDb, ensureCleoStructure, ensureGlobalScaffold, } from '../scaffold.js';
16
- import { checkGlobalSchemas } from '../schema-management.js';
17
- import { getAccessor } from '../store/data-accessor.js';
18
- import { checkCleoGitignore, checkCoreFilesNotIgnored, checkLegacyAgentOutputs, checkNodeVersion, checkVitalFilesTracked, } from '../validation/doctor/checks.js';
19
- import { checkStorageMigration } from './storage-preflight.js';
20
- const execAsync = promisify(execFile);
21
- const _require = createRequire(import.meta.url);
22
- const databaseSyncCtor = (() => {
23
- try {
24
- return _require('node:sqlite').DatabaseSync;
25
- }
26
- catch {
27
- return null;
28
- }
29
- })();
30
- /** Stale JSON files that should not exist alongside tasks.db (ADR-006). */
31
- const STALE_JSON_FILES = ['todo.json', 'sessions.json', 'todo-archive.json'];
32
- function resolveStructuredLogPath(cleoDir) {
33
- const defaultPath = join(cleoDir, 'logs', 'cleo.log');
34
- const configPath = join(cleoDir, 'config.json');
35
- if (!existsSync(configPath))
36
- return defaultPath;
37
- try {
38
- const config = JSON.parse(readFileSync(configPath, 'utf-8'));
39
- if (!config.logging?.filePath)
40
- return defaultPath;
41
- return join(cleoDir, config.logging.filePath);
42
- }
43
- catch {
44
- return defaultPath;
45
- }
46
- }
47
- function checkAuditLogAvailability(dbPath) {
48
- if (!databaseSyncCtor) {
49
- return {
50
- name: 'audit_log',
51
- status: 'warn',
52
- message: 'audit_log check unavailable: node:sqlite runtime not found',
53
- };
54
- }
55
- try {
56
- const db = new databaseSyncCtor(dbPath, { readOnly: true });
57
- try {
58
- const tableRow = db
59
- .prepare("SELECT name FROM sqlite_master WHERE type='table' AND name='audit_log'")
60
- .get();
61
- if (!tableRow?.name) {
62
- return {
63
- name: 'audit_log',
64
- status: 'fail',
65
- message: 'audit_log table missing from tasks.db (run: cleo upgrade)',
66
- };
67
- }
68
- const countRow = db.prepare('SELECT COUNT(1) AS count FROM audit_log').get();
69
- return {
70
- name: 'audit_log',
71
- status: 'pass',
72
- message: `audit_log table available (${countRow?.count ?? 0} rows)`,
73
- };
74
- }
75
- finally {
76
- db.close();
77
- }
78
- }
79
- catch {
80
- return {
81
- name: 'audit_log',
82
- status: 'warn',
83
- message: 'Unable to validate audit_log availability from tasks.db',
84
- };
85
- }
86
- }
87
- /** Run system health checks (SQLite-first per ADR-006). */
88
- export function getSystemHealth(projectRoot, opts) {
89
- const cleoDir = join(projectRoot, '.cleo');
90
- const checks = [];
91
- // Check .cleo directory
92
- if (existsSync(cleoDir)) {
93
- checks.push({ name: 'cleo_dir', status: 'pass', message: '.cleo directory exists' });
94
- }
95
- else {
96
- checks.push({ name: 'cleo_dir', status: 'fail', message: '.cleo directory not found' });
97
- }
98
- // Check tasks.db (primary data store per ADR-006)
99
- const dbPath = join(cleoDir, 'tasks.db');
100
- if (existsSync(dbPath)) {
101
- try {
102
- const dbSize = statSync(dbPath).size;
103
- if (dbSize > 0) {
104
- checks.push({ name: 'tasks_db', status: 'pass', message: `tasks.db: ${dbSize} bytes` });
105
- }
106
- else {
107
- checks.push({ name: 'tasks_db', status: 'warn', message: 'tasks.db exists but is empty' });
108
- }
109
- }
110
- catch {
111
- checks.push({
112
- name: 'tasks_db',
113
- status: 'fail',
114
- message: 'tasks.db exists but is not readable',
115
- });
116
- }
117
- }
118
- else {
119
- checks.push({ name: 'tasks_db', status: 'fail', message: 'tasks.db not found' });
120
- }
121
- if (existsSync(dbPath)) {
122
- checks.push(checkAuditLogAvailability(dbPath));
123
- }
124
- // Check config.json (config remains JSON per ADR-006)
125
- const configPath = join(cleoDir, 'config.json');
126
- if (existsSync(configPath)) {
127
- try {
128
- JSON.parse(readFileSync(configPath, 'utf-8'));
129
- checks.push({ name: 'config_json', status: 'pass', message: 'config.json is valid JSON' });
130
- }
131
- catch {
132
- checks.push({
133
- name: 'config_json',
134
- status: 'warn',
135
- message: 'config.json is not valid JSON',
136
- });
137
- }
138
- }
139
- else {
140
- checks.push({ name: 'config_json', status: 'warn', message: 'config.json not found' });
141
- }
142
- // Check for stale JSON files alongside tasks.db
143
- if (existsSync(dbPath)) {
144
- const staleFiles = STALE_JSON_FILES.filter((f) => existsSync(join(cleoDir, f)));
145
- if (staleFiles.length > 0) {
146
- checks.push({
147
- name: 'stale_json',
148
- status: 'warn',
149
- message: `Stale JSON files found alongside tasks.db: ${staleFiles.join(', ')}. Run: cleo upgrade`,
150
- });
151
- }
152
- }
153
- if (opts?.detailed) {
154
- const logPath = resolveStructuredLogPath(cleoDir);
155
- if (existsSync(logPath)) {
156
- checks.push({
157
- name: 'log_file',
158
- status: 'pass',
159
- message: `structured log present: ${logPath}`,
160
- });
161
- }
162
- else {
163
- checks.push({
164
- name: 'log_file',
165
- status: 'warn',
166
- message: `structured log not found: ${logPath}`,
167
- });
168
- }
169
- const backupDir = join(cleoDir, '.backups');
170
- if (existsSync(backupDir)) {
171
- checks.push({ name: 'backups_dir', status: 'pass', message: '.backups directory exists' });
172
- }
173
- else {
174
- checks.push({
175
- name: 'backups_dir',
176
- status: 'pass',
177
- message: 'No backups directory (created on first write)',
178
- });
179
- }
180
- }
181
- // Get version
182
- let version = 'unknown';
183
- try {
184
- const pkgPath = join(projectRoot, 'package.json');
185
- if (existsSync(pkgPath)) {
186
- const pkg = JSON.parse(readFileSync(pkgPath, 'utf-8'));
187
- version = pkg.version || 'unknown';
188
- }
189
- }
190
- catch {
191
- // fallback
192
- }
193
- const failCount = checks.filter((c) => c.status === 'fail').length;
194
- const warnCount = checks.filter((c) => c.status === 'warn').length;
195
- const overall = failCount > 0 ? 'error' : warnCount > 0 ? 'warning' : 'healthy';
196
- const installation = failCount > 0 ? 'degraded' : 'ok';
197
- return { overall, checks, version, installation };
198
- }
199
- /** Run extended diagnostics with fix suggestions. */
200
- export async function getSystemDiagnostics(projectRoot, opts) {
201
- const healthResult = getSystemHealth(projectRoot, { detailed: true });
202
- const diagChecks = healthResult.checks.map((c) => ({
203
- name: c.name,
204
- status: c.status,
205
- details: c.message,
206
- fix: c.status === 'fail'
207
- ? c.name === 'cleo_dir'
208
- ? 'Run: cleo init'
209
- : c.name === 'tasks_db'
210
- ? 'Run: cleo init (or restore from backup)'
211
- : undefined
212
- : undefined,
213
- }));
214
- // Storage migration pre-flight check
215
- const preflight = checkStorageMigration(projectRoot);
216
- if (preflight.migrationNeeded) {
217
- diagChecks.push({
218
- name: 'storage_migration',
219
- status: 'fail',
220
- details: preflight.summary,
221
- fix: preflight.fix ?? undefined,
222
- });
223
- }
224
- else {
225
- diagChecks.push({
226
- name: 'storage_migration',
227
- status: 'pass',
228
- details: preflight.summary,
229
- });
230
- }
231
- // Schema version check — read via DataAccessor (per ADR-006)
232
- const cleoDir = join(projectRoot, '.cleo');
233
- const dbPath = join(cleoDir, 'tasks.db');
234
- if (existsSync(dbPath)) {
235
- try {
236
- const accessor = await getAccessor(projectRoot);
237
- const schemaVersion = await accessor.getSchemaVersion();
238
- if (schemaVersion) {
239
- diagChecks.push({
240
- name: 'schema_version',
241
- status: 'pass',
242
- details: `Schema version: ${schemaVersion}`,
243
- });
244
- }
245
- else {
246
- diagChecks.push({
247
- name: 'schema_version',
248
- status: 'warn',
249
- details: 'No schema version in SQLite',
250
- fix: 'Run: cleo upgrade',
251
- });
252
- }
253
- }
254
- catch {
255
- diagChecks.push({
256
- name: 'schema_version',
257
- status: 'warn',
258
- details: 'Could not read schema version from SQLite',
259
- fix: 'Run: cleo upgrade',
260
- });
261
- }
262
- }
263
- // Check for stale sessions — read from SQLite accessor
264
- if (existsSync(dbPath)) {
265
- try {
266
- const accessor = await getAccessor(projectRoot);
267
- const sessions = await accessor.loadSessions();
268
- const activeSessions = sessions.filter((s) => s.status === 'active');
269
- if (activeSessions.length > 3) {
270
- diagChecks.push({
271
- name: 'stale_sessions',
272
- status: 'warn',
273
- details: `${activeSessions.length} active sessions (may include stale)`,
274
- fix: 'Run: cleo session gc',
275
- });
276
- }
277
- else {
278
- diagChecks.push({
279
- name: 'stale_sessions',
280
- status: 'pass',
281
- details: `${activeSessions.length} active session(s)`,
282
- });
283
- }
284
- }
285
- catch {
286
- // skip
287
- }
288
- }
289
- // Filter checks if specific ones requested
290
- let filteredChecks = diagChecks;
291
- if (opts?.checks && opts.checks.length > 0) {
292
- filteredChecks = diagChecks.filter((c) => opts.checks.includes(c.name));
293
- }
294
- const passedCount = filteredChecks.filter((c) => c.status === 'pass').length;
295
- const warnedCount = filteredChecks.filter((c) => c.status === 'warn').length;
296
- const failedCount = filteredChecks.filter((c) => c.status === 'fail').length;
297
- return {
298
- timestamp: new Date().toISOString(),
299
- checks: filteredChecks,
300
- summary: {
301
- total: filteredChecks.length,
302
- passed: passedCount,
303
- warned: warnedCount,
304
- failed: failedCount,
305
- },
306
- };
307
- }
308
- async function commandExists(cmd) {
309
- try {
310
- const { stdout } = await execAsync('which', [cmd]);
311
- return stdout.trim();
312
- }
313
- catch {
314
- return null;
315
- }
316
- }
317
- async function fileSize(path) {
318
- try {
319
- return statSync(path).size;
320
- }
321
- catch {
322
- return -1;
323
- }
324
- }
325
- function mapCheckResult(cr) {
326
- return {
327
- check: cr.id,
328
- status: cr.status === 'passed'
329
- ? 'ok'
330
- : cr.status === 'info'
331
- ? 'ok'
332
- : cr.status === 'warning'
333
- ? 'warning'
334
- : 'error',
335
- message: cr.message,
336
- ...(cr.fix ? { fix: cr.fix } : {}),
337
- };
338
- }
339
- /** Map HookCheckResult[] from hooks.ts into a single DoctorCheck summary. */
340
- function mapHookResults(results) {
341
- const missing = results.filter((r) => !r.installed);
342
- const stale = results.filter((r) => r.installed && !r.current);
343
- if (missing.length > 0) {
344
- return {
345
- check: 'git_hooks',
346
- status: 'warning',
347
- message: `Missing git hooks: ${missing.map((r) => r.hook).join(', ')}`,
348
- details: { missing: missing.map((r) => r.hook), fix: 'cleo init --force' },
349
- };
350
- }
351
- if (stale.length > 0) {
352
- return {
353
- check: 'git_hooks',
354
- status: 'warning',
355
- message: `Stale git hooks: ${stale.map((r) => r.hook).join(', ')}`,
356
- details: { stale: stale.map((r) => r.hook), fix: 'cleo upgrade' },
357
- };
358
- }
359
- return {
360
- check: 'git_hooks',
361
- status: 'ok',
362
- message: `All ${results.length} managed git hooks installed and current`,
363
- };
364
- }
365
- /** Map schema-management.ts CheckResult into a DoctorCheck. */
366
- function mapSchemaCheckResult(sr) {
367
- if (sr.missing.length > 0) {
368
- return {
369
- check: 'global_schemas',
370
- status: 'warning',
371
- message: `Missing global schemas: ${sr.missing.join(', ')}`,
372
- details: { missing: sr.missing, fix: 'cleo upgrade' },
373
- };
374
- }
375
- if (sr.stale.length > 0) {
376
- return {
377
- check: 'global_schemas',
378
- status: 'warning',
379
- message: `Stale global schemas: ${sr.stale.join(', ')}`,
380
- details: { stale: sr.stale, fix: 'cleo upgrade' },
381
- };
382
- }
383
- return {
384
- check: 'global_schemas',
385
- status: 'ok',
386
- message: `All ${sr.installed} global schemas installed and current`,
387
- };
388
- }
389
- /**
390
- * Check contributor project dev channel availability and health.
391
- * No-op for non-contributor projects (ADR-029).
392
- *
393
- * Reports whether cleo-dev is on PATH and responsive. Does NOT mandate
394
- * using cleo-dev — agents should prefer it when healthy, fall back to
395
- * production cleo when the dev build is broken.
396
- */
397
- function checkContributorChannel(projectRoot) {
398
- const configPath = join(projectRoot, '.cleo', 'config.json');
399
- if (!existsSync(configPath)) {
400
- return { check: 'contributor_channel', status: 'ok', message: 'Not a contributor project' };
401
- }
402
- let isContributor = false;
403
- let devCli = 'cleo-dev';
404
- try {
405
- const config = JSON.parse(readFileSync(configPath, 'utf-8'));
406
- isContributor = config.contributor?.isContributorProject === true;
407
- devCli = config.contributor?.devCli ?? 'cleo-dev';
408
- }
409
- catch {
410
- return { check: 'contributor_channel', status: 'ok', message: 'Not a contributor project' };
411
- }
412
- if (!isContributor) {
413
- return { check: 'contributor_channel', status: 'ok', message: 'Not a contributor project' };
414
- }
415
- // Check that cleo-dev is on PATH
416
- const pathDirs = (process.env['PATH'] ?? '').split(':').filter(Boolean);
417
- const devCliOnPath = pathDirs.some((dir) => existsSync(join(dir, devCli)));
418
- if (!devCliOnPath) {
419
- return {
420
- check: 'contributor_channel',
421
- status: 'warning',
422
- message: `Contributor project: '${devCli}' not on PATH. Using production cleo. Run ./install.sh --dev to enable dev channel.`,
423
- fix: './install.sh --dev',
424
- };
425
- }
426
- // Probe whether the dev CLI actually responds
427
- try {
428
- const version = execFileSync(devCli, ['--version'], { timeout: 5000 }).toString().trim();
429
- return {
430
- check: 'contributor_channel',
431
- status: 'ok',
432
- message: `Contributor project: '${devCli}' healthy (v${version}). Prefer dev channel for unreleased features.`,
433
- };
434
- }
435
- catch {
436
- return {
437
- check: 'contributor_channel',
438
- status: 'warning',
439
- message: `Contributor project: '${devCli}' on PATH but not responding. Dev build may need rebuild (npm run build). Production cleo available as fallback.`,
440
- fix: 'npm run build',
441
- };
442
- }
443
- }
444
- /**
445
- * Run comprehensive doctor diagnostics combining dependency checks,
446
- * directory checks, data file checks, gitignore checks, and environment info.
447
- * @task T4795
448
- */
449
- export async function coreDoctorReport(projectRoot) {
450
- const checks = [];
451
- // 1. Check dependencies (jq removed — no longer needed since SQLite migration, ADR-006)
452
- const gitPath = await commandExists('git');
453
- checks.push({
454
- check: 'git_installed',
455
- status: gitPath ? 'ok' : 'warning',
456
- message: gitPath
457
- ? `git found: ${gitPath}`
458
- : 'git not found (optional, needed for version control features)',
459
- });
460
- // 2. Check CLEO directories
461
- const cleoDir = join(projectRoot, '.cleo');
462
- const dirExists = existsSync(cleoDir);
463
- checks.push({
464
- check: 'project_dir',
465
- status: dirExists ? 'ok' : 'error',
466
- message: dirExists
467
- ? `Project dir: ${cleoDir}`
468
- : `Project dir not found: ${cleoDir}. Run: cleo init`,
469
- });
470
- // 3. Check data files — SQLite is the primary store (ADR-006)
471
- const dbPath = join(cleoDir, 'tasks.db');
472
- const dbExists = existsSync(dbPath);
473
- const dbSize = await fileSize(dbPath);
474
- checks.push({
475
- check: 'tasks_db',
476
- status: dbExists ? 'ok' : 'error',
477
- message: dbExists ? `tasks.db: ${dbSize} bytes` : `tasks.db not found. Run: cleo init`,
478
- });
479
- if (dbExists) {
480
- try {
481
- const accessor = await getAccessor(projectRoot);
482
- const taskCount = await accessor.countTasks();
483
- const schemaVersion = (await accessor.getMetaValue('schemaVersion')) ?? 'unknown';
484
- checks.push({
485
- check: 'tasks_db_data',
486
- status: 'ok',
487
- message: `${taskCount} tasks, schema v${schemaVersion}`,
488
- details: { taskCount, schemaVersion },
489
- });
490
- }
491
- catch {
492
- checks.push({
493
- check: 'tasks_db_data',
494
- status: 'error',
495
- message: 'Failed to read tasks from SQLite database',
496
- });
497
- }
498
- const auditLogCheck = checkAuditLogAvailability(dbPath);
499
- checks.push({
500
- check: 'audit_log',
501
- status: auditLogCheck.status === 'pass'
502
- ? 'ok'
503
- : auditLogCheck.status === 'warn'
504
- ? 'warning'
505
- : 'error',
506
- message: auditLogCheck.message ?? 'audit_log availability check completed',
507
- ...(auditLogCheck.status === 'fail' ? { fix: 'Run: cleo upgrade' } : {}),
508
- });
509
- // SQLite integrity check
510
- try {
511
- const { getNativeDb, getDb: getDbInit } = await import('../store/sqlite.js');
512
- // Ensure the DB is initialized so getNativeDb() returns a valid handle
513
- await getDbInit(projectRoot);
514
- const nativeDb = getNativeDb();
515
- if (nativeDb) {
516
- const result = nativeDb.prepare('PRAGMA integrity_check').get();
517
- const integrityOk = result?.integrity_check === 'ok';
518
- checks.push({
519
- check: 'sqlite_integrity',
520
- status: integrityOk ? 'ok' : 'warning',
521
- message: integrityOk
522
- ? 'SQLite integrity check passed'
523
- : 'SQLite integrity check reported issues',
524
- ...(integrityOk ? {} : { fix: 'Run: cleo upgrade' }),
525
- });
526
- }
527
- }
528
- catch {
529
- // SQLite integrity check is best-effort
530
- }
531
- }
532
- const configPath = join(cleoDir, 'config.json');
533
- const configExists = existsSync(configPath);
534
- checks.push({
535
- check: 'config_file',
536
- status: configExists ? 'ok' : 'warning',
537
- message: configExists ? 'config.json present' : 'config.json not found (using defaults)',
538
- });
539
- // Check for stale JSON files that should have been cleaned up after migration
540
- const staleJsonFiles = STALE_JSON_FILES.filter((f) => existsSync(join(cleoDir, f)));
541
- if (dbExists && staleJsonFiles.length > 0) {
542
- checks.push({
543
- check: 'stale_json',
544
- status: 'warning',
545
- message: `Stale JSON files found alongside tasks.db: ${staleJsonFiles.join(', ')}. Run: cleo upgrade`,
546
- details: { files: staleJsonFiles },
547
- });
548
- }
549
- const logPath = resolveStructuredLogPath(cleoDir);
550
- const logExists = existsSync(logPath);
551
- checks.push({
552
- check: 'log_file',
553
- status: logExists ? 'ok' : 'warning',
554
- message: logExists
555
- ? `structured log present: ${logPath}`
556
- : `structured log not found: ${logPath}`,
557
- });
558
- // 4. Check root .gitignore for .cleo/ blocking
559
- const rootGitignorePath = join(projectRoot, '.gitignore');
560
- if (existsSync(rootGitignorePath)) {
561
- try {
562
- const gitignoreContent = readFileSync(rootGitignorePath, 'utf-8');
563
- const blockingLines = gitignoreContent.split('\n').filter((line) => {
564
- const trimmed = line.trim();
565
- if (trimmed.startsWith('#') || trimmed === '')
566
- return false;
567
- return /^\/?\.cleo\/?(\*)?$/.test(trimmed);
568
- });
569
- checks.push({
570
- check: 'root_gitignore',
571
- status: blockingLines.length > 0 ? 'warning' : 'ok',
572
- message: blockingLines.length > 0
573
- ? `.cleo/ is ignored in root .gitignore. Run 'cleo init' to fix.`
574
- : 'Root .gitignore does not block .cleo/',
575
- ...(blockingLines.length > 0 ? { details: { blockingLines } } : {}),
576
- });
577
- }
578
- catch {
579
- // Ignore read errors for gitignore check
580
- }
581
- }
582
- // 5. Gitignore integrity, vital files, legacy paths (delegated to core checks)
583
- checks.push(mapCheckResult(checkCleoGitignore(projectRoot)));
584
- checks.push(mapCheckResult(checkVitalFilesTracked(projectRoot)));
585
- checks.push(mapCheckResult(checkCoreFilesNotIgnored(projectRoot)));
586
- checks.push(mapCheckResult(checkLegacyAgentOutputs(projectRoot)));
587
- // 5b. Isolated .cleo/.git checkpoint repo check (T4872)
588
- const cleoGitHeadExists = existsSync(join(cleoDir, '.git', 'HEAD'));
589
- checks.push({
590
- check: 'cleo_git_repo',
591
- status: cleoGitHeadExists ? 'ok' : 'warning',
592
- message: cleoGitHeadExists
593
- ? '.cleo/.git isolated checkpoint repo exists'
594
- : '.cleo/.git not found — run: cleo init',
595
- });
596
- // 5c. Global scaffold checks: home, templates, schemas
597
- checks.push(mapCheckResult(checkGlobalHome()));
598
- checks.push(mapCheckResult(checkGlobalTemplates()));
599
- checks.push(mapSchemaCheckResult(checkGlobalSchemas()));
600
- // 5d. Project scaffold checks: log dir, structure, git hooks, project-info, injection
601
- checks.push(mapCheckResult(checkLogDir(projectRoot)));
602
- const hookResults = await checkGitHooks(projectRoot);
603
- checks.push(mapHookResults(hookResults));
604
- checks.push(mapCheckResult(checkProjectInfo(projectRoot)));
605
- // Project context check
606
- checks.push(mapCheckResult(checkProjectContext(projectRoot)));
607
- checks.push(mapCheckResult(checkInjection(projectRoot)));
608
- // Contributor project channel check (ADR-029)
609
- checks.push(checkContributorChannel(projectRoot));
610
- // Agent definition presence check
611
- const agentDefPath = join(getAgentsHome(), 'agents', 'cleo-subagent');
612
- checks.push({
613
- check: 'agent_definition',
614
- status: existsSync(agentDefPath) ? 'ok' : 'warning',
615
- message: existsSync(agentDefPath)
616
- ? 'cleo-subagent agent definition installed'
617
- : 'cleo-subagent not found — run: cleo init',
618
- ...(existsSync(agentDefPath) ? {} : { fix: 'cleo init' }),
619
- });
620
- // 6a. GitHub templates presence (informational only — non-critical)
621
- const gitDir = join(projectRoot, '.git');
622
- const gitHubTemplatesDir = join(projectRoot, '.github', 'ISSUE_TEMPLATE');
623
- if (existsSync(gitDir)) {
624
- // Only check when this is a git repo
625
- checks.push({
626
- check: 'github_templates',
627
- status: existsSync(gitHubTemplatesDir) ? 'ok' : 'warning',
628
- message: existsSync(gitHubTemplatesDir)
629
- ? '.github/ISSUE_TEMPLATE/ present'
630
- : '.github/ISSUE_TEMPLATE/ not found — run: cleo init or cleo upgrade',
631
- ...(existsSync(gitHubTemplatesDir) ? {} : { fix: 'cleo init' }),
632
- });
633
- }
634
- // 6. Environment - Node.js version validation
635
- checks.push(mapCheckResult(checkNodeVersion()));
636
- const sysInfo = getSystemInfo();
637
- checks.push({
638
- check: 'platform',
639
- status: 'ok',
640
- message: `${sysInfo.osType} ${sysInfo.osRelease} (${sysInfo.platform}/${sysInfo.arch}), Node ${sysInfo.nodeVersion}`,
641
- details: {
642
- platform: sysInfo.platform,
643
- arch: sysInfo.arch,
644
- osType: sysInfo.osType,
645
- osRelease: sysInfo.osRelease,
646
- nodeVersion: sysInfo.nodeVersion,
647
- totalMemory: sysInfo.totalMemory,
648
- freeMemory: sysInfo.freeMemory,
649
- hostname: sysInfo.hostname,
650
- },
651
- });
652
- // Summary
653
- const errorCount = checks.filter((c) => c.status === 'error').length;
654
- const warningCount = checks.filter((c) => c.status === 'warning').length;
655
- const healthy = errorCount === 0;
656
- return { healthy, errors: errorCount, warnings: warningCount, checks };
657
- }
658
- /**
659
- * Run auto-fix for failed doctor checks by calling the corresponding ensure* functions.
660
- * Returns a list of fix results for each attempted repair.
661
- */
662
- export async function runDoctorFixes(projectRoot) {
663
- const { ensureCleoStructure, ensureGitignore, ensureConfig, ensureProjectInfo, ensureProjectContext, ensureCleoGitRepo, ensureGlobalHome, ensureGlobalTemplates, } = await import('../scaffold.js');
664
- const { ensureGitHooks } = await import('../hooks.js');
665
- const { ensureGlobalSchemas } = await import('../schema-management.js');
666
- const { ensureInjection } = await import('../injection.js');
667
- const report = await coreDoctorReport(projectRoot);
668
- const failedChecks = report.checks.filter((c) => c.status !== 'ok');
669
- const results = [];
670
- // Map check names to their fix functions
671
- const fixMap = {
672
- project_dir: async () => {
673
- const r = await ensureCleoStructure(projectRoot);
674
- return {
675
- check: 'project_dir',
676
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
677
- message: r.details ?? r.action,
678
- };
679
- },
680
- cleo_gitignore: async () => {
681
- const r = await ensureGitignore(projectRoot);
682
- return {
683
- check: 'cleo_gitignore',
684
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
685
- message: r.details ?? r.action,
686
- };
687
- },
688
- config_file: async () => {
689
- const r = await ensureConfig(projectRoot);
690
- return {
691
- check: 'config_file',
692
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
693
- message: r.details ?? r.action,
694
- };
695
- },
696
- cleo_project_info: async () => {
697
- const r = await ensureProjectInfo(projectRoot, { force: true });
698
- return {
699
- check: 'cleo_project_info',
700
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
701
- message: r.details ?? r.action,
702
- };
703
- },
704
- cleo_project_context: async () => {
705
- const r = await ensureProjectContext(projectRoot, { force: true });
706
- return {
707
- check: 'cleo_project_context',
708
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
709
- message: r.details ?? r.action,
710
- };
711
- },
712
- cleo_git_repo: async () => {
713
- const r = await ensureCleoGitRepo(projectRoot);
714
- return {
715
- check: 'cleo_git_repo',
716
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
717
- message: r.details ?? r.action,
718
- };
719
- },
720
- contributor_channel: async () => {
721
- const { ensureContributorMcp } = await import('../scaffold.js');
722
- const r = await ensureContributorMcp(projectRoot);
723
- return {
724
- check: 'contributor_channel',
725
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
726
- message: r.details ?? r.action,
727
- };
728
- },
729
- git_hooks: async () => {
730
- const r = await ensureGitHooks(projectRoot, { force: true });
731
- return {
732
- check: 'git_hooks',
733
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
734
- message: r.details ?? r.action,
735
- };
736
- },
737
- global_schemas: async () => {
738
- const r = ensureGlobalSchemas();
739
- const msg = `Installed ${r.installed}, updated ${r.updated} of ${r.total} schemas`;
740
- return {
741
- check: 'global_schemas',
742
- action: r.installed + r.updated > 0 ? 'fixed' : 'skipped',
743
- message: msg,
744
- };
745
- },
746
- injection_health: async () => {
747
- const r = await ensureInjection(projectRoot);
748
- return {
749
- check: 'injection_health',
750
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
751
- message: r.details ?? r.action,
752
- };
753
- },
754
- cleo_structure: async () => {
755
- const r = await ensureCleoStructure(projectRoot);
756
- return {
757
- check: 'cleo_structure',
758
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
759
- message: r.details ?? r.action,
760
- };
761
- },
762
- global_home: async () => {
763
- const r = await ensureGlobalHome();
764
- return {
765
- check: 'global_home',
766
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
767
- message: r.details ?? r.action,
768
- };
769
- },
770
- global_templates: async () => {
771
- const r = await ensureGlobalTemplates();
772
- return {
773
- check: 'global_templates',
774
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
775
- message: r.details ?? r.action,
776
- };
777
- },
778
- log_dir: async () => {
779
- // Log dir is part of REQUIRED_CLEO_SUBDIRS, so ensureCleoStructure fixes it
780
- const r = await ensureCleoStructure(projectRoot);
781
- return {
782
- check: 'log_dir',
783
- action: r.action === 'skipped' ? 'skipped' : 'fixed',
784
- message: r.details ?? r.action,
785
- };
786
- },
787
- };
788
- for (const check of failedChecks) {
789
- const fixer = fixMap[check.check];
790
- if (!fixer)
791
- continue;
792
- try {
793
- const result = await fixer();
794
- results.push(result);
795
- }
796
- catch (err) {
797
- results.push({
798
- check: check.check,
799
- action: 'failed',
800
- message: err instanceof Error ? err.message : String(err),
801
- });
802
- }
803
- }
804
- return results;
805
- }
806
- /**
807
- * Unified startup health check for MCP server and CLI entry points.
808
- *
809
- * This is the single entry point for startup diagnostics. It follows a
810
- * three-phase approach:
811
- *
812
- * Phase 1: Global scaffold (~/.cleo/) — always auto-repaired.
813
- * The global home is CLEO infrastructure, not project data. It is safe
814
- * to create/repair unconditionally on every startup.
815
- *
816
- * Phase 2: Project detection — determines if this is an initialized project.
817
- * Uses isProjectInitialized() from paths.ts as the SSoT for detection.
818
- *
819
- * Phase 3: Project health — lightweight checks on the project scaffold.
820
- * If the project is initialized, runs check* functions to detect drift.
821
- * Auto-repairs safe items (missing subdirs via ensureCleoStructure).
822
- * Flags items requiring full upgrade (missing DB, config issues).
823
- *
824
- * Design principles:
825
- * - SSoT: All checks delegate to scaffold.ts check* functions
826
- * - DRY: No duplicated health-check logic
827
- * - SRP: This function only diagnoses and does safe auto-repair
828
- * - Graceful: Never throws. All errors are captured as check results.
829
- * - Logged: Returns structured results for the caller to log via pino
830
- *
831
- * @param projectRoot - Absolute path to the project root (defaults to cwd)
832
- */
833
- export async function startupHealthCheck(projectRoot) {
834
- const root = projectRoot ?? process.cwd();
835
- const system = getSystemInfo();
836
- const checks = [];
837
- const failures = [];
838
- let globalHealthy = true;
839
- let projectHealthy = true;
840
- // ── Phase 1: Global scaffold (~/.cleo/) ──────────────────────────
841
- // Always auto-repair. This is infrastructure, not project data.
842
- try {
843
- // Check current state first (read-only)
844
- const globalHomeCheck = checkGlobalHome();
845
- const globalTemplateCheck = checkGlobalTemplates();
846
- const globalSchemaCheck = checkGlobalSchemas();
847
- const globalNeedsRepair = globalHomeCheck.status !== 'passed' ||
848
- globalTemplateCheck.status !== 'passed' ||
849
- !globalSchemaCheck.ok;
850
- if (globalNeedsRepair) {
851
- // Auto-repair home and templates via ensureGlobalScaffold (idempotent, safe)
852
- const scaffoldResult = await ensureGlobalScaffold();
853
- checks.push({
854
- check: 'global_home',
855
- status: 'pass',
856
- message: scaffoldResult.home.action === 'skipped'
857
- ? 'Global home already current'
858
- : `Global home ${scaffoldResult.home.action}: ${scaffoldResult.home.details ?? ''}`,
859
- repaired: scaffoldResult.home.action !== 'skipped',
860
- });
861
- // Schemas are read at runtime from the package path; only copy if stale
862
- if (!globalSchemaCheck.ok) {
863
- const { ensureGlobalSchemas } = await import('../schema-management.js');
864
- const schemaResult = ensureGlobalSchemas();
865
- checks.push({
866
- check: 'global_schemas',
867
- status: 'pass',
868
- message: `Schemas: ${schemaResult.installed} installed, ${schemaResult.updated} updated of ${schemaResult.total}`,
869
- repaired: schemaResult.installed > 0 || schemaResult.updated > 0,
870
- });
871
- }
872
- else {
873
- checks.push({
874
- check: 'global_schemas',
875
- status: 'pass',
876
- message: `All ${globalSchemaCheck.installed} schemas current`,
877
- });
878
- }
879
- checks.push({
880
- check: 'global_templates',
881
- status: 'pass',
882
- message: scaffoldResult.templates.action === 'skipped'
883
- ? 'Templates already current'
884
- : `Templates ${scaffoldResult.templates.action}: ${scaffoldResult.templates.details ?? ''}`,
885
- repaired: scaffoldResult.templates.action !== 'skipped',
886
- });
887
- }
888
- else {
889
- checks.push({ check: 'global_home', status: 'pass', message: 'Global home healthy' }, {
890
- check: 'global_schemas',
891
- status: 'pass',
892
- message: `All ${globalSchemaCheck.installed} schemas current`,
893
- }, { check: 'global_templates', status: 'pass', message: 'Templates present' });
894
- }
895
- }
896
- catch (err) {
897
- // Global scaffold failure is non-fatal but degrades the system
898
- globalHealthy = false;
899
- const msg = err instanceof Error ? err.message : String(err);
900
- const failCheck = {
901
- check: 'global_scaffold',
902
- status: 'fail',
903
- message: `Global scaffold repair failed: ${msg}`,
904
- };
905
- checks.push(failCheck);
906
- failures.push(failCheck);
907
- }
908
- // ── Phase 2: Project detection ───────────────────────────────────
909
- if (!isProjectInitialized(root)) {
910
- checks.push({
911
- check: 'project_initialized',
912
- status: 'fail',
913
- message: 'Project not initialized (.cleo/ or tasks.db missing)',
914
- });
915
- return {
916
- state: 'needs_init',
917
- globalHealthy,
918
- projectHealthy: false,
919
- checks,
920
- failures,
921
- system,
922
- };
923
- }
924
- checks.push({
925
- check: 'project_initialized',
926
- status: 'pass',
927
- message: 'Project initialized',
928
- });
929
- // ── Phase 3: Lightweight project health checks ───────────────────
930
- // Run read-only check* functions to detect drift. Only auto-repair
931
- // safe structural items (missing subdirs). Flag everything else.
932
- const structureCheck = checkCleoStructure(root);
933
- const configCheck = checkConfig(root);
934
- const dbCheck = checkSqliteDb(root);
935
- const logDirCheck = checkLogDir(root);
936
- // Structure: auto-repairable (missing subdirs are safe to create)
937
- if (structureCheck.status !== 'passed') {
938
- try {
939
- await ensureCleoStructure(root);
940
- checks.push({
941
- check: 'cleo_structure',
942
- status: 'pass',
943
- message: 'Structure repaired: missing subdirectories created',
944
- repaired: true,
945
- });
946
- }
947
- catch (err) {
948
- projectHealthy = false;
949
- const msg = err instanceof Error ? err.message : String(err);
950
- const failCheck = {
951
- check: 'cleo_structure',
952
- status: 'fail',
953
- message: `Structure repair failed: ${msg}`,
954
- };
955
- checks.push(failCheck);
956
- failures.push(failCheck);
957
- }
958
- }
959
- else {
960
- checks.push({ check: 'cleo_structure', status: 'pass', message: 'Structure healthy' });
961
- }
962
- // Config: NOT auto-repairable on startup (requires explicit init/upgrade)
963
- if (configCheck.status === 'failed') {
964
- projectHealthy = false;
965
- const failCheck = {
966
- check: 'config',
967
- status: 'fail',
968
- message: configCheck.message,
969
- };
970
- checks.push(failCheck);
971
- failures.push(failCheck);
972
- }
973
- else {
974
- checks.push({
975
- check: 'config',
976
- status: configCheck.status === 'warning' ? 'warn' : 'pass',
977
- message: configCheck.message,
978
- });
979
- }
980
- // SQLite DB: NOT auto-repairable on startup
981
- if (dbCheck.status === 'failed') {
982
- projectHealthy = false;
983
- const failCheck = {
984
- check: 'sqlite_db',
985
- status: 'fail',
986
- message: dbCheck.message,
987
- };
988
- checks.push(failCheck);
989
- failures.push(failCheck);
990
- }
991
- else {
992
- checks.push({
993
- check: 'sqlite_db',
994
- status: dbCheck.status === 'warning' ? 'warn' : 'pass',
995
- message: dbCheck.message,
996
- });
997
- }
998
- // Log directory: auto-repairable (part of ensureCleoStructure above,
999
- // but verify explicitly since it was just added to REQUIRED_CLEO_SUBDIRS)
1000
- if (logDirCheck.status !== 'passed') {
1001
- // ensureCleoStructure above should have created it, but check again
1002
- checks.push({
1003
- check: 'log_dir',
1004
- status: 'warn',
1005
- message: logDirCheck.message,
1006
- });
1007
- }
1008
- else {
1009
- checks.push({ check: 'log_dir', status: 'pass', message: 'Log directory present' });
1010
- }
1011
- // Brain.db: warning-level check (not a startup failure)
1012
- const brainDbCheck = checkBrainDb(root);
1013
- checks.push({
1014
- check: 'brain_db',
1015
- status: brainDbCheck.status === 'passed' ? 'pass' : 'warn',
1016
- message: brainDbCheck.message,
1017
- });
1018
- // Memory bridge: info-level check
1019
- const memBridgeCheck = checkMemoryBridge(root);
1020
- checks.push({
1021
- check: 'memory_bridge',
1022
- status: memBridgeCheck.status === 'passed' ? 'pass' : 'warn',
1023
- message: memBridgeCheck.message,
1024
- });
1025
- // NEXUS auto-registration (best-effort, never blocks startup)
1026
- try {
1027
- const { nexusReconcile } = await import('../nexus/registry.js');
1028
- await nexusReconcile(root);
1029
- checks.push({
1030
- check: 'nexus_registration',
1031
- status: 'pass',
1032
- message: 'NEXUS registry reconciled',
1033
- });
1034
- }
1035
- catch {
1036
- checks.push({
1037
- check: 'nexus_registration',
1038
- status: 'warn',
1039
- message: 'NEXUS reconciliation skipped (non-fatal)',
1040
- });
1041
- }
1042
- // Determine overall state
1043
- const hasFailures = failures.length > 0;
1044
- const state = hasFailures && !projectHealthy ? 'needs_upgrade' : 'healthy';
1045
- return {
1046
- state,
1047
- globalHealthy,
1048
- projectHealthy,
1049
- checks,
1050
- failures,
1051
- system,
1052
- };
1053
- }
1054
- //# sourceMappingURL=health.js.map