@cleocode/core 2026.4.13 → 2026.4.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +69233 -175
- package/dist/index.js.map +7 -1
- package/dist/init.d.ts.map +1 -1
- package/dist/internal.d.ts +16 -5
- package/dist/internal.d.ts.map +1 -1
- package/dist/memory/brain-embedding.d.ts +1 -1
- package/dist/memory/embedding-local.d.ts +8 -3
- package/dist/memory/embedding-local.d.ts.map +1 -1
- package/dist/memory/embedding-worker.d.ts +1 -1
- package/dist/memory/learnings.d.ts +2 -2
- package/dist/memory/patterns.d.ts +6 -6
- package/dist/store/agent-registry-accessor.d.ts +54 -1
- package/dist/store/agent-registry-accessor.d.ts.map +1 -1
- package/dist/store/backup-crypto.d.ts +89 -0
- package/dist/store/backup-crypto.d.ts.map +1 -0
- package/dist/store/backup-pack.d.ts +91 -0
- package/dist/store/backup-pack.d.ts.map +1 -0
- package/dist/store/backup-unpack.d.ts +140 -0
- package/dist/store/backup-unpack.d.ts.map +1 -0
- package/dist/store/migrate-signaldock-to-conduit.d.ts.map +1 -1
- package/dist/store/regenerators.d.ts +126 -0
- package/dist/store/regenerators.d.ts.map +1 -0
- package/dist/store/restore-conflict-report.d.ts +118 -0
- package/dist/store/restore-conflict-report.d.ts.map +1 -0
- package/dist/store/restore-json-merge.d.ts +187 -0
- package/dist/store/restore-json-merge.d.ts.map +1 -0
- package/dist/store/sqlite-backup.d.ts +60 -5
- package/dist/store/sqlite-backup.d.ts.map +1 -1
- package/dist/store/t310-readiness.d.ts +83 -0
- package/dist/store/t310-readiness.d.ts.map +1 -0
- package/package.json +9 -9
- package/src/__tests__/cli-parity.test.ts +19 -14
- package/src/__tests__/human-output.test.ts +13 -11
- package/src/init.ts +18 -8
- package/src/internal.ts +4 -1
- package/src/memory/__tests__/brain-automation.test.ts +2 -2
- package/src/memory/brain-embedding.ts +1 -1
- package/src/memory/embedding-local.ts +10 -5
- package/src/memory/embedding-worker.ts +1 -1
- package/src/skills/__tests__/discovery.test.ts +22 -7
- package/src/store/__tests__/performance-safety.test.ts +11 -5
- package/src/store/migrate-signaldock-to-conduit.ts +14 -7
- package/src/validation/protocols/_shared.ts +1 -1
- package/dist/adapters/adapter-registry.js +0 -64
- package/dist/adapters/adapter-registry.js.map +0 -1
- package/dist/adapters/discovery.js +0 -83
- package/dist/adapters/discovery.js.map +0 -1
- package/dist/adapters/index.js +0 -9
- package/dist/adapters/index.js.map +0 -1
- package/dist/adapters/manager.js +0 -260
- package/dist/adapters/manager.js.map +0 -1
- package/dist/admin/export-tasks.js +0 -171
- package/dist/admin/export-tasks.js.map +0 -1
- package/dist/admin/export.js +0 -103
- package/dist/admin/export.js.map +0 -1
- package/dist/admin/help.js +0 -106
- package/dist/admin/help.js.map +0 -1
- package/dist/admin/import-tasks.js +0 -182
- package/dist/admin/import-tasks.js.map +0 -1
- package/dist/admin/import.js +0 -129
- package/dist/admin/import.js.map +0 -1
- package/dist/admin/index.js +0 -13
- package/dist/admin/index.js.map +0 -1
- package/dist/adrs/find.js +0 -134
- package/dist/adrs/find.js.map +0 -1
- package/dist/adrs/index.js +0 -15
- package/dist/adrs/index.js.map +0 -1
- package/dist/adrs/link-pipeline.js +0 -160
- package/dist/adrs/link-pipeline.js.map +0 -1
- package/dist/adrs/list.js +0 -43
- package/dist/adrs/list.js.map +0 -1
- package/dist/adrs/parse.js +0 -51
- package/dist/adrs/parse.js.map +0 -1
- package/dist/adrs/show.js +0 -22
- package/dist/adrs/show.js.map +0 -1
- package/dist/adrs/sync.js +0 -188
- package/dist/adrs/sync.js.map +0 -1
- package/dist/adrs/types.js +0 -9
- package/dist/adrs/types.js.map +0 -1
- package/dist/adrs/validate.js +0 -57
- package/dist/adrs/validate.js.map +0 -1
- package/dist/agents/agent-registry.js +0 -288
- package/dist/agents/agent-registry.js.map +0 -1
- package/dist/agents/agent-schema.js +0 -82
- package/dist/agents/agent-schema.js.map +0 -1
- package/dist/agents/capacity.js +0 -116
- package/dist/agents/capacity.js.map +0 -1
- package/dist/agents/execution-learning.js +0 -474
- package/dist/agents/execution-learning.js.map +0 -1
- package/dist/agents/health-monitor.js +0 -217
- package/dist/agents/health-monitor.js.map +0 -1
- package/dist/agents/index.js +0 -29
- package/dist/agents/index.js.map +0 -1
- package/dist/agents/registry.js +0 -314
- package/dist/agents/registry.js.map +0 -1
- package/dist/agents/retry.js +0 -215
- package/dist/agents/retry.js.map +0 -1
- package/dist/audit-prune.js +0 -94
- package/dist/audit-prune.js.map +0 -1
- package/dist/audit.js +0 -68
- package/dist/audit.js.map +0 -1
- package/dist/backfill/index.js +0 -229
- package/dist/backfill/index.js.map +0 -1
- package/dist/bootstrap.js +0 -344
- package/dist/bootstrap.js.map +0 -1
- package/dist/caamp/adapter.js +0 -259
- package/dist/caamp/adapter.js.map +0 -1
- package/dist/caamp/capability-check.js +0 -38
- package/dist/caamp/capability-check.js.map +0 -1
- package/dist/caamp/index.js +0 -21
- package/dist/caamp/index.js.map +0 -1
- package/dist/caamp-init.js +0 -16
- package/dist/caamp-init.js.map +0 -1
- package/dist/cleo.js +0 -322
- package/dist/cleo.js.map +0 -1
- package/dist/code/index.js +0 -10
- package/dist/code/index.js.map +0 -1
- package/dist/code/outline.js +0 -165
- package/dist/code/outline.js.map +0 -1
- package/dist/code/parser.js +0 -295
- package/dist/code/parser.js.map +0 -1
- package/dist/code/search.js +0 -135
- package/dist/code/search.js.map +0 -1
- package/dist/code/unfold.js +0 -155
- package/dist/code/unfold.js.map +0 -1
- package/dist/codebase-map/analyzers/architecture.js +0 -129
- package/dist/codebase-map/analyzers/architecture.js.map +0 -1
- package/dist/codebase-map/analyzers/concerns.js +0 -122
- package/dist/codebase-map/analyzers/concerns.js.map +0 -1
- package/dist/codebase-map/analyzers/conventions.js +0 -149
- package/dist/codebase-map/analyzers/conventions.js.map +0 -1
- package/dist/codebase-map/analyzers/integrations.js +0 -108
- package/dist/codebase-map/analyzers/integrations.js.map +0 -1
- package/dist/codebase-map/analyzers/stack.js +0 -117
- package/dist/codebase-map/analyzers/stack.js.map +0 -1
- package/dist/codebase-map/analyzers/structure.js +0 -137
- package/dist/codebase-map/analyzers/structure.js.map +0 -1
- package/dist/codebase-map/analyzers/testing.js +0 -118
- package/dist/codebase-map/analyzers/testing.js.map +0 -1
- package/dist/codebase-map/index.js +0 -57
- package/dist/codebase-map/index.js.map +0 -1
- package/dist/codebase-map/store.js +0 -122
- package/dist/codebase-map/store.js.map +0 -1
- package/dist/codebase-map/summary.js +0 -152
- package/dist/codebase-map/summary.js.map +0 -1
- package/dist/compliance/index.js +0 -288
- package/dist/compliance/index.js.map +0 -1
- package/dist/compliance/protocol-enforcement.js +0 -332
- package/dist/compliance/protocol-enforcement.js.map +0 -1
- package/dist/compliance/protocol-rules.js +0 -786
- package/dist/compliance/protocol-rules.js.map +0 -1
- package/dist/compliance/protocol-types.js +0 -79
- package/dist/compliance/protocol-types.js.map +0 -1
- package/dist/compliance/store.js +0 -53
- package/dist/compliance/store.js.map +0 -1
- package/dist/conduit/conduit-client.js +0 -107
- package/dist/conduit/conduit-client.js.map +0 -1
- package/dist/conduit/factory.js +0 -52
- package/dist/conduit/factory.js.map +0 -1
- package/dist/conduit/http-transport.js +0 -155
- package/dist/conduit/http-transport.js.map +0 -1
- package/dist/conduit/index.js +0 -15
- package/dist/conduit/index.js.map +0 -1
- package/dist/conduit/local-transport.js +0 -255
- package/dist/conduit/local-transport.js.map +0 -1
- package/dist/conduit/sse-transport.js +0 -299
- package/dist/conduit/sse-transport.js.map +0 -1
- package/dist/config/build-config.js +0 -29
- package/dist/config/build-config.js.map +0 -1
- package/dist/config.js +0 -400
- package/dist/config.js.map +0 -1
- package/dist/constants.js +0 -18
- package/dist/constants.js.map +0 -1
- package/dist/context/index.js +0 -137
- package/dist/context/index.js.map +0 -1
- package/dist/crypto/credentials.js +0 -191
- package/dist/crypto/credentials.js.map +0 -1
- package/dist/discovery.js +0 -182
- package/dist/discovery.js.map +0 -1
- package/dist/engine-result.js +0 -12
- package/dist/engine-result.js.map +0 -1
- package/dist/error-catalog.js +0 -404
- package/dist/error-catalog.js.map +0 -1
- package/dist/error-registry.js +0 -393
- package/dist/error-registry.js.map +0 -1
- package/dist/errors.js +0 -173
- package/dist/errors.js.map +0 -1
- package/dist/hooks/handlers/agent-hooks.js +0 -106
- package/dist/hooks/handlers/agent-hooks.js.map +0 -1
- package/dist/hooks/handlers/context-hooks.js +0 -111
- package/dist/hooks/handlers/context-hooks.js.map +0 -1
- package/dist/hooks/handlers/error-hooks.js +0 -52
- package/dist/hooks/handlers/error-hooks.js.map +0 -1
- package/dist/hooks/handlers/file-hooks.js +0 -104
- package/dist/hooks/handlers/file-hooks.js.map +0 -1
- package/dist/hooks/handlers/handler-helpers.js +0 -61
- package/dist/hooks/handlers/handler-helpers.js.map +0 -1
- package/dist/hooks/handlers/index.js +0 -28
- package/dist/hooks/handlers/index.js.map +0 -1
- package/dist/hooks/handlers/memory-bridge-refresh.js +0 -42
- package/dist/hooks/handlers/memory-bridge-refresh.js.map +0 -1
- package/dist/hooks/handlers/notification-hooks.js +0 -62
- package/dist/hooks/handlers/notification-hooks.js.map +0 -1
- package/dist/hooks/handlers/session-hooks.js +0 -142
- package/dist/hooks/handlers/session-hooks.js.map +0 -1
- package/dist/hooks/handlers/task-hooks.js +0 -65
- package/dist/hooks/handlers/task-hooks.js.map +0 -1
- package/dist/hooks/handlers/work-capture-hooks.js +0 -165
- package/dist/hooks/handlers/work-capture-hooks.js.map +0 -1
- package/dist/hooks/index.js +0 -13
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/payload-schemas.js +0 -220
- package/dist/hooks/payload-schemas.js.map +0 -1
- package/dist/hooks/provider-hooks.js +0 -66
- package/dist/hooks/provider-hooks.js.map +0 -1
- package/dist/hooks/registry.js +0 -229
- package/dist/hooks/registry.js.map +0 -1
- package/dist/hooks/types.js +0 -66
- package/dist/hooks/types.js.map +0 -1
- package/dist/hooks.js +0 -136
- package/dist/hooks.js.map +0 -1
- package/dist/init.js +0 -851
- package/dist/init.js.map +0 -1
- package/dist/inject/index.js +0 -82
- package/dist/inject/index.js.map +0 -1
- package/dist/injection.js +0 -343
- package/dist/injection.js.map +0 -1
- package/dist/intelligence/adaptive-validation.js +0 -497
- package/dist/intelligence/adaptive-validation.js.map +0 -1
- package/dist/intelligence/impact.js +0 -675
- package/dist/intelligence/impact.js.map +0 -1
- package/dist/intelligence/index.js +0 -22
- package/dist/intelligence/index.js.map +0 -1
- package/dist/intelligence/patterns.js +0 -492
- package/dist/intelligence/patterns.js.map +0 -1
- package/dist/intelligence/prediction.js +0 -499
- package/dist/intelligence/prediction.js.map +0 -1
- package/dist/intelligence/types.js +0 -13
- package/dist/intelligence/types.js.map +0 -1
- package/dist/internal.js +0 -306
- package/dist/internal.js.map +0 -1
- package/dist/issue/create.js +0 -121
- package/dist/issue/create.js.map +0 -1
- package/dist/issue/diagnostics.js +0 -59
- package/dist/issue/diagnostics.js.map +0 -1
- package/dist/issue/index.js +0 -10
- package/dist/issue/index.js.map +0 -1
- package/dist/issue/template-parser.js +0 -267
- package/dist/issue/template-parser.js.map +0 -1
- package/dist/json-schema-validator.js +0 -76
- package/dist/json-schema-validator.js.map +0 -1
- package/dist/lib/index.js +0 -11
- package/dist/lib/index.js.map +0 -1
- package/dist/lib/retry.js +0 -152
- package/dist/lib/retry.js.map +0 -1
- package/dist/lib/tree-sitter-languages.js +0 -71
- package/dist/lib/tree-sitter-languages.js.map +0 -1
- package/dist/lifecycle/chain-composition.js +0 -152
- package/dist/lifecycle/chain-composition.js.map +0 -1
- package/dist/lifecycle/chain-store.js +0 -246
- package/dist/lifecycle/chain-store.js.map +0 -1
- package/dist/lifecycle/consolidate-rcasd.js +0 -352
- package/dist/lifecycle/consolidate-rcasd.js.map +0 -1
- package/dist/lifecycle/default-chain.js +0 -176
- package/dist/lifecycle/default-chain.js.map +0 -1
- package/dist/lifecycle/evidence.js +0 -180
- package/dist/lifecycle/evidence.js.map +0 -1
- package/dist/lifecycle/frontmatter.js +0 -363
- package/dist/lifecycle/frontmatter.js.map +0 -1
- package/dist/lifecycle/index.js +0 -756
- package/dist/lifecycle/index.js.map +0 -1
- package/dist/lifecycle/pipeline.js +0 -656
- package/dist/lifecycle/pipeline.js.map +0 -1
- package/dist/lifecycle/rcasd-index.js +0 -326
- package/dist/lifecycle/rcasd-index.js.map +0 -1
- package/dist/lifecycle/rcasd-paths.js +0 -220
- package/dist/lifecycle/rcasd-paths.js.map +0 -1
- package/dist/lifecycle/resume.js +0 -864
- package/dist/lifecycle/resume.js.map +0 -1
- package/dist/lifecycle/stage-artifacts.js +0 -94
- package/dist/lifecycle/stage-artifacts.js.map +0 -1
- package/dist/lifecycle/stage-guidance.js +0 -234
- package/dist/lifecycle/stage-guidance.js.map +0 -1
- package/dist/lifecycle/stages.js +0 -534
- package/dist/lifecycle/stages.js.map +0 -1
- package/dist/lifecycle/state-machine.js +0 -516
- package/dist/lifecycle/state-machine.js.map +0 -1
- package/dist/lifecycle/tessera-engine.js +0 -249
- package/dist/lifecycle/tessera-engine.js.map +0 -1
- package/dist/logger.js +0 -140
- package/dist/logger.js.map +0 -1
- package/dist/memory/auto-extract.js +0 -177
- package/dist/memory/auto-extract.js.map +0 -1
- package/dist/memory/brain-embedding.js +0 -66
- package/dist/memory/brain-embedding.js.map +0 -1
- package/dist/memory/brain-lifecycle.js +0 -298
- package/dist/memory/brain-lifecycle.js.map +0 -1
- package/dist/memory/brain-links.js +0 -161
- package/dist/memory/brain-links.js.map +0 -1
- package/dist/memory/brain-maintenance.js +0 -114
- package/dist/memory/brain-maintenance.js.map +0 -1
- package/dist/memory/brain-migration.js +0 -149
- package/dist/memory/brain-migration.js.map +0 -1
- package/dist/memory/brain-reasoning.js +0 -215
- package/dist/memory/brain-reasoning.js.map +0 -1
- package/dist/memory/brain-retrieval.js +0 -542
- package/dist/memory/brain-retrieval.js.map +0 -1
- package/dist/memory/brain-row-types.js +0 -10
- package/dist/memory/brain-row-types.js.map +0 -1
- package/dist/memory/brain-search.js +0 -519
- package/dist/memory/brain-search.js.map +0 -1
- package/dist/memory/brain-similarity.js +0 -145
- package/dist/memory/brain-similarity.js.map +0 -1
- package/dist/memory/claude-mem-migration.js +0 -277
- package/dist/memory/claude-mem-migration.js.map +0 -1
- package/dist/memory/decisions.js +0 -162
- package/dist/memory/decisions.js.map +0 -1
- package/dist/memory/embedding-local.js +0 -97
- package/dist/memory/embedding-local.js.map +0 -1
- package/dist/memory/embedding-queue.js +0 -271
- package/dist/memory/embedding-queue.js.map +0 -1
- package/dist/memory/embedding-worker.js +0 -58
- package/dist/memory/embedding-worker.js.map +0 -1
- package/dist/memory/engine-compat.js +0 -1397
- package/dist/memory/engine-compat.js.map +0 -1
- package/dist/memory/index.js +0 -1140
- package/dist/memory/index.js.map +0 -1
- package/dist/memory/learnings.js +0 -121
- package/dist/memory/learnings.js.map +0 -1
- package/dist/memory/memory-bridge.js +0 -370
- package/dist/memory/memory-bridge.js.map +0 -1
- package/dist/memory/patterns.js +0 -122
- package/dist/memory/patterns.js.map +0 -1
- package/dist/memory/pipeline-manifest-sqlite.js +0 -975
- package/dist/memory/pipeline-manifest-sqlite.js.map +0 -1
- package/dist/memory/session-memory.js +0 -331
- package/dist/memory/session-memory.js.map +0 -1
- package/dist/metrics/ab-test.js +0 -260
- package/dist/metrics/ab-test.js.map +0 -1
- package/dist/metrics/aggregation.js +0 -363
- package/dist/metrics/aggregation.js.map +0 -1
- package/dist/metrics/common.js +0 -64
- package/dist/metrics/common.js.map +0 -1
- package/dist/metrics/enums.js +0 -78
- package/dist/metrics/enums.js.map +0 -1
- package/dist/metrics/index.js +0 -19
- package/dist/metrics/index.js.map +0 -1
- package/dist/metrics/model-provider-registry.js +0 -88
- package/dist/metrics/model-provider-registry.js.map +0 -1
- package/dist/metrics/otel-integration.js +0 -263
- package/dist/metrics/otel-integration.js.map +0 -1
- package/dist/metrics/provider-detection.js +0 -103
- package/dist/metrics/provider-detection.js.map +0 -1
- package/dist/metrics/token-estimation.js +0 -253
- package/dist/metrics/token-estimation.js.map +0 -1
- package/dist/metrics/token-service.js +0 -450
- package/dist/metrics/token-service.js.map +0 -1
- package/dist/migration/agent-outputs.js +0 -316
- package/dist/migration/agent-outputs.js.map +0 -1
- package/dist/migration/checksum.js +0 -92
- package/dist/migration/checksum.js.map +0 -1
- package/dist/migration/index.js +0 -282
- package/dist/migration/index.js.map +0 -1
- package/dist/migration/logger.js +0 -360
- package/dist/migration/logger.js.map +0 -1
- package/dist/migration/preflight.js +0 -9
- package/dist/migration/preflight.js.map +0 -1
- package/dist/migration/state.js +0 -421
- package/dist/migration/state.js.map +0 -1
- package/dist/migration/validate.js +0 -241
- package/dist/migration/validate.js.map +0 -1
- package/dist/mvi-helpers.js +0 -74
- package/dist/mvi-helpers.js.map +0 -1
- package/dist/nexus/deps.js +0 -375
- package/dist/nexus/deps.js.map +0 -1
- package/dist/nexus/discover.js +0 -288
- package/dist/nexus/discover.js.map +0 -1
- package/dist/nexus/hash.js +0 -10
- package/dist/nexus/hash.js.map +0 -1
- package/dist/nexus/index.js +0 -40
- package/dist/nexus/index.js.map +0 -1
- package/dist/nexus/migrate-json-to-sqlite.js +0 -115
- package/dist/nexus/migrate-json-to-sqlite.js.map +0 -1
- package/dist/nexus/permissions.js +0 -105
- package/dist/nexus/permissions.js.map +0 -1
- package/dist/nexus/query.js +0 -175
- package/dist/nexus/query.js.map +0 -1
- package/dist/nexus/registry.js +0 -584
- package/dist/nexus/registry.js.map +0 -1
- package/dist/nexus/sharing/index.js +0 -288
- package/dist/nexus/sharing/index.js.map +0 -1
- package/dist/nexus/transfer-types.js +0 -8
- package/dist/nexus/transfer-types.js.map +0 -1
- package/dist/nexus/transfer.js +0 -263
- package/dist/nexus/transfer.js.map +0 -1
- package/dist/nexus/workspace.js +0 -355
- package/dist/nexus/workspace.js.map +0 -1
- package/dist/observability/index.js +0 -103
- package/dist/observability/index.js.map +0 -1
- package/dist/observability/log-filter.js +0 -63
- package/dist/observability/log-filter.js.map +0 -1
- package/dist/observability/log-parser.js +0 -99
- package/dist/observability/log-parser.js.map +0 -1
- package/dist/observability/log-reader.js +0 -139
- package/dist/observability/log-reader.js.map +0 -1
- package/dist/observability/types.js +0 -19
- package/dist/observability/types.js.map +0 -1
- package/dist/orchestration/analyze.js +0 -107
- package/dist/orchestration/analyze.js.map +0 -1
- package/dist/orchestration/bootstrap.js +0 -132
- package/dist/orchestration/bootstrap.js.map +0 -1
- package/dist/orchestration/context.js +0 -56
- package/dist/orchestration/context.js.map +0 -1
- package/dist/orchestration/critical-path.js +0 -100
- package/dist/orchestration/critical-path.js.map +0 -1
- package/dist/orchestration/hierarchy.js +0 -183
- package/dist/orchestration/hierarchy.js.map +0 -1
- package/dist/orchestration/index.js +0 -287
- package/dist/orchestration/index.js.map +0 -1
- package/dist/orchestration/parallel.js +0 -89
- package/dist/orchestration/parallel.js.map +0 -1
- package/dist/orchestration/protocol-validators.js +0 -815
- package/dist/orchestration/protocol-validators.js.map +0 -1
- package/dist/orchestration/skill-ops.js +0 -98
- package/dist/orchestration/skill-ops.js.map +0 -1
- package/dist/orchestration/status.js +0 -107
- package/dist/orchestration/status.js.map +0 -1
- package/dist/orchestration/unblock.js +0 -103
- package/dist/orchestration/unblock.js.map +0 -1
- package/dist/orchestration/validate-spawn.js +0 -67
- package/dist/orchestration/validate-spawn.js.map +0 -1
- package/dist/orchestration/waves.js +0 -86
- package/dist/orchestration/waves.js.map +0 -1
- package/dist/otel/index.js +0 -163
- package/dist/otel/index.js.map +0 -1
- package/dist/output.js +0 -164
- package/dist/output.js.map +0 -1
- package/dist/pagination.js +0 -64
- package/dist/pagination.js.map +0 -1
- package/dist/paths.js +0 -842
- package/dist/paths.js.map +0 -1
- package/dist/phases/deps.js +0 -372
- package/dist/phases/deps.js.map +0 -1
- package/dist/phases/index.js +0 -349
- package/dist/phases/index.js.map +0 -1
- package/dist/pipeline/index.js +0 -10
- package/dist/pipeline/index.js.map +0 -1
- package/dist/pipeline/phase.js +0 -45
- package/dist/pipeline/phase.js.map +0 -1
- package/dist/platform.js +0 -211
- package/dist/platform.js.map +0 -1
- package/dist/project-info.js +0 -84
- package/dist/project-info.js.map +0 -1
- package/dist/reconciliation/index.js +0 -10
- package/dist/reconciliation/index.js.map +0 -1
- package/dist/reconciliation/link-store.js +0 -129
- package/dist/reconciliation/link-store.js.map +0 -1
- package/dist/reconciliation/reconciliation-engine.js +0 -298
- package/dist/reconciliation/reconciliation-engine.js.map +0 -1
- package/dist/release/artifacts.js +0 -427
- package/dist/release/artifacts.js.map +0 -1
- package/dist/release/changelog-writer.js +0 -151
- package/dist/release/changelog-writer.js.map +0 -1
- package/dist/release/channel.js +0 -144
- package/dist/release/channel.js.map +0 -1
- package/dist/release/ci.js +0 -166
- package/dist/release/ci.js.map +0 -1
- package/dist/release/github-pr.js +0 -225
- package/dist/release/github-pr.js.map +0 -1
- package/dist/release/guards.js +0 -116
- package/dist/release/guards.js.map +0 -1
- package/dist/release/index.js +0 -22
- package/dist/release/index.js.map +0 -1
- package/dist/release/release-config.js +0 -158
- package/dist/release/release-config.js.map +0 -1
- package/dist/release/release-manifest.js +0 -1019
- package/dist/release/release-manifest.js.map +0 -1
- package/dist/release/version-bump.js +0 -255
- package/dist/release/version-bump.js.map +0 -1
- package/dist/remote/index.js +0 -257
- package/dist/remote/index.js.map +0 -1
- package/dist/repair.js +0 -130
- package/dist/repair.js.map +0 -1
- package/dist/research/index.js +0 -2
- package/dist/research/index.js.map +0 -1
- package/dist/roadmap/index.js +0 -59
- package/dist/roadmap/index.js.map +0 -1
- package/dist/routing/capability-matrix.js +0 -1556
- package/dist/routing/capability-matrix.js.map +0 -1
- package/dist/routing/index.js +0 -9
- package/dist/routing/index.js.map +0 -1
- package/dist/scaffold.js +0 -1759
- package/dist/scaffold.js.map +0 -1
- package/dist/schema-management.js +0 -295
- package/dist/schema-management.js.map +0 -1
- package/dist/security/index.js +0 -9
- package/dist/security/index.js.map +0 -1
- package/dist/security/input-sanitization.js +0 -321
- package/dist/security/input-sanitization.js.map +0 -1
- package/dist/sequence/index.js +0 -295
- package/dist/sequence/index.js.map +0 -1
- package/dist/sessions/assumptions.js +0 -54
- package/dist/sessions/assumptions.js.map +0 -1
- package/dist/sessions/briefing.js +0 -377
- package/dist/sessions/briefing.js.map +0 -1
- package/dist/sessions/context-alert.js +0 -222
- package/dist/sessions/context-alert.js.map +0 -1
- package/dist/sessions/context-inject.js +0 -61
- package/dist/sessions/context-inject.js.map +0 -1
- package/dist/sessions/context-monitor.js +0 -98
- package/dist/sessions/context-monitor.js.map +0 -1
- package/dist/sessions/decisions.js +0 -65
- package/dist/sessions/decisions.js.map +0 -1
- package/dist/sessions/find.js +0 -65
- package/dist/sessions/find.js.map +0 -1
- package/dist/sessions/handoff.js +0 -328
- package/dist/sessions/handoff.js.map +0 -1
- package/dist/sessions/hitl-warnings.js +0 -254
- package/dist/sessions/hitl-warnings.js.map +0 -1
- package/dist/sessions/index.js +0 -327
- package/dist/sessions/index.js.map +0 -1
- package/dist/sessions/session-archive.js +0 -40
- package/dist/sessions/session-archive.js.map +0 -1
- package/dist/sessions/session-cleanup.js +0 -59
- package/dist/sessions/session-cleanup.js.map +0 -1
- package/dist/sessions/session-drift.js +0 -134
- package/dist/sessions/session-drift.js.map +0 -1
- package/dist/sessions/session-enforcement.js +0 -144
- package/dist/sessions/session-enforcement.js.map +0 -1
- package/dist/sessions/session-grade.js +0 -253
- package/dist/sessions/session-grade.js.map +0 -1
- package/dist/sessions/session-history.js +0 -42
- package/dist/sessions/session-history.js.map +0 -1
- package/dist/sessions/session-id.js +0 -81
- package/dist/sessions/session-id.js.map +0 -1
- package/dist/sessions/session-memory-bridge.js +0 -52
- package/dist/sessions/session-memory-bridge.js.map +0 -1
- package/dist/sessions/session-show.js +0 -24
- package/dist/sessions/session-show.js.map +0 -1
- package/dist/sessions/session-stats.js +0 -69
- package/dist/sessions/session-stats.js.map +0 -1
- package/dist/sessions/session-suspend.js +0 -39
- package/dist/sessions/session-suspend.js.map +0 -1
- package/dist/sessions/session-switch.js +0 -51
- package/dist/sessions/session-switch.js.map +0 -1
- package/dist/sessions/session-view.js +0 -76
- package/dist/sessions/session-view.js.map +0 -1
- package/dist/sessions/snapshot.js +0 -213
- package/dist/sessions/snapshot.js.map +0 -1
- package/dist/sessions/statusline-setup.js +0 -85
- package/dist/sessions/statusline-setup.js.map +0 -1
- package/dist/sessions/types.js +0 -8
- package/dist/sessions/types.js.map +0 -1
- package/dist/skills/agents/config.js +0 -94
- package/dist/skills/agents/config.js.map +0 -1
- package/dist/skills/agents/install.js +0 -116
- package/dist/skills/agents/install.js.map +0 -1
- package/dist/skills/agents/registry.js +0 -161
- package/dist/skills/agents/registry.js.map +0 -1
- package/dist/skills/discovery.js +0 -333
- package/dist/skills/discovery.js.map +0 -1
- package/dist/skills/dispatch.js +0 -347
- package/dist/skills/dispatch.js.map +0 -1
- package/dist/skills/dynamic-skill-generator.js +0 -87
- package/dist/skills/dynamic-skill-generator.js.map +0 -1
- package/dist/skills/index.js +0 -44
- package/dist/skills/index.js.map +0 -1
- package/dist/skills/injection/subagent.js +0 -195
- package/dist/skills/injection/subagent.js.map +0 -1
- package/dist/skills/injection/token.js +0 -260
- package/dist/skills/injection/token.js.map +0 -1
- package/dist/skills/install.js +0 -40
- package/dist/skills/install.js.map +0 -1
- package/dist/skills/manifests/contribution.js +0 -175
- package/dist/skills/manifests/contribution.js.map +0 -1
- package/dist/skills/manifests/research.js +0 -281
- package/dist/skills/manifests/research.js.map +0 -1
- package/dist/skills/manifests/resolver.js +0 -146
- package/dist/skills/manifests/resolver.js.map +0 -1
- package/dist/skills/marketplace.js +0 -90
- package/dist/skills/marketplace.js.map +0 -1
- package/dist/skills/orchestrator/spawn.js +0 -178
- package/dist/skills/orchestrator/spawn.js.map +0 -1
- package/dist/skills/orchestrator/startup.js +0 -451
- package/dist/skills/orchestrator/startup.js.map +0 -1
- package/dist/skills/orchestrator/validator.js +0 -301
- package/dist/skills/orchestrator/validator.js.map +0 -1
- package/dist/skills/precedence-integration.js +0 -73
- package/dist/skills/precedence-integration.js.map +0 -1
- package/dist/skills/precedence-types.js +0 -16
- package/dist/skills/precedence-types.js.map +0 -1
- package/dist/skills/routing-table.js +0 -63
- package/dist/skills/routing-table.js.map +0 -1
- package/dist/skills/skill-paths.js +0 -217
- package/dist/skills/skill-paths.js.map +0 -1
- package/dist/skills/test-utility.js +0 -55
- package/dist/skills/test-utility.js.map +0 -1
- package/dist/skills/types.js +0 -118
- package/dist/skills/types.js.map +0 -1
- package/dist/skills/validation.js +0 -183
- package/dist/skills/validation.js.map +0 -1
- package/dist/skills/version.js +0 -57
- package/dist/skills/version.js.map +0 -1
- package/dist/snapshot/index.js +0 -188
- package/dist/snapshot/index.js.map +0 -1
- package/dist/spawn/adapter-registry.js +0 -246
- package/dist/spawn/adapter-registry.js.map +0 -1
- package/dist/spawn/index.js +0 -10
- package/dist/spawn/index.js.map +0 -1
- package/dist/stats/index.js +0 -343
- package/dist/stats/index.js.map +0 -1
- package/dist/stats/workflow-telemetry.js +0 -400
- package/dist/stats/workflow-telemetry.js.map +0 -1
- package/dist/sticky/archive.js +0 -47
- package/dist/sticky/archive.js.map +0 -1
- package/dist/sticky/convert.js +0 -235
- package/dist/sticky/convert.js.map +0 -1
- package/dist/sticky/create.js +0 -48
- package/dist/sticky/create.js.map +0 -1
- package/dist/sticky/id.js +0 -35
- package/dist/sticky/id.js.map +0 -1
- package/dist/sticky/index.js +0 -16
- package/dist/sticky/index.js.map +0 -1
- package/dist/sticky/list.js +0 -44
- package/dist/sticky/list.js.map +0 -1
- package/dist/sticky/purge.js +0 -45
- package/dist/sticky/purge.js.map +0 -1
- package/dist/sticky/show.js +0 -42
- package/dist/sticky/show.js.map +0 -1
- package/dist/sticky/types.js +0 -10
- package/dist/sticky/types.js.map +0 -1
- package/dist/store/agent-registry-accessor.js +0 -783
- package/dist/store/agent-registry-accessor.js.map +0 -1
- package/dist/store/api-key-kdf.js +0 -84
- package/dist/store/api-key-kdf.js.map +0 -1
- package/dist/store/atomic.js +0 -167
- package/dist/store/atomic.js.map +0 -1
- package/dist/store/backup.js +0 -94
- package/dist/store/backup.js.map +0 -1
- package/dist/store/brain-accessor.js +0 -397
- package/dist/store/brain-accessor.js.map +0 -1
- package/dist/store/brain-schema.js +0 -215
- package/dist/store/brain-schema.js.map +0 -1
- package/dist/store/brain-sqlite.js +0 -222
- package/dist/store/brain-sqlite.js.map +0 -1
- package/dist/store/cache.js +0 -168
- package/dist/store/cache.js.map +0 -1
- package/dist/store/chain-schema.js +0 -51
- package/dist/store/chain-schema.js.map +0 -1
- package/dist/store/cleanup-legacy.js +0 -171
- package/dist/store/cleanup-legacy.js.map +0 -1
- package/dist/store/conduit-sqlite.js +0 -570
- package/dist/store/conduit-sqlite.js.map +0 -1
- package/dist/store/converters.js +0 -124
- package/dist/store/converters.js.map +0 -1
- package/dist/store/cross-db-cleanup.js +0 -319
- package/dist/store/cross-db-cleanup.js.map +0 -1
- package/dist/store/data-accessor.js +0 -26
- package/dist/store/data-accessor.js.map +0 -1
- package/dist/store/data-safety-central.js +0 -269
- package/dist/store/data-safety-central.js.map +0 -1
- package/dist/store/data-safety.js +0 -274
- package/dist/store/data-safety.js.map +0 -1
- package/dist/store/db-helpers.js +0 -224
- package/dist/store/db-helpers.js.map +0 -1
- package/dist/store/export.js +0 -155
- package/dist/store/export.js.map +0 -1
- package/dist/store/file-utils.js +0 -270
- package/dist/store/file-utils.js.map +0 -1
- package/dist/store/git-checkpoint.js +0 -365
- package/dist/store/git-checkpoint.js.map +0 -1
- package/dist/store/global-salt.js +0 -147
- package/dist/store/global-salt.js.map +0 -1
- package/dist/store/import-logging.js +0 -139
- package/dist/store/import-logging.js.map +0 -1
- package/dist/store/import-remap.js +0 -145
- package/dist/store/import-remap.js.map +0 -1
- package/dist/store/import-sort.js +0 -121
- package/dist/store/import-sort.js.map +0 -1
- package/dist/store/index.js +0 -29
- package/dist/store/index.js.map +0 -1
- package/dist/store/json.js +0 -208
- package/dist/store/json.js.map +0 -1
- package/dist/store/lifecycle-store.js +0 -249
- package/dist/store/lifecycle-store.js.map +0 -1
- package/dist/store/lock.js +0 -70
- package/dist/store/lock.js.map +0 -1
- package/dist/store/migrate-signaldock-to-conduit.js +0 -555
- package/dist/store/migrate-signaldock-to-conduit.js.map +0 -1
- package/dist/store/migration-manager.js +0 -151
- package/dist/store/migration-manager.js.map +0 -1
- package/dist/store/migration-sqlite.js +0 -676
- package/dist/store/migration-sqlite.js.map +0 -1
- package/dist/store/nexus-schema.js +0 -62
- package/dist/store/nexus-schema.js.map +0 -1
- package/dist/store/nexus-sqlite.js +0 -242
- package/dist/store/nexus-sqlite.js.map +0 -1
- package/dist/store/nexus-validation-schemas.js +0 -40
- package/dist/store/nexus-validation-schemas.js.map +0 -1
- package/dist/store/parsers.js +0 -37
- package/dist/store/parsers.js.map +0 -1
- package/dist/store/project-detect.js +0 -457
- package/dist/store/project-detect.js.map +0 -1
- package/dist/store/provider.js +0 -101
- package/dist/store/provider.js.map +0 -1
- package/dist/store/safety-data-accessor.js +0 -257
- package/dist/store/safety-data-accessor.js.map +0 -1
- package/dist/store/schema.js +0 -7
- package/dist/store/schema.js.map +0 -1
- package/dist/store/session-store.js +0 -219
- package/dist/store/session-store.js.map +0 -1
- package/dist/store/signaldock-sqlite.js +0 -550
- package/dist/store/signaldock-sqlite.js.map +0 -1
- package/dist/store/sqlite-backup.js +0 -359
- package/dist/store/sqlite-backup.js.map +0 -1
- package/dist/store/sqlite-data-accessor.js +0 -787
- package/dist/store/sqlite-data-accessor.js.map +0 -1
- package/dist/store/sqlite.js +0 -481
- package/dist/store/sqlite.js.map +0 -1
- package/dist/store/status-registry.js +0 -8
- package/dist/store/status-registry.js.map +0 -1
- package/dist/store/task-store.js +0 -358
- package/dist/store/task-store.js.map +0 -1
- package/dist/store/tasks-schema.js +0 -610
- package/dist/store/tasks-schema.js.map +0 -1
- package/dist/store/typed-query.js +0 -15
- package/dist/store/typed-query.js.map +0 -1
- package/dist/store/validation-schemas.js +0 -278
- package/dist/store/validation-schemas.js.map +0 -1
- package/dist/system/archive-analytics.js +0 -277
- package/dist/system/archive-analytics.js.map +0 -1
- package/dist/system/archive-stats.js +0 -64
- package/dist/system/archive-stats.js.map +0 -1
- package/dist/system/audit.js +0 -145
- package/dist/system/audit.js.map +0 -1
- package/dist/system/backup.js +0 -280
- package/dist/system/backup.js.map +0 -1
- package/dist/system/cleanup.js +0 -134
- package/dist/system/cleanup.js.map +0 -1
- package/dist/system/health.js +0 -1100
- package/dist/system/health.js.map +0 -1
- package/dist/system/index.js +0 -18
- package/dist/system/index.js.map +0 -1
- package/dist/system/inject-generate.js +0 -122
- package/dist/system/inject-generate.js.map +0 -1
- package/dist/system/labels.js +0 -38
- package/dist/system/labels.js.map +0 -1
- package/dist/system/metrics.js +0 -61
- package/dist/system/metrics.js.map +0 -1
- package/dist/system/migrate.js +0 -43
- package/dist/system/migrate.js.map +0 -1
- package/dist/system/platform-paths.js +0 -80
- package/dist/system/platform-paths.js.map +0 -1
- package/dist/system/runtime.js +0 -161
- package/dist/system/runtime.js.map +0 -1
- package/dist/system/safestop.js +0 -99
- package/dist/system/safestop.js.map +0 -1
- package/dist/system/storage-preflight.js +0 -123
- package/dist/system/storage-preflight.js.map +0 -1
- package/dist/task-work/index.js +0 -159
- package/dist/task-work/index.js.map +0 -1
- package/dist/tasks/add.js +0 -736
- package/dist/tasks/add.js.map +0 -1
- package/dist/tasks/analyze.js +0 -85
- package/dist/tasks/analyze.js.map +0 -1
- package/dist/tasks/archive.js +0 -90
- package/dist/tasks/archive.js.map +0 -1
- package/dist/tasks/atomicity.js +0 -83
- package/dist/tasks/atomicity.js.map +0 -1
- package/dist/tasks/cancel-ops.js +0 -83
- package/dist/tasks/cancel-ops.js.map +0 -1
- package/dist/tasks/complete.js +0 -214
- package/dist/tasks/complete.js.map +0 -1
- package/dist/tasks/crossref-extract.js +0 -73
- package/dist/tasks/crossref-extract.js.map +0 -1
- package/dist/tasks/delete-preview.js +0 -192
- package/dist/tasks/delete-preview.js.map +0 -1
- package/dist/tasks/delete.js +0 -120
- package/dist/tasks/delete.js.map +0 -1
- package/dist/tasks/deletion-strategy.js +0 -200
- package/dist/tasks/deletion-strategy.js.map +0 -1
- package/dist/tasks/dependency-check.js +0 -278
- package/dist/tasks/dependency-check.js.map +0 -1
- package/dist/tasks/deps-ready.js +0 -32
- package/dist/tasks/deps-ready.js.map +0 -1
- package/dist/tasks/enforcement.js +0 -86
- package/dist/tasks/enforcement.js.map +0 -1
- package/dist/tasks/epic-enforcement.js +0 -294
- package/dist/tasks/epic-enforcement.js.map +0 -1
- package/dist/tasks/find.js +0 -157
- package/dist/tasks/find.js.map +0 -1
- package/dist/tasks/graph-cache.js +0 -127
- package/dist/tasks/graph-cache.js.map +0 -1
- package/dist/tasks/graph-ops.js +0 -171
- package/dist/tasks/graph-ops.js.map +0 -1
- package/dist/tasks/graph-rag.js +0 -328
- package/dist/tasks/graph-rag.js.map +0 -1
- package/dist/tasks/hierarchy-policy.js +0 -149
- package/dist/tasks/hierarchy-policy.js.map +0 -1
- package/dist/tasks/hierarchy.js +0 -185
- package/dist/tasks/hierarchy.js.map +0 -1
- package/dist/tasks/id-generator.js +0 -65
- package/dist/tasks/id-generator.js.map +0 -1
- package/dist/tasks/index.js +0 -14
- package/dist/tasks/index.js.map +0 -1
- package/dist/tasks/labels.js +0 -55
- package/dist/tasks/labels.js.map +0 -1
- package/dist/tasks/list.js +0 -75
- package/dist/tasks/list.js.map +0 -1
- package/dist/tasks/phase-tracking.js +0 -133
- package/dist/tasks/phase-tracking.js.map +0 -1
- package/dist/tasks/pipeline-stage.js +0 -248
- package/dist/tasks/pipeline-stage.js.map +0 -1
- package/dist/tasks/plan.js +0 -268
- package/dist/tasks/plan.js.map +0 -1
- package/dist/tasks/relates.js +0 -101
- package/dist/tasks/relates.js.map +0 -1
- package/dist/tasks/show.js +0 -83
- package/dist/tasks/show.js.map +0 -1
- package/dist/tasks/size-weighting.js +0 -86
- package/dist/tasks/size-weighting.js.map +0 -1
- package/dist/tasks/staleness.js +0 -86
- package/dist/tasks/staleness.js.map +0 -1
- package/dist/tasks/task-ops.js +0 -1741
- package/dist/tasks/task-ops.js.map +0 -1
- package/dist/tasks/update.js +0 -303
- package/dist/tasks/update.js.map +0 -1
- package/dist/templates/index.js +0 -10
- package/dist/templates/index.js.map +0 -1
- package/dist/templates/parser.js +0 -254
- package/dist/templates/parser.js.map +0 -1
- package/dist/ui/aliases.js +0 -153
- package/dist/ui/aliases.js.map +0 -1
- package/dist/ui/changelog.js +0 -184
- package/dist/ui/changelog.js.map +0 -1
- package/dist/ui/command-registry.js +0 -168
- package/dist/ui/command-registry.js.map +0 -1
- package/dist/ui/flags.js +0 -94
- package/dist/ui/flags.js.map +0 -1
- package/dist/ui/index.js +0 -24
- package/dist/ui/index.js.map +0 -1
- package/dist/upgrade.js +0 -1148
- package/dist/upgrade.js.map +0 -1
- package/dist/validation/chain-validation.js +0 -146
- package/dist/validation/chain-validation.js.map +0 -1
- package/dist/validation/compliance.js +0 -155
- package/dist/validation/compliance.js.map +0 -1
- package/dist/validation/docs-sync.js +0 -212
- package/dist/validation/docs-sync.js.map +0 -1
- package/dist/validation/doctor/checks.js +0 -1069
- package/dist/validation/doctor/checks.js.map +0 -1
- package/dist/validation/doctor/index.js +0 -9
- package/dist/validation/doctor/index.js.map +0 -1
- package/dist/validation/doctor/project-cache.js +0 -160
- package/dist/validation/doctor/project-cache.js.map +0 -1
- package/dist/validation/doctor/utils.js +0 -155
- package/dist/validation/doctor/utils.js.map +0 -1
- package/dist/validation/engine.js +0 -914
- package/dist/validation/engine.js.map +0 -1
- package/dist/validation/gap-check.js +0 -175
- package/dist/validation/gap-check.js.map +0 -1
- package/dist/validation/index.js +0 -40
- package/dist/validation/index.js.map +0 -1
- package/dist/validation/manifest.js +0 -237
- package/dist/validation/manifest.js.map +0 -1
- package/dist/validation/operation-gate-validators.js +0 -724
- package/dist/validation/operation-gate-validators.js.map +0 -1
- package/dist/validation/operation-verification-gates.js +0 -532
- package/dist/validation/operation-verification-gates.js.map +0 -1
- package/dist/validation/param-utils.js +0 -141
- package/dist/validation/param-utils.js.map +0 -1
- package/dist/validation/protocol-common.js +0 -300
- package/dist/validation/protocol-common.js.map +0 -1
- package/dist/validation/protocols/_shared.js +0 -82
- package/dist/validation/protocols/_shared.js.map +0 -1
- package/dist/validation/protocols/architecture-decision.js +0 -31
- package/dist/validation/protocols/architecture-decision.js.map +0 -1
- package/dist/validation/protocols/artifact-publish.js +0 -28
- package/dist/validation/protocols/artifact-publish.js.map +0 -1
- package/dist/validation/protocols/consensus.js +0 -41
- package/dist/validation/protocols/consensus.js.map +0 -1
- package/dist/validation/protocols/contribution.js +0 -27
- package/dist/validation/protocols/contribution.js.map +0 -1
- package/dist/validation/protocols/decomposition.js +0 -28
- package/dist/validation/protocols/decomposition.js.map +0 -1
- package/dist/validation/protocols/implementation.js +0 -24
- package/dist/validation/protocols/implementation.js.map +0 -1
- package/dist/validation/protocols/provenance.js +0 -29
- package/dist/validation/protocols/provenance.js.map +0 -1
- package/dist/validation/protocols/release.js +0 -29
- package/dist/validation/protocols/release.js.map +0 -1
- package/dist/validation/protocols/research.js +0 -24
- package/dist/validation/protocols/research.js.map +0 -1
- package/dist/validation/protocols/specification.js +0 -27
- package/dist/validation/protocols/specification.js.map +0 -1
- package/dist/validation/protocols/testing.js +0 -30
- package/dist/validation/protocols/testing.js.map +0 -1
- package/dist/validation/protocols/validation.js +0 -30
- package/dist/validation/protocols/validation.js.map +0 -1
- package/dist/validation/schema-integrity.js +0 -170
- package/dist/validation/schema-integrity.js.map +0 -1
- package/dist/validation/schema-validator.js +0 -176
- package/dist/validation/schema-validator.js.map +0 -1
- package/dist/validation/validate-ops.js +0 -937
- package/dist/validation/validate-ops.js.map +0 -1
- package/dist/validation/validation-rules.js +0 -226
- package/dist/validation/validation-rules.js.map +0 -1
- package/dist/validation/verification.js +0 -321
- package/dist/validation/verification.js.map +0 -1
package/dist/migration/state.js
DELETED
|
@@ -1,421 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Migration state tracking and recovery.
|
|
3
|
-
*
|
|
4
|
-
* Provides persistent tracking of migration progress to enable:
|
|
5
|
-
* - Resumable migrations after interruptions
|
|
6
|
-
* - Debugging of failed migrations
|
|
7
|
-
* - Progress monitoring during long operations
|
|
8
|
-
*
|
|
9
|
-
* @task T4726
|
|
10
|
-
* @epic T4454
|
|
11
|
-
*/
|
|
12
|
-
import { createHash } from 'node:crypto';
|
|
13
|
-
import { existsSync } from 'node:fs';
|
|
14
|
-
import { readFile, unlink, writeFile } from 'node:fs/promises';
|
|
15
|
-
import { join } from 'node:path';
|
|
16
|
-
/** State file name */
|
|
17
|
-
const STATE_FILENAME = '.migration-state.json';
|
|
18
|
-
/**
|
|
19
|
-
* Compute SHA-256 checksum of file content.
|
|
20
|
-
* @param filePath - Path to the file
|
|
21
|
-
* @returns Hex-encoded SHA-256 checksum, or empty string if file doesn't exist
|
|
22
|
-
*/
|
|
23
|
-
async function computeFileChecksum(filePath) {
|
|
24
|
-
try {
|
|
25
|
-
const content = await readFile(filePath);
|
|
26
|
-
return createHash('sha256').update(content).digest('hex');
|
|
27
|
-
}
|
|
28
|
-
catch {
|
|
29
|
-
return '';
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Count records in a JSON file.
|
|
34
|
-
* @param filePath - Path to the JSON file
|
|
35
|
-
* @param key - Key to count (e.g., 'tasks', 'sessions')
|
|
36
|
-
* @returns Count of records, or 0 if file doesn't exist or is invalid
|
|
37
|
-
*/
|
|
38
|
-
async function countRecords(filePath, key) {
|
|
39
|
-
try {
|
|
40
|
-
const content = await readFile(filePath, 'utf-8');
|
|
41
|
-
const data = JSON.parse(content);
|
|
42
|
-
return (data[key] ?? []).length;
|
|
43
|
-
}
|
|
44
|
-
catch {
|
|
45
|
-
return 0;
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
/**
|
|
49
|
-
* Create initial migration state at the start of migration.
|
|
50
|
-
*
|
|
51
|
-
* Captures source file checksums and initializes progress tracking.
|
|
52
|
-
* Uses atomic write pattern to ensure state is never in an inconsistent state.
|
|
53
|
-
*
|
|
54
|
-
* @param cleoDir - Path to .cleo directory
|
|
55
|
-
* @param sourceFiles - Optional pre-computed source file info
|
|
56
|
-
* @returns The created migration state
|
|
57
|
-
* @task T4726
|
|
58
|
-
*/
|
|
59
|
-
export async function createMigrationState(cleoDir, sourceFiles) {
|
|
60
|
-
// If source files not provided, compute them
|
|
61
|
-
const files = sourceFiles ?? {};
|
|
62
|
-
if (!files.todoJson) {
|
|
63
|
-
const todoPath = join(cleoDir, 'todo.json');
|
|
64
|
-
if (existsSync(todoPath)) {
|
|
65
|
-
files.todoJson = {
|
|
66
|
-
path: todoPath,
|
|
67
|
-
checksum: await computeFileChecksum(todoPath),
|
|
68
|
-
taskCount: await countRecords(todoPath, 'tasks'),
|
|
69
|
-
};
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
if (!files.sessionsJson) {
|
|
73
|
-
const sessionsPath = join(cleoDir, 'sessions.json');
|
|
74
|
-
if (existsSync(sessionsPath)) {
|
|
75
|
-
files.sessionsJson = {
|
|
76
|
-
path: sessionsPath,
|
|
77
|
-
checksum: await computeFileChecksum(sessionsPath),
|
|
78
|
-
sessionCount: await countRecords(sessionsPath, 'sessions'),
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
if (!files.archiveJson) {
|
|
83
|
-
const archivePath = join(cleoDir, 'todo-archive.json');
|
|
84
|
-
if (existsSync(archivePath)) {
|
|
85
|
-
files.archiveJson = {
|
|
86
|
-
path: archivePath,
|
|
87
|
-
checksum: await computeFileChecksum(archivePath),
|
|
88
|
-
archivedCount: (await countRecords(archivePath, 'tasks')) ||
|
|
89
|
-
(await countRecords(archivePath, 'archivedTasks')),
|
|
90
|
-
};
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
const state = {
|
|
94
|
-
version: '1.0.0',
|
|
95
|
-
startedAt: new Date().toISOString(),
|
|
96
|
-
phase: 'init',
|
|
97
|
-
sourceFiles: files,
|
|
98
|
-
progress: {
|
|
99
|
-
tasksImported: 0,
|
|
100
|
-
archivedImported: 0,
|
|
101
|
-
sessionsImported: 0,
|
|
102
|
-
totalTasks: files.todoJson?.taskCount ?? 0,
|
|
103
|
-
totalArchived: files.archiveJson?.archivedCount ?? 0,
|
|
104
|
-
totalSessions: files.sessionsJson?.sessionCount ?? 0,
|
|
105
|
-
},
|
|
106
|
-
errors: [],
|
|
107
|
-
warnings: [],
|
|
108
|
-
};
|
|
109
|
-
await writeMigrationState(cleoDir, state);
|
|
110
|
-
return state;
|
|
111
|
-
}
|
|
112
|
-
/**
|
|
113
|
-
* Write migration state to disk atomically.
|
|
114
|
-
* Uses write-to-temp-then-rename pattern for safety.
|
|
115
|
-
*
|
|
116
|
-
* @param cleoDir - Path to .cleo directory
|
|
117
|
-
* @param state - Migration state to write
|
|
118
|
-
*/
|
|
119
|
-
async function writeMigrationState(cleoDir, state) {
|
|
120
|
-
const statePath = join(cleoDir, STATE_FILENAME);
|
|
121
|
-
const tempPath = `${statePath}.tmp`;
|
|
122
|
-
await writeFile(tempPath, JSON.stringify(state, null, 2));
|
|
123
|
-
await writeFile(statePath, await readFile(tempPath));
|
|
124
|
-
// Clean up temp file
|
|
125
|
-
try {
|
|
126
|
-
await unlink(tempPath);
|
|
127
|
-
}
|
|
128
|
-
catch {
|
|
129
|
-
// Ignore cleanup errors
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
/**
|
|
133
|
-
* Update migration state with partial updates.
|
|
134
|
-
*
|
|
135
|
-
* Merges updates with existing state and writes atomically.
|
|
136
|
-
* Automatically adds timestamp to phase transitions.
|
|
137
|
-
*
|
|
138
|
-
* @param cleoDir - Path to .cleo directory
|
|
139
|
-
* @param updates - Partial state updates to apply
|
|
140
|
-
* @returns The updated migration state
|
|
141
|
-
* @task T4726
|
|
142
|
-
*/
|
|
143
|
-
export async function updateMigrationState(cleoDir, updates) {
|
|
144
|
-
const current = await loadMigrationState(cleoDir);
|
|
145
|
-
if (!current) {
|
|
146
|
-
throw new Error('No migration state exists. Call createMigrationState first.');
|
|
147
|
-
}
|
|
148
|
-
// Deep merge progress if provided
|
|
149
|
-
const mergedProgress = updates.progress
|
|
150
|
-
? {
|
|
151
|
-
tasksImported: updates.progress.tasksImported ?? current.progress.tasksImported,
|
|
152
|
-
archivedImported: updates.progress.archivedImported ?? current.progress.archivedImported,
|
|
153
|
-
sessionsImported: updates.progress.sessionsImported ?? current.progress.sessionsImported,
|
|
154
|
-
totalTasks: updates.progress.totalTasks ?? current.progress.totalTasks,
|
|
155
|
-
totalArchived: updates.progress.totalArchived ?? current.progress.totalArchived,
|
|
156
|
-
totalSessions: updates.progress.totalSessions ?? current.progress.totalSessions,
|
|
157
|
-
}
|
|
158
|
-
: current.progress;
|
|
159
|
-
// Deep merge sourceFiles if provided
|
|
160
|
-
const mergedSourceFiles = updates.sourceFiles
|
|
161
|
-
? { ...current.sourceFiles, ...updates.sourceFiles }
|
|
162
|
-
: current.sourceFiles;
|
|
163
|
-
// Merge arrays
|
|
164
|
-
const mergedErrors = updates.errors ? [...current.errors, ...updates.errors] : current.errors;
|
|
165
|
-
const mergedWarnings = updates.warnings
|
|
166
|
-
? [...current.warnings, ...updates.warnings]
|
|
167
|
-
: current.warnings;
|
|
168
|
-
const updated = {
|
|
169
|
-
...current,
|
|
170
|
-
...updates,
|
|
171
|
-
progress: mergedProgress,
|
|
172
|
-
sourceFiles: mergedSourceFiles,
|
|
173
|
-
errors: mergedErrors,
|
|
174
|
-
warnings: mergedWarnings,
|
|
175
|
-
};
|
|
176
|
-
await writeMigrationState(cleoDir, updated);
|
|
177
|
-
return updated;
|
|
178
|
-
}
|
|
179
|
-
/**
|
|
180
|
-
* Update just the migration phase.
|
|
181
|
-
* Convenience wrapper for common phase transition.
|
|
182
|
-
*
|
|
183
|
-
* @param cleoDir - Path to .cleo directory
|
|
184
|
-
* @param phase - New phase
|
|
185
|
-
* @returns The updated migration state
|
|
186
|
-
* @task T4726
|
|
187
|
-
*/
|
|
188
|
-
export async function updateMigrationPhase(cleoDir, phase) {
|
|
189
|
-
return updateMigrationState(cleoDir, { phase });
|
|
190
|
-
}
|
|
191
|
-
/**
|
|
192
|
-
* Update progress counters during import.
|
|
193
|
-
*
|
|
194
|
-
* @param cleoDir - Path to .cleo directory
|
|
195
|
-
* @param progress - Progress updates (only changed counters needed)
|
|
196
|
-
* @returns The updated migration state
|
|
197
|
-
* @task T4726
|
|
198
|
-
*/
|
|
199
|
-
export async function updateMigrationProgress(cleoDir, progress) {
|
|
200
|
-
const current = await loadMigrationState(cleoDir);
|
|
201
|
-
if (!current) {
|
|
202
|
-
throw new Error('No migration state exists');
|
|
203
|
-
}
|
|
204
|
-
const mergedProgress = {
|
|
205
|
-
tasksImported: progress.tasksImported ?? current.progress.tasksImported,
|
|
206
|
-
archivedImported: progress.archivedImported ?? current.progress.archivedImported,
|
|
207
|
-
sessionsImported: progress.sessionsImported ?? current.progress.sessionsImported,
|
|
208
|
-
totalTasks: progress.totalTasks ?? current.progress.totalTasks,
|
|
209
|
-
totalArchived: progress.totalArchived ?? current.progress.totalArchived,
|
|
210
|
-
totalSessions: progress.totalSessions ?? current.progress.totalSessions,
|
|
211
|
-
};
|
|
212
|
-
return updateMigrationState(cleoDir, { progress: mergedProgress });
|
|
213
|
-
}
|
|
214
|
-
/**
|
|
215
|
-
* Add an error to the migration state.
|
|
216
|
-
*
|
|
217
|
-
* @param cleoDir - Path to .cleo directory
|
|
218
|
-
* @param error - Error message
|
|
219
|
-
* @returns The updated migration state
|
|
220
|
-
* @task T4726
|
|
221
|
-
*/
|
|
222
|
-
export async function addMigrationError(cleoDir, error) {
|
|
223
|
-
const state = await loadMigrationState(cleoDir);
|
|
224
|
-
if (!state) {
|
|
225
|
-
throw new Error('No migration state exists');
|
|
226
|
-
}
|
|
227
|
-
state.errors.push(error);
|
|
228
|
-
state.phase = 'failed';
|
|
229
|
-
await writeMigrationState(cleoDir, state);
|
|
230
|
-
return state;
|
|
231
|
-
}
|
|
232
|
-
/**
|
|
233
|
-
* Add a warning to the migration state.
|
|
234
|
-
*
|
|
235
|
-
* @param cleoDir - Path to .cleo directory
|
|
236
|
-
* @param warning - Warning message
|
|
237
|
-
* @returns The updated migration state
|
|
238
|
-
* @task T4726
|
|
239
|
-
*/
|
|
240
|
-
export async function addMigrationWarning(cleoDir, warning) {
|
|
241
|
-
const state = await loadMigrationState(cleoDir);
|
|
242
|
-
if (!state) {
|
|
243
|
-
throw new Error('No migration state exists');
|
|
244
|
-
}
|
|
245
|
-
state.warnings.push(warning);
|
|
246
|
-
await writeMigrationState(cleoDir, state);
|
|
247
|
-
return state;
|
|
248
|
-
}
|
|
249
|
-
/**
|
|
250
|
-
* Load existing migration state.
|
|
251
|
-
*
|
|
252
|
-
* @param cleoDir - Path to .cleo directory
|
|
253
|
-
* @returns Migration state, or null if no state file exists
|
|
254
|
-
* @task T4726
|
|
255
|
-
*/
|
|
256
|
-
export async function loadMigrationState(cleoDir) {
|
|
257
|
-
try {
|
|
258
|
-
const statePath = join(cleoDir, STATE_FILENAME);
|
|
259
|
-
const content = await readFile(statePath, 'utf-8');
|
|
260
|
-
return JSON.parse(content);
|
|
261
|
-
}
|
|
262
|
-
catch {
|
|
263
|
-
return null;
|
|
264
|
-
}
|
|
265
|
-
}
|
|
266
|
-
/**
|
|
267
|
-
* Check if a migration is in progress.
|
|
268
|
-
*
|
|
269
|
-
* @param cleoDir - Path to .cleo directory
|
|
270
|
-
* @returns true if migration state exists and is not complete/failed
|
|
271
|
-
* @task T4726
|
|
272
|
-
*/
|
|
273
|
-
export async function isMigrationInProgress(cleoDir) {
|
|
274
|
-
const state = await loadMigrationState(cleoDir);
|
|
275
|
-
if (!state)
|
|
276
|
-
return false;
|
|
277
|
-
return state.phase !== 'complete' && state.phase !== 'failed';
|
|
278
|
-
}
|
|
279
|
-
/**
|
|
280
|
-
* Check if migration can be resumed.
|
|
281
|
-
*
|
|
282
|
-
* @param cleoDir - Path to .cleo directory
|
|
283
|
-
* @returns Object with resume info, or null if cannot resume
|
|
284
|
-
* @task T4726
|
|
285
|
-
*/
|
|
286
|
-
export async function canResumeMigration(cleoDir) {
|
|
287
|
-
const state = await loadMigrationState(cleoDir);
|
|
288
|
-
if (!state)
|
|
289
|
-
return null;
|
|
290
|
-
// Can resume if we're not complete and not failed
|
|
291
|
-
const canResume = state.phase !== 'complete' && state.phase !== 'failed';
|
|
292
|
-
return {
|
|
293
|
-
canResume,
|
|
294
|
-
phase: state.phase,
|
|
295
|
-
progress: state.progress,
|
|
296
|
-
errors: state.errors,
|
|
297
|
-
};
|
|
298
|
-
}
|
|
299
|
-
/**
|
|
300
|
-
* Mark migration as complete.
|
|
301
|
-
*
|
|
302
|
-
* @param cleoDir - Path to .cleo directory
|
|
303
|
-
* @returns The completed migration state
|
|
304
|
-
* @task T4726
|
|
305
|
-
*/
|
|
306
|
-
export async function completeMigration(cleoDir) {
|
|
307
|
-
const state = await updateMigrationState(cleoDir, {
|
|
308
|
-
phase: 'complete',
|
|
309
|
-
completedAt: new Date().toISOString(),
|
|
310
|
-
});
|
|
311
|
-
// Auto-cleanup completed state after a delay
|
|
312
|
-
// Keep it for a short while for verification purposes
|
|
313
|
-
setTimeout(() => {
|
|
314
|
-
clearMigrationState(cleoDir).catch(() => {
|
|
315
|
-
// Ignore cleanup errors
|
|
316
|
-
});
|
|
317
|
-
}, 5000);
|
|
318
|
-
return state;
|
|
319
|
-
}
|
|
320
|
-
/**
|
|
321
|
-
* Mark migration as failed with error details.
|
|
322
|
-
*
|
|
323
|
-
* @param cleoDir - Path to .cleo directory
|
|
324
|
-
* @param error - Primary error message
|
|
325
|
-
* @returns The failed migration state
|
|
326
|
-
* @task T4726
|
|
327
|
-
*/
|
|
328
|
-
export async function failMigration(cleoDir, error) {
|
|
329
|
-
return updateMigrationState(cleoDir, {
|
|
330
|
-
phase: 'failed',
|
|
331
|
-
errors: [error],
|
|
332
|
-
});
|
|
333
|
-
}
|
|
334
|
-
/**
|
|
335
|
-
* Clear migration state file.
|
|
336
|
-
* Safe to call even if state doesn't exist.
|
|
337
|
-
*
|
|
338
|
-
* @param cleoDir - Path to .cleo directory
|
|
339
|
-
* @task T4726
|
|
340
|
-
*/
|
|
341
|
-
export async function clearMigrationState(cleoDir) {
|
|
342
|
-
try {
|
|
343
|
-
const statePath = join(cleoDir, STATE_FILENAME);
|
|
344
|
-
await unlink(statePath);
|
|
345
|
-
}
|
|
346
|
-
catch {
|
|
347
|
-
// Ignore if doesn't exist
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
/**
|
|
351
|
-
* Get a summary of migration state for display.
|
|
352
|
-
*
|
|
353
|
-
* @param cleoDir - Path to .cleo directory
|
|
354
|
-
* @returns Human-readable summary, or null if no state
|
|
355
|
-
* @task T4726
|
|
356
|
-
*/
|
|
357
|
-
export async function getMigrationSummary(cleoDir) {
|
|
358
|
-
const state = await loadMigrationState(cleoDir);
|
|
359
|
-
if (!state)
|
|
360
|
-
return null;
|
|
361
|
-
const { phase, progress, errors, warnings, startedAt, completedAt } = state;
|
|
362
|
-
const lines = [
|
|
363
|
-
`Migration Status: ${phase.toUpperCase()}`,
|
|
364
|
-
`Started: ${new Date(startedAt).toLocaleString()}`,
|
|
365
|
-
];
|
|
366
|
-
if (completedAt) {
|
|
367
|
-
lines.push(`Completed: ${new Date(completedAt).toLocaleString()}`);
|
|
368
|
-
}
|
|
369
|
-
lines.push(`Progress: ${progress.tasksImported}/${progress.totalTasks} tasks, ` +
|
|
370
|
-
`${progress.archivedImported}/${progress.totalArchived} archived, ` +
|
|
371
|
-
`${progress.sessionsImported}/${progress.totalSessions} sessions`);
|
|
372
|
-
if (errors.length > 0) {
|
|
373
|
-
lines.push(`\nErrors (${errors.length}):`);
|
|
374
|
-
for (const e of errors) {
|
|
375
|
-
lines.push(` - ${e}`);
|
|
376
|
-
}
|
|
377
|
-
}
|
|
378
|
-
if (warnings.length > 0) {
|
|
379
|
-
lines.push(`\nWarnings (${warnings.length}):`);
|
|
380
|
-
for (const w of warnings) {
|
|
381
|
-
lines.push(` - ${w}`);
|
|
382
|
-
}
|
|
383
|
-
}
|
|
384
|
-
return lines.join('\n');
|
|
385
|
-
}
|
|
386
|
-
/**
|
|
387
|
-
* Verify source files haven't changed since migration started.
|
|
388
|
-
*
|
|
389
|
-
* Compares current checksums with stored checksums to detect
|
|
390
|
-
* if source files were modified during migration.
|
|
391
|
-
*
|
|
392
|
-
* @param cleoDir - Path to .cleo directory
|
|
393
|
-
* @returns Object with verification results
|
|
394
|
-
* @task T4726
|
|
395
|
-
*/
|
|
396
|
-
export async function verifySourceIntegrity(cleoDir) {
|
|
397
|
-
const state = await loadMigrationState(cleoDir);
|
|
398
|
-
if (!state) {
|
|
399
|
-
return { valid: false, changed: [], missing: ['state'] };
|
|
400
|
-
}
|
|
401
|
-
const changed = [];
|
|
402
|
-
const missing = [];
|
|
403
|
-
for (const [key, fileInfo] of Object.entries(state.sourceFiles)) {
|
|
404
|
-
if (!fileInfo)
|
|
405
|
-
continue;
|
|
406
|
-
if (!existsSync(fileInfo.path)) {
|
|
407
|
-
missing.push(key);
|
|
408
|
-
continue;
|
|
409
|
-
}
|
|
410
|
-
const currentChecksum = await computeFileChecksum(fileInfo.path);
|
|
411
|
-
if (currentChecksum !== fileInfo.checksum) {
|
|
412
|
-
changed.push(key);
|
|
413
|
-
}
|
|
414
|
-
}
|
|
415
|
-
return {
|
|
416
|
-
valid: changed.length === 0 && missing.length === 0,
|
|
417
|
-
changed,
|
|
418
|
-
missing,
|
|
419
|
-
};
|
|
420
|
-
}
|
|
421
|
-
//# sourceMappingURL=state.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"state.js","sourceRoot":"","sources":["../../src/migration/state.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,241 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Pre-migration JSON validation.
|
|
3
|
-
*
|
|
4
|
-
* Validates all JSON source files BEFORE any destructive database operations.
|
|
5
|
-
* This prevents data loss scenarios where the database is deleted but JSON parsing fails.
|
|
6
|
-
*
|
|
7
|
-
* @task T4725
|
|
8
|
-
* @epic T4454
|
|
9
|
-
*/
|
|
10
|
-
import { existsSync, readFileSync, statSync } from 'node:fs';
|
|
11
|
-
import { join } from 'node:path';
|
|
12
|
-
/**
|
|
13
|
-
* Parse a JSON parse error to extract line and column information.
|
|
14
|
-
*/
|
|
15
|
-
function parseJsonError(error) {
|
|
16
|
-
const message = String(error);
|
|
17
|
-
// Try to extract line/column from standard JSON parse errors
|
|
18
|
-
// Format: "Unexpected token X in JSON at position Y" or similar
|
|
19
|
-
const lineMatch = message.match(/line\s+(\d+)/i);
|
|
20
|
-
const columnMatch = message.match(/column\s+(\d+)/i);
|
|
21
|
-
return {
|
|
22
|
-
message,
|
|
23
|
-
line: lineMatch ? parseInt(lineMatch[1], 10) : undefined,
|
|
24
|
-
column: columnMatch ? parseInt(columnMatch[1], 10) : undefined,
|
|
25
|
-
};
|
|
26
|
-
}
|
|
27
|
-
/**
|
|
28
|
-
* Validate a single JSON file.
|
|
29
|
-
*
|
|
30
|
-
* @param filePath - Full path to the JSON file
|
|
31
|
-
* @param countExtractor - Function to extract count from parsed data
|
|
32
|
-
* @returns Validation result
|
|
33
|
-
*/
|
|
34
|
-
function validateJsonFile(filePath, countExtractor) {
|
|
35
|
-
const result = {
|
|
36
|
-
valid: false,
|
|
37
|
-
exists: false,
|
|
38
|
-
count: 0,
|
|
39
|
-
};
|
|
40
|
-
if (!existsSync(filePath)) {
|
|
41
|
-
// File doesn't exist - this is OK, just means no data of this type
|
|
42
|
-
result.valid = true;
|
|
43
|
-
return result;
|
|
44
|
-
}
|
|
45
|
-
result.exists = true;
|
|
46
|
-
try {
|
|
47
|
-
// Check if file is readable and non-empty
|
|
48
|
-
const stats = statSync(filePath);
|
|
49
|
-
if (stats.size === 0) {
|
|
50
|
-
result.error = 'File is empty (0 bytes)';
|
|
51
|
-
return result;
|
|
52
|
-
}
|
|
53
|
-
const content = readFileSync(filePath, 'utf-8');
|
|
54
|
-
if (content.trim().length === 0) {
|
|
55
|
-
result.error = 'File contains only whitespace';
|
|
56
|
-
return result;
|
|
57
|
-
}
|
|
58
|
-
// Attempt to parse
|
|
59
|
-
const data = JSON.parse(content);
|
|
60
|
-
result.valid = true;
|
|
61
|
-
result.count = countExtractor(data);
|
|
62
|
-
}
|
|
63
|
-
catch (err) {
|
|
64
|
-
const parsed = parseJsonError(err);
|
|
65
|
-
result.error = `Parse error: ${parsed.message}`;
|
|
66
|
-
if (parsed.line)
|
|
67
|
-
result.line = parsed.line;
|
|
68
|
-
if (parsed.column)
|
|
69
|
-
result.column = parsed.column;
|
|
70
|
-
}
|
|
71
|
-
return result;
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Validate all JSON source files before migration.
|
|
75
|
-
*
|
|
76
|
-
* This function MUST be called BEFORE any destructive database operations.
|
|
77
|
-
* It checks that all JSON files are parseable and contain expected data.
|
|
78
|
-
*
|
|
79
|
-
* @param cleoDir - Path to the .cleo directory
|
|
80
|
-
* @returns Validation result with details for each file
|
|
81
|
-
* @task T4725
|
|
82
|
-
*/
|
|
83
|
-
export function validateSourceFiles(cleoDir) {
|
|
84
|
-
const warnings = [];
|
|
85
|
-
// Validate todo.json
|
|
86
|
-
const todoPath = join(cleoDir, 'todo.json');
|
|
87
|
-
const todoJson = validateJsonFile(todoPath, (data) => {
|
|
88
|
-
const record = data;
|
|
89
|
-
return Array.isArray(record.tasks) ? record.tasks.length : 0;
|
|
90
|
-
});
|
|
91
|
-
if (todoJson.exists && todoJson.valid && todoJson.count === 0) {
|
|
92
|
-
warnings.push(`todo.json has 0 tasks (file exists but task array is empty)`);
|
|
93
|
-
}
|
|
94
|
-
if (todoJson.exists && !todoJson.valid) {
|
|
95
|
-
const location = todoJson.line
|
|
96
|
-
? ` at line ${todoJson.line}${todoJson.column ? `, column ${todoJson.column}` : ''}`
|
|
97
|
-
: '';
|
|
98
|
-
todoJson.error = `${todoJson.error}${location} in ${todoPath}`;
|
|
99
|
-
}
|
|
100
|
-
// Validate sessions.json
|
|
101
|
-
const sessionsPath = join(cleoDir, 'sessions.json');
|
|
102
|
-
const sessionsJson = validateJsonFile(sessionsPath, (data) => {
|
|
103
|
-
const record = data;
|
|
104
|
-
return Array.isArray(record.sessions) ? record.sessions.length : 0;
|
|
105
|
-
});
|
|
106
|
-
if (sessionsJson.exists && sessionsJson.valid && sessionsJson.count === 0) {
|
|
107
|
-
warnings.push(`sessions.json has 0 sessions`);
|
|
108
|
-
}
|
|
109
|
-
if (sessionsJson.exists && !sessionsJson.valid) {
|
|
110
|
-
const location = sessionsJson.line
|
|
111
|
-
? ` at line ${sessionsJson.line}${sessionsJson.column ? `, column ${sessionsJson.column}` : ''}`
|
|
112
|
-
: '';
|
|
113
|
-
sessionsJson.error = `${sessionsJson.error}${location} in ${sessionsPath}`;
|
|
114
|
-
}
|
|
115
|
-
// Validate todo-archive.json
|
|
116
|
-
const archivePath = join(cleoDir, 'todo-archive.json');
|
|
117
|
-
const archiveJson = validateJsonFile(archivePath, (data) => {
|
|
118
|
-
const record = data;
|
|
119
|
-
// Support both 'tasks' and 'archivedTasks' keys
|
|
120
|
-
const tasks = Array.isArray(record.tasks) ? record.tasks : [];
|
|
121
|
-
const archivedTasks = Array.isArray(record.archivedTasks) ? record.archivedTasks : [];
|
|
122
|
-
return tasks.length + archivedTasks.length;
|
|
123
|
-
});
|
|
124
|
-
if (archiveJson.exists && archiveJson.valid && archiveJson.count === 0) {
|
|
125
|
-
warnings.push(`todo-archive.json has 0 archived tasks`);
|
|
126
|
-
}
|
|
127
|
-
if (archiveJson.exists && !archiveJson.valid) {
|
|
128
|
-
const location = archiveJson.line
|
|
129
|
-
? ` at line ${archiveJson.line}${archiveJson.column ? `, column ${archiveJson.column}` : ''}`
|
|
130
|
-
: '';
|
|
131
|
-
archiveJson.error = `${archiveJson.error}${location} in ${archivePath}`;
|
|
132
|
-
}
|
|
133
|
-
// Calculate totals
|
|
134
|
-
const totalTasks = (todoJson.valid ? todoJson.count : 0) + (archiveJson.valid ? archiveJson.count : 0);
|
|
135
|
-
// Determine overall validity
|
|
136
|
-
const valid = todoJson.valid && sessionsJson.valid && archiveJson.valid;
|
|
137
|
-
return {
|
|
138
|
-
valid,
|
|
139
|
-
todoJson,
|
|
140
|
-
sessionsJson,
|
|
141
|
-
archiveJson,
|
|
142
|
-
totalTasks,
|
|
143
|
-
warnings,
|
|
144
|
-
};
|
|
145
|
-
}
|
|
146
|
-
/**
|
|
147
|
-
* Format validation result for human-readable output.
|
|
148
|
-
*
|
|
149
|
-
* @param result - Validation result
|
|
150
|
-
* @returns Formatted string
|
|
151
|
-
*/
|
|
152
|
-
export function formatValidationResult(result) {
|
|
153
|
-
const lines = [];
|
|
154
|
-
if (result.valid) {
|
|
155
|
-
lines.push('✓ All JSON files are valid');
|
|
156
|
-
}
|
|
157
|
-
else {
|
|
158
|
-
lines.push('✗ JSON validation failed');
|
|
159
|
-
}
|
|
160
|
-
// todo.json status
|
|
161
|
-
if (result.todoJson.exists) {
|
|
162
|
-
if (result.todoJson.valid) {
|
|
163
|
-
lines.push(` todo.json: ${result.todoJson.count} tasks`);
|
|
164
|
-
}
|
|
165
|
-
else {
|
|
166
|
-
lines.push(` todo.json: ERROR - ${result.todoJson.error}`);
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
else {
|
|
170
|
-
lines.push(' todo.json: not found (will be skipped)');
|
|
171
|
-
}
|
|
172
|
-
// sessions.json status
|
|
173
|
-
if (result.sessionsJson.exists) {
|
|
174
|
-
if (result.sessionsJson.valid) {
|
|
175
|
-
lines.push(` sessions.json: ${result.sessionsJson.count} sessions`);
|
|
176
|
-
}
|
|
177
|
-
else {
|
|
178
|
-
lines.push(` sessions.json: ERROR - ${result.sessionsJson.error}`);
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
else {
|
|
182
|
-
lines.push(' sessions.json: not found (will be skipped)');
|
|
183
|
-
}
|
|
184
|
-
// archive.json status
|
|
185
|
-
if (result.archiveJson.exists) {
|
|
186
|
-
if (result.archiveJson.valid) {
|
|
187
|
-
lines.push(` todo-archive.json: ${result.archiveJson.count} archived tasks`);
|
|
188
|
-
}
|
|
189
|
-
else {
|
|
190
|
-
lines.push(` todo-archive.json: ERROR - ${result.archiveJson.error}`);
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
else {
|
|
194
|
-
lines.push(' todo-archive.json: not found (will be skipped)');
|
|
195
|
-
}
|
|
196
|
-
// Warnings
|
|
197
|
-
if (result.warnings.length > 0) {
|
|
198
|
-
lines.push('\nWarnings:');
|
|
199
|
-
for (const warning of result.warnings) {
|
|
200
|
-
lines.push(` ⚠ ${warning}`);
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
// Total
|
|
204
|
-
if (result.valid) {
|
|
205
|
-
lines.push(`\nTotal tasks to migrate: ${result.totalTasks}`);
|
|
206
|
-
}
|
|
207
|
-
return lines.join('\n');
|
|
208
|
-
}
|
|
209
|
-
/**
|
|
210
|
-
* Check for task count mismatch between existing database and JSON.
|
|
211
|
-
*
|
|
212
|
-
* This helps detect cases where the database has data but JSON is empty
|
|
213
|
-
* (indicating a potential configuration or path issue).
|
|
214
|
-
*
|
|
215
|
-
* @param cleoDir - Path to .cleo directory
|
|
216
|
-
* @param jsonTaskCount - Number of tasks found in JSON
|
|
217
|
-
* @returns Warning message if mismatch detected, null otherwise
|
|
218
|
-
*/
|
|
219
|
-
export function checkTaskCountMismatch(cleoDir, jsonTaskCount) {
|
|
220
|
-
const dbPath = join(cleoDir, 'tasks.db');
|
|
221
|
-
if (!existsSync(dbPath)) {
|
|
222
|
-
return null; // No existing DB, no mismatch possible
|
|
223
|
-
}
|
|
224
|
-
try {
|
|
225
|
-
const stats = statSync(dbPath);
|
|
226
|
-
if (stats.size === 0) {
|
|
227
|
-
return null; // Empty DB file
|
|
228
|
-
}
|
|
229
|
-
// DB exists and has content, but JSON has 0 tasks
|
|
230
|
-
if (jsonTaskCount === 0) {
|
|
231
|
-
return (`WARNING: Existing database (${stats.size} bytes) found but JSON has 0 tasks. ` +
|
|
232
|
-
`This may indicate wrong directory or missing JSON files. ` +
|
|
233
|
-
`Migration will result in data loss unless JSON files are in the correct location.`);
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
catch {
|
|
237
|
-
// Can't stat the DB, ignore
|
|
238
|
-
}
|
|
239
|
-
return null;
|
|
240
|
-
}
|
|
241
|
-
//# sourceMappingURL=validate.js.map
|