@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,706 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Sleep-Time Consolidation — LLM-driven background memory hygiene for CLEO BRAIN.
|
|
3
|
-
*
|
|
4
|
-
* Implements the "sleep-time compute" pattern inspired by Letta OS: after a
|
|
5
|
-
* session ends, a cheap LLM pass runs in the background to:
|
|
6
|
-
* 1. Merge near-duplicate entries (embedding similarity > 0.85)
|
|
7
|
-
* 2. Prune short-tier stale entries with low quality (7d old, quality < 0.4)
|
|
8
|
-
* 3. Synthesize frequently-cited learnings into higher-quality patterns
|
|
9
|
-
* 4. Extract cross-cutting insights from clusters of related observations
|
|
10
|
-
*
|
|
11
|
-
* All LLM calls use `claude-haiku-4-5-20251001` (cheapest available model).
|
|
12
|
-
* No API key = silent no-op for LLM steps; structural steps still run.
|
|
13
|
-
* All errors are caught and logged — nothing here may block session end.
|
|
14
|
-
*
|
|
15
|
-
* ## Configuration
|
|
16
|
-
*
|
|
17
|
-
* Add to `config.json` under `brain.sleepConsolidation`:
|
|
18
|
-
* ```json
|
|
19
|
-
* {
|
|
20
|
-
* "brain": {
|
|
21
|
-
* "sleepConsolidation": {
|
|
22
|
-
* "enabled": true
|
|
23
|
-
* }
|
|
24
|
-
* }
|
|
25
|
-
* }
|
|
26
|
-
* ```
|
|
27
|
-
*
|
|
28
|
-
* @task T555
|
|
29
|
-
* @epic T549
|
|
30
|
-
* @see packages/core/src/memory/observer-reflector.ts (Observer/Reflector pattern)
|
|
31
|
-
* @see packages/core/src/memory/brain-lifecycle.ts (runConsolidation)
|
|
32
|
-
*/
|
|
33
|
-
import { randomBytes } from 'node:crypto';
|
|
34
|
-
import { getBrainNativeDb } from '../store/brain-sqlite.js';
|
|
35
|
-
import { typedAll } from '../store/typed-query.js';
|
|
36
|
-
import { resolveAnthropicApiKey } from './anthropic-key-resolver.js';
|
|
37
|
-
import { storeLearning } from './learnings.js';
|
|
38
|
-
import { storePattern } from './patterns.js';
|
|
39
|
-
// ============================================================================
|
|
40
|
-
// Constants
|
|
41
|
-
// ============================================================================
|
|
42
|
-
/** Cheap model for all sleep-consolidation LLM calls. */
|
|
43
|
-
const SLEEP_MODEL = 'claude-haiku-4-5-20251001';
|
|
44
|
-
/** Embedding similarity threshold above which two entries are considered duplicates. */
|
|
45
|
-
const DUPLICATE_SIMILARITY_THRESHOLD = 0.85;
|
|
46
|
-
/** Minimum age (days) before a short-tier entry can be pruned for low quality. */
|
|
47
|
-
const STALE_AGE_DAYS = 7;
|
|
48
|
-
/** Maximum quality score for a short-tier entry to be considered for pruning. */
|
|
49
|
-
const PRUNE_QUALITY_THRESHOLD = 0.4;
|
|
50
|
-
/** Minimum citation count to trigger pattern synthesis for a learning. */
|
|
51
|
-
const SYNTHESIS_CITATION_MIN = 3;
|
|
52
|
-
/** Maximum tokens for LLM responses. */
|
|
53
|
-
const MAX_RESPONSE_TOKENS = 1024;
|
|
54
|
-
/** Source tag written to brain_observations for sleep-consolidation results. */
|
|
55
|
-
const SLEEP_SOURCE = 'sleep-consolidation';
|
|
56
|
-
/**
|
|
57
|
-
* Load sleep consolidation configuration from the project config.
|
|
58
|
-
* Defaults to enabled=true when config is missing or unreadable.
|
|
59
|
-
*
|
|
60
|
-
* @param projectRoot - Project root directory.
|
|
61
|
-
*/
|
|
62
|
-
async function loadSleepConfig(projectRoot) {
|
|
63
|
-
try {
|
|
64
|
-
const { loadConfig } = await import('../config.js');
|
|
65
|
-
const config = await loadConfig(projectRoot);
|
|
66
|
-
const brain = config.brain;
|
|
67
|
-
const sc = brain?.['sleepConsolidation'];
|
|
68
|
-
return { enabled: sc?.['enabled'] !== false };
|
|
69
|
-
}
|
|
70
|
-
catch {
|
|
71
|
-
return { enabled: true };
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
/**
|
|
75
|
-
* Call the Anthropic Messages API via native fetch using the cheap model.
|
|
76
|
-
*
|
|
77
|
-
* Uses `resolveAnthropicApiKey()` — never accesses ANTHROPIC_API_KEY directly.
|
|
78
|
-
* Returns null when the key is unavailable or the call fails.
|
|
79
|
-
*
|
|
80
|
-
* @param systemPrompt - System instruction for the LLM.
|
|
81
|
-
* @param userContent - User message content.
|
|
82
|
-
*/
|
|
83
|
-
async function callLlm(systemPrompt, userContent) {
|
|
84
|
-
const apiKey = resolveAnthropicApiKey();
|
|
85
|
-
if (!apiKey)
|
|
86
|
-
return null;
|
|
87
|
-
try {
|
|
88
|
-
const response = await fetch('https://api.anthropic.com/v1/messages', {
|
|
89
|
-
method: 'POST',
|
|
90
|
-
headers: {
|
|
91
|
-
'Content-Type': 'application/json',
|
|
92
|
-
'x-api-key': apiKey,
|
|
93
|
-
'anthropic-version': '2023-06-01',
|
|
94
|
-
},
|
|
95
|
-
body: JSON.stringify({
|
|
96
|
-
model: SLEEP_MODEL,
|
|
97
|
-
max_tokens: MAX_RESPONSE_TOKENS,
|
|
98
|
-
system: systemPrompt,
|
|
99
|
-
messages: [{ role: 'user', content: userContent }],
|
|
100
|
-
}),
|
|
101
|
-
});
|
|
102
|
-
if (!response.ok) {
|
|
103
|
-
const body = await response.text().catch(() => '');
|
|
104
|
-
console.warn(`[sleep-consolidation] Anthropic API error ${response.status}: ${body.slice(0, 200)}`);
|
|
105
|
-
return null;
|
|
106
|
-
}
|
|
107
|
-
const data = (await response.json());
|
|
108
|
-
const textBlock = data.content.find((b) => b.type === 'text');
|
|
109
|
-
return textBlock?.text ?? null;
|
|
110
|
-
}
|
|
111
|
-
catch (err) {
|
|
112
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
113
|
-
console.warn(`[sleep-consolidation] LLM call failed: ${msg}`);
|
|
114
|
-
return null;
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
/**
|
|
118
|
-
* Attempt to parse LLM response as JSON. Strips markdown code fences before
|
|
119
|
-
* parsing. Returns null on parse failure.
|
|
120
|
-
*/
|
|
121
|
-
function parseJson(text) {
|
|
122
|
-
try {
|
|
123
|
-
const cleaned = text
|
|
124
|
-
.replace(/^```(?:json)?\s*/m, '')
|
|
125
|
-
.replace(/\s*```\s*$/m, '')
|
|
126
|
-
.trim();
|
|
127
|
-
return JSON.parse(cleaned);
|
|
128
|
-
}
|
|
129
|
-
catch {
|
|
130
|
-
return null;
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
// ============================================================================
|
|
134
|
-
// Cosine similarity helper
|
|
135
|
-
// ============================================================================
|
|
136
|
-
/**
|
|
137
|
-
* Compute cosine similarity between two Float32 embedding buffers.
|
|
138
|
-
*
|
|
139
|
-
* Returns 0 when either buffer is null, empty, or different lengths.
|
|
140
|
-
* Embeddings are stored as raw Buffer of 4-byte floats (sqlite-vec format).
|
|
141
|
-
*
|
|
142
|
-
* @param a - First embedding buffer.
|
|
143
|
-
* @param b - Second embedding buffer.
|
|
144
|
-
*/
|
|
145
|
-
function cosineSimilarity(a, b) {
|
|
146
|
-
if (!a || !b || a.length === 0 || a.length !== b.length)
|
|
147
|
-
return 0;
|
|
148
|
-
const floatCount = Math.floor(a.length / 4);
|
|
149
|
-
if (floatCount === 0)
|
|
150
|
-
return 0;
|
|
151
|
-
let dot = 0;
|
|
152
|
-
let normA = 0;
|
|
153
|
-
let normB = 0;
|
|
154
|
-
for (let i = 0; i < floatCount; i++) {
|
|
155
|
-
const va = a.readFloatLE(i * 4);
|
|
156
|
-
const vb = b.readFloatLE(i * 4);
|
|
157
|
-
dot += va * vb;
|
|
158
|
-
normA += va * va;
|
|
159
|
-
normB += vb * vb;
|
|
160
|
-
}
|
|
161
|
-
const denom = Math.sqrt(normA) * Math.sqrt(normB);
|
|
162
|
-
return denom === 0 ? 0 : dot / denom;
|
|
163
|
-
}
|
|
164
|
-
// ============================================================================
|
|
165
|
-
// Step 1: Merge Duplicates
|
|
166
|
-
// ============================================================================
|
|
167
|
-
/**
|
|
168
|
-
* Find near-duplicate entries using embedding cosine similarity > 0.85.
|
|
169
|
-
*
|
|
170
|
-
* For each pair above the threshold, asks the LLM whether to keep/merge.
|
|
171
|
-
* The LLM confirms or overrides the merge decision. Kept entry gains the
|
|
172
|
-
* evicted entry's citation count. Duplicates are soft-evicted (invalid_at set).
|
|
173
|
-
*
|
|
174
|
-
* Falls back to structural merge (keep higher quality) when no API key is
|
|
175
|
-
* available or the LLM call fails.
|
|
176
|
-
*
|
|
177
|
-
* @param projectRoot - Project root for brain.db resolution.
|
|
178
|
-
*/
|
|
179
|
-
async function stepMergeDuplicates(projectRoot) {
|
|
180
|
-
const { getBrainDb } = await import('../store/brain-sqlite.js');
|
|
181
|
-
await getBrainDb(projectRoot);
|
|
182
|
-
const nativeDb = getBrainNativeDb();
|
|
183
|
-
if (!nativeDb)
|
|
184
|
-
return { merged: 0, llmDecisions: 0 };
|
|
185
|
-
let merged = 0;
|
|
186
|
-
let llmDecisions = 0;
|
|
187
|
-
const now = new Date().toISOString().replace('T', ' ').slice(0, 19);
|
|
188
|
-
// Fetch observations that have embeddings and are active
|
|
189
|
-
let rows;
|
|
190
|
-
try {
|
|
191
|
-
rows = typedAll(nativeDb.prepare(`
|
|
192
|
-
SELECT id, title, narrative, quality_score, citation_count, memory_tier, created_at, embedding
|
|
193
|
-
FROM brain_observations
|
|
194
|
-
WHERE embedding IS NOT NULL
|
|
195
|
-
AND invalid_at IS NULL
|
|
196
|
-
AND memory_tier = 'short'
|
|
197
|
-
ORDER BY quality_score DESC
|
|
198
|
-
LIMIT 200
|
|
199
|
-
`));
|
|
200
|
-
}
|
|
201
|
-
catch {
|
|
202
|
-
return { merged: 0, llmDecisions: 0 };
|
|
203
|
-
}
|
|
204
|
-
if (rows.length < 2)
|
|
205
|
-
return { merged: 0, llmDecisions: 0 };
|
|
206
|
-
// Build candidate pairs above the similarity threshold
|
|
207
|
-
const pairs = [];
|
|
208
|
-
for (let i = 0; i < rows.length; i++) {
|
|
209
|
-
for (let j = i + 1; j < rows.length; j++) {
|
|
210
|
-
const sim = cosineSimilarity(rows[i].embedding, rows[j].embedding);
|
|
211
|
-
if (sim >= DUPLICATE_SIMILARITY_THRESHOLD) {
|
|
212
|
-
pairs.push({ a: rows[i], b: rows[j], similarity: sim });
|
|
213
|
-
}
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
if (pairs.length === 0)
|
|
217
|
-
return { merged: 0, llmDecisions: 0 };
|
|
218
|
-
// Ask the LLM for a batch merge decision (max 10 pairs per call)
|
|
219
|
-
const pairBatch = pairs.slice(0, 10);
|
|
220
|
-
const pairDescriptions = pairBatch.map(({ a, b, similarity }, idx) => ({
|
|
221
|
-
pair: idx,
|
|
222
|
-
similarity: Math.round(similarity * 100) / 100,
|
|
223
|
-
a: { id: a.id, text: `${a.title ?? ''} ${a.narrative ?? ''}`.trim().slice(0, 120) },
|
|
224
|
-
b: { id: b.id, text: `${b.title ?? ''} ${b.narrative ?? ''}`.trim().slice(0, 120) },
|
|
225
|
-
}));
|
|
226
|
-
const systemPrompt = 'You are a memory deduplication assistant. Given pairs of nearly-identical memory entries ' +
|
|
227
|
-
'evaluate whether they should be merged. For each pair output: {"pair":N,"merge":true/false,"keep":"<id>"}. ' +
|
|
228
|
-
'Output a JSON array only, no prose. Merge when content is substantially the same; keep when content is distinct.';
|
|
229
|
-
const userContent = `Memory entry pairs to evaluate:\n${JSON.stringify(pairDescriptions, null, 2)}`;
|
|
230
|
-
let decisions = [];
|
|
231
|
-
const rawResponse = await callLlm(systemPrompt, userContent);
|
|
232
|
-
if (rawResponse) {
|
|
233
|
-
const parsed = parseJson(rawResponse);
|
|
234
|
-
if (Array.isArray(parsed)) {
|
|
235
|
-
decisions = parsed;
|
|
236
|
-
llmDecisions = decisions.filter((d) => d.merge).length;
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
// Apply decisions (structural fallback when LLM unavailable)
|
|
240
|
-
const processedIds = new Set();
|
|
241
|
-
for (let idx = 0; idx < pairBatch.length; idx++) {
|
|
242
|
-
const { a, b } = pairBatch[idx];
|
|
243
|
-
if (processedIds.has(a.id) || processedIds.has(b.id))
|
|
244
|
-
continue;
|
|
245
|
-
const decision = decisions.find((d) => d.pair === idx);
|
|
246
|
-
const shouldMerge = decision ? decision.merge : true; // default: merge near-duplicates
|
|
247
|
-
if (!shouldMerge)
|
|
248
|
-
continue;
|
|
249
|
-
// Determine which to keep: prefer LLM decision, fallback to higher quality
|
|
250
|
-
let keepId;
|
|
251
|
-
let evictId;
|
|
252
|
-
if (decision?.keep === a.id || decision?.keep === b.id) {
|
|
253
|
-
keepId = decision.keep;
|
|
254
|
-
evictId = keepId === a.id ? b.id : a.id;
|
|
255
|
-
}
|
|
256
|
-
else {
|
|
257
|
-
const aQ = a.quality_score ?? 0.5;
|
|
258
|
-
const bQ = b.quality_score ?? 0.5;
|
|
259
|
-
keepId = aQ >= bQ ? a.id : b.id;
|
|
260
|
-
evictId = keepId === a.id ? b.id : a.id;
|
|
261
|
-
}
|
|
262
|
-
const keepRow = a.id === keepId ? a : b;
|
|
263
|
-
const evictRow = a.id === evictId ? a : b;
|
|
264
|
-
const combinedCitations = (keepRow.citation_count ?? 0) + (evictRow.citation_count ?? 0);
|
|
265
|
-
try {
|
|
266
|
-
nativeDb
|
|
267
|
-
.prepare(`UPDATE brain_observations SET invalid_at = ?, updated_at = ? WHERE id = ?`)
|
|
268
|
-
.run(now, now, evictId);
|
|
269
|
-
if (combinedCitations > (keepRow.citation_count ?? 0)) {
|
|
270
|
-
nativeDb
|
|
271
|
-
.prepare(`UPDATE brain_observations SET citation_count = ?, updated_at = ? WHERE id = ?`)
|
|
272
|
-
.run(combinedCitations, now, keepId);
|
|
273
|
-
}
|
|
274
|
-
merged++;
|
|
275
|
-
processedIds.add(a.id);
|
|
276
|
-
processedIds.add(b.id);
|
|
277
|
-
}
|
|
278
|
-
catch {
|
|
279
|
-
/* best-effort */
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
return { merged, llmDecisions };
|
|
283
|
-
}
|
|
284
|
-
// ============================================================================
|
|
285
|
-
// Step 2: Prune Stale Entries
|
|
286
|
-
// ============================================================================
|
|
287
|
-
/**
|
|
288
|
-
* Prune short-tier entries older than STALE_AGE_DAYS with quality < PRUNE_QUALITY_THRESHOLD.
|
|
289
|
-
*
|
|
290
|
-
* Before evicting, asks the LLM whether any entries should be preserved despite
|
|
291
|
-
* their low score. Preserved entries have their quality_score bumped to 0.5 so
|
|
292
|
-
* they survive future prune passes.
|
|
293
|
-
*
|
|
294
|
-
* @param projectRoot - Project root for brain.db resolution.
|
|
295
|
-
*/
|
|
296
|
-
async function stepPruneStale(projectRoot) {
|
|
297
|
-
const { getBrainDb } = await import('../store/brain-sqlite.js');
|
|
298
|
-
await getBrainDb(projectRoot);
|
|
299
|
-
const nativeDb = getBrainNativeDb();
|
|
300
|
-
if (!nativeDb)
|
|
301
|
-
return { pruned: 0, preserved: 0 };
|
|
302
|
-
const staleCutoff = new Date(Date.now() - STALE_AGE_DAYS * 24 * 60 * 60 * 1000)
|
|
303
|
-
.toISOString()
|
|
304
|
-
.replace('T', ' ')
|
|
305
|
-
.slice(0, 19);
|
|
306
|
-
const now = new Date().toISOString().replace('T', ' ').slice(0, 19);
|
|
307
|
-
let candidates;
|
|
308
|
-
try {
|
|
309
|
-
candidates = typedAll(nativeDb.prepare(`
|
|
310
|
-
SELECT id, title, narrative, quality_score, citation_count, memory_tier, created_at, embedding
|
|
311
|
-
FROM brain_observations
|
|
312
|
-
WHERE memory_tier = 'short'
|
|
313
|
-
AND invalid_at IS NULL
|
|
314
|
-
AND quality_score IS NOT NULL
|
|
315
|
-
AND quality_score < ?
|
|
316
|
-
AND created_at < ?
|
|
317
|
-
ORDER BY quality_score ASC
|
|
318
|
-
LIMIT 50
|
|
319
|
-
`), PRUNE_QUALITY_THRESHOLD, staleCutoff);
|
|
320
|
-
}
|
|
321
|
-
catch {
|
|
322
|
-
return { pruned: 0, preserved: 0 };
|
|
323
|
-
}
|
|
324
|
-
if (candidates.length === 0)
|
|
325
|
-
return { pruned: 0, preserved: 0 };
|
|
326
|
-
// Ask LLM which entries to preserve despite low quality
|
|
327
|
-
const candidateDescriptions = candidates.slice(0, 20).map((row) => ({
|
|
328
|
-
id: row.id,
|
|
329
|
-
age_days: Math.round((Date.now() - new Date(row.created_at ?? 0).getTime()) / (24 * 60 * 60 * 1000)),
|
|
330
|
-
quality: Math.round((row.quality_score ?? 0) * 100) / 100,
|
|
331
|
-
citations: row.citation_count,
|
|
332
|
-
text: `${row.title ?? ''} ${row.narrative ?? ''}`.trim().slice(0, 100),
|
|
333
|
-
}));
|
|
334
|
-
const systemPrompt = 'You are a memory curator. Given a list of low-quality, stale memory entries, ' +
|
|
335
|
-
'decide which ones are worth preserving (i.e. contain unique, non-redundant information ' +
|
|
336
|
-
'that would be hard to reconstruct). Return a JSON array of IDs to preserve: {"preserve":["id1","id2",...]}. ' +
|
|
337
|
-
'Only preserve entries with genuinely unique information. When in doubt, allow eviction.';
|
|
338
|
-
const userContent = `Candidate entries for eviction:\n${JSON.stringify(candidateDescriptions, null, 2)}`;
|
|
339
|
-
let preserveIds = new Set();
|
|
340
|
-
const rawResponse = await callLlm(systemPrompt, userContent);
|
|
341
|
-
if (rawResponse) {
|
|
342
|
-
const parsed = parseJson(rawResponse);
|
|
343
|
-
if (parsed && Array.isArray(parsed.preserve)) {
|
|
344
|
-
preserveIds = new Set(parsed.preserve);
|
|
345
|
-
}
|
|
346
|
-
}
|
|
347
|
-
let pruned = 0;
|
|
348
|
-
let preserved = 0;
|
|
349
|
-
for (const row of candidates) {
|
|
350
|
-
if (preserveIds.has(row.id)) {
|
|
351
|
-
// Bump quality so it won't be pruned next pass
|
|
352
|
-
try {
|
|
353
|
-
nativeDb
|
|
354
|
-
.prepare(`UPDATE brain_observations SET quality_score = 0.5, updated_at = ? WHERE id = ?`)
|
|
355
|
-
.run(now, row.id);
|
|
356
|
-
preserved++;
|
|
357
|
-
}
|
|
358
|
-
catch {
|
|
359
|
-
/* best-effort */
|
|
360
|
-
}
|
|
361
|
-
}
|
|
362
|
-
else {
|
|
363
|
-
try {
|
|
364
|
-
nativeDb
|
|
365
|
-
.prepare(`UPDATE brain_observations SET invalid_at = ?, updated_at = ? WHERE id = ?`)
|
|
366
|
-
.run(now, now, row.id);
|
|
367
|
-
pruned++;
|
|
368
|
-
}
|
|
369
|
-
catch {
|
|
370
|
-
/* best-effort */
|
|
371
|
-
}
|
|
372
|
-
}
|
|
373
|
-
}
|
|
374
|
-
return { pruned, preserved };
|
|
375
|
-
}
|
|
376
|
-
// ============================================================================
|
|
377
|
-
// Step 3: Strengthen Patterns
|
|
378
|
-
// ============================================================================
|
|
379
|
-
/**
|
|
380
|
-
* Find learnings cited >= SYNTHESIS_CITATION_MIN times and ask the LLM to
|
|
381
|
-
* synthesize them into a single higher-quality pattern entry.
|
|
382
|
-
*
|
|
383
|
-
* The synthesized pattern is stored via storePattern() with
|
|
384
|
-
* source='sleep-consolidation'. The original learnings are left intact.
|
|
385
|
-
*
|
|
386
|
-
* @param projectRoot - Project root for brain.db resolution.
|
|
387
|
-
*/
|
|
388
|
-
async function stepStrengthenPatterns(projectRoot) {
|
|
389
|
-
const { getBrainDb } = await import('../store/brain-sqlite.js');
|
|
390
|
-
await getBrainDb(projectRoot);
|
|
391
|
-
const nativeDb = getBrainNativeDb();
|
|
392
|
-
if (!nativeDb)
|
|
393
|
-
return { synthesized: 0, patternsGenerated: 0 };
|
|
394
|
-
let candidates;
|
|
395
|
-
try {
|
|
396
|
-
candidates = typedAll(nativeDb.prepare(`
|
|
397
|
-
SELECT id, insight, confidence, citation_count, source, memory_tier
|
|
398
|
-
FROM brain_learnings
|
|
399
|
-
WHERE citation_count >= ?
|
|
400
|
-
AND invalid_at IS NULL
|
|
401
|
-
ORDER BY citation_count DESC, confidence DESC
|
|
402
|
-
LIMIT 10
|
|
403
|
-
`), SYNTHESIS_CITATION_MIN);
|
|
404
|
-
}
|
|
405
|
-
catch {
|
|
406
|
-
return { synthesized: 0, patternsGenerated: 0 };
|
|
407
|
-
}
|
|
408
|
-
if (candidates.length === 0)
|
|
409
|
-
return { synthesized: 0, patternsGenerated: 0 };
|
|
410
|
-
// Check if we already have a sleep-consolidation pattern from these
|
|
411
|
-
// (avoid re-synthesizing the same learnings every session)
|
|
412
|
-
let existingPatterns;
|
|
413
|
-
try {
|
|
414
|
-
existingPatterns = typedAll(nativeDb.prepare(`
|
|
415
|
-
SELECT id, pattern, context, impact, frequency, memory_tier
|
|
416
|
-
FROM brain_patterns
|
|
417
|
-
WHERE source_type = ?
|
|
418
|
-
AND invalid_at IS NULL
|
|
419
|
-
ORDER BY frequency DESC
|
|
420
|
-
LIMIT 5
|
|
421
|
-
`), SLEEP_SOURCE);
|
|
422
|
-
}
|
|
423
|
-
catch {
|
|
424
|
-
existingPatterns = [];
|
|
425
|
-
}
|
|
426
|
-
const existingPatternTexts = existingPatterns.map((p) => p.pattern.slice(0, 80)).join('; ');
|
|
427
|
-
const learningDescriptions = candidates.map((l) => ({
|
|
428
|
-
id: l.id,
|
|
429
|
-
insight: l.insight.slice(0, 200),
|
|
430
|
-
citations: l.citation_count,
|
|
431
|
-
confidence: Math.round(l.confidence * 100) / 100,
|
|
432
|
-
}));
|
|
433
|
-
const systemPrompt = 'You are a knowledge synthesizer. Given frequently-cited learnings, extract 1-3 ' +
|
|
434
|
-
'higher-order patterns that capture the essence of what has been repeatedly confirmed. ' +
|
|
435
|
-
'Each pattern should be actionable and generalizable. ' +
|
|
436
|
-
'Return JSON: {"patterns":[{"pattern":"...","context":"...","impact":"high|medium|low"}]}. ' +
|
|
437
|
-
'Skip patterns already captured in the existing list. Output JSON only, no prose.';
|
|
438
|
-
const userContent = `Frequently-cited learnings to synthesize:\n${JSON.stringify(learningDescriptions, null, 2)}\n\n` +
|
|
439
|
-
`Already captured patterns (do not duplicate): ${existingPatternTexts || 'none'}`;
|
|
440
|
-
const rawResponse = await callLlm(systemPrompt, userContent);
|
|
441
|
-
if (!rawResponse)
|
|
442
|
-
return { synthesized: candidates.length, patternsGenerated: 0 };
|
|
443
|
-
const parsed = parseJson(rawResponse);
|
|
444
|
-
if (!parsed || !Array.isArray(parsed.patterns)) {
|
|
445
|
-
return { synthesized: candidates.length, patternsGenerated: 0 };
|
|
446
|
-
}
|
|
447
|
-
let patternsGenerated = 0;
|
|
448
|
-
for (const p of parsed.patterns) {
|
|
449
|
-
if (!p.pattern?.trim())
|
|
450
|
-
continue;
|
|
451
|
-
try {
|
|
452
|
-
const impact = p.impact === 'high' || p.impact === 'medium' || p.impact === 'low' ? p.impact : 'medium';
|
|
453
|
-
await storePattern(projectRoot, {
|
|
454
|
-
type: 'optimization',
|
|
455
|
-
pattern: p.pattern.slice(0, 500),
|
|
456
|
-
context: (p.context ?? '').slice(0, 500),
|
|
457
|
-
impact,
|
|
458
|
-
source: SLEEP_SOURCE,
|
|
459
|
-
});
|
|
460
|
-
patternsGenerated++;
|
|
461
|
-
}
|
|
462
|
-
catch {
|
|
463
|
-
/* best-effort */
|
|
464
|
-
}
|
|
465
|
-
}
|
|
466
|
-
return { synthesized: candidates.length, patternsGenerated };
|
|
467
|
-
}
|
|
468
|
-
// ============================================================================
|
|
469
|
-
// Step 4: Generate Cross-Cutting Insights
|
|
470
|
-
// ============================================================================
|
|
471
|
-
/**
|
|
472
|
-
* Cluster recent observations by shared entity overlap and ask the LLM to
|
|
473
|
-
* extract a cross-cutting insight for each cluster.
|
|
474
|
-
*
|
|
475
|
-
* Insights are stored as brain_observations with source='sleep-consolidation'
|
|
476
|
-
* and memory_tier='medium' (they represent synthesized knowledge).
|
|
477
|
-
*
|
|
478
|
-
* @param projectRoot - Project root for brain.db resolution.
|
|
479
|
-
*/
|
|
480
|
-
async function stepGenerateInsights(projectRoot) {
|
|
481
|
-
const { getBrainDb } = await import('../store/brain-sqlite.js');
|
|
482
|
-
await getBrainDb(projectRoot);
|
|
483
|
-
const nativeDb = getBrainNativeDb();
|
|
484
|
-
if (!nativeDb)
|
|
485
|
-
return { clustersProcessed: 0, insightsStored: 0 };
|
|
486
|
-
// Fetch recent non-sleep observations (last 14 days)
|
|
487
|
-
const recent14d = new Date(Date.now() - 14 * 24 * 60 * 60 * 1000)
|
|
488
|
-
.toISOString()
|
|
489
|
-
.replace('T', ' ')
|
|
490
|
-
.slice(0, 19);
|
|
491
|
-
let observations;
|
|
492
|
-
try {
|
|
493
|
-
observations = typedAll(nativeDb.prepare(`
|
|
494
|
-
SELECT id,
|
|
495
|
-
COALESCE(title, '') || ' ' || COALESCE(narrative, '') AS text
|
|
496
|
-
FROM brain_observations
|
|
497
|
-
WHERE created_at >= ?
|
|
498
|
-
AND invalid_at IS NULL
|
|
499
|
-
AND (source_type IS NULL OR source_type NOT IN (?, 'observer-compressed'))
|
|
500
|
-
ORDER BY quality_score DESC
|
|
501
|
-
LIMIT 60
|
|
502
|
-
`), recent14d, SLEEP_SOURCE);
|
|
503
|
-
}
|
|
504
|
-
catch {
|
|
505
|
-
return { clustersProcessed: 0, insightsStored: 0 };
|
|
506
|
-
}
|
|
507
|
-
if (observations.length < 5)
|
|
508
|
-
return { clustersProcessed: 0, insightsStored: 0 };
|
|
509
|
-
// Simple entity-based clustering: tokenise each observation into words >=4
|
|
510
|
-
// chars, group observations sharing >= 3 tokens into the same cluster.
|
|
511
|
-
const STOP = new Set([
|
|
512
|
-
'this',
|
|
513
|
-
'that',
|
|
514
|
-
'with',
|
|
515
|
-
'from',
|
|
516
|
-
'have',
|
|
517
|
-
'been',
|
|
518
|
-
'will',
|
|
519
|
-
'when',
|
|
520
|
-
'then',
|
|
521
|
-
'they',
|
|
522
|
-
'were',
|
|
523
|
-
'also',
|
|
524
|
-
'into',
|
|
525
|
-
'over',
|
|
526
|
-
'some',
|
|
527
|
-
'more',
|
|
528
|
-
'very',
|
|
529
|
-
'just',
|
|
530
|
-
'each',
|
|
531
|
-
'both',
|
|
532
|
-
]);
|
|
533
|
-
function tokenize(text) {
|
|
534
|
-
const tokens = text
|
|
535
|
-
.toLowerCase()
|
|
536
|
-
.replace(/[^a-z0-9\s]/g, ' ')
|
|
537
|
-
.split(/\s+/)
|
|
538
|
-
.filter((t) => t.length >= 4 && !STOP.has(t));
|
|
539
|
-
return new Set(tokens);
|
|
540
|
-
}
|
|
541
|
-
const tokenSets = observations.map((o) => ({ id: o.id, text: o.text, tokens: tokenize(o.text) }));
|
|
542
|
-
// Build clusters greedily (each observation joins the first compatible cluster)
|
|
543
|
-
const clusters = [];
|
|
544
|
-
for (const obs of tokenSets) {
|
|
545
|
-
let placed = false;
|
|
546
|
-
for (const cluster of clusters) {
|
|
547
|
-
// Check overlap with the first member of the cluster
|
|
548
|
-
const firstText = tokenSets.find((t) => t.id === cluster.memberIds[0]);
|
|
549
|
-
if (!firstText)
|
|
550
|
-
continue;
|
|
551
|
-
let shared = 0;
|
|
552
|
-
for (const tok of obs.tokens) {
|
|
553
|
-
if (firstText.tokens.has(tok))
|
|
554
|
-
shared++;
|
|
555
|
-
}
|
|
556
|
-
if (shared >= 3) {
|
|
557
|
-
cluster.memberIds.push(obs.id);
|
|
558
|
-
cluster.texts.push(obs.text.slice(0, 120));
|
|
559
|
-
placed = true;
|
|
560
|
-
break;
|
|
561
|
-
}
|
|
562
|
-
}
|
|
563
|
-
if (!placed && clusters.length < 5) {
|
|
564
|
-
clusters.push({ memberIds: [obs.id], texts: [obs.text.slice(0, 120)] });
|
|
565
|
-
}
|
|
566
|
-
}
|
|
567
|
-
// Only process clusters with >= 3 members
|
|
568
|
-
const validClusters = clusters.filter((c) => c.memberIds.length >= 3);
|
|
569
|
-
if (validClusters.length === 0)
|
|
570
|
-
return { clustersProcessed: 0, insightsStored: 0 };
|
|
571
|
-
const clusterDescriptions = validClusters.map((c, i) => ({
|
|
572
|
-
cluster: i,
|
|
573
|
-
entries: c.texts.slice(0, 5),
|
|
574
|
-
}));
|
|
575
|
-
const systemPrompt = 'You are a cross-domain insight extractor. Given clusters of related memory entries, ' +
|
|
576
|
-
'identify one cross-cutting insight per cluster that would not be obvious from any single entry. ' +
|
|
577
|
-
'Return JSON: {"insights":[{"cluster":N,"insight":"...","confidence":0.0-1.0}]}. ' +
|
|
578
|
-
'Only include high-value insights (confidence >= 0.7). Output JSON only, no prose.';
|
|
579
|
-
const userContent = `Memory clusters to analyse:\n${JSON.stringify(clusterDescriptions, null, 2)}`;
|
|
580
|
-
const rawResponse = await callLlm(systemPrompt, userContent);
|
|
581
|
-
if (!rawResponse)
|
|
582
|
-
return { clustersProcessed: validClusters.length, insightsStored: 0 };
|
|
583
|
-
const parsed = parseJson(rawResponse);
|
|
584
|
-
if (!parsed || !Array.isArray(parsed.insights)) {
|
|
585
|
-
return { clustersProcessed: validClusters.length, insightsStored: 0 };
|
|
586
|
-
}
|
|
587
|
-
let insightsStored = 0;
|
|
588
|
-
const now = new Date().toISOString().replace('T', ' ').slice(0, 19);
|
|
589
|
-
for (const insight of parsed.insights) {
|
|
590
|
-
if (!insight.insight?.trim())
|
|
591
|
-
continue;
|
|
592
|
-
const confidence = Math.max(0, Math.min(1, insight.confidence ?? 0.7));
|
|
593
|
-
if (confidence < 0.7)
|
|
594
|
-
continue;
|
|
595
|
-
try {
|
|
596
|
-
// Store as a learning (cross-cutting insights are learnings, not observations)
|
|
597
|
-
await storeLearning(projectRoot, {
|
|
598
|
-
insight: insight.insight.slice(0, 500),
|
|
599
|
-
source: SLEEP_SOURCE,
|
|
600
|
-
confidence,
|
|
601
|
-
actionable: true,
|
|
602
|
-
application: 'Cross-cutting insight synthesized from clustered observations',
|
|
603
|
-
});
|
|
604
|
-
insightsStored++;
|
|
605
|
-
}
|
|
606
|
-
catch {
|
|
607
|
-
/* best-effort */
|
|
608
|
-
}
|
|
609
|
-
}
|
|
610
|
-
// Log the run itself as an observation for traceability
|
|
611
|
-
if (insightsStored > 0) {
|
|
612
|
-
try {
|
|
613
|
-
const runId = `O-${randomBytes(4).toString('hex')}`;
|
|
614
|
-
nativeDb
|
|
615
|
-
.prepare(`
|
|
616
|
-
INSERT INTO brain_observations
|
|
617
|
-
(id, type, title, narrative, source_type, quality_score, memory_tier, created_at)
|
|
618
|
-
VALUES (?, 'change', ?, ?, ?, 0.6, 'short', ?)
|
|
619
|
-
`)
|
|
620
|
-
.run(runId, `[sleep-consolidation] Insight generation run`, `Generated ${insightsStored} cross-cutting insights from ${validClusters.length} clusters.`, SLEEP_SOURCE, now);
|
|
621
|
-
}
|
|
622
|
-
catch {
|
|
623
|
-
/* best-effort */
|
|
624
|
-
}
|
|
625
|
-
}
|
|
626
|
-
return { clustersProcessed: validClusters.length, insightsStored };
|
|
627
|
-
}
|
|
628
|
-
// ============================================================================
|
|
629
|
-
// Main entry point
|
|
630
|
-
// ============================================================================
|
|
631
|
-
/**
|
|
632
|
-
* Run the full sleep-time consolidation pipeline for CLEO BRAIN.
|
|
633
|
-
*
|
|
634
|
-
* This is the main entry point for LLM-driven background memory hygiene.
|
|
635
|
-
* It is designed to run after session end (via setImmediate) and must never
|
|
636
|
-
* throw — all errors are caught and logged.
|
|
637
|
-
*
|
|
638
|
-
* Steps (in order):
|
|
639
|
-
* 1. Merge duplicates — embedding-similarity-based dedup with LLM confirmation
|
|
640
|
-
* 2. Prune stale — evict low-quality short-tier entries; LLM may preserve some
|
|
641
|
-
* 3. Strengthen patterns — synthesize frequently-cited learnings into patterns
|
|
642
|
-
* 4. Generate insights — extract cross-cutting insights from observation clusters
|
|
643
|
-
*
|
|
644
|
-
* Graceful degradation: when no Anthropic API key is available, LLM steps
|
|
645
|
-
* silently skip their LLM call and fall back to structural heuristics.
|
|
646
|
-
*
|
|
647
|
-
* @param projectRoot - Project root directory for brain.db resolution.
|
|
648
|
-
* @returns Aggregated result counts from each step.
|
|
649
|
-
*/
|
|
650
|
-
export async function runSleepConsolidation(projectRoot) {
|
|
651
|
-
const empty = {
|
|
652
|
-
ran: false,
|
|
653
|
-
mergeDuplicates: { merged: 0, llmDecisions: 0 },
|
|
654
|
-
pruneStale: { pruned: 0, preserved: 0 },
|
|
655
|
-
strengthenPatterns: { synthesized: 0, patternsGenerated: 0 },
|
|
656
|
-
generateInsights: { clustersProcessed: 0, insightsStored: 0 },
|
|
657
|
-
};
|
|
658
|
-
// Check configuration
|
|
659
|
-
let config;
|
|
660
|
-
try {
|
|
661
|
-
config = await loadSleepConfig(projectRoot);
|
|
662
|
-
}
|
|
663
|
-
catch {
|
|
664
|
-
config = { enabled: true };
|
|
665
|
-
}
|
|
666
|
-
if (!config.enabled) {
|
|
667
|
-
return empty;
|
|
668
|
-
}
|
|
669
|
-
const result = {
|
|
670
|
-
ran: true,
|
|
671
|
-
mergeDuplicates: { merged: 0, llmDecisions: 0 },
|
|
672
|
-
pruneStale: { pruned: 0, preserved: 0 },
|
|
673
|
-
strengthenPatterns: { synthesized: 0, patternsGenerated: 0 },
|
|
674
|
-
generateInsights: { clustersProcessed: 0, insightsStored: 0 },
|
|
675
|
-
};
|
|
676
|
-
// Step 1: Merge duplicates
|
|
677
|
-
try {
|
|
678
|
-
result.mergeDuplicates = await stepMergeDuplicates(projectRoot);
|
|
679
|
-
}
|
|
680
|
-
catch (err) {
|
|
681
|
-
console.warn('[sleep-consolidation] Step 1 (merge duplicates) failed:', err);
|
|
682
|
-
}
|
|
683
|
-
// Step 2: Prune stale
|
|
684
|
-
try {
|
|
685
|
-
result.pruneStale = await stepPruneStale(projectRoot);
|
|
686
|
-
}
|
|
687
|
-
catch (err) {
|
|
688
|
-
console.warn('[sleep-consolidation] Step 2 (prune stale) failed:', err);
|
|
689
|
-
}
|
|
690
|
-
// Step 3: Strengthen patterns
|
|
691
|
-
try {
|
|
692
|
-
result.strengthenPatterns = await stepStrengthenPatterns(projectRoot);
|
|
693
|
-
}
|
|
694
|
-
catch (err) {
|
|
695
|
-
console.warn('[sleep-consolidation] Step 3 (strengthen patterns) failed:', err);
|
|
696
|
-
}
|
|
697
|
-
// Step 4: Generate insights
|
|
698
|
-
try {
|
|
699
|
-
result.generateInsights = await stepGenerateInsights(projectRoot);
|
|
700
|
-
}
|
|
701
|
-
catch (err) {
|
|
702
|
-
console.warn('[sleep-consolidation] Step 4 (generate insights) failed:', err);
|
|
703
|
-
}
|
|
704
|
-
return result;
|
|
705
|
-
}
|
|
706
|
-
//# sourceMappingURL=sleep-consolidation.js.map
|