@cleocode/core 2026.4.12 → 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 +11 -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 +52 -2
- 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__/backup-crypto.test.ts +101 -0
- package/src/store/__tests__/backup-pack.test.ts +491 -0
- package/src/store/__tests__/backup-unpack.test.ts +298 -0
- package/src/store/__tests__/performance-safety.test.ts +11 -5
- package/src/store/__tests__/regenerators.test.ts +234 -0
- package/src/store/__tests__/restore-conflict-report.test.ts +274 -0
- package/src/store/__tests__/restore-json-merge.test.ts +521 -0
- package/src/store/__tests__/t310-readiness.test.ts +111 -0
- package/src/store/__tests__/t311-integration.test.ts +661 -0
- package/src/store/backup-crypto.ts +209 -0
- package/src/store/backup-pack.ts +739 -0
- package/src/store/backup-unpack.ts +583 -0
- package/src/store/migrate-signaldock-to-conduit.ts +14 -7
- package/src/store/regenerators.ts +243 -0
- package/src/store/restore-conflict-report.ts +317 -0
- package/src/store/restore-json-merge.ts +653 -0
- package/src/store/t310-readiness.ts +119 -0
- 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
|
@@ -1,787 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* SQLite-based implementation of the DataAccessor interface.
|
|
3
|
-
*
|
|
4
|
-
* Materializes TaskFile/ArchiveFile/SessionsFile from SQLite tables,
|
|
5
|
-
* allowing core modules to continue using whole-file data structures
|
|
6
|
-
* while storage is backed by the relational database.
|
|
7
|
-
*
|
|
8
|
-
* Uses existing sqlite.ts engine (node:sqlite / drizzle-orm) and
|
|
9
|
-
* task-store.ts / session-store.ts for row-level operations.
|
|
10
|
-
*
|
|
11
|
-
* @epic T4454
|
|
12
|
-
*/
|
|
13
|
-
import { and, eq, inArray, isNull, like, ne, notInArray, or, sql } from 'drizzle-orm';
|
|
14
|
-
import { archivedTaskToRow, rowToSession, rowToTask, taskToRow } from './converters.js';
|
|
15
|
-
import { cleanupBrainRefsOnSessionDelete } from './cross-db-cleanup.js';
|
|
16
|
-
import { batchUpdateDependencies, loadDependenciesForTasks, loadRelationsForTasks, updateDependencies, upsertSession, upsertTask, } from './db-helpers.js';
|
|
17
|
-
import { closeDb, getDb, getNativeTasksDb } from './sqlite.js';
|
|
18
|
-
import { TERMINAL_TASK_STATUSES } from './status-registry.js';
|
|
19
|
-
import * as schema from './tasks-schema.js';
|
|
20
|
-
/**
|
|
21
|
-
* Generate a unique audit log entry ID.
|
|
22
|
-
* @task T4837
|
|
23
|
-
*/
|
|
24
|
-
function generateAuditLogId() {
|
|
25
|
-
const epoch = Math.floor(Date.now() / 1000);
|
|
26
|
-
const rand = Math.random().toString(36).slice(2, 8);
|
|
27
|
-
return `log-${epoch}-${rand}`;
|
|
28
|
-
}
|
|
29
|
-
// ---- Schema meta helpers ----
|
|
30
|
-
/** Read a JSON blob from the schema_meta table by key. */
|
|
31
|
-
async function getMetaValue(cwd, key) {
|
|
32
|
-
const db = await getDb(cwd);
|
|
33
|
-
const rows = await db
|
|
34
|
-
.select()
|
|
35
|
-
.from(schema.schemaMeta)
|
|
36
|
-
.where(eq(schema.schemaMeta.key, key))
|
|
37
|
-
.all();
|
|
38
|
-
if (rows.length === 0 || !rows[0])
|
|
39
|
-
return null;
|
|
40
|
-
try {
|
|
41
|
-
return JSON.parse(rows[0].value);
|
|
42
|
-
}
|
|
43
|
-
catch {
|
|
44
|
-
return null;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
/** Write a JSON blob to the schema_meta table by key. */
|
|
48
|
-
export async function setMetaValue(cwd, key, value) {
|
|
49
|
-
const db = await getDb(cwd);
|
|
50
|
-
const json = JSON.stringify(value);
|
|
51
|
-
await db
|
|
52
|
-
.insert(schema.schemaMeta)
|
|
53
|
-
.values({ key, value: json })
|
|
54
|
-
.onConflictDoUpdate({
|
|
55
|
-
target: schema.schemaMeta.key,
|
|
56
|
-
set: { value: json },
|
|
57
|
-
})
|
|
58
|
-
.run();
|
|
59
|
-
}
|
|
60
|
-
// ---- Accessor factory ----
|
|
61
|
-
/**
|
|
62
|
-
* Create a SQLite-backed DataAccessor.
|
|
63
|
-
*
|
|
64
|
-
* Opens (or creates) the SQLite database at `.cleo/tasks.db` and returns
|
|
65
|
-
* a DataAccessor that materializes/dematerializes whole-file structures
|
|
66
|
-
* from the relational tables.
|
|
67
|
-
*
|
|
68
|
-
* @param cwd - Working directory for path resolution (defaults to process.cwd())
|
|
69
|
-
*/
|
|
70
|
-
export async function createSqliteDataAccessor(cwd) {
|
|
71
|
-
// Eagerly initialize the database to ensure tables exist
|
|
72
|
-
await getDb(cwd);
|
|
73
|
-
/** Load all task IDs for cross-task dependency validation. */
|
|
74
|
-
async function getAllTaskIds() {
|
|
75
|
-
const db = await getDb(cwd);
|
|
76
|
-
const rows = await db.select({ id: schema.tasks.id }).from(schema.tasks).all();
|
|
77
|
-
return new Set(rows.map((r) => r.id));
|
|
78
|
-
}
|
|
79
|
-
const accessor = {
|
|
80
|
-
engine: 'sqlite',
|
|
81
|
-
// ---- loadArchive ----
|
|
82
|
-
async loadArchive() {
|
|
83
|
-
const db = await getDb(cwd);
|
|
84
|
-
// Query tasks where status = 'archived'
|
|
85
|
-
const archivedRows = await db
|
|
86
|
-
.select()
|
|
87
|
-
.from(schema.tasks)
|
|
88
|
-
.where(eq(schema.tasks.status, 'archived'))
|
|
89
|
-
.all();
|
|
90
|
-
if (archivedRows.length === 0)
|
|
91
|
-
return null;
|
|
92
|
-
const archivedTasks = archivedRows.map((row) => {
|
|
93
|
-
const task = rowToTask(row);
|
|
94
|
-
// Restore the original terminal status for the archive representation
|
|
95
|
-
// but keep the archived metadata accessible
|
|
96
|
-
return {
|
|
97
|
-
...task,
|
|
98
|
-
// In archive files, tasks retain their pre-archive status if available,
|
|
99
|
-
// but since we store as 'archived' in DB, use the archived info
|
|
100
|
-
archivedAt: row.archivedAt ?? undefined,
|
|
101
|
-
archiveReason: row.archiveReason ?? undefined,
|
|
102
|
-
cycleTimeDays: row.cycleTimeDays ?? undefined,
|
|
103
|
-
};
|
|
104
|
-
});
|
|
105
|
-
// Load dependencies and relations for archived tasks, filtering orphaned refs
|
|
106
|
-
if (archivedTasks.length > 0) {
|
|
107
|
-
// Also load all active task IDs so we can validate cross-references
|
|
108
|
-
const activeRows = await db
|
|
109
|
-
.select({ id: schema.tasks.id })
|
|
110
|
-
.from(schema.tasks)
|
|
111
|
-
.where(ne(schema.tasks.status, 'archived'))
|
|
112
|
-
.all();
|
|
113
|
-
const allKnownIds = new Set([
|
|
114
|
-
...archivedTasks.map((t) => t.id),
|
|
115
|
-
...activeRows.map((r) => r.id),
|
|
116
|
-
]);
|
|
117
|
-
await loadDependenciesForTasks(db, archivedTasks, allKnownIds);
|
|
118
|
-
await loadRelationsForTasks(db, archivedTasks);
|
|
119
|
-
}
|
|
120
|
-
return {
|
|
121
|
-
archivedTasks,
|
|
122
|
-
version: '1.0.0',
|
|
123
|
-
};
|
|
124
|
-
},
|
|
125
|
-
// ---- saveArchive ----
|
|
126
|
-
async saveArchive(data) {
|
|
127
|
-
const db = await getDb(cwd);
|
|
128
|
-
// Pre-compute archive IDs + active task IDs for dependency validation
|
|
129
|
-
const archiveIds = new Set(data.archivedTasks.map((t) => t.id));
|
|
130
|
-
const activeRows = await db
|
|
131
|
-
.select({ id: schema.tasks.id })
|
|
132
|
-
.from(schema.tasks)
|
|
133
|
-
.where(ne(schema.tasks.status, 'archived'))
|
|
134
|
-
.all();
|
|
135
|
-
const validDepIds = new Set([...archiveIds, ...activeRows.map((r) => r.id)]);
|
|
136
|
-
// Wrap all upserts + dependency updates in a single transaction
|
|
137
|
-
const nativeDb = getNativeTasksDb();
|
|
138
|
-
if (!nativeDb) {
|
|
139
|
-
throw new Error('Native database not initialized');
|
|
140
|
-
}
|
|
141
|
-
nativeDb.prepare('BEGIN IMMEDIATE').run();
|
|
142
|
-
try {
|
|
143
|
-
// Collect dependency data for batch update
|
|
144
|
-
const depBatch = [];
|
|
145
|
-
for (const task of data.archivedTasks) {
|
|
146
|
-
const row = archivedTaskToRow(task);
|
|
147
|
-
// Extract archive-specific fields if they exist on the task object
|
|
148
|
-
const taskAny = task;
|
|
149
|
-
const archiveFields = {
|
|
150
|
-
archivedAt: taskAny.archivedAt ?? row.completedAt ?? new Date().toISOString(),
|
|
151
|
-
archiveReason: taskAny.archiveReason ?? 'completed',
|
|
152
|
-
cycleTimeDays: taskAny.cycleTimeDays ?? null,
|
|
153
|
-
};
|
|
154
|
-
await upsertTask(db, row, archiveFields);
|
|
155
|
-
depBatch.push({ taskId: task.id, deps: task.depends ?? [] });
|
|
156
|
-
}
|
|
157
|
-
// Single batch operation for all dependency updates
|
|
158
|
-
await batchUpdateDependencies(db, depBatch, validDepIds);
|
|
159
|
-
nativeDb.prepare('COMMIT').run();
|
|
160
|
-
}
|
|
161
|
-
catch (err) {
|
|
162
|
-
nativeDb.prepare('ROLLBACK').run();
|
|
163
|
-
throw err;
|
|
164
|
-
}
|
|
165
|
-
},
|
|
166
|
-
// ---- loadSessions ----
|
|
167
|
-
async loadSessions() {
|
|
168
|
-
const db = await getDb(cwd);
|
|
169
|
-
const sessionRows = await db.select().from(schema.sessions).all();
|
|
170
|
-
return sessionRows.map(rowToSession);
|
|
171
|
-
},
|
|
172
|
-
// ---- saveSessions ----
|
|
173
|
-
async saveSessions(sessions) {
|
|
174
|
-
const db = await getDb(cwd);
|
|
175
|
-
// Get existing session IDs
|
|
176
|
-
const existingRows = await db.select({ id: schema.sessions.id }).from(schema.sessions).all();
|
|
177
|
-
const existingIds = new Set(existingRows.map((r) => r.id));
|
|
178
|
-
const incomingIds = new Set(sessions.map((s) => s.id));
|
|
179
|
-
// Delete sessions that are no longer in the data
|
|
180
|
-
for (const eid of existingIds) {
|
|
181
|
-
if (!incomingIds.has(eid)) {
|
|
182
|
-
await db.delete(schema.sessions).where(eq(schema.sessions.id, eid)).run();
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
// Upsert all sessions
|
|
186
|
-
for (const session of sessions) {
|
|
187
|
-
await upsertSession(db, session);
|
|
188
|
-
}
|
|
189
|
-
},
|
|
190
|
-
// ---- appendLog ----
|
|
191
|
-
async appendLog(entry) {
|
|
192
|
-
const db = await getDb(cwd);
|
|
193
|
-
await db
|
|
194
|
-
.insert(schema.auditLog)
|
|
195
|
-
.values({
|
|
196
|
-
id: entry.id ?? generateAuditLogId(),
|
|
197
|
-
timestamp: entry.timestamp ?? new Date().toISOString(),
|
|
198
|
-
action: entry.action ?? entry.operation ?? 'unknown',
|
|
199
|
-
taskId: entry.taskId ?? 'unknown',
|
|
200
|
-
actor: entry.actor ?? 'system',
|
|
201
|
-
detailsJson: entry.details ? JSON.stringify(entry.details) : '{}',
|
|
202
|
-
beforeJson: entry.before ? JSON.stringify(entry.before) : null,
|
|
203
|
-
afterJson: entry.after ? JSON.stringify(entry.after) : null,
|
|
204
|
-
})
|
|
205
|
-
.run();
|
|
206
|
-
},
|
|
207
|
-
// ---- Fine-grained task operations (T5034) ----
|
|
208
|
-
async upsertSingleTask(task) {
|
|
209
|
-
const db = await getDb(cwd);
|
|
210
|
-
const row = taskToRow(task);
|
|
211
|
-
await upsertTask(db, row);
|
|
212
|
-
await updateDependencies(db, task.id, task.depends ?? []);
|
|
213
|
-
},
|
|
214
|
-
async addRelation(taskId, relatedTo, relationType, reason) {
|
|
215
|
-
const db = await getDb(cwd);
|
|
216
|
-
// Validate relation type - throw on invalid (T5168)
|
|
217
|
-
const validTypes = [
|
|
218
|
-
'related',
|
|
219
|
-
'blocks',
|
|
220
|
-
'duplicates',
|
|
221
|
-
'absorbs',
|
|
222
|
-
'fixes',
|
|
223
|
-
'extends',
|
|
224
|
-
'supersedes',
|
|
225
|
-
];
|
|
226
|
-
if (!validTypes.includes(relationType)) {
|
|
227
|
-
throw new Error(`Invalid relation type: ${relationType}. Valid types: ${validTypes.join(', ')}`);
|
|
228
|
-
}
|
|
229
|
-
await db
|
|
230
|
-
.insert(schema.taskRelations)
|
|
231
|
-
.values({
|
|
232
|
-
taskId,
|
|
233
|
-
relatedTo,
|
|
234
|
-
relationType: relationType,
|
|
235
|
-
reason: reason ?? null,
|
|
236
|
-
})
|
|
237
|
-
.onConflictDoNothing()
|
|
238
|
-
.run();
|
|
239
|
-
},
|
|
240
|
-
async archiveSingleTask(taskId, fields) {
|
|
241
|
-
const db = await getDb(cwd);
|
|
242
|
-
// Verify the task exists before archiving
|
|
243
|
-
const rows = await db
|
|
244
|
-
.select({ id: schema.tasks.id })
|
|
245
|
-
.from(schema.tasks)
|
|
246
|
-
.where(eq(schema.tasks.id, taskId))
|
|
247
|
-
.all();
|
|
248
|
-
if (rows.length === 0)
|
|
249
|
-
return;
|
|
250
|
-
await db
|
|
251
|
-
.update(schema.tasks)
|
|
252
|
-
.set({
|
|
253
|
-
status: 'archived',
|
|
254
|
-
archivedAt: fields.archivedAt ?? new Date().toISOString(),
|
|
255
|
-
archiveReason: fields.archiveReason ?? 'completed',
|
|
256
|
-
cycleTimeDays: fields.cycleTimeDays ?? null,
|
|
257
|
-
updatedAt: new Date().toISOString(),
|
|
258
|
-
})
|
|
259
|
-
.where(eq(schema.tasks.id, taskId))
|
|
260
|
-
.run();
|
|
261
|
-
},
|
|
262
|
-
async removeSingleTask(taskId) {
|
|
263
|
-
const db = await getDb(cwd);
|
|
264
|
-
// Delete dependencies first (both directions)
|
|
265
|
-
await db
|
|
266
|
-
.delete(schema.taskDependencies)
|
|
267
|
-
.where(eq(schema.taskDependencies.taskId, taskId))
|
|
268
|
-
.run();
|
|
269
|
-
await db
|
|
270
|
-
.delete(schema.taskDependencies)
|
|
271
|
-
.where(eq(schema.taskDependencies.dependsOn, taskId))
|
|
272
|
-
.run();
|
|
273
|
-
// Delete the task itself
|
|
274
|
-
await db.delete(schema.tasks).where(eq(schema.tasks.id, taskId)).run();
|
|
275
|
-
},
|
|
276
|
-
async loadSingleTask(taskId) {
|
|
277
|
-
const db = await getDb(cwd);
|
|
278
|
-
const rows = await db
|
|
279
|
-
.select()
|
|
280
|
-
.from(schema.tasks)
|
|
281
|
-
.where(eq(schema.tasks.id, taskId))
|
|
282
|
-
.limit(1)
|
|
283
|
-
.all();
|
|
284
|
-
if (rows.length === 0 || !rows[0])
|
|
285
|
-
return null;
|
|
286
|
-
const task = rowToTask(rows[0]);
|
|
287
|
-
// Load all task IDs so dependency validation doesn't filter out cross-task refs
|
|
288
|
-
const allIdRows = await db.select({ id: schema.tasks.id }).from(schema.tasks).all();
|
|
289
|
-
const allIds = new Set(allIdRows.map((r) => r.id));
|
|
290
|
-
await loadDependenciesForTasks(db, [task], allIds);
|
|
291
|
-
await loadRelationsForTasks(db, [task]);
|
|
292
|
-
return task;
|
|
293
|
-
},
|
|
294
|
-
async getActiveSession() {
|
|
295
|
-
const db = await getDb(cwd);
|
|
296
|
-
const rows = await db
|
|
297
|
-
.select()
|
|
298
|
-
.from(schema.sessions)
|
|
299
|
-
.where(eq(schema.sessions.status, 'active'))
|
|
300
|
-
.orderBy(sql `${schema.sessions.startedAt} DESC`)
|
|
301
|
-
.limit(1)
|
|
302
|
-
.all();
|
|
303
|
-
if (rows.length === 0 || !rows[0])
|
|
304
|
-
return null;
|
|
305
|
-
return rowToSession(rows[0]);
|
|
306
|
-
},
|
|
307
|
-
async upsertSingleSession(session) {
|
|
308
|
-
const db = await getDb(cwd);
|
|
309
|
-
await upsertSession(db, session);
|
|
310
|
-
},
|
|
311
|
-
async removeSingleSession(sessionId) {
|
|
312
|
-
const db = await getDb(cwd);
|
|
313
|
-
await db.delete(schema.sessions).where(eq(schema.sessions.id, sessionId)).run();
|
|
314
|
-
// Best-effort cross-db cleanup: nullify brain.db references to this session
|
|
315
|
-
void cleanupBrainRefsOnSessionDelete(sessionId, cwd);
|
|
316
|
-
},
|
|
317
|
-
// ---- Targeted query methods (Phase 2 modernization) ----
|
|
318
|
-
async queryTasks(filters) {
|
|
319
|
-
const db = await getDb(cwd);
|
|
320
|
-
const conditions = [];
|
|
321
|
-
// Exclude archived by default unless explicitly requested
|
|
322
|
-
if (filters.status) {
|
|
323
|
-
const statuses = Array.isArray(filters.status) ? filters.status : [filters.status];
|
|
324
|
-
if (!statuses.includes('archived')) {
|
|
325
|
-
conditions.push(ne(schema.tasks.status, 'archived'));
|
|
326
|
-
}
|
|
327
|
-
conditions.push(inArray(schema.tasks.status, statuses));
|
|
328
|
-
}
|
|
329
|
-
else if (filters.excludeStatus) {
|
|
330
|
-
const excluded = Array.isArray(filters.excludeStatus)
|
|
331
|
-
? filters.excludeStatus
|
|
332
|
-
: [filters.excludeStatus];
|
|
333
|
-
for (const s of excluded) {
|
|
334
|
-
conditions.push(ne(schema.tasks.status, s));
|
|
335
|
-
}
|
|
336
|
-
}
|
|
337
|
-
else {
|
|
338
|
-
conditions.push(ne(schema.tasks.status, 'archived'));
|
|
339
|
-
}
|
|
340
|
-
if (filters.priority)
|
|
341
|
-
conditions.push(eq(schema.tasks.priority, filters.priority));
|
|
342
|
-
if (filters.type)
|
|
343
|
-
conditions.push(eq(schema.tasks.type, filters.type));
|
|
344
|
-
if (filters.phase)
|
|
345
|
-
conditions.push(eq(schema.tasks.phase, filters.phase));
|
|
346
|
-
if (filters.parentId !== undefined) {
|
|
347
|
-
if (filters.parentId === null) {
|
|
348
|
-
conditions.push(isNull(schema.tasks.parentId));
|
|
349
|
-
}
|
|
350
|
-
else {
|
|
351
|
-
conditions.push(eq(schema.tasks.parentId, filters.parentId));
|
|
352
|
-
}
|
|
353
|
-
}
|
|
354
|
-
if (filters.search) {
|
|
355
|
-
const pattern = `%${filters.search}%`;
|
|
356
|
-
conditions.push(or(like(schema.tasks.title, pattern), like(schema.tasks.description, pattern), like(schema.tasks.id, pattern)));
|
|
357
|
-
}
|
|
358
|
-
if (filters.label) {
|
|
359
|
-
// label stored in JSON array — use LIKE on the serialized column
|
|
360
|
-
conditions.push(like(schema.tasks.labelsJson, `%${JSON.stringify(filters.label)}%`));
|
|
361
|
-
}
|
|
362
|
-
const where = conditions.length > 0 ? and(...conditions) : undefined;
|
|
363
|
-
// Count total matching rows (before pagination)
|
|
364
|
-
const countResult = await db
|
|
365
|
-
.select({ count: sql `count(*)` })
|
|
366
|
-
.from(schema.tasks)
|
|
367
|
-
.where(where)
|
|
368
|
-
.get();
|
|
369
|
-
const total = countResult?.count ?? 0;
|
|
370
|
-
// Build ordered query
|
|
371
|
-
let orderClause;
|
|
372
|
-
switch (filters.orderBy) {
|
|
373
|
-
case 'createdAt':
|
|
374
|
-
orderClause = sql `${schema.tasks.createdAt} ASC`;
|
|
375
|
-
break;
|
|
376
|
-
case 'updatedAt':
|
|
377
|
-
orderClause = sql `${schema.tasks.updatedAt} DESC NULLS LAST`;
|
|
378
|
-
break;
|
|
379
|
-
case 'priority': {
|
|
380
|
-
// Map priority to numeric sort: critical=0, high=1, medium=2, low=3
|
|
381
|
-
orderClause = sql `CASE ${schema.tasks.priority}
|
|
382
|
-
WHEN 'critical' THEN 0 WHEN 'high' THEN 1
|
|
383
|
-
WHEN 'medium' THEN 2 WHEN 'low' THEN 3 ELSE 4 END ASC`;
|
|
384
|
-
break;
|
|
385
|
-
}
|
|
386
|
-
default:
|
|
387
|
-
// position ASC, createdAt ASC (default)
|
|
388
|
-
orderClause = sql `${schema.tasks.position} ASC, ${schema.tasks.createdAt} ASC`;
|
|
389
|
-
}
|
|
390
|
-
let query = db.select().from(schema.tasks).where(where).orderBy(orderClause);
|
|
391
|
-
if (filters.limit !== undefined) {
|
|
392
|
-
query = query.limit(filters.limit);
|
|
393
|
-
}
|
|
394
|
-
if (filters.offset !== undefined) {
|
|
395
|
-
query = query.offset(filters.offset);
|
|
396
|
-
}
|
|
397
|
-
const rows = await query.all();
|
|
398
|
-
const tasks = rows.map(rowToTask);
|
|
399
|
-
// Load dependencies and relations with full ID set for cross-task refs
|
|
400
|
-
if (tasks.length > 0) {
|
|
401
|
-
const allIds = await getAllTaskIds();
|
|
402
|
-
await loadDependenciesForTasks(db, tasks, allIds);
|
|
403
|
-
await loadRelationsForTasks(db, tasks);
|
|
404
|
-
}
|
|
405
|
-
return { tasks, total };
|
|
406
|
-
},
|
|
407
|
-
async countTasks(filters) {
|
|
408
|
-
const db = await getDb(cwd);
|
|
409
|
-
const conditions = [];
|
|
410
|
-
if (filters?.status) {
|
|
411
|
-
const statuses = Array.isArray(filters.status) ? filters.status : [filters.status];
|
|
412
|
-
conditions.push(inArray(schema.tasks.status, statuses));
|
|
413
|
-
}
|
|
414
|
-
else {
|
|
415
|
-
conditions.push(ne(schema.tasks.status, 'archived'));
|
|
416
|
-
}
|
|
417
|
-
if (filters?.parentId) {
|
|
418
|
-
conditions.push(eq(schema.tasks.parentId, filters.parentId));
|
|
419
|
-
}
|
|
420
|
-
const where = conditions.length > 0 ? and(...conditions) : undefined;
|
|
421
|
-
const result = await db
|
|
422
|
-
.select({ count: sql `count(*)` })
|
|
423
|
-
.from(schema.tasks)
|
|
424
|
-
.where(where)
|
|
425
|
-
.get();
|
|
426
|
-
return result?.count ?? 0;
|
|
427
|
-
},
|
|
428
|
-
async getChildren(parentId) {
|
|
429
|
-
const db = await getDb(cwd);
|
|
430
|
-
const rows = await db
|
|
431
|
-
.select()
|
|
432
|
-
.from(schema.tasks)
|
|
433
|
-
.where(and(eq(schema.tasks.parentId, parentId), ne(schema.tasks.status, 'archived')))
|
|
434
|
-
.orderBy(sql `${schema.tasks.position} ASC, ${schema.tasks.createdAt} ASC`)
|
|
435
|
-
.all();
|
|
436
|
-
const tasks = rows.map(rowToTask);
|
|
437
|
-
if (tasks.length > 0) {
|
|
438
|
-
const allIds = await getAllTaskIds();
|
|
439
|
-
await loadDependenciesForTasks(db, tasks, allIds);
|
|
440
|
-
await loadRelationsForTasks(db, tasks);
|
|
441
|
-
}
|
|
442
|
-
return tasks;
|
|
443
|
-
},
|
|
444
|
-
async countChildren(parentId) {
|
|
445
|
-
const db = await getDb(cwd);
|
|
446
|
-
const result = await db
|
|
447
|
-
.select({ count: sql `count(*)` })
|
|
448
|
-
.from(schema.tasks)
|
|
449
|
-
.where(and(eq(schema.tasks.parentId, parentId), ne(schema.tasks.status, 'archived')))
|
|
450
|
-
.get();
|
|
451
|
-
return result?.count ?? 0;
|
|
452
|
-
},
|
|
453
|
-
async countActiveChildren(parentId) {
|
|
454
|
-
const db = await getDb(cwd);
|
|
455
|
-
const result = await db
|
|
456
|
-
.select({ count: sql `count(*)` })
|
|
457
|
-
.from(schema.tasks)
|
|
458
|
-
.where(and(eq(schema.tasks.parentId, parentId), notInArray(schema.tasks.status, [...TERMINAL_TASK_STATUSES])))
|
|
459
|
-
.get();
|
|
460
|
-
return result?.count ?? 0;
|
|
461
|
-
},
|
|
462
|
-
async getAncestorChain(taskId) {
|
|
463
|
-
const nativeDb = getNativeTasksDb();
|
|
464
|
-
if (!nativeDb)
|
|
465
|
-
return [];
|
|
466
|
-
const idRows = nativeDb
|
|
467
|
-
.prepare(`WITH RECURSIVE ancestor_ids(id, depth) AS (
|
|
468
|
-
SELECT parent_id, 0 FROM tasks WHERE id = ? AND parent_id IS NOT NULL
|
|
469
|
-
UNION ALL
|
|
470
|
-
SELECT t.parent_id, a.depth + 1 FROM tasks t
|
|
471
|
-
JOIN ancestor_ids a ON t.id = a.id
|
|
472
|
-
WHERE t.parent_id IS NOT NULL
|
|
473
|
-
)
|
|
474
|
-
SELECT id FROM ancestor_ids ORDER BY depth DESC`)
|
|
475
|
-
.all(taskId);
|
|
476
|
-
if (idRows.length === 0)
|
|
477
|
-
return [];
|
|
478
|
-
const db = await getDb(cwd);
|
|
479
|
-
const ids = idRows.map((r) => r.id);
|
|
480
|
-
const taskRows = await db
|
|
481
|
-
.select()
|
|
482
|
-
.from(schema.tasks)
|
|
483
|
-
.where(inArray(schema.tasks.id, ids))
|
|
484
|
-
.all();
|
|
485
|
-
const tasks = taskRows.map(rowToTask);
|
|
486
|
-
if (tasks.length > 0) {
|
|
487
|
-
const allIds = await getAllTaskIds();
|
|
488
|
-
await loadDependenciesForTasks(db, tasks, allIds);
|
|
489
|
-
await loadRelationsForTasks(db, tasks);
|
|
490
|
-
}
|
|
491
|
-
// Preserve depth order (ancestors from root down)
|
|
492
|
-
const orderMap = new Map(ids.map((id, i) => [id, i]));
|
|
493
|
-
tasks.sort((a, b) => (orderMap.get(a.id) ?? 0) - (orderMap.get(b.id) ?? 0));
|
|
494
|
-
return tasks;
|
|
495
|
-
},
|
|
496
|
-
async getSubtree(rootId) {
|
|
497
|
-
const nativeDb = getNativeTasksDb();
|
|
498
|
-
if (!nativeDb)
|
|
499
|
-
return [];
|
|
500
|
-
// Get IDs from the CTE, then load via Drizzle for proper conversion
|
|
501
|
-
const idRows = nativeDb
|
|
502
|
-
.prepare(`WITH RECURSIVE subtree AS (
|
|
503
|
-
SELECT id FROM tasks WHERE id = ?
|
|
504
|
-
UNION ALL
|
|
505
|
-
SELECT t.id FROM tasks t
|
|
506
|
-
JOIN subtree s ON t.parent_id = s.id
|
|
507
|
-
)
|
|
508
|
-
SELECT id FROM subtree`)
|
|
509
|
-
.all(rootId);
|
|
510
|
-
if (idRows.length === 0)
|
|
511
|
-
return [];
|
|
512
|
-
const db = await getDb(cwd);
|
|
513
|
-
const ids = idRows.map((r) => r.id);
|
|
514
|
-
const rows = await db.select().from(schema.tasks).where(inArray(schema.tasks.id, ids)).all();
|
|
515
|
-
const tasks = rows.map(rowToTask);
|
|
516
|
-
if (tasks.length > 0) {
|
|
517
|
-
const allIds = await getAllTaskIds();
|
|
518
|
-
await loadDependenciesForTasks(db, tasks, allIds);
|
|
519
|
-
await loadRelationsForTasks(db, tasks);
|
|
520
|
-
}
|
|
521
|
-
return tasks;
|
|
522
|
-
},
|
|
523
|
-
async getDependents(taskId) {
|
|
524
|
-
const db = await getDb(cwd);
|
|
525
|
-
// Find tasks whose depends list includes taskId (reverse lookup)
|
|
526
|
-
const depRows = await db
|
|
527
|
-
.select()
|
|
528
|
-
.from(schema.taskDependencies)
|
|
529
|
-
.where(eq(schema.taskDependencies.dependsOn, taskId))
|
|
530
|
-
.all();
|
|
531
|
-
if (depRows.length === 0)
|
|
532
|
-
return [];
|
|
533
|
-
const dependentIds = depRows.map((r) => r.taskId);
|
|
534
|
-
const rows = await db
|
|
535
|
-
.select()
|
|
536
|
-
.from(schema.tasks)
|
|
537
|
-
.where(inArray(schema.tasks.id, dependentIds))
|
|
538
|
-
.all();
|
|
539
|
-
const tasks = rows.map(rowToTask);
|
|
540
|
-
if (tasks.length > 0) {
|
|
541
|
-
const allIds = await getAllTaskIds();
|
|
542
|
-
await loadDependenciesForTasks(db, tasks, allIds);
|
|
543
|
-
await loadRelationsForTasks(db, tasks);
|
|
544
|
-
}
|
|
545
|
-
return tasks;
|
|
546
|
-
},
|
|
547
|
-
async getDependencyChain(taskId) {
|
|
548
|
-
const nativeDb = getNativeTasksDb();
|
|
549
|
-
if (!nativeDb)
|
|
550
|
-
return [];
|
|
551
|
-
const rows = nativeDb
|
|
552
|
-
.prepare(`WITH RECURSIVE dep_chain(id) AS (
|
|
553
|
-
SELECT depends_on FROM task_dependencies WHERE task_id = ?
|
|
554
|
-
UNION
|
|
555
|
-
SELECT td.depends_on FROM task_dependencies td
|
|
556
|
-
JOIN dep_chain dc ON td.task_id = dc.id
|
|
557
|
-
)
|
|
558
|
-
SELECT id FROM dep_chain`)
|
|
559
|
-
.all(taskId);
|
|
560
|
-
return rows.map((r) => r.id);
|
|
561
|
-
},
|
|
562
|
-
async taskExists(taskId) {
|
|
563
|
-
const db = await getDb(cwd);
|
|
564
|
-
const result = await db
|
|
565
|
-
.select({ id: schema.tasks.id })
|
|
566
|
-
.from(schema.tasks)
|
|
567
|
-
.where(eq(schema.tasks.id, taskId))
|
|
568
|
-
.limit(1)
|
|
569
|
-
.get();
|
|
570
|
-
return !!result;
|
|
571
|
-
},
|
|
572
|
-
async loadTasks(taskIds) {
|
|
573
|
-
if (taskIds.length === 0)
|
|
574
|
-
return [];
|
|
575
|
-
const db = await getDb(cwd);
|
|
576
|
-
const rows = await db
|
|
577
|
-
.select()
|
|
578
|
-
.from(schema.tasks)
|
|
579
|
-
.where(inArray(schema.tasks.id, taskIds))
|
|
580
|
-
.all();
|
|
581
|
-
const tasks = rows.map(rowToTask);
|
|
582
|
-
if (tasks.length > 0) {
|
|
583
|
-
const allIds = await getAllTaskIds();
|
|
584
|
-
await loadDependenciesForTasks(db, tasks, allIds);
|
|
585
|
-
await loadRelationsForTasks(db, tasks);
|
|
586
|
-
}
|
|
587
|
-
return tasks;
|
|
588
|
-
},
|
|
589
|
-
// ---- Position helpers (T024/T025) ----
|
|
590
|
-
async getNextPosition(parentId) {
|
|
591
|
-
const nativeDb = getNativeTasksDb();
|
|
592
|
-
if (!nativeDb) {
|
|
593
|
-
throw new Error('Native database not initialized');
|
|
594
|
-
}
|
|
595
|
-
const row = parentId === null
|
|
596
|
-
? nativeDb
|
|
597
|
-
.prepare(`SELECT COALESCE(MAX(position), 0) + 1 AS next_pos FROM tasks WHERE parent_id IS NULL AND status != 'archived'`)
|
|
598
|
-
.get()
|
|
599
|
-
: nativeDb
|
|
600
|
-
.prepare(`SELECT COALESCE(MAX(position), 0) + 1 AS next_pos FROM tasks WHERE parent_id = ? AND status != 'archived'`)
|
|
601
|
-
.get(parentId);
|
|
602
|
-
return row?.next_pos ?? 1;
|
|
603
|
-
},
|
|
604
|
-
async shiftPositions(parentId, fromPosition, delta) {
|
|
605
|
-
const nativeDb = getNativeTasksDb();
|
|
606
|
-
if (!nativeDb) {
|
|
607
|
-
throw new Error('Native database not initialized');
|
|
608
|
-
}
|
|
609
|
-
if (parentId === null) {
|
|
610
|
-
nativeDb
|
|
611
|
-
.prepare(`UPDATE tasks SET position = position + ?, position_version = position_version + 1, updated_at = ? WHERE parent_id IS NULL AND position >= ? AND status != 'archived'`)
|
|
612
|
-
.run(delta, new Date().toISOString(), fromPosition);
|
|
613
|
-
}
|
|
614
|
-
else {
|
|
615
|
-
nativeDb
|
|
616
|
-
.prepare(`UPDATE tasks SET position = position + ?, position_version = position_version + 1, updated_at = ? WHERE parent_id = ? AND position >= ? AND status != 'archived'`)
|
|
617
|
-
.run(delta, new Date().toISOString(), parentId, fromPosition);
|
|
618
|
-
}
|
|
619
|
-
},
|
|
620
|
-
// ---- Targeted write methods ----
|
|
621
|
-
async updateTaskFields(taskId, fields) {
|
|
622
|
-
const db = await getDb(cwd);
|
|
623
|
-
const updateRow = {
|
|
624
|
-
updatedAt: fields.updatedAt ?? new Date().toISOString(),
|
|
625
|
-
};
|
|
626
|
-
// Copy only provided fields
|
|
627
|
-
const fieldMap = [
|
|
628
|
-
['title', 'title'],
|
|
629
|
-
['description', 'description'],
|
|
630
|
-
['status', 'status'],
|
|
631
|
-
['priority', 'priority'],
|
|
632
|
-
['type', 'type'],
|
|
633
|
-
['parentId', 'parentId'],
|
|
634
|
-
['phase', 'phase'],
|
|
635
|
-
['size', 'size'],
|
|
636
|
-
['position', 'position'],
|
|
637
|
-
['positionVersion', 'positionVersion'],
|
|
638
|
-
['labelsJson', 'labelsJson'],
|
|
639
|
-
['notesJson', 'notesJson'],
|
|
640
|
-
['acceptanceJson', 'acceptanceJson'],
|
|
641
|
-
['filesJson', 'filesJson'],
|
|
642
|
-
['origin', 'origin'],
|
|
643
|
-
['blockedBy', 'blockedBy'],
|
|
644
|
-
['epicLifecycle', 'epicLifecycle'],
|
|
645
|
-
['noAutoComplete', 'noAutoComplete'],
|
|
646
|
-
['completedAt', 'completedAt'],
|
|
647
|
-
['cancelledAt', 'cancelledAt'],
|
|
648
|
-
['cancellationReason', 'cancellationReason'],
|
|
649
|
-
['verificationJson', 'verificationJson'],
|
|
650
|
-
['createdBy', 'createdBy'],
|
|
651
|
-
['modifiedBy', 'modifiedBy'],
|
|
652
|
-
['sessionId', 'sessionId'],
|
|
653
|
-
['assignee', 'assignee'],
|
|
654
|
-
];
|
|
655
|
-
for (const [key, col] of fieldMap) {
|
|
656
|
-
if (fields[key] !== undefined) {
|
|
657
|
-
updateRow[col] = fields[key];
|
|
658
|
-
}
|
|
659
|
-
}
|
|
660
|
-
await db.update(schema.tasks).set(updateRow).where(eq(schema.tasks.id, taskId)).run();
|
|
661
|
-
},
|
|
662
|
-
async transaction(fn) {
|
|
663
|
-
const nativeDb = getNativeTasksDb();
|
|
664
|
-
if (!nativeDb) {
|
|
665
|
-
throw new Error('Native database not initialized');
|
|
666
|
-
}
|
|
667
|
-
const db = await getDb(cwd);
|
|
668
|
-
nativeDb.prepare('BEGIN IMMEDIATE').run();
|
|
669
|
-
try {
|
|
670
|
-
const tx = {
|
|
671
|
-
async upsertSingleTask(task) {
|
|
672
|
-
const row = taskToRow(task);
|
|
673
|
-
await upsertTask(db, row);
|
|
674
|
-
await updateDependencies(db, task.id, task.depends ?? []);
|
|
675
|
-
},
|
|
676
|
-
async archiveSingleTask(taskId, fields) {
|
|
677
|
-
await db
|
|
678
|
-
.update(schema.tasks)
|
|
679
|
-
.set({
|
|
680
|
-
status: 'archived',
|
|
681
|
-
archivedAt: fields.archivedAt ?? new Date().toISOString(),
|
|
682
|
-
archiveReason: fields.archiveReason ?? 'completed',
|
|
683
|
-
cycleTimeDays: fields.cycleTimeDays ?? null,
|
|
684
|
-
updatedAt: new Date().toISOString(),
|
|
685
|
-
})
|
|
686
|
-
.where(eq(schema.tasks.id, taskId))
|
|
687
|
-
.run();
|
|
688
|
-
},
|
|
689
|
-
async removeSingleTask(taskId) {
|
|
690
|
-
await db
|
|
691
|
-
.delete(schema.taskDependencies)
|
|
692
|
-
.where(eq(schema.taskDependencies.taskId, taskId))
|
|
693
|
-
.run();
|
|
694
|
-
await db
|
|
695
|
-
.delete(schema.taskDependencies)
|
|
696
|
-
.where(eq(schema.taskDependencies.dependsOn, taskId))
|
|
697
|
-
.run();
|
|
698
|
-
await db.delete(schema.tasks).where(eq(schema.tasks.id, taskId)).run();
|
|
699
|
-
},
|
|
700
|
-
async setMetaValue(key, value) {
|
|
701
|
-
await setMetaValue(cwd, key, value);
|
|
702
|
-
},
|
|
703
|
-
async updateTaskFields(taskId, flds) {
|
|
704
|
-
// Delegate to the outer accessor's implementation
|
|
705
|
-
await accessor.updateTaskFields(taskId, flds);
|
|
706
|
-
},
|
|
707
|
-
async appendLog(entry) {
|
|
708
|
-
await accessor.appendLog(entry);
|
|
709
|
-
},
|
|
710
|
-
};
|
|
711
|
-
const result = await fn(tx);
|
|
712
|
-
nativeDb.prepare('COMMIT').run();
|
|
713
|
-
return result;
|
|
714
|
-
}
|
|
715
|
-
catch (err) {
|
|
716
|
-
nativeDb.prepare('ROLLBACK').run();
|
|
717
|
-
throw err;
|
|
718
|
-
}
|
|
719
|
-
},
|
|
720
|
-
// ---- close ----
|
|
721
|
-
async close() {
|
|
722
|
-
closeDb();
|
|
723
|
-
},
|
|
724
|
-
// ---- Metadata ----
|
|
725
|
-
async getMetaValue(key) {
|
|
726
|
-
return getMetaValue(cwd, key);
|
|
727
|
-
},
|
|
728
|
-
async setMetaValue(key, value) {
|
|
729
|
-
return setMetaValue(cwd, key, value);
|
|
730
|
-
},
|
|
731
|
-
async getSchemaVersion() {
|
|
732
|
-
const meta = await getMetaValue(cwd, 'file_meta');
|
|
733
|
-
return meta?.schemaVersion ?? null;
|
|
734
|
-
},
|
|
735
|
-
// ---- Agent instances ----
|
|
736
|
-
async listAgentInstances(filters) {
|
|
737
|
-
const { listAgentInstances: listAgents } = await import('../agents/registry.js');
|
|
738
|
-
// Cast generic string filters to the specific union types expected by the agents module
|
|
739
|
-
return listAgents(filters, cwd);
|
|
740
|
-
},
|
|
741
|
-
async getAgentInstance(agentId) {
|
|
742
|
-
const { getAgentInstance: getAgent } = await import('../agents/registry.js');
|
|
743
|
-
return getAgent(agentId, cwd);
|
|
744
|
-
},
|
|
745
|
-
// ---- Agent task claiming ----
|
|
746
|
-
async claimTask(taskId, agentId) {
|
|
747
|
-
const nativeDb = getNativeTasksDb();
|
|
748
|
-
if (!nativeDb) {
|
|
749
|
-
throw new Error('Native database not initialized');
|
|
750
|
-
}
|
|
751
|
-
// Verify the task exists first
|
|
752
|
-
const existsRow = nativeDb.prepare('SELECT assignee FROM tasks WHERE id = ?').get(taskId);
|
|
753
|
-
if (!existsRow) {
|
|
754
|
-
throw new Error(`Task not found: ${taskId}`);
|
|
755
|
-
}
|
|
756
|
-
// Atomic claim: only succeeds if assignee IS NULL or already claimed by this agent.
|
|
757
|
-
// This prevents race conditions between concurrent agents.
|
|
758
|
-
const result = nativeDb
|
|
759
|
-
.prepare('UPDATE tasks SET assignee = ?, updated_at = ? WHERE id = ? AND (assignee IS NULL OR assignee = ?)')
|
|
760
|
-
.run(agentId, new Date().toISOString(), taskId, agentId);
|
|
761
|
-
if (result.changes === 0) {
|
|
762
|
-
// Row was not updated — task is claimed by a different agent
|
|
763
|
-
const currentRow = nativeDb
|
|
764
|
-
.prepare('SELECT assignee FROM tasks WHERE id = ?')
|
|
765
|
-
.get(taskId);
|
|
766
|
-
throw new Error(`Task ${taskId} is already claimed by agent: ${currentRow?.assignee ?? 'unknown'}`);
|
|
767
|
-
}
|
|
768
|
-
},
|
|
769
|
-
async unclaimTask(taskId) {
|
|
770
|
-
const nativeDb = getNativeTasksDb();
|
|
771
|
-
if (!nativeDb) {
|
|
772
|
-
throw new Error('Native database not initialized');
|
|
773
|
-
}
|
|
774
|
-
// Verify the task exists
|
|
775
|
-
const existsRow = nativeDb.prepare('SELECT id FROM tasks WHERE id = ?').get(taskId);
|
|
776
|
-
if (!existsRow) {
|
|
777
|
-
throw new Error(`Task not found: ${taskId}`);
|
|
778
|
-
}
|
|
779
|
-
// Clear the assignee — no-op if already null
|
|
780
|
-
nativeDb
|
|
781
|
-
.prepare('UPDATE tasks SET assignee = NULL, updated_at = ? WHERE id = ?')
|
|
782
|
-
.run(new Date().toISOString(), taskId);
|
|
783
|
-
},
|
|
784
|
-
};
|
|
785
|
-
return accessor;
|
|
786
|
-
}
|
|
787
|
-
//# sourceMappingURL=sqlite-data-accessor.js.map
|