@cleocode/core 2026.4.41 → 2026.4.43
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/conduit/factory.d.ts +10 -5
- package/dist/conduit/factory.d.ts.map +1 -1
- package/dist/index.js +77 -8
- package/dist/index.js.map +3 -3
- package/dist/init.d.ts.map +1 -1
- package/dist/store/brain-sqlite.d.ts.map +1 -1
- package/package.json +13 -8
- package/src/conduit/factory.ts +20 -17
- package/src/init.ts +22 -1
- package/src/store/__tests__/git-checkpoint.test.ts +12 -15
- package/src/store/brain-sqlite.ts +12 -0
- 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 -232
- 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 -435
- 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 -14
- 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 -420
- 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 -407
- 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 -219
- 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/conduit-hooks.js +0 -229
- package/dist/hooks/handlers/conduit-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 -37
- package/dist/hooks/handlers/index.js.map +0 -1
- package/dist/hooks/handlers/intelligence-hooks.js +0 -69
- package/dist/hooks/handlers/intelligence-hooks.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 -190
- package/dist/hooks/handlers/session-hooks.js.map +0 -1
- package/dist/hooks/handlers/task-hooks.js +0 -90
- package/dist/hooks/handlers/task-hooks.js.map +0 -1
- package/dist/hooks/handlers/watchdog-hooks.js +0 -162
- package/dist/hooks/handlers/watchdog-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 -942
- 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 -377
- 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 -324
- 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 -75
- 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/anthropic-key-resolver.js +0 -105
- package/dist/memory/anthropic-key-resolver.js.map +0 -1
- package/dist/memory/auto-extract.js +0 -77
- package/dist/memory/auto-extract.js.map +0 -1
- package/dist/memory/brain-backfill.js +0 -389
- package/dist/memory/brain-backfill.js.map +0 -1
- package/dist/memory/brain-consolidator.js +0 -294
- package/dist/memory/brain-consolidator.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 -818
- 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-purge.js +0 -243
- package/dist/memory/brain-purge.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 -1044
- 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 -613
- 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 -236
- package/dist/memory/decisions.js.map +0 -1
- package/dist/memory/embedding-local.js +0 -102
- 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 -1597
- package/dist/memory/engine-compat.js.map +0 -1
- package/dist/memory/extraction-gate.js +0 -459
- package/dist/memory/extraction-gate.js.map +0 -1
- package/dist/memory/graph-auto-populate.js +0 -148
- package/dist/memory/graph-auto-populate.js.map +0 -1
- package/dist/memory/graph-memory-bridge.js +0 -519
- package/dist/memory/graph-memory-bridge.js.map +0 -1
- package/dist/memory/graph-queries.js +0 -290
- package/dist/memory/graph-queries.js.map +0 -1
- package/dist/memory/index.js +0 -1146
- package/dist/memory/index.js.map +0 -1
- package/dist/memory/learnings.js +0 -197
- package/dist/memory/learnings.js.map +0 -1
- package/dist/memory/llm-extraction.js +0 -425
- package/dist/memory/llm-extraction.js.map +0 -1
- package/dist/memory/memory-bridge.js +0 -382
- package/dist/memory/memory-bridge.js.map +0 -1
- package/dist/memory/mental-model-injection.js +0 -61
- package/dist/memory/mental-model-injection.js.map +0 -1
- package/dist/memory/mental-model-queue.js +0 -211
- package/dist/memory/mental-model-queue.js.map +0 -1
- package/dist/memory/observer-reflector.js +0 -626
- package/dist/memory/observer-reflector.js.map +0 -1
- package/dist/memory/patterns.js +0 -192
- 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/quality-feedback.js +0 -449
- package/dist/memory/quality-feedback.js.map +0 -1
- package/dist/memory/quality-scoring.js +0 -182
- package/dist/memory/quality-scoring.js.map +0 -1
- package/dist/memory/session-memory.js +0 -331
- package/dist/memory/session-memory.js.map +0 -1
- package/dist/memory/sleep-consolidation.js +0 -706
- package/dist/memory/sleep-consolidation.js.map +0 -1
- package/dist/memory/temporal-supersession.js +0 -403
- package/dist/memory/temporal-supersession.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 -73
- 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/nexus-bridge.js +0 -321
- package/dist/nexus/nexus-bridge.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 -271
- 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 -882
- 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 -175
- 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 -1798
- 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 -326
- 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 -30
- 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 -350
- 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 -57
- 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 -886
- 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-crypto.js +0 -184
- package/dist/store/backup-crypto.js.map +0 -1
- package/dist/store/backup-pack.js +0 -581
- package/dist/store/backup-pack.js.map +0 -1
- package/dist/store/backup-unpack.js +0 -449
- package/dist/store/backup-unpack.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 -429
- package/dist/store/brain-accessor.js.map +0 -1
- package/dist/store/brain-schema.js +0 -579
- package/dist/store/brain-schema.js.map +0 -1
- package/dist/store/brain-sqlite.js +0 -297
- 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 -562
- package/dist/store/migrate-signaldock-to-conduit.js.map +0 -1
- package/dist/store/migration-manager.js +0 -288
- 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 -268
- 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/regenerators.js +0 -207
- package/dist/store/regenerators.js.map +0 -1
- package/dist/store/restore-conflict-report.js +0 -206
- package/dist/store/restore-conflict-report.js.map +0 -1
- package/dist/store/restore-json-merge.js +0 -454
- package/dist/store/restore-json-merge.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 -498
- 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 -483
- 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/t310-readiness.js +0 -115
- package/dist/store/t310-readiness.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/dependencies.js +0 -466
- package/dist/system/dependencies.js.map +0 -1
- package/dist/system/health.js +0 -1206
- 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 -89
- 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 -837
- 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 -248
- 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 -163
- 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 -173
- 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 -1371
- 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/migrations/drizzle-nexus/20260412000001_t529-nexus-graph-tables/migration.sql +0 -49
|
@@ -1,321 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Nexus Bridge Generator
|
|
3
|
-
*
|
|
4
|
-
* Generates .cleo/nexus-bridge.md from nexus.db content. This file is
|
|
5
|
-
* the code intelligence equivalent of memory-bridge.md — it summarizes
|
|
6
|
-
* the codebase graph for agent consumption.
|
|
7
|
-
*
|
|
8
|
-
* Content assembly:
|
|
9
|
-
* - Index status (file count, node count, relation count, last indexed)
|
|
10
|
-
* - Symbol counts by kind (functions, classes, methods, etc.)
|
|
11
|
-
* - Relation counts by type (calls, imports, extends, etc.)
|
|
12
|
-
* - Top entry points (most outgoing CALLS edges, exported)
|
|
13
|
-
* - Functional clusters (communities by symbol count)
|
|
14
|
-
* - Code intelligence command reference
|
|
15
|
-
*
|
|
16
|
-
* Regeneration triggers:
|
|
17
|
-
* - cleo nexus analyze (called after pipeline flush)
|
|
18
|
-
* - Manual: cleo nexus refresh-bridge
|
|
19
|
-
*
|
|
20
|
-
* @task T551
|
|
21
|
-
* @epic T549
|
|
22
|
-
*/
|
|
23
|
-
import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
|
|
24
|
-
import { join } from 'node:path';
|
|
25
|
-
// ============================================================================
|
|
26
|
-
// DB helpers
|
|
27
|
-
// ============================================================================
|
|
28
|
-
/** Type-safe wrapper for DatabaseSync.prepare().all(). */
|
|
29
|
-
function typedAll(db, sql, ...params) {
|
|
30
|
-
return db.prepare(sql).all(...params);
|
|
31
|
-
}
|
|
32
|
-
/** Type-safe wrapper for DatabaseSync.prepare().get(). */
|
|
33
|
-
function typedGet(db, sql, ...params) {
|
|
34
|
-
return db.prepare(sql).get(...params);
|
|
35
|
-
}
|
|
36
|
-
// ============================================================================
|
|
37
|
-
// Query helpers
|
|
38
|
-
// ============================================================================
|
|
39
|
-
/** Query total node/relation counts and last indexed timestamp. */
|
|
40
|
-
function queryIndexMeta(db, projectId) {
|
|
41
|
-
try {
|
|
42
|
-
const nodeMeta = typedGet(db, `SELECT COUNT(*) as total_nodes,
|
|
43
|
-
COUNT(CASE WHEN kind = 'file' THEN 1 END) as file_count,
|
|
44
|
-
MAX(indexed_at) as last_indexed_at
|
|
45
|
-
FROM nexus_nodes
|
|
46
|
-
WHERE project_id = ?`, projectId);
|
|
47
|
-
const relMeta = typedGet(db, `SELECT COUNT(*) as total_relations
|
|
48
|
-
FROM nexus_relations
|
|
49
|
-
WHERE project_id = ?`, projectId);
|
|
50
|
-
return {
|
|
51
|
-
total_nodes: nodeMeta?.total_nodes ?? 0,
|
|
52
|
-
total_relations: relMeta?.total_relations ?? 0,
|
|
53
|
-
file_count: nodeMeta?.file_count ?? 0,
|
|
54
|
-
last_indexed_at: nodeMeta?.last_indexed_at ?? null,
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
catch {
|
|
58
|
-
return {
|
|
59
|
-
total_nodes: 0,
|
|
60
|
-
total_relations: 0,
|
|
61
|
-
file_count: 0,
|
|
62
|
-
last_indexed_at: null,
|
|
63
|
-
};
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
/** Query node counts grouped by kind. */
|
|
67
|
-
function queryNodeKindCounts(db, projectId) {
|
|
68
|
-
try {
|
|
69
|
-
return typedAll(db, `SELECT kind, COUNT(*) as count
|
|
70
|
-
FROM nexus_nodes
|
|
71
|
-
WHERE project_id = ?
|
|
72
|
-
AND kind NOT IN ('file', 'folder', 'community', 'process')
|
|
73
|
-
GROUP BY kind
|
|
74
|
-
ORDER BY count DESC
|
|
75
|
-
LIMIT 10`, projectId);
|
|
76
|
-
}
|
|
77
|
-
catch {
|
|
78
|
-
return [];
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
/** Query relation counts grouped by type. */
|
|
82
|
-
function queryRelationTypeCounts(db, projectId) {
|
|
83
|
-
try {
|
|
84
|
-
return typedAll(db, `SELECT type, COUNT(*) as count
|
|
85
|
-
FROM nexus_relations
|
|
86
|
-
WHERE project_id = ?
|
|
87
|
-
AND type NOT IN ('member_of', 'step_in_process', 'entry_point_of')
|
|
88
|
-
GROUP BY type
|
|
89
|
-
ORDER BY count DESC
|
|
90
|
-
LIMIT 8`, projectId);
|
|
91
|
-
}
|
|
92
|
-
catch {
|
|
93
|
-
return [];
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
/** Query top entry points by outgoing CALLS edge count. */
|
|
97
|
-
function queryTopEntryPoints(db, projectId, limit = 5) {
|
|
98
|
-
try {
|
|
99
|
-
return typedAll(db, `SELECT n.name, n.file_path, COUNT(*) as callees, n.is_exported
|
|
100
|
-
FROM nexus_relations r
|
|
101
|
-
JOIN nexus_nodes n ON r.source_id = n.id
|
|
102
|
-
WHERE r.type = 'calls'
|
|
103
|
-
AND r.project_id = ?
|
|
104
|
-
AND n.kind IN ('function', 'method', 'constructor')
|
|
105
|
-
GROUP BY r.source_id
|
|
106
|
-
ORDER BY callees DESC
|
|
107
|
-
LIMIT ?`, projectId, limit);
|
|
108
|
-
}
|
|
109
|
-
catch {
|
|
110
|
-
return [];
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
/** Query community nodes ordered by member count. */
|
|
114
|
-
function queryCommunities(db, projectId, limit = 6) {
|
|
115
|
-
try {
|
|
116
|
-
return typedAll(db, `SELECT id, label, meta_json, indexed_at
|
|
117
|
-
FROM nexus_nodes
|
|
118
|
-
WHERE project_id = ?
|
|
119
|
-
AND kind = 'community'
|
|
120
|
-
ORDER BY indexed_at DESC
|
|
121
|
-
LIMIT ?`, projectId, limit);
|
|
122
|
-
}
|
|
123
|
-
catch {
|
|
124
|
-
return [];
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
/** Query count of execution flow (process) nodes. */
|
|
128
|
-
function queryProcessCount(db, projectId) {
|
|
129
|
-
try {
|
|
130
|
-
const row = typedGet(db, `SELECT COUNT(*) as count
|
|
131
|
-
FROM nexus_nodes
|
|
132
|
-
WHERE project_id = ?
|
|
133
|
-
AND kind = 'process'`, projectId);
|
|
134
|
-
return row?.count ?? 0;
|
|
135
|
-
}
|
|
136
|
-
catch {
|
|
137
|
-
return 0;
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
// ============================================================================
|
|
141
|
-
// Content generation
|
|
142
|
-
// ============================================================================
|
|
143
|
-
/**
|
|
144
|
-
* Generate nexus bridge markdown content from nexus.db.
|
|
145
|
-
* Returns the full markdown string (does not write to disk).
|
|
146
|
-
*
|
|
147
|
-
* @param projectId - Project registry ID used to scope nexus.db queries
|
|
148
|
-
* @param repoPath - Absolute path to the repository root (used for display)
|
|
149
|
-
* @returns Markdown string summarizing the code intelligence index
|
|
150
|
-
*/
|
|
151
|
-
export async function generateNexusBridgeContent(projectId, repoPath) {
|
|
152
|
-
const { getNexusDb, getNexusNativeDb } = await import('../store/nexus-sqlite.js');
|
|
153
|
-
// Ensure DB is initialized
|
|
154
|
-
await getNexusDb();
|
|
155
|
-
const nativeDb = getNexusNativeDb();
|
|
156
|
-
if (!nativeDb) {
|
|
157
|
-
return buildEmptyBridge(repoPath);
|
|
158
|
-
}
|
|
159
|
-
// Check whether this project has been indexed at all
|
|
160
|
-
const meta = queryIndexMeta(nativeDb, projectId);
|
|
161
|
-
if (meta.total_nodes === 0) {
|
|
162
|
-
return buildEmptyBridge(repoPath);
|
|
163
|
-
}
|
|
164
|
-
const lines = [
|
|
165
|
-
'# CLEO Nexus Bridge — Code Intelligence',
|
|
166
|
-
'',
|
|
167
|
-
`> Auto-generated from nexus index. Regenerate with \`cleo nexus analyze\`.`,
|
|
168
|
-
`> Project: ${repoPath}`,
|
|
169
|
-
'',
|
|
170
|
-
];
|
|
171
|
-
// --- Index Status ---
|
|
172
|
-
const kindCounts = queryNodeKindCounts(nativeDb, projectId);
|
|
173
|
-
const relCounts = queryRelationTypeCounts(nativeDb, projectId);
|
|
174
|
-
const processCount = queryProcessCount(nativeDb, projectId);
|
|
175
|
-
const communities = queryCommunities(nativeDb, projectId);
|
|
176
|
-
const symbolBreakdown = kindCounts.map((r) => `${r.kind}s: ${r.count}`).join(', ');
|
|
177
|
-
const callsCount = relCounts.find((r) => r.type === 'calls')?.count ?? 0;
|
|
178
|
-
const importsCount = relCounts.find((r) => r.type === 'imports')?.count ?? 0;
|
|
179
|
-
const extendsCount = relCounts.find((r) => r.type === 'extends')?.count ?? 0;
|
|
180
|
-
const freshnessLabel = meta.last_indexed_at ? meta.last_indexed_at.slice(0, 10) : 'unknown';
|
|
181
|
-
lines.push('## Index Status');
|
|
182
|
-
lines.push('');
|
|
183
|
-
lines.push(`- **Files**: ${meta.file_count.toLocaleString()} indexed`);
|
|
184
|
-
lines.push(`- **Symbols**: ${meta.total_nodes.toLocaleString()} total${symbolBreakdown ? ` (${symbolBreakdown})` : ''}`);
|
|
185
|
-
lines.push(`- **Relations**: ${meta.total_relations.toLocaleString()} total (calls: ${callsCount.toLocaleString()}, imports: ${importsCount.toLocaleString()}, extends: ${extendsCount.toLocaleString()})`);
|
|
186
|
-
lines.push(`- **Communities**: ${communities.length} functional clusters`);
|
|
187
|
-
lines.push(`- **Execution Flows**: ${processCount} traced processes`);
|
|
188
|
-
lines.push(`- **Last Indexed**: ${meta.last_indexed_at ?? 'never'}`);
|
|
189
|
-
lines.push(`- **Date**: ${freshnessLabel}`);
|
|
190
|
-
lines.push('');
|
|
191
|
-
// --- Top Entry Points ---
|
|
192
|
-
const entryPoints = queryTopEntryPoints(nativeDb, projectId);
|
|
193
|
-
if (entryPoints.length > 0) {
|
|
194
|
-
lines.push('## Top Entry Points');
|
|
195
|
-
lines.push('');
|
|
196
|
-
entryPoints.forEach((ep, i) => {
|
|
197
|
-
const name = ep.name ?? '(unknown)';
|
|
198
|
-
const filePath = ep.file_path ?? '';
|
|
199
|
-
const displayPath = filePath.length > 60 ? `...${filePath.slice(-57)}` : filePath;
|
|
200
|
-
lines.push(`${i + 1}. \`${name}\` — ${displayPath} (${ep.callees} callees)`);
|
|
201
|
-
});
|
|
202
|
-
lines.push('');
|
|
203
|
-
}
|
|
204
|
-
// --- Functional Clusters ---
|
|
205
|
-
if (communities.length > 0) {
|
|
206
|
-
lines.push('## Functional Clusters');
|
|
207
|
-
lines.push('');
|
|
208
|
-
communities.forEach((c, i) => {
|
|
209
|
-
let symbolCount = 0;
|
|
210
|
-
let topFolder = '';
|
|
211
|
-
try {
|
|
212
|
-
if (c.meta_json) {
|
|
213
|
-
const meta = JSON.parse(c.meta_json);
|
|
214
|
-
symbolCount = typeof meta['symbolCount'] === 'number' ? meta['symbolCount'] : 0;
|
|
215
|
-
const folders = meta['topFolders'];
|
|
216
|
-
if (Array.isArray(folders) && folders.length > 0) {
|
|
217
|
-
topFolder = String(folders[0]);
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
catch {
|
|
222
|
-
// ignore parse errors
|
|
223
|
-
}
|
|
224
|
-
const symbolsLabel = symbolCount > 0 ? ` (${symbolCount} symbols)` : '';
|
|
225
|
-
const folderLabel = topFolder ? ` — ${topFolder}` : '';
|
|
226
|
-
lines.push(`${i + 1}. **${c.label}**${symbolsLabel}${folderLabel}`);
|
|
227
|
-
});
|
|
228
|
-
lines.push('');
|
|
229
|
-
}
|
|
230
|
-
// --- Code Intelligence Commands ---
|
|
231
|
-
lines.push('## Code Intelligence Commands');
|
|
232
|
-
lines.push('');
|
|
233
|
-
lines.push('| Need | Command |');
|
|
234
|
-
lines.push('|------|---------|');
|
|
235
|
-
lines.push('| What calls this function? | `cleo nexus context <symbol>` |');
|
|
236
|
-
lines.push('| What breaks if I change this? | `cleo nexus impact <symbol>` |');
|
|
237
|
-
lines.push('| What functional areas exist? | `cleo nexus clusters` |');
|
|
238
|
-
lines.push('| What execution flows exist? | `cleo nexus flows` |');
|
|
239
|
-
lines.push('| Re-index after code changes | `cleo nexus analyze` |');
|
|
240
|
-
lines.push('| Index freshness check | `cleo nexus status` |');
|
|
241
|
-
lines.push('');
|
|
242
|
-
return lines.join('\n');
|
|
243
|
-
}
|
|
244
|
-
/**
|
|
245
|
-
* Write nexus bridge content to .cleo/nexus-bridge.md.
|
|
246
|
-
*
|
|
247
|
-
* @param projectRoot - Absolute path to the project root
|
|
248
|
-
* @param projectId - Project registry ID (used to scope nexus.db queries)
|
|
249
|
-
* @returns Result with path and whether the file was written
|
|
250
|
-
*/
|
|
251
|
-
export async function writeNexusBridge(projectRoot, projectId) {
|
|
252
|
-
const cleoDir = join(projectRoot, '.cleo');
|
|
253
|
-
const bridgePath = join(cleoDir, 'nexus-bridge.md');
|
|
254
|
-
// Derive project ID from path if not provided (matches nexus analyze convention)
|
|
255
|
-
const resolvedProjectId = projectId ?? Buffer.from(projectRoot).toString('base64url').slice(0, 32);
|
|
256
|
-
try {
|
|
257
|
-
const content = await generateNexusBridgeContent(resolvedProjectId, projectRoot);
|
|
258
|
-
if (!existsSync(cleoDir)) {
|
|
259
|
-
mkdirSync(cleoDir, { recursive: true });
|
|
260
|
-
}
|
|
261
|
-
// Only write if content changed (avoid unnecessary git noise)
|
|
262
|
-
if (existsSync(bridgePath)) {
|
|
263
|
-
const existing = readFileSync(bridgePath, 'utf-8');
|
|
264
|
-
// Compare without the date line since it changes daily
|
|
265
|
-
const stripDate = (s) => s.replace(/^> Date: .*/m, '');
|
|
266
|
-
if (stripDate(existing) === stripDate(content)) {
|
|
267
|
-
return { path: bridgePath, written: false };
|
|
268
|
-
}
|
|
269
|
-
}
|
|
270
|
-
writeFileSync(bridgePath, content, 'utf-8');
|
|
271
|
-
return { path: bridgePath, written: true };
|
|
272
|
-
}
|
|
273
|
-
catch (err) {
|
|
274
|
-
console.error('[CLEO] Failed to write nexus bridge:', err instanceof Error ? err.message : String(err));
|
|
275
|
-
return { path: bridgePath, written: false };
|
|
276
|
-
}
|
|
277
|
-
}
|
|
278
|
-
/**
|
|
279
|
-
* Best-effort nexus bridge refresh. Never throws.
|
|
280
|
-
* Called after cleo nexus analyze completes.
|
|
281
|
-
*
|
|
282
|
-
* @param projectRoot - Absolute path to the project root
|
|
283
|
-
* @param projectId - Project registry ID (used to scope nexus.db queries)
|
|
284
|
-
*/
|
|
285
|
-
export async function refreshNexusBridge(projectRoot, projectId) {
|
|
286
|
-
try {
|
|
287
|
-
await writeNexusBridge(projectRoot, projectId);
|
|
288
|
-
}
|
|
289
|
-
catch (err) {
|
|
290
|
-
console.error('[CLEO] Nexus bridge refresh failed:', err instanceof Error ? err.message : String(err));
|
|
291
|
-
}
|
|
292
|
-
}
|
|
293
|
-
// ============================================================================
|
|
294
|
-
// Helpers
|
|
295
|
-
// ============================================================================
|
|
296
|
-
/** Build placeholder content when no index data exists. */
|
|
297
|
-
function buildEmptyBridge(repoPath) {
|
|
298
|
-
return [
|
|
299
|
-
'# CLEO Nexus Bridge — Code Intelligence',
|
|
300
|
-
'',
|
|
301
|
-
`> Auto-generated from nexus index. Regenerate with \`cleo nexus analyze\`.`,
|
|
302
|
-
`> Project: ${repoPath}`,
|
|
303
|
-
'',
|
|
304
|
-
'## Index Status',
|
|
305
|
-
'',
|
|
306
|
-
'Not indexed. Run `cleo nexus analyze` to build the code intelligence index.',
|
|
307
|
-
'',
|
|
308
|
-
'## Code Intelligence Commands',
|
|
309
|
-
'',
|
|
310
|
-
'| Need | Command |',
|
|
311
|
-
'|------|---------|',
|
|
312
|
-
'| Build the index | `cleo nexus analyze` |',
|
|
313
|
-
'| Check index status | `cleo nexus status` |',
|
|
314
|
-
'| What calls this function? | `cleo nexus context <symbol>` |',
|
|
315
|
-
'| What breaks if I change this? | `cleo nexus impact <symbol>` |',
|
|
316
|
-
'| What functional areas exist? | `cleo nexus clusters` |',
|
|
317
|
-
'| What execution flows exist? | `cleo nexus flows` |',
|
|
318
|
-
'',
|
|
319
|
-
].join('\n');
|
|
320
|
-
}
|
|
321
|
-
//# sourceMappingURL=nexus-bridge.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"nexus-bridge.js","sourceRoot":"","sources":["../../src/nexus/nexus-bridge.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* NEXUS permission enforcement - three-tier access control for cross-project operations.
|
|
3
|
-
*
|
|
4
|
-
* Permission model:
|
|
5
|
-
* read (1) - Query tasks, discover relationships
|
|
6
|
-
* write (2) - read + modify task fields, add relationships
|
|
7
|
-
* execute (3) - write + create/delete tasks, run commands
|
|
8
|
-
*
|
|
9
|
-
* Hierarchical: execute includes write includes read.
|
|
10
|
-
* Same-project operations always have full permissions.
|
|
11
|
-
*
|
|
12
|
-
* @task T4574
|
|
13
|
-
* @epic T4540
|
|
14
|
-
*/
|
|
15
|
-
import { ExitCode } from '@cleocode/contracts';
|
|
16
|
-
import { CleoError } from '../errors.js';
|
|
17
|
-
import { nexusGetProject, nexusSetPermission } from './registry.js';
|
|
18
|
-
// ── Constants ────────────────────────────────────────────────────────
|
|
19
|
-
const PERMISSION_LEVELS = {
|
|
20
|
-
read: 1,
|
|
21
|
-
write: 2,
|
|
22
|
-
execute: 3,
|
|
23
|
-
};
|
|
24
|
-
// ── Functions ────────────────────────────────────────────────────────
|
|
25
|
-
/**
|
|
26
|
-
* Convert a permission string to its numeric level.
|
|
27
|
-
* Returns 0 for invalid/unknown permissions.
|
|
28
|
-
*/
|
|
29
|
-
export function permissionLevel(permission) {
|
|
30
|
-
return PERMISSION_LEVELS[permission] ?? 0;
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Get the permission level for a registered project.
|
|
34
|
-
* Returns 'read' as default if the project has no explicit permission.
|
|
35
|
-
*/
|
|
36
|
-
export async function getPermission(nameOrHash) {
|
|
37
|
-
const project = await nexusGetProject(nameOrHash);
|
|
38
|
-
if (!project)
|
|
39
|
-
return 'read';
|
|
40
|
-
return project.permissions ?? 'read';
|
|
41
|
-
}
|
|
42
|
-
/**
|
|
43
|
-
* Check if a project has sufficient permissions (non-throwing).
|
|
44
|
-
* Uses hierarchical comparison: execute >= write >= read.
|
|
45
|
-
*
|
|
46
|
-
* @returns true if the granted permission meets or exceeds the required level.
|
|
47
|
-
*/
|
|
48
|
-
export async function checkPermission(nameOrHash, required) {
|
|
49
|
-
// Test bypass
|
|
50
|
-
if (process.env['NEXUS_SKIP_PERMISSION_CHECK'] === 'true') {
|
|
51
|
-
return true;
|
|
52
|
-
}
|
|
53
|
-
const granted = await getPermission(nameOrHash);
|
|
54
|
-
return permissionLevel(granted) >= permissionLevel(required);
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Require a permission level or throw CleoError.
|
|
58
|
-
* Used as a guard at the start of cross-project operations.
|
|
59
|
-
*/
|
|
60
|
-
export async function requirePermission(nameOrHash, required, operationName = 'operation') {
|
|
61
|
-
// Test bypass
|
|
62
|
-
if (process.env['NEXUS_SKIP_PERMISSION_CHECK'] === 'true') {
|
|
63
|
-
return;
|
|
64
|
-
}
|
|
65
|
-
const granted = await getPermission(nameOrHash);
|
|
66
|
-
if (permissionLevel(granted) < permissionLevel(required)) {
|
|
67
|
-
throw new CleoError(ExitCode.NEXUS_PERMISSION_DENIED, `Permission denied: '${required}' required for '${operationName}' on project '${nameOrHash}' (granted: ${granted})`);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Full permission check returning a structured result.
|
|
72
|
-
*/
|
|
73
|
-
export async function checkPermissionDetail(nameOrHash, required) {
|
|
74
|
-
const granted = await getPermission(nameOrHash);
|
|
75
|
-
return {
|
|
76
|
-
project: nameOrHash,
|
|
77
|
-
required,
|
|
78
|
-
granted,
|
|
79
|
-
allowed: permissionLevel(granted) >= permissionLevel(required),
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
/**
|
|
83
|
-
* Set the permission level for a project.
|
|
84
|
-
* Validates the permission value and updates the registry.
|
|
85
|
-
* @task T4574
|
|
86
|
-
*/
|
|
87
|
-
export async function setPermission(nameOrHash, permission) {
|
|
88
|
-
if (!nameOrHash) {
|
|
89
|
-
throw new CleoError(ExitCode.INVALID_INPUT, 'Project name or hash required');
|
|
90
|
-
}
|
|
91
|
-
await nexusSetPermission(nameOrHash, permission);
|
|
92
|
-
}
|
|
93
|
-
/** Convenience: check read access. */
|
|
94
|
-
export async function canRead(nameOrHash) {
|
|
95
|
-
return checkPermission(nameOrHash, 'read');
|
|
96
|
-
}
|
|
97
|
-
/** Convenience: check write access. */
|
|
98
|
-
export async function canWrite(nameOrHash) {
|
|
99
|
-
return checkPermission(nameOrHash, 'write');
|
|
100
|
-
}
|
|
101
|
-
/** Convenience: check execute access. */
|
|
102
|
-
export async function canExecute(nameOrHash) {
|
|
103
|
-
return checkPermission(nameOrHash, 'execute');
|
|
104
|
-
}
|
|
105
|
-
//# sourceMappingURL=permissions.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"permissions.js","sourceRoot":"","sources":["../../src/nexus/permissions.ts"],"names":[],"mappings":"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"}
|
package/dist/nexus/query.js
DELETED
|
@@ -1,175 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* NEXUS query parser and resolver - cross-project task references.
|
|
3
|
-
*
|
|
4
|
-
* Supports the `project:taskId` syntax:
|
|
5
|
-
* - `my-app:T001` - Named project
|
|
6
|
-
* - `.:T001` - Current project
|
|
7
|
-
* - `*:T001` - Wildcard (all projects)
|
|
8
|
-
* - `T001` - Implicit current project
|
|
9
|
-
*
|
|
10
|
-
* @task T4574
|
|
11
|
-
* @epic T4540
|
|
12
|
-
*/
|
|
13
|
-
import { existsSync, readFileSync } from 'node:fs';
|
|
14
|
-
import { basename, join } from 'node:path';
|
|
15
|
-
import { ExitCode } from '@cleocode/contracts';
|
|
16
|
-
import { CleoError } from '../errors.js';
|
|
17
|
-
import { getAccessor } from '../store/data-accessor.js';
|
|
18
|
-
import { nexusGetProject, readRegistry } from './registry.js';
|
|
19
|
-
// ── Query syntax ─────────────────────────────────────────────────────
|
|
20
|
-
/** Regex for a bare task ID (T followed by 3+ digits). */
|
|
21
|
-
const TASK_ID_RE = /^T\d{3,}$/;
|
|
22
|
-
/** Regex for project:taskId syntax. */
|
|
23
|
-
const QUALIFIED_RE = /^([a-z0-9_-]+|\.|\*):T\d{3,}$/;
|
|
24
|
-
/**
|
|
25
|
-
* Validate a query string matches expected syntax.
|
|
26
|
-
*/
|
|
27
|
-
export function validateSyntax(query) {
|
|
28
|
-
if (!query)
|
|
29
|
-
return false;
|
|
30
|
-
return TASK_ID_RE.test(query) || QUALIFIED_RE.test(query);
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Parse a query string into its components.
|
|
34
|
-
* @throws CleoError with NEXUS_INVALID_SYNTAX for bad format.
|
|
35
|
-
*/
|
|
36
|
-
export function parseQuery(query, currentProject) {
|
|
37
|
-
if (!validateSyntax(query)) {
|
|
38
|
-
throw new CleoError(ExitCode.NEXUS_INVALID_SYNTAX, `Invalid query syntax: ${query}. Expected: T001, project:T001, .:T001, or *:T001`);
|
|
39
|
-
}
|
|
40
|
-
// Check for colon separator
|
|
41
|
-
const colonIdx = query.indexOf(':');
|
|
42
|
-
if (colonIdx === -1) {
|
|
43
|
-
// Bare task ID -- implicit current project
|
|
44
|
-
const project = currentProject ?? getCurrentProject();
|
|
45
|
-
return { project, taskId: query, wildcard: false };
|
|
46
|
-
}
|
|
47
|
-
const prefix = query.substring(0, colonIdx);
|
|
48
|
-
const taskId = query.substring(colonIdx + 1);
|
|
49
|
-
switch (prefix) {
|
|
50
|
-
case '.': {
|
|
51
|
-
const project = currentProject ?? getCurrentProject();
|
|
52
|
-
return { project, taskId, wildcard: false };
|
|
53
|
-
}
|
|
54
|
-
case '*':
|
|
55
|
-
return { project: '*', taskId, wildcard: true };
|
|
56
|
-
default:
|
|
57
|
-
return { project: prefix, taskId, wildcard: false };
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
/**
|
|
61
|
-
* Get the current project name from context.
|
|
62
|
-
* Reads .cleo/project-info.json or falls back to directory name.
|
|
63
|
-
*/
|
|
64
|
-
export function getCurrentProject() {
|
|
65
|
-
// Allow test/env override
|
|
66
|
-
if (process.env['NEXUS_CURRENT_PROJECT']) {
|
|
67
|
-
return process.env['NEXUS_CURRENT_PROJECT'];
|
|
68
|
-
}
|
|
69
|
-
// Try to read from .cleo/project-info.json (matches bash behavior)
|
|
70
|
-
try {
|
|
71
|
-
const infoPath = join(process.cwd(), '.cleo', 'project-info.json');
|
|
72
|
-
if (existsSync(infoPath)) {
|
|
73
|
-
const data = JSON.parse(readFileSync(infoPath, 'utf-8'));
|
|
74
|
-
if (typeof data.name === 'string' && data.name.length > 0) {
|
|
75
|
-
return data.name;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
catch {
|
|
80
|
-
// Fall through to directory name
|
|
81
|
-
}
|
|
82
|
-
// Fallback to cwd directory name
|
|
83
|
-
return basename(process.cwd());
|
|
84
|
-
}
|
|
85
|
-
/**
|
|
86
|
-
* Resolve a project name to its filesystem path.
|
|
87
|
-
* Handles special cases: "." (current), "*" (wildcard marker).
|
|
88
|
-
*/
|
|
89
|
-
export async function resolveProjectPath(projectName) {
|
|
90
|
-
if (projectName === '*') {
|
|
91
|
-
return 'WILDCARD';
|
|
92
|
-
}
|
|
93
|
-
if (projectName === '.') {
|
|
94
|
-
try {
|
|
95
|
-
const accessor = await getAccessor(process.cwd());
|
|
96
|
-
const count = await accessor.countTasks();
|
|
97
|
-
if (count >= 0)
|
|
98
|
-
return process.cwd();
|
|
99
|
-
throw new Error('No task data');
|
|
100
|
-
}
|
|
101
|
-
catch {
|
|
102
|
-
throw new CleoError(ExitCode.NEXUS_PROJECT_NOT_FOUND, 'Current directory is not a CLEO project');
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
// Look up in registry
|
|
106
|
-
const project = await nexusGetProject(projectName);
|
|
107
|
-
if (!project) {
|
|
108
|
-
throw new CleoError(ExitCode.NEXUS_PROJECT_NOT_FOUND, `Project not found in registry: ${projectName}`, { fix: `cleo nexus register /path/to/project --name ${projectName}` });
|
|
109
|
-
}
|
|
110
|
-
return project.path;
|
|
111
|
-
}
|
|
112
|
-
/**
|
|
113
|
-
* Read tasks from a project's task database.
|
|
114
|
-
*/
|
|
115
|
-
async function readProjectTasks(projectPath) {
|
|
116
|
-
const tasksDbPath = join(projectPath, '.cleo', 'tasks.db');
|
|
117
|
-
try {
|
|
118
|
-
const accessor = await getAccessor(projectPath);
|
|
119
|
-
const { tasks } = await accessor.queryTasks({});
|
|
120
|
-
return tasks;
|
|
121
|
-
}
|
|
122
|
-
catch {
|
|
123
|
-
throw new CleoError(ExitCode.NOT_FOUND, `Project task data not found: ${tasksDbPath}`);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
/**
|
|
127
|
-
* Resolve a query to task data.
|
|
128
|
-
* For wildcard queries, returns an array of matches from all projects.
|
|
129
|
-
* For named projects, returns a single task with project context.
|
|
130
|
-
*/
|
|
131
|
-
export async function resolveTask(query, currentProject) {
|
|
132
|
-
const parsed = parseQuery(query, currentProject);
|
|
133
|
-
if (parsed.wildcard) {
|
|
134
|
-
return resolveWildcard(parsed.taskId);
|
|
135
|
-
}
|
|
136
|
-
// Resolve project path
|
|
137
|
-
const projectPath = await resolveProjectPath(parsed.project);
|
|
138
|
-
const tasks = await readProjectTasks(projectPath);
|
|
139
|
-
const task = tasks.find((t) => t.id === parsed.taskId);
|
|
140
|
-
if (!task) {
|
|
141
|
-
throw new CleoError(ExitCode.NOT_FOUND, `Task not found: ${parsed.taskId} in project ${parsed.project}`);
|
|
142
|
-
}
|
|
143
|
-
return { ...task, _project: parsed.project };
|
|
144
|
-
}
|
|
145
|
-
/**
|
|
146
|
-
* Search for a task ID across all registered projects.
|
|
147
|
-
*/
|
|
148
|
-
async function resolveWildcard(taskId) {
|
|
149
|
-
const registry = await readRegistry();
|
|
150
|
-
if (!registry)
|
|
151
|
-
return [];
|
|
152
|
-
const results = [];
|
|
153
|
-
for (const project of Object.values(registry.projects)) {
|
|
154
|
-
try {
|
|
155
|
-
const tasks = await readProjectTasks(project.path);
|
|
156
|
-
const match = tasks.find((t) => t.id === taskId);
|
|
157
|
-
if (match) {
|
|
158
|
-
results.push({ ...match, _project: project.name });
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
catch {
|
|
162
|
-
// Skip projects with unreadable task data
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
return results;
|
|
166
|
-
}
|
|
167
|
-
/**
|
|
168
|
-
* Extract the project name from a query without full resolution.
|
|
169
|
-
* Useful for permission checks before task lookup.
|
|
170
|
-
*/
|
|
171
|
-
export function getProjectFromQuery(query, currentProject) {
|
|
172
|
-
const parsed = parseQuery(query, currentProject);
|
|
173
|
-
return parsed.project;
|
|
174
|
-
}
|
|
175
|
-
//# sourceMappingURL=query.js.map
|
package/dist/nexus/query.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../src/nexus/query.ts"],"names":[],"mappings":"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"}
|