@cleocode/core 2026.4.7 → 2026.4.11
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/adapters/adapter-registry.js +64 -0
- package/dist/adapters/adapter-registry.js.map +1 -0
- package/dist/adapters/discovery.js +83 -0
- package/dist/adapters/discovery.js.map +1 -0
- package/dist/adapters/index.js +9 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/adapters/manager.js +260 -0
- package/dist/adapters/manager.js.map +1 -0
- package/dist/admin/export-tasks.js +171 -0
- package/dist/admin/export-tasks.js.map +1 -0
- package/dist/admin/export.js +103 -0
- package/dist/admin/export.js.map +1 -0
- package/dist/admin/help.js +106 -0
- package/dist/admin/help.js.map +1 -0
- package/dist/admin/import-tasks.js +182 -0
- package/dist/admin/import-tasks.js.map +1 -0
- package/dist/admin/import.js +129 -0
- package/dist/admin/import.js.map +1 -0
- package/dist/admin/index.js +13 -0
- package/dist/admin/index.js.map +1 -0
- package/dist/adrs/find.js +134 -0
- package/dist/adrs/find.js.map +1 -0
- package/dist/adrs/index.js +15 -0
- package/dist/adrs/index.js.map +1 -0
- package/dist/adrs/link-pipeline.js +160 -0
- package/dist/adrs/link-pipeline.js.map +1 -0
- package/dist/adrs/list.js +43 -0
- package/dist/adrs/list.js.map +1 -0
- package/dist/adrs/parse.js +51 -0
- package/dist/adrs/parse.js.map +1 -0
- package/dist/adrs/show.js +22 -0
- package/dist/adrs/show.js.map +1 -0
- package/dist/adrs/sync.js +188 -0
- package/dist/adrs/sync.js.map +1 -0
- package/dist/adrs/types.js +9 -0
- package/dist/adrs/types.js.map +1 -0
- package/dist/adrs/validate.js +57 -0
- package/dist/adrs/validate.js.map +1 -0
- package/dist/agents/agent-registry.js +288 -0
- package/dist/agents/agent-registry.js.map +1 -0
- package/dist/agents/agent-schema.d.ts +2 -2
- package/dist/agents/agent-schema.js +82 -0
- package/dist/agents/agent-schema.js.map +1 -0
- package/dist/agents/capacity.js +116 -0
- package/dist/agents/capacity.js.map +1 -0
- package/dist/agents/execution-learning.js +474 -0
- package/dist/agents/execution-learning.js.map +1 -0
- package/dist/agents/health-monitor.js +217 -0
- package/dist/agents/health-monitor.js.map +1 -0
- package/dist/agents/index.js +29 -0
- package/dist/agents/index.js.map +1 -0
- package/dist/agents/registry.js +314 -0
- package/dist/agents/registry.js.map +1 -0
- package/dist/agents/retry.js +215 -0
- package/dist/agents/retry.js.map +1 -0
- package/dist/audit-prune.js +94 -0
- package/dist/audit-prune.js.map +1 -0
- package/dist/audit.js +68 -0
- package/dist/audit.js.map +1 -0
- package/dist/backfill/index.js +229 -0
- package/dist/backfill/index.js.map +1 -0
- package/dist/bootstrap.js +344 -0
- package/dist/bootstrap.js.map +1 -0
- package/dist/caamp/adapter.js +259 -0
- package/dist/caamp/adapter.js.map +1 -0
- package/dist/caamp/capability-check.js +38 -0
- package/dist/caamp/capability-check.js.map +1 -0
- package/dist/caamp/index.js +21 -0
- package/dist/caamp/index.js.map +1 -0
- package/dist/caamp-init.js +16 -0
- package/dist/caamp-init.js.map +1 -0
- package/dist/cleo.js +322 -0
- package/dist/cleo.js.map +1 -0
- package/dist/code/index.js +10 -0
- package/dist/code/index.js.map +1 -0
- package/dist/code/outline.js +165 -0
- package/dist/code/outline.js.map +1 -0
- package/dist/code/parser.js +295 -0
- package/dist/code/parser.js.map +1 -0
- package/dist/code/search.js +135 -0
- package/dist/code/search.js.map +1 -0
- package/dist/code/unfold.js +155 -0
- package/dist/code/unfold.js.map +1 -0
- package/dist/codebase-map/analyzers/architecture.js +130 -0
- package/dist/codebase-map/analyzers/architecture.js.map +1 -0
- package/dist/codebase-map/analyzers/concerns.js +122 -0
- package/dist/codebase-map/analyzers/concerns.js.map +1 -0
- package/dist/codebase-map/analyzers/conventions.js +149 -0
- package/dist/codebase-map/analyzers/conventions.js.map +1 -0
- package/dist/codebase-map/analyzers/integrations.js +108 -0
- package/dist/codebase-map/analyzers/integrations.js.map +1 -0
- package/dist/codebase-map/analyzers/stack.js +117 -0
- package/dist/codebase-map/analyzers/stack.js.map +1 -0
- package/dist/codebase-map/analyzers/structure.js +137 -0
- package/dist/codebase-map/analyzers/structure.js.map +1 -0
- package/dist/codebase-map/analyzers/testing.js +118 -0
- package/dist/codebase-map/analyzers/testing.js.map +1 -0
- package/dist/codebase-map/index.js +57 -0
- package/dist/codebase-map/index.js.map +1 -0
- package/dist/codebase-map/store.js +122 -0
- package/dist/codebase-map/store.js.map +1 -0
- package/dist/codebase-map/summary.js +152 -0
- package/dist/codebase-map/summary.js.map +1 -0
- package/dist/compliance/index.js +288 -0
- package/dist/compliance/index.js.map +1 -0
- package/dist/compliance/protocol-enforcement.js +332 -0
- package/dist/compliance/protocol-enforcement.js.map +1 -0
- package/dist/compliance/protocol-rules.js +786 -0
- package/dist/compliance/protocol-rules.js.map +1 -0
- package/dist/compliance/protocol-types.js +79 -0
- package/dist/compliance/protocol-types.js.map +1 -0
- package/dist/compliance/store.js +53 -0
- package/dist/compliance/store.js.map +1 -0
- package/dist/conduit/conduit-client.js +107 -0
- package/dist/conduit/conduit-client.js.map +1 -0
- package/dist/conduit/factory.js +52 -0
- package/dist/conduit/factory.js.map +1 -0
- package/dist/conduit/http-transport.js +155 -0
- package/dist/conduit/http-transport.js.map +1 -0
- package/dist/conduit/index.js +15 -0
- package/dist/conduit/index.js.map +1 -0
- package/dist/conduit/local-transport.js +245 -0
- package/dist/conduit/local-transport.js.map +1 -0
- package/dist/conduit/sse-transport.js +299 -0
- package/dist/conduit/sse-transport.js.map +1 -0
- package/dist/config/build-config.js +29 -0
- package/dist/config/build-config.js.map +1 -0
- package/dist/config.js +401 -0
- package/dist/config.js.map +1 -0
- package/dist/constants.js +18 -0
- package/dist/constants.js.map +1 -0
- package/dist/context/index.js +137 -0
- package/dist/context/index.js.map +1 -0
- package/dist/crypto/credentials.js +191 -0
- package/dist/crypto/credentials.js.map +1 -0
- package/dist/discovery.js +182 -0
- package/dist/discovery.js.map +1 -0
- package/dist/engine-result.js +12 -0
- package/dist/engine-result.js.map +1 -0
- package/dist/error-catalog.js +404 -0
- package/dist/error-catalog.js.map +1 -0
- package/dist/error-registry.js +393 -0
- package/dist/error-registry.js.map +1 -0
- package/dist/errors.js +167 -0
- package/dist/errors.js.map +1 -0
- package/dist/hooks/handlers/agent-hooks.js +106 -0
- package/dist/hooks/handlers/agent-hooks.js.map +1 -0
- package/dist/hooks/handlers/context-hooks.js +111 -0
- package/dist/hooks/handlers/context-hooks.js.map +1 -0
- package/dist/hooks/handlers/error-hooks.js +52 -0
- package/dist/hooks/handlers/error-hooks.js.map +1 -0
- package/dist/hooks/handlers/file-hooks.js +104 -0
- package/dist/hooks/handlers/file-hooks.js.map +1 -0
- package/dist/hooks/handlers/handler-helpers.js +61 -0
- package/dist/hooks/handlers/handler-helpers.js.map +1 -0
- package/dist/hooks/handlers/index.js +28 -0
- package/dist/hooks/handlers/index.js.map +1 -0
- package/dist/hooks/handlers/memory-bridge-refresh.js +42 -0
- package/dist/hooks/handlers/memory-bridge-refresh.js.map +1 -0
- package/dist/hooks/handlers/notification-hooks.js +62 -0
- package/dist/hooks/handlers/notification-hooks.js.map +1 -0
- package/dist/hooks/handlers/session-hooks.d.ts +21 -0
- package/dist/hooks/handlers/session-hooks.d.ts.map +1 -1
- package/dist/hooks/handlers/session-hooks.js +142 -0
- package/dist/hooks/handlers/session-hooks.js.map +1 -0
- package/dist/hooks/handlers/task-hooks.js +65 -0
- package/dist/hooks/handlers/task-hooks.js.map +1 -0
- package/dist/hooks/handlers/work-capture-hooks.js +165 -0
- package/dist/hooks/handlers/work-capture-hooks.js.map +1 -0
- package/dist/hooks/index.js +13 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/payload-schemas.d.ts +2 -2
- package/dist/hooks/payload-schemas.js +220 -0
- package/dist/hooks/payload-schemas.js.map +1 -0
- package/dist/hooks/provider-hooks.js +66 -0
- package/dist/hooks/provider-hooks.js.map +1 -0
- package/dist/hooks/registry.js +229 -0
- package/dist/hooks/registry.js.map +1 -0
- package/dist/hooks/types.js +66 -0
- package/dist/hooks/types.js.map +1 -0
- package/dist/hooks.js +136 -0
- package/dist/hooks.js.map +1 -0
- package/dist/index.js +3361 -3095
- package/dist/index.js.map +4 -4
- package/dist/init.js +852 -0
- package/dist/init.js.map +1 -0
- package/dist/inject/index.js +82 -0
- package/dist/inject/index.js.map +1 -0
- package/dist/injection.js +343 -0
- package/dist/injection.js.map +1 -0
- package/dist/intelligence/adaptive-validation.js +497 -0
- package/dist/intelligence/adaptive-validation.js.map +1 -0
- package/dist/intelligence/impact.js +675 -0
- package/dist/intelligence/impact.js.map +1 -0
- package/dist/intelligence/index.js +22 -0
- package/dist/intelligence/index.js.map +1 -0
- package/dist/intelligence/patterns.js +492 -0
- package/dist/intelligence/patterns.js.map +1 -0
- package/dist/intelligence/prediction.js +499 -0
- package/dist/intelligence/prediction.js.map +1 -0
- package/dist/intelligence/types.js +13 -0
- package/dist/intelligence/types.js.map +1 -0
- package/dist/internal.d.ts +7 -2
- package/dist/internal.d.ts.map +1 -1
- package/dist/internal.js +299 -0
- package/dist/internal.js.map +1 -0
- package/dist/issue/create.js +121 -0
- package/dist/issue/create.js.map +1 -0
- package/dist/issue/diagnostics.js +59 -0
- package/dist/issue/diagnostics.js.map +1 -0
- package/dist/issue/index.js +10 -0
- package/dist/issue/index.js.map +1 -0
- package/dist/issue/template-parser.js +267 -0
- package/dist/issue/template-parser.js.map +1 -0
- package/dist/json-schema-validator.js +76 -0
- package/dist/json-schema-validator.js.map +1 -0
- package/dist/lib/index.js +11 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/retry.js +152 -0
- package/dist/lib/retry.js.map +1 -0
- package/dist/lib/tree-sitter-languages.js +71 -0
- package/dist/lib/tree-sitter-languages.js.map +1 -0
- package/dist/lifecycle/chain-composition.js +152 -0
- package/dist/lifecycle/chain-composition.js.map +1 -0
- package/dist/lifecycle/chain-store.js +246 -0
- package/dist/lifecycle/chain-store.js.map +1 -0
- package/dist/lifecycle/consolidate-rcasd.js +352 -0
- package/dist/lifecycle/consolidate-rcasd.js.map +1 -0
- package/dist/lifecycle/default-chain.js +176 -0
- package/dist/lifecycle/default-chain.js.map +1 -0
- package/dist/lifecycle/evidence.js +180 -0
- package/dist/lifecycle/evidence.js.map +1 -0
- package/dist/lifecycle/frontmatter.js +363 -0
- package/dist/lifecycle/frontmatter.js.map +1 -0
- package/dist/lifecycle/index.js +756 -0
- package/dist/lifecycle/index.js.map +1 -0
- package/dist/lifecycle/pipeline.js +656 -0
- package/dist/lifecycle/pipeline.js.map +1 -0
- package/dist/lifecycle/rcasd-index.js +326 -0
- package/dist/lifecycle/rcasd-index.js.map +1 -0
- package/dist/lifecycle/rcasd-paths.js +220 -0
- package/dist/lifecycle/rcasd-paths.js.map +1 -0
- package/dist/lifecycle/resume.js +864 -0
- package/dist/lifecycle/resume.js.map +1 -0
- package/dist/lifecycle/stage-artifacts.js +94 -0
- package/dist/lifecycle/stage-artifacts.js.map +1 -0
- package/dist/lifecycle/stage-guidance.js +234 -0
- package/dist/lifecycle/stage-guidance.js.map +1 -0
- package/dist/lifecycle/stages.js +534 -0
- package/dist/lifecycle/stages.js.map +1 -0
- package/dist/lifecycle/state-machine.js +516 -0
- package/dist/lifecycle/state-machine.js.map +1 -0
- package/dist/lifecycle/tessera-engine.js +249 -0
- package/dist/lifecycle/tessera-engine.js.map +1 -0
- package/dist/logger.js +140 -0
- package/dist/logger.js.map +1 -0
- package/dist/memory/auto-extract.js +177 -0
- package/dist/memory/auto-extract.js.map +1 -0
- package/dist/memory/brain-embedding.js +66 -0
- package/dist/memory/brain-embedding.js.map +1 -0
- package/dist/memory/brain-lifecycle.js +298 -0
- package/dist/memory/brain-lifecycle.js.map +1 -0
- package/dist/memory/brain-links.js +161 -0
- package/dist/memory/brain-links.js.map +1 -0
- package/dist/memory/brain-maintenance.js +114 -0
- package/dist/memory/brain-maintenance.js.map +1 -0
- package/dist/memory/brain-migration.js +149 -0
- package/dist/memory/brain-migration.js.map +1 -0
- package/dist/memory/brain-reasoning.js +215 -0
- package/dist/memory/brain-reasoning.js.map +1 -0
- package/dist/memory/brain-retrieval.js +542 -0
- package/dist/memory/brain-retrieval.js.map +1 -0
- package/dist/memory/brain-row-types.js +10 -0
- package/dist/memory/brain-row-types.js.map +1 -0
- package/dist/memory/brain-search.js +519 -0
- package/dist/memory/brain-search.js.map +1 -0
- package/dist/memory/brain-similarity.js +145 -0
- package/dist/memory/brain-similarity.js.map +1 -0
- package/dist/memory/claude-mem-migration.js +277 -0
- package/dist/memory/claude-mem-migration.js.map +1 -0
- package/dist/memory/decisions.js +162 -0
- package/dist/memory/decisions.js.map +1 -0
- package/dist/memory/embedding-local.js +97 -0
- package/dist/memory/embedding-local.js.map +1 -0
- package/dist/memory/embedding-queue.js +271 -0
- package/dist/memory/embedding-queue.js.map +1 -0
- package/dist/memory/embedding-worker.js +58 -0
- package/dist/memory/embedding-worker.js.map +1 -0
- package/dist/memory/engine-compat.js +1397 -0
- package/dist/memory/engine-compat.js.map +1 -0
- package/dist/memory/index.js +1140 -0
- package/dist/memory/index.js.map +1 -0
- package/dist/memory/learnings.d.ts +4 -4
- package/dist/memory/learnings.js +121 -0
- package/dist/memory/learnings.js.map +1 -0
- package/dist/memory/memory-bridge.js +370 -0
- package/dist/memory/memory-bridge.js.map +1 -0
- package/dist/memory/patterns.d.ts +6 -6
- package/dist/memory/patterns.js +122 -0
- package/dist/memory/patterns.js.map +1 -0
- package/dist/memory/pipeline-manifest-sqlite.js +975 -0
- package/dist/memory/pipeline-manifest-sqlite.js.map +1 -0
- package/dist/memory/session-memory.js +331 -0
- package/dist/memory/session-memory.js.map +1 -0
- package/dist/metrics/ab-test.js +260 -0
- package/dist/metrics/ab-test.js.map +1 -0
- package/dist/metrics/aggregation.js +363 -0
- package/dist/metrics/aggregation.js.map +1 -0
- package/dist/metrics/common.js +64 -0
- package/dist/metrics/common.js.map +1 -0
- package/dist/metrics/enums.js +78 -0
- package/dist/metrics/enums.js.map +1 -0
- package/dist/metrics/index.js +19 -0
- package/dist/metrics/index.js.map +1 -0
- package/dist/metrics/model-provider-registry.js +88 -0
- package/dist/metrics/model-provider-registry.js.map +1 -0
- package/dist/metrics/otel-integration.js +263 -0
- package/dist/metrics/otel-integration.js.map +1 -0
- package/dist/metrics/provider-detection.js +103 -0
- package/dist/metrics/provider-detection.js.map +1 -0
- package/dist/metrics/token-estimation.js +253 -0
- package/dist/metrics/token-estimation.js.map +1 -0
- package/dist/metrics/token-service.js +450 -0
- package/dist/metrics/token-service.js.map +1 -0
- package/dist/migration/agent-outputs.js +316 -0
- package/dist/migration/agent-outputs.js.map +1 -0
- package/dist/migration/checksum.js +92 -0
- package/dist/migration/checksum.js.map +1 -0
- package/dist/migration/index.js +282 -0
- package/dist/migration/index.js.map +1 -0
- package/dist/migration/logger.js +360 -0
- package/dist/migration/logger.js.map +1 -0
- package/dist/migration/preflight.js +9 -0
- package/dist/migration/preflight.js.map +1 -0
- package/dist/migration/state.js +421 -0
- package/dist/migration/state.js.map +1 -0
- package/dist/migration/validate.js +241 -0
- package/dist/migration/validate.js.map +1 -0
- package/dist/mvi-helpers.js +74 -0
- package/dist/mvi-helpers.js.map +1 -0
- package/dist/nexus/deps.js +375 -0
- package/dist/nexus/deps.js.map +1 -0
- package/dist/nexus/discover.js +288 -0
- package/dist/nexus/discover.js.map +1 -0
- package/dist/nexus/hash.js +10 -0
- package/dist/nexus/hash.js.map +1 -0
- package/dist/nexus/index.js +40 -0
- package/dist/nexus/index.js.map +1 -0
- package/dist/nexus/migrate-json-to-sqlite.js +115 -0
- package/dist/nexus/migrate-json-to-sqlite.js.map +1 -0
- package/dist/nexus/permissions.js +105 -0
- package/dist/nexus/permissions.js.map +1 -0
- package/dist/nexus/query.js +175 -0
- package/dist/nexus/query.js.map +1 -0
- package/dist/nexus/registry.js +584 -0
- package/dist/nexus/registry.js.map +1 -0
- package/dist/nexus/sharing/index.js +288 -0
- package/dist/nexus/sharing/index.js.map +1 -0
- package/dist/nexus/transfer-types.js +8 -0
- package/dist/nexus/transfer-types.js.map +1 -0
- package/dist/nexus/transfer.js +263 -0
- package/dist/nexus/transfer.js.map +1 -0
- package/dist/nexus/workspace.js +355 -0
- package/dist/nexus/workspace.js.map +1 -0
- package/dist/observability/index.js +103 -0
- package/dist/observability/index.js.map +1 -0
- package/dist/observability/log-filter.js +63 -0
- package/dist/observability/log-filter.js.map +1 -0
- package/dist/observability/log-parser.js +99 -0
- package/dist/observability/log-parser.js.map +1 -0
- package/dist/observability/log-reader.js +139 -0
- package/dist/observability/log-reader.js.map +1 -0
- package/dist/observability/types.js +19 -0
- package/dist/observability/types.js.map +1 -0
- package/dist/orchestration/analyze.js +107 -0
- package/dist/orchestration/analyze.js.map +1 -0
- package/dist/orchestration/bootstrap.js +132 -0
- package/dist/orchestration/bootstrap.js.map +1 -0
- package/dist/orchestration/context.js +56 -0
- package/dist/orchestration/context.js.map +1 -0
- package/dist/orchestration/critical-path.js +100 -0
- package/dist/orchestration/critical-path.js.map +1 -0
- package/dist/orchestration/hierarchy.js +183 -0
- package/dist/orchestration/hierarchy.js.map +1 -0
- package/dist/orchestration/index.js +287 -0
- package/dist/orchestration/index.js.map +1 -0
- package/dist/orchestration/parallel.js +89 -0
- package/dist/orchestration/parallel.js.map +1 -0
- package/dist/orchestration/protocol-validators.js +815 -0
- package/dist/orchestration/protocol-validators.js.map +1 -0
- package/dist/orchestration/skill-ops.js +98 -0
- package/dist/orchestration/skill-ops.js.map +1 -0
- package/dist/orchestration/status.js +107 -0
- package/dist/orchestration/status.js.map +1 -0
- package/dist/orchestration/unblock.js +103 -0
- package/dist/orchestration/unblock.js.map +1 -0
- package/dist/orchestration/validate-spawn.js +67 -0
- package/dist/orchestration/validate-spawn.js.map +1 -0
- package/dist/orchestration/waves.js +86 -0
- package/dist/orchestration/waves.js.map +1 -0
- package/dist/otel/index.js +163 -0
- package/dist/otel/index.js.map +1 -0
- package/dist/output.js +164 -0
- package/dist/output.js.map +1 -0
- package/dist/pagination.js +64 -0
- package/dist/pagination.js.map +1 -0
- package/dist/paths.d.ts +39 -9
- package/dist/paths.d.ts.map +1 -1
- package/dist/paths.js +776 -0
- package/dist/paths.js.map +1 -0
- package/dist/phases/deps.js +372 -0
- package/dist/phases/deps.js.map +1 -0
- package/dist/phases/index.js +349 -0
- package/dist/phases/index.js.map +1 -0
- package/dist/pipeline/index.js +10 -0
- package/dist/pipeline/index.js.map +1 -0
- package/dist/pipeline/phase.js +45 -0
- package/dist/pipeline/phase.js.map +1 -0
- package/dist/platform.js +211 -0
- package/dist/platform.js.map +1 -0
- package/dist/project-info.js +84 -0
- package/dist/project-info.js.map +1 -0
- package/dist/reconciliation/index.js +10 -0
- package/dist/reconciliation/index.js.map +1 -0
- package/dist/reconciliation/link-store.js +129 -0
- package/dist/reconciliation/link-store.js.map +1 -0
- package/dist/reconciliation/reconciliation-engine.js +298 -0
- package/dist/reconciliation/reconciliation-engine.js.map +1 -0
- package/dist/release/artifacts.js +427 -0
- package/dist/release/artifacts.js.map +1 -0
- package/dist/release/changelog-writer.js +151 -0
- package/dist/release/changelog-writer.js.map +1 -0
- package/dist/release/channel.js +144 -0
- package/dist/release/channel.js.map +1 -0
- package/dist/release/ci.js +166 -0
- package/dist/release/ci.js.map +1 -0
- package/dist/release/github-pr.js +225 -0
- package/dist/release/github-pr.js.map +1 -0
- package/dist/release/guards.js +116 -0
- package/dist/release/guards.js.map +1 -0
- package/dist/release/index.js +22 -0
- package/dist/release/index.js.map +1 -0
- package/dist/release/release-config.js +158 -0
- package/dist/release/release-config.js.map +1 -0
- package/dist/release/release-manifest.js +1019 -0
- package/dist/release/release-manifest.js.map +1 -0
- package/dist/release/version-bump.js +255 -0
- package/dist/release/version-bump.js.map +1 -0
- package/dist/remote/index.js +257 -0
- package/dist/remote/index.js.map +1 -0
- package/dist/repair.js +130 -0
- package/dist/repair.js.map +1 -0
- package/dist/research/index.js +2 -0
- package/dist/research/index.js.map +1 -0
- package/dist/roadmap/index.js +59 -0
- package/dist/roadmap/index.js.map +1 -0
- package/dist/routing/capability-matrix.js +1556 -0
- package/dist/routing/capability-matrix.js.map +1 -0
- package/dist/routing/index.js +9 -0
- package/dist/routing/index.js.map +1 -0
- package/dist/scaffold.d.ts +15 -2
- package/dist/scaffold.d.ts.map +1 -1
- package/dist/scaffold.js +1759 -0
- package/dist/scaffold.js.map +1 -0
- package/dist/schema-management.js +295 -0
- package/dist/schema-management.js.map +1 -0
- package/dist/security/index.js +9 -0
- package/dist/security/index.js.map +1 -0
- package/dist/security/input-sanitization.js +321 -0
- package/dist/security/input-sanitization.js.map +1 -0
- package/dist/sequence/index.js +295 -0
- package/dist/sequence/index.js.map +1 -0
- package/dist/sessions/assumptions.js +54 -0
- package/dist/sessions/assumptions.js.map +1 -0
- package/dist/sessions/briefing.js +377 -0
- package/dist/sessions/briefing.js.map +1 -0
- package/dist/sessions/context-alert.js +222 -0
- package/dist/sessions/context-alert.js.map +1 -0
- package/dist/sessions/context-inject.js +61 -0
- package/dist/sessions/context-inject.js.map +1 -0
- package/dist/sessions/context-monitor.js +98 -0
- package/dist/sessions/context-monitor.js.map +1 -0
- package/dist/sessions/decisions.js +65 -0
- package/dist/sessions/decisions.js.map +1 -0
- package/dist/sessions/find.js +65 -0
- package/dist/sessions/find.js.map +1 -0
- package/dist/sessions/handoff.js +328 -0
- package/dist/sessions/handoff.js.map +1 -0
- package/dist/sessions/hitl-warnings.js +254 -0
- package/dist/sessions/hitl-warnings.js.map +1 -0
- package/dist/sessions/index.js +327 -0
- package/dist/sessions/index.js.map +1 -0
- package/dist/sessions/session-archive.js +40 -0
- package/dist/sessions/session-archive.js.map +1 -0
- package/dist/sessions/session-cleanup.js +59 -0
- package/dist/sessions/session-cleanup.js.map +1 -0
- package/dist/sessions/session-drift.js +134 -0
- package/dist/sessions/session-drift.js.map +1 -0
- package/dist/sessions/session-enforcement.js +144 -0
- package/dist/sessions/session-enforcement.js.map +1 -0
- package/dist/sessions/session-grade.js +253 -0
- package/dist/sessions/session-grade.js.map +1 -0
- package/dist/sessions/session-history.js +42 -0
- package/dist/sessions/session-history.js.map +1 -0
- package/dist/sessions/session-id.js +81 -0
- package/dist/sessions/session-id.js.map +1 -0
- package/dist/sessions/session-memory-bridge.js +52 -0
- package/dist/sessions/session-memory-bridge.js.map +1 -0
- package/dist/sessions/session-show.js +24 -0
- package/dist/sessions/session-show.js.map +1 -0
- package/dist/sessions/session-stats.js +69 -0
- package/dist/sessions/session-stats.js.map +1 -0
- package/dist/sessions/session-suspend.js +39 -0
- package/dist/sessions/session-suspend.js.map +1 -0
- package/dist/sessions/session-switch.js +51 -0
- package/dist/sessions/session-switch.js.map +1 -0
- package/dist/sessions/session-view.js +76 -0
- package/dist/sessions/session-view.js.map +1 -0
- package/dist/sessions/snapshot.js +213 -0
- package/dist/sessions/snapshot.js.map +1 -0
- package/dist/sessions/statusline-setup.js +85 -0
- package/dist/sessions/statusline-setup.js.map +1 -0
- package/dist/sessions/types.js +8 -0
- package/dist/sessions/types.js.map +1 -0
- package/dist/skills/agents/config.js +94 -0
- package/dist/skills/agents/config.js.map +1 -0
- package/dist/skills/agents/install.js +116 -0
- package/dist/skills/agents/install.js.map +1 -0
- package/dist/skills/agents/registry.js +161 -0
- package/dist/skills/agents/registry.js.map +1 -0
- package/dist/skills/discovery.js +333 -0
- package/dist/skills/discovery.js.map +1 -0
- package/dist/skills/dispatch.js +347 -0
- package/dist/skills/dispatch.js.map +1 -0
- package/dist/skills/dynamic-skill-generator.js +87 -0
- package/dist/skills/dynamic-skill-generator.js.map +1 -0
- package/dist/skills/index.js +44 -0
- package/dist/skills/index.js.map +1 -0
- package/dist/skills/injection/subagent.js +195 -0
- package/dist/skills/injection/subagent.js.map +1 -0
- package/dist/skills/injection/token.js +260 -0
- package/dist/skills/injection/token.js.map +1 -0
- package/dist/skills/install.js +40 -0
- package/dist/skills/install.js.map +1 -0
- package/dist/skills/manifests/contribution.js +175 -0
- package/dist/skills/manifests/contribution.js.map +1 -0
- package/dist/skills/manifests/research.js +281 -0
- package/dist/skills/manifests/research.js.map +1 -0
- package/dist/skills/manifests/resolver.js +146 -0
- package/dist/skills/manifests/resolver.js.map +1 -0
- package/dist/skills/marketplace.js +90 -0
- package/dist/skills/marketplace.js.map +1 -0
- package/dist/skills/orchestrator/spawn.js +178 -0
- package/dist/skills/orchestrator/spawn.js.map +1 -0
- package/dist/skills/orchestrator/startup.js +451 -0
- package/dist/skills/orchestrator/startup.js.map +1 -0
- package/dist/skills/orchestrator/validator.js +301 -0
- package/dist/skills/orchestrator/validator.js.map +1 -0
- package/dist/skills/precedence-integration.js +73 -0
- package/dist/skills/precedence-integration.js.map +1 -0
- package/dist/skills/precedence-types.js +16 -0
- package/dist/skills/precedence-types.js.map +1 -0
- package/dist/skills/routing-table.js +63 -0
- package/dist/skills/routing-table.js.map +1 -0
- package/dist/skills/skill-paths.js +217 -0
- package/dist/skills/skill-paths.js.map +1 -0
- package/dist/skills/test-utility.js +55 -0
- package/dist/skills/test-utility.js.map +1 -0
- package/dist/skills/types.js +118 -0
- package/dist/skills/types.js.map +1 -0
- package/dist/skills/validation.js +183 -0
- package/dist/skills/validation.js.map +1 -0
- package/dist/skills/version.js +57 -0
- package/dist/skills/version.js.map +1 -0
- package/dist/snapshot/index.js +188 -0
- package/dist/snapshot/index.js.map +1 -0
- package/dist/spawn/adapter-registry.js +246 -0
- package/dist/spawn/adapter-registry.js.map +1 -0
- package/dist/spawn/index.js +10 -0
- package/dist/spawn/index.js.map +1 -0
- package/dist/stats/index.js +343 -0
- package/dist/stats/index.js.map +1 -0
- package/dist/stats/workflow-telemetry.js +400 -0
- package/dist/stats/workflow-telemetry.js.map +1 -0
- package/dist/sticky/archive.js +47 -0
- package/dist/sticky/archive.js.map +1 -0
- package/dist/sticky/convert.js +235 -0
- package/dist/sticky/convert.js.map +1 -0
- package/dist/sticky/create.js +48 -0
- package/dist/sticky/create.js.map +1 -0
- package/dist/sticky/id.js +35 -0
- package/dist/sticky/id.js.map +1 -0
- package/dist/sticky/index.js +16 -0
- package/dist/sticky/index.js.map +1 -0
- package/dist/sticky/list.js +44 -0
- package/dist/sticky/list.js.map +1 -0
- package/dist/sticky/purge.js +45 -0
- package/dist/sticky/purge.js.map +1 -0
- package/dist/sticky/show.js +42 -0
- package/dist/sticky/show.js.map +1 -0
- package/dist/sticky/types.js +10 -0
- package/dist/sticky/types.js.map +1 -0
- package/dist/store/agent-registry-accessor.js +265 -0
- package/dist/store/agent-registry-accessor.js.map +1 -0
- package/dist/store/atomic.js +167 -0
- package/dist/store/atomic.js.map +1 -0
- package/dist/store/backup.js +94 -0
- package/dist/store/backup.js.map +1 -0
- package/dist/store/brain-accessor.js +397 -0
- package/dist/store/brain-accessor.js.map +1 -0
- package/dist/store/brain-schema.d.ts +8 -8
- package/dist/store/brain-schema.js +215 -0
- package/dist/store/brain-schema.js.map +1 -0
- package/dist/store/brain-sqlite.js +222 -0
- package/dist/store/brain-sqlite.js.map +1 -0
- package/dist/store/cache.js +168 -0
- package/dist/store/cache.js.map +1 -0
- package/dist/store/chain-schema.js +51 -0
- package/dist/store/chain-schema.js.map +1 -0
- package/dist/store/cleanup-legacy.d.ts +128 -0
- package/dist/store/cleanup-legacy.d.ts.map +1 -0
- package/dist/store/converters.js +124 -0
- package/dist/store/converters.js.map +1 -0
- package/dist/store/cross-db-cleanup.js +319 -0
- package/dist/store/cross-db-cleanup.js.map +1 -0
- package/dist/store/data-accessor.js +26 -0
- package/dist/store/data-accessor.js.map +1 -0
- package/dist/store/data-safety-central.js +269 -0
- package/dist/store/data-safety-central.js.map +1 -0
- package/dist/store/data-safety.js +274 -0
- package/dist/store/data-safety.js.map +1 -0
- package/dist/store/db-helpers.js +224 -0
- package/dist/store/db-helpers.js.map +1 -0
- package/dist/store/export.js +155 -0
- package/dist/store/export.js.map +1 -0
- package/dist/store/file-utils.js +270 -0
- package/dist/store/file-utils.js.map +1 -0
- package/dist/store/git-checkpoint.js +365 -0
- package/dist/store/git-checkpoint.js.map +1 -0
- package/dist/store/import-logging.js +139 -0
- package/dist/store/import-logging.js.map +1 -0
- package/dist/store/import-remap.js +145 -0
- package/dist/store/import-remap.js.map +1 -0
- package/dist/store/import-sort.js +121 -0
- package/dist/store/import-sort.js.map +1 -0
- package/dist/store/index.d.ts +1 -0
- package/dist/store/index.d.ts.map +1 -1
- package/dist/store/index.js +29 -0
- package/dist/store/index.js.map +1 -0
- package/dist/store/json.js +208 -0
- package/dist/store/json.js.map +1 -0
- package/dist/store/lifecycle-store.js +249 -0
- package/dist/store/lifecycle-store.js.map +1 -0
- package/dist/store/lock.js +70 -0
- package/dist/store/lock.js.map +1 -0
- package/dist/store/migration-manager.js +151 -0
- package/dist/store/migration-manager.js.map +1 -0
- package/dist/store/migration-sqlite.js +676 -0
- package/dist/store/migration-sqlite.js.map +1 -0
- package/dist/store/nexus-schema.js +62 -0
- package/dist/store/nexus-schema.js.map +1 -0
- package/dist/store/nexus-sqlite.d.ts +14 -2
- package/dist/store/nexus-sqlite.d.ts.map +1 -1
- package/dist/store/nexus-sqlite.js +217 -0
- package/dist/store/nexus-sqlite.js.map +1 -0
- package/dist/store/nexus-validation-schemas.js +40 -0
- package/dist/store/nexus-validation-schemas.js.map +1 -0
- package/dist/store/parsers.js +37 -0
- package/dist/store/parsers.js.map +1 -0
- package/dist/store/project-detect.js +457 -0
- package/dist/store/project-detect.js.map +1 -0
- package/dist/store/provider.js +101 -0
- package/dist/store/provider.js.map +1 -0
- package/dist/store/safety-data-accessor.js +257 -0
- package/dist/store/safety-data-accessor.js.map +1 -0
- package/dist/store/schema.js +7 -0
- package/dist/store/schema.js.map +1 -0
- package/dist/store/session-store.js +219 -0
- package/dist/store/session-store.js.map +1 -0
- package/dist/store/signaldock-sqlite.js +400 -0
- package/dist/store/signaldock-sqlite.js.map +1 -0
- package/dist/store/sqlite-backup.d.ts +121 -10
- package/dist/store/sqlite-backup.d.ts.map +1 -1
- package/dist/store/sqlite-backup.js +241 -0
- package/dist/store/sqlite-backup.js.map +1 -0
- package/dist/store/sqlite-data-accessor.js +787 -0
- package/dist/store/sqlite-data-accessor.js.map +1 -0
- package/dist/store/sqlite.d.ts.map +1 -1
- package/dist/store/sqlite.js +481 -0
- package/dist/store/sqlite.js.map +1 -0
- package/dist/store/status-registry.js +8 -0
- package/dist/store/status-registry.js.map +1 -0
- package/dist/store/task-store.js +358 -0
- package/dist/store/task-store.js.map +1 -0
- package/dist/store/tasks-schema.d.ts +8 -8
- package/dist/store/tasks-schema.js +610 -0
- package/dist/store/tasks-schema.js.map +1 -0
- package/dist/store/typed-query.js +15 -0
- package/dist/store/typed-query.js.map +1 -0
- package/dist/store/validation-schemas.d.ts +37 -37
- package/dist/store/validation-schemas.js +278 -0
- package/dist/store/validation-schemas.js.map +1 -0
- package/dist/system/archive-analytics.js +277 -0
- package/dist/system/archive-analytics.js.map +1 -0
- package/dist/system/archive-stats.js +64 -0
- package/dist/system/archive-stats.js.map +1 -0
- package/dist/system/audit.js +145 -0
- package/dist/system/audit.js.map +1 -0
- package/dist/system/backup.d.ts +91 -3
- package/dist/system/backup.d.ts.map +1 -1
- package/dist/system/backup.js +280 -0
- package/dist/system/backup.js.map +1 -0
- package/dist/system/cleanup.js +134 -0
- package/dist/system/cleanup.js.map +1 -0
- package/dist/system/health.js +1100 -0
- package/dist/system/health.js.map +1 -0
- package/dist/system/index.js +18 -0
- package/dist/system/index.js.map +1 -0
- package/dist/system/inject-generate.js +122 -0
- package/dist/system/inject-generate.js.map +1 -0
- package/dist/system/labels.js +38 -0
- package/dist/system/labels.js.map +1 -0
- package/dist/system/metrics.js +61 -0
- package/dist/system/metrics.js.map +1 -0
- package/dist/system/migrate.js +43 -0
- package/dist/system/migrate.js.map +1 -0
- package/dist/system/platform-paths.js +80 -0
- package/dist/system/platform-paths.js.map +1 -0
- package/dist/system/runtime.js +161 -0
- package/dist/system/runtime.js.map +1 -0
- package/dist/system/safestop.js +99 -0
- package/dist/system/safestop.js.map +1 -0
- package/dist/system/storage-preflight.js +123 -0
- package/dist/system/storage-preflight.js.map +1 -0
- package/dist/task-work/index.js +159 -0
- package/dist/task-work/index.js.map +1 -0
- package/dist/tasks/add.js +661 -0
- package/dist/tasks/add.js.map +1 -0
- package/dist/tasks/analyze.js +85 -0
- package/dist/tasks/analyze.js.map +1 -0
- package/dist/tasks/archive.js +90 -0
- package/dist/tasks/archive.js.map +1 -0
- package/dist/tasks/atomicity.js +83 -0
- package/dist/tasks/atomicity.js.map +1 -0
- package/dist/tasks/cancel-ops.js +83 -0
- package/dist/tasks/cancel-ops.js.map +1 -0
- package/dist/tasks/complete.js +211 -0
- package/dist/tasks/complete.js.map +1 -0
- package/dist/tasks/crossref-extract.js +73 -0
- package/dist/tasks/crossref-extract.js.map +1 -0
- package/dist/tasks/delete-preview.js +192 -0
- package/dist/tasks/delete-preview.js.map +1 -0
- package/dist/tasks/delete.js +120 -0
- package/dist/tasks/delete.js.map +1 -0
- package/dist/tasks/deletion-strategy.js +200 -0
- package/dist/tasks/deletion-strategy.js.map +1 -0
- package/dist/tasks/dependency-check.js +278 -0
- package/dist/tasks/dependency-check.js.map +1 -0
- package/dist/tasks/deps-ready.js +32 -0
- package/dist/tasks/deps-ready.js.map +1 -0
- package/dist/tasks/enforcement.js +86 -0
- package/dist/tasks/enforcement.js.map +1 -0
- package/dist/tasks/epic-enforcement.js +294 -0
- package/dist/tasks/epic-enforcement.js.map +1 -0
- package/dist/tasks/find.js +154 -0
- package/dist/tasks/find.js.map +1 -0
- package/dist/tasks/graph-cache.js +127 -0
- package/dist/tasks/graph-cache.js.map +1 -0
- package/dist/tasks/graph-ops.js +171 -0
- package/dist/tasks/graph-ops.js.map +1 -0
- package/dist/tasks/graph-rag.js +328 -0
- package/dist/tasks/graph-rag.js.map +1 -0
- package/dist/tasks/hierarchy-policy.js +149 -0
- package/dist/tasks/hierarchy-policy.js.map +1 -0
- package/dist/tasks/hierarchy.js +185 -0
- package/dist/tasks/hierarchy.js.map +1 -0
- package/dist/tasks/id-generator.js +65 -0
- package/dist/tasks/id-generator.js.map +1 -0
- package/dist/tasks/index.js +14 -0
- package/dist/tasks/index.js.map +1 -0
- package/dist/tasks/labels.js +52 -0
- package/dist/tasks/labels.js.map +1 -0
- package/dist/tasks/list.js +75 -0
- package/dist/tasks/list.js.map +1 -0
- package/dist/tasks/phase-tracking.js +133 -0
- package/dist/tasks/phase-tracking.js.map +1 -0
- package/dist/tasks/pipeline-stage.js +248 -0
- package/dist/tasks/pipeline-stage.js.map +1 -0
- package/dist/tasks/plan.js +268 -0
- package/dist/tasks/plan.js.map +1 -0
- package/dist/tasks/relates.js +89 -0
- package/dist/tasks/relates.js.map +1 -0
- package/dist/tasks/show.js +80 -0
- package/dist/tasks/show.js.map +1 -0
- package/dist/tasks/size-weighting.js +86 -0
- package/dist/tasks/size-weighting.js.map +1 -0
- package/dist/tasks/staleness.js +86 -0
- package/dist/tasks/staleness.js.map +1 -0
- package/dist/tasks/task-ops.js +1741 -0
- package/dist/tasks/task-ops.js.map +1 -0
- package/dist/tasks/update.js +277 -0
- package/dist/tasks/update.js.map +1 -0
- package/dist/templates/index.js +10 -0
- package/dist/templates/index.js.map +1 -0
- package/dist/templates/parser.js +254 -0
- package/dist/templates/parser.js.map +1 -0
- package/dist/ui/aliases.js +153 -0
- package/dist/ui/aliases.js.map +1 -0
- package/dist/ui/changelog.js +184 -0
- package/dist/ui/changelog.js.map +1 -0
- package/dist/ui/command-registry.js +168 -0
- package/dist/ui/command-registry.js.map +1 -0
- package/dist/ui/flags.js +94 -0
- package/dist/ui/flags.js.map +1 -0
- package/dist/ui/index.js +24 -0
- package/dist/ui/index.js.map +1 -0
- package/dist/upgrade.js +1148 -0
- package/dist/upgrade.js.map +1 -0
- package/dist/validation/chain-validation.js +146 -0
- package/dist/validation/chain-validation.js.map +1 -0
- package/dist/validation/compliance.js +155 -0
- package/dist/validation/compliance.js.map +1 -0
- package/dist/validation/docs-sync.js +212 -0
- package/dist/validation/docs-sync.js.map +1 -0
- package/dist/validation/doctor/checks.js +1069 -0
- package/dist/validation/doctor/checks.js.map +1 -0
- package/dist/validation/doctor/index.js +9 -0
- package/dist/validation/doctor/index.js.map +1 -0
- package/dist/validation/doctor/project-cache.js +160 -0
- package/dist/validation/doctor/project-cache.js.map +1 -0
- package/dist/validation/doctor/utils.js +155 -0
- package/dist/validation/doctor/utils.js.map +1 -0
- package/dist/validation/engine.js +902 -0
- package/dist/validation/engine.js.map +1 -0
- package/dist/validation/gap-check.js +175 -0
- package/dist/validation/gap-check.js.map +1 -0
- package/dist/validation/index.js +40 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/manifest.js +237 -0
- package/dist/validation/manifest.js.map +1 -0
- package/dist/validation/operation-gate-validators.js +724 -0
- package/dist/validation/operation-gate-validators.js.map +1 -0
- package/dist/validation/operation-verification-gates.js +532 -0
- package/dist/validation/operation-verification-gates.js.map +1 -0
- package/dist/validation/param-utils.js +139 -0
- package/dist/validation/param-utils.js.map +1 -0
- package/dist/validation/protocol-common.js +300 -0
- package/dist/validation/protocol-common.js.map +1 -0
- package/dist/validation/protocols/_shared.js +75 -0
- package/dist/validation/protocols/_shared.js.map +1 -0
- package/dist/validation/protocols/architecture-decision.js +31 -0
- package/dist/validation/protocols/architecture-decision.js.map +1 -0
- package/dist/validation/protocols/artifact-publish.js +28 -0
- package/dist/validation/protocols/artifact-publish.js.map +1 -0
- package/dist/validation/protocols/consensus.js +41 -0
- package/dist/validation/protocols/consensus.js.map +1 -0
- package/dist/validation/protocols/contribution.js +27 -0
- package/dist/validation/protocols/contribution.js.map +1 -0
- package/dist/validation/protocols/decomposition.js +28 -0
- package/dist/validation/protocols/decomposition.js.map +1 -0
- package/dist/validation/protocols/implementation.js +24 -0
- package/dist/validation/protocols/implementation.js.map +1 -0
- package/dist/validation/protocols/provenance.js +29 -0
- package/dist/validation/protocols/provenance.js.map +1 -0
- package/dist/validation/protocols/release.js +29 -0
- package/dist/validation/protocols/release.js.map +1 -0
- package/dist/validation/protocols/research.js +24 -0
- package/dist/validation/protocols/research.js.map +1 -0
- package/dist/validation/protocols/specification.js +27 -0
- package/dist/validation/protocols/specification.js.map +1 -0
- package/dist/validation/protocols/testing.js +30 -0
- package/dist/validation/protocols/testing.js.map +1 -0
- package/dist/validation/protocols/validation.js +30 -0
- package/dist/validation/protocols/validation.js.map +1 -0
- package/dist/validation/schema-integrity.js +170 -0
- package/dist/validation/schema-integrity.js.map +1 -0
- package/dist/validation/schema-validator.js +176 -0
- package/dist/validation/schema-validator.js.map +1 -0
- package/dist/validation/validate-ops.js +937 -0
- package/dist/validation/validate-ops.js.map +1 -0
- package/dist/validation/validation-rules.js +226 -0
- package/dist/validation/validation-rules.js.map +1 -0
- package/dist/validation/verification.js +321 -0
- package/dist/validation/verification.js.map +1 -0
- package/package.json +10 -8
- package/src/__tests__/paths-walkup.test.ts +305 -0
- package/src/__tests__/paths.test.ts +61 -17
- package/src/hooks/handlers/session-hooks.ts +42 -0
- package/src/internal.ts +19 -2
- package/src/paths.ts +91 -14
- package/src/scaffold.ts +22 -3
- package/src/store/__tests__/cleanup-legacy.test.ts +268 -0
- package/src/store/__tests__/database-topology-integration.test.ts +504 -0
- package/src/store/__tests__/sqlite-backup-global.test.ts +281 -0
- package/src/store/__tests__/sqlite-backup.test.ts +118 -10
- package/src/store/cleanup-legacy.ts +208 -0
- package/src/store/index.ts +7 -0
- package/src/store/nexus-sqlite.ts +32 -3
- package/src/store/sqlite-backup.ts +368 -37
- package/src/store/sqlite.ts +19 -3
- package/src/system/__tests__/backup.test.ts +237 -0
- package/src/system/backup.ts +248 -28
- package/templates/cleo-gitignore +19 -3
package/dist/init.js
ADDED
|
@@ -0,0 +1,852 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Core init logic - project initialization and maintenance.
|
|
3
|
+
*
|
|
4
|
+
* Single source of truth for all init operations. CLI delegates here
|
|
5
|
+
* (shared-core pattern).
|
|
6
|
+
*
|
|
7
|
+
* Handles:
|
|
8
|
+
* 1. .cleo/ directory structure creation
|
|
9
|
+
* 2. Core data files (config.json, tasks.db)
|
|
10
|
+
* 3. Schema file installation (~/.cleo/schemas/)
|
|
11
|
+
* 4. Sequence counter (SQLite schema_meta)
|
|
12
|
+
* 5. Project info (.cleo/project-info.json)
|
|
13
|
+
* 6. CAAMP injection into agent instruction files (AGENTS.md hub pattern)
|
|
14
|
+
* 7. (removed — was MCP server installation)
|
|
15
|
+
* 8. Agent definition installation (cleo-subagent)
|
|
16
|
+
* 9. Core skill installation via CAAMP
|
|
17
|
+
* 10. NEXUS project registration
|
|
18
|
+
* 11. Project type detection (--detect)
|
|
19
|
+
* 12. Injection refresh
|
|
20
|
+
* 13. Git hook installation (commit-msg, pre-commit)
|
|
21
|
+
* 14. GitHub issue/PR templates (.github/ directory)
|
|
22
|
+
*
|
|
23
|
+
* @task T4681
|
|
24
|
+
* @task T4682
|
|
25
|
+
* @task T4684
|
|
26
|
+
* @task T4685
|
|
27
|
+
* @task T4686
|
|
28
|
+
* @task T4687
|
|
29
|
+
* @task T4689
|
|
30
|
+
* @task T4706
|
|
31
|
+
* @task T4707
|
|
32
|
+
* @epic T4663
|
|
33
|
+
*/
|
|
34
|
+
import { existsSync, readdirSync, readFileSync } from 'node:fs';
|
|
35
|
+
import { copyFile, lstat, mkdir, readFile, symlink, unlink, writeFile } from 'node:fs/promises';
|
|
36
|
+
import { platform } from 'node:os';
|
|
37
|
+
import { basename, dirname, join } from 'node:path';
|
|
38
|
+
import { ExitCode } from '@cleocode/contracts';
|
|
39
|
+
import { classifyProject } from './discovery.js';
|
|
40
|
+
import { CleoError } from './errors.js';
|
|
41
|
+
import { ensureGitHooks } from './hooks.js';
|
|
42
|
+
import { ensureInjection } from './injection.js';
|
|
43
|
+
import { writeMemoryBridge } from './memory/memory-bridge.js';
|
|
44
|
+
import { migrateAgentOutputs } from './migration/agent-outputs.js';
|
|
45
|
+
import { getAgentsHome, getCleoDirAbsolute, getProjectRoot } from './paths.js';
|
|
46
|
+
// Shared utility imports
|
|
47
|
+
import { ensureBrainDb, ensureCleoGitRepo, ensureCleoOsHub, ensureCleoStructure, ensureConfig, ensureGitignore, ensureProjectContext, ensureProjectInfo, getPackageRoot, removeCleoFromRootGitignore, } from './scaffold.js';
|
|
48
|
+
import { ensureGlobalSchemas } from './schema-management.js';
|
|
49
|
+
import { readJson } from './store/json.js';
|
|
50
|
+
// ── Helpers ──────────────────────────────────────────────────────────
|
|
51
|
+
/**
|
|
52
|
+
* Symlink type for directory symlinks.
|
|
53
|
+
* On Windows, use 'junction' (no admin privileges required).
|
|
54
|
+
* On Unix, use 'dir'.
|
|
55
|
+
*/
|
|
56
|
+
const DIR_SYMLINK_TYPE = platform() === 'win32' ? 'junction' : 'dir';
|
|
57
|
+
// ── Init-specific operations ─────────────────────────────────────────
|
|
58
|
+
/**
|
|
59
|
+
* Resolve the absolute path to the bundled `seed-agents/` directory inside
|
|
60
|
+
* the `@cleocode/agents` package.
|
|
61
|
+
*
|
|
62
|
+
* Mirrors the multi-candidate resolution pattern used by
|
|
63
|
+
* {@link initAgentDefinition} so the same code path works across all layouts:
|
|
64
|
+
* 1. **npm install** — `require.resolve('@cleocode/agents/package.json')`
|
|
65
|
+
* finds the package under `node_modules/@cleocode/agents/`.
|
|
66
|
+
* 2. **Workspace dev (bundled CLI)** — walks up from `getPackageRoot()`
|
|
67
|
+
* (which resolves to `packages/cleo/dist/` or `packages/core/`) to find
|
|
68
|
+
* `packages/agents/seed-agents/`.
|
|
69
|
+
* 3. **Monorepo dev (source)** — falls back to `packages/agents/seed-agents/`
|
|
70
|
+
* relative to `getPackageRoot()`.
|
|
71
|
+
*
|
|
72
|
+
* @returns Absolute path to an existing `seed-agents/` directory, or `null`
|
|
73
|
+
* if no candidate exists. Returning `null` lets callers skip the
|
|
74
|
+
* seed install gracefully without crashing.
|
|
75
|
+
*
|
|
76
|
+
* @task T283
|
|
77
|
+
* @epic T280
|
|
78
|
+
*/
|
|
79
|
+
export async function resolveSeedAgentsDir() {
|
|
80
|
+
// Primary: resolve via Node module resolution (@cleocode/agents)
|
|
81
|
+
try {
|
|
82
|
+
const { createRequire } = await import('node:module');
|
|
83
|
+
const req = createRequire(import.meta.url);
|
|
84
|
+
const agentsPkgMain = req.resolve('@cleocode/agents/package.json');
|
|
85
|
+
const agentsPkgRoot = dirname(agentsPkgMain);
|
|
86
|
+
const candidate = join(agentsPkgRoot, 'seed-agents');
|
|
87
|
+
if (existsSync(candidate)) {
|
|
88
|
+
return candidate;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
catch {
|
|
92
|
+
// Not resolvable via require.resolve — fall through to bundled path
|
|
93
|
+
}
|
|
94
|
+
// Walk a series of candidate paths relative to getPackageRoot(), which
|
|
95
|
+
// can resolve to several different locations depending on whether we're
|
|
96
|
+
// running from packages/core/dist, packages/cleo/dist, or installed under
|
|
97
|
+
// node_modules/@cleocode/.
|
|
98
|
+
const packageRoot = getPackageRoot();
|
|
99
|
+
const candidates = [
|
|
100
|
+
// Workspace fallback: bundled alongside core under packages/agents/seed-agents
|
|
101
|
+
join(packageRoot, 'agents', 'seed-agents'),
|
|
102
|
+
// Sibling-package layout (e.g. node_modules/@cleocode/core -> ../agents)
|
|
103
|
+
join(packageRoot, '..', 'agents', 'seed-agents'),
|
|
104
|
+
// Bundled CLI: packages/cleo/dist -> ../../agents/seed-agents
|
|
105
|
+
join(packageRoot, '..', '..', 'agents', 'seed-agents'),
|
|
106
|
+
// Bundled CLI dist subdir: packages/cleo/dist/cli -> ../../../packages/agents
|
|
107
|
+
join(packageRoot, '..', '..', 'packages', 'agents', 'seed-agents'),
|
|
108
|
+
// Monorepo workspace from repo root
|
|
109
|
+
join(packageRoot, '..', '..', '..', 'packages', 'agents', 'seed-agents'),
|
|
110
|
+
];
|
|
111
|
+
return candidates.find((p) => existsSync(p)) ?? null;
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Install cleo-subagent agent definition to ~/.agents/agents/.
|
|
115
|
+
* @task T4685
|
|
116
|
+
*/
|
|
117
|
+
export async function initAgentDefinition(created, warnings) {
|
|
118
|
+
// Resolve agents package via require.resolve, then workspace/bundled fallback
|
|
119
|
+
let agentSourceDir = null;
|
|
120
|
+
try {
|
|
121
|
+
const { createRequire } = await import('node:module');
|
|
122
|
+
const req = createRequire(import.meta.url);
|
|
123
|
+
const agentsPkgMain = req.resolve('@cleocode/agents/package.json');
|
|
124
|
+
const agentsPkgRoot = dirname(agentsPkgMain);
|
|
125
|
+
const candidate = join(agentsPkgRoot, 'cleo-subagent');
|
|
126
|
+
if (existsSync(candidate)) {
|
|
127
|
+
agentSourceDir = candidate;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
catch {
|
|
131
|
+
// Not resolvable via require.resolve — fall through to bundled path
|
|
132
|
+
}
|
|
133
|
+
if (!agentSourceDir) {
|
|
134
|
+
const packageRoot = getPackageRoot();
|
|
135
|
+
const bundled = join(packageRoot, 'agents', 'cleo-subagent');
|
|
136
|
+
if (existsSync(bundled)) {
|
|
137
|
+
agentSourceDir = bundled;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
if (!agentSourceDir) {
|
|
141
|
+
warnings.push('agents/cleo-subagent/ not found in package, skipping agent definition install');
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
const globalAgentsDir = join(getAgentsHome(), 'agents', 'cleo-subagent');
|
|
145
|
+
await mkdir(dirname(globalAgentsDir), { recursive: true });
|
|
146
|
+
try {
|
|
147
|
+
// Check if symlink already exists and points to correct target
|
|
148
|
+
try {
|
|
149
|
+
const stat = await lstat(globalAgentsDir);
|
|
150
|
+
if (stat.isSymbolicLink()) {
|
|
151
|
+
const { readlink } = await import('node:fs/promises');
|
|
152
|
+
const currentTarget = await readlink(globalAgentsDir);
|
|
153
|
+
if (currentTarget === agentSourceDir) {
|
|
154
|
+
return; // Symlink intact and pointing to correct location
|
|
155
|
+
}
|
|
156
|
+
// Stale symlink — remove and recreate
|
|
157
|
+
await unlink(globalAgentsDir);
|
|
158
|
+
}
|
|
159
|
+
else if (stat.isDirectory()) {
|
|
160
|
+
return; // Copied dir, leave as-is
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
catch {
|
|
164
|
+
// Doesn't exist, proceed to create
|
|
165
|
+
}
|
|
166
|
+
// Create symlink from ~/.agents/agents/cleo-subagent -> package agents/cleo-subagent/
|
|
167
|
+
await symlink(agentSourceDir, globalAgentsDir, DIR_SYMLINK_TYPE);
|
|
168
|
+
created.push('agent: cleo-subagent (symlinked)');
|
|
169
|
+
}
|
|
170
|
+
catch (_err) {
|
|
171
|
+
// If symlink fails (e.g., permissions), try copying
|
|
172
|
+
try {
|
|
173
|
+
await mkdir(globalAgentsDir, { recursive: true });
|
|
174
|
+
const files = readdirSync(agentSourceDir);
|
|
175
|
+
for (const file of files) {
|
|
176
|
+
await copyFile(join(agentSourceDir, file), join(globalAgentsDir, file));
|
|
177
|
+
}
|
|
178
|
+
created.push('agent: cleo-subagent (copied)');
|
|
179
|
+
}
|
|
180
|
+
catch (copyErr) {
|
|
181
|
+
warnings.push(`Agent definition install: ${copyErr instanceof Error ? copyErr.message : String(copyErr)}`);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* No-op. Kept for API compatibility.
|
|
187
|
+
* @task T4706
|
|
188
|
+
*/
|
|
189
|
+
export async function initMcpServer(_projectRoot, _created, _warnings) {
|
|
190
|
+
// No-op: removed
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Install CLEO core skills to the canonical skills directory via CAAMP.
|
|
194
|
+
* @task T4707
|
|
195
|
+
* @task T4689
|
|
196
|
+
*/
|
|
197
|
+
export async function initCoreSkills(created, warnings) {
|
|
198
|
+
try {
|
|
199
|
+
const { getInstalledProviders, installSkill, registerSkillLibraryFromPath } = await import('@cleocode/caamp');
|
|
200
|
+
const providers = getInstalledProviders();
|
|
201
|
+
if (providers.length === 0) {
|
|
202
|
+
return;
|
|
203
|
+
}
|
|
204
|
+
// Find skills package via require.resolve, then workspace path, then node_modules fallback
|
|
205
|
+
const packageRoot = getPackageRoot();
|
|
206
|
+
let ctSkillsRoot = null;
|
|
207
|
+
try {
|
|
208
|
+
// Primary: resolve via Node module resolution (@cleocode/skills)
|
|
209
|
+
const { createRequire } = await import('node:module');
|
|
210
|
+
const req = createRequire(import.meta.url);
|
|
211
|
+
const skillsPkgMain = req.resolve('@cleocode/skills/package.json');
|
|
212
|
+
const skillsPkgRoot = dirname(skillsPkgMain);
|
|
213
|
+
if (existsSync(join(skillsPkgRoot, 'skills.json'))) {
|
|
214
|
+
ctSkillsRoot = skillsPkgRoot;
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
catch {
|
|
218
|
+
// Not resolvable via require.resolve — try workspace and node_modules fallbacks
|
|
219
|
+
}
|
|
220
|
+
if (!ctSkillsRoot) {
|
|
221
|
+
try {
|
|
222
|
+
// Workspace monorepo fallback (packages/skills/)
|
|
223
|
+
const bundledPath = join(packageRoot, 'packages', 'skills');
|
|
224
|
+
if (existsSync(join(bundledPath, 'skills.json'))) {
|
|
225
|
+
ctSkillsRoot = bundledPath;
|
|
226
|
+
}
|
|
227
|
+
else {
|
|
228
|
+
// node_modules fallback
|
|
229
|
+
const ctSkillsPath = join(packageRoot, 'node_modules', '@cleocode', 'skills');
|
|
230
|
+
if (existsSync(join(ctSkillsPath, 'skills.json'))) {
|
|
231
|
+
ctSkillsRoot = ctSkillsPath;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
catch {
|
|
236
|
+
// not found
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
if (!ctSkillsRoot) {
|
|
240
|
+
warnings.push('skills package not found, skipping core skill installation');
|
|
241
|
+
return;
|
|
242
|
+
}
|
|
243
|
+
// Register bundled skill library with CAAMP
|
|
244
|
+
try {
|
|
245
|
+
registerSkillLibraryFromPath(ctSkillsRoot);
|
|
246
|
+
}
|
|
247
|
+
catch {
|
|
248
|
+
warnings.push('Failed to register skill library with CAAMP');
|
|
249
|
+
}
|
|
250
|
+
// Read the skills catalog to find core skills
|
|
251
|
+
const catalogPath = join(ctSkillsRoot, 'skills.json');
|
|
252
|
+
const catalog = JSON.parse(readFileSync(catalogPath, 'utf-8'));
|
|
253
|
+
const skills = catalog.skills ?? [];
|
|
254
|
+
// Install core and recommended skills (tier 0, 1, 2)
|
|
255
|
+
const coreSkills = skills.filter((s) => s.tier <= 2);
|
|
256
|
+
const installed = [];
|
|
257
|
+
for (const skill of coreSkills) {
|
|
258
|
+
const skillSourceDir = dirname(join(ctSkillsRoot, skill.path));
|
|
259
|
+
if (!existsSync(skillSourceDir)) {
|
|
260
|
+
continue;
|
|
261
|
+
}
|
|
262
|
+
try {
|
|
263
|
+
const result = await installSkill(skillSourceDir, skill.name, providers, true);
|
|
264
|
+
if (result.success) {
|
|
265
|
+
installed.push(skill.name);
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
catch {
|
|
269
|
+
// Skill may already be installed, continue
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
if (installed.length > 0) {
|
|
273
|
+
created.push(`skills: ${installed.length} core skills installed`);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
catch (err) {
|
|
277
|
+
warnings.push(`Core skill install: ${err instanceof Error ? err.message : String(err)}`);
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
/**
|
|
281
|
+
* Register/reconcile project with NEXUS.
|
|
282
|
+
* Uses nexusReconcile for idempotent handshake — auto-registers if new,
|
|
283
|
+
* updates path if moved, confirms identity if unchanged.
|
|
284
|
+
* @task T4684
|
|
285
|
+
* @task T5368
|
|
286
|
+
*/
|
|
287
|
+
export async function initNexusRegistration(projectRoot, created, warnings) {
|
|
288
|
+
try {
|
|
289
|
+
const { nexusReconcile } = await import('./nexus/registry.js');
|
|
290
|
+
const result = await nexusReconcile(projectRoot);
|
|
291
|
+
if (result.status === 'auto_registered') {
|
|
292
|
+
created.push('NEXUS registration (auto-registered new project)');
|
|
293
|
+
}
|
|
294
|
+
else if (result.status === 'path_updated') {
|
|
295
|
+
created.push(`NEXUS registration (path updated: ${result.oldPath} → ${result.newPath})`);
|
|
296
|
+
}
|
|
297
|
+
else if (result.status === 'ok') {
|
|
298
|
+
created.push('NEXUS registration (project verified and active)');
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
catch (err) {
|
|
302
|
+
const errStr = String(err);
|
|
303
|
+
if (errStr.includes('NEXUS_PROJECT_EXISTS')) {
|
|
304
|
+
warnings.push('NEXUS registration: Project already registered');
|
|
305
|
+
}
|
|
306
|
+
else if (errStr.includes('NEXUS_REGISTRY_CORRUPT')) {
|
|
307
|
+
warnings.push(`NEXUS registration: Identity conflict - ${err instanceof Error ? err.message : errStr}. Run 'cleo nexus unregister' and re-register.`);
|
|
308
|
+
}
|
|
309
|
+
else {
|
|
310
|
+
warnings.push(`NEXUS registration: ${err instanceof Error ? err.message : errStr}`);
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
// ── GitHub Templates ─────────────────────────────────────────────────
|
|
315
|
+
/**
|
|
316
|
+
* Install GitHub issue and PR templates to .github/ if a git repo exists
|
|
317
|
+
* but .github/ISSUE_TEMPLATE/ is not yet present.
|
|
318
|
+
*
|
|
319
|
+
* Idempotent: skips files that already exist. Never overwrites existing
|
|
320
|
+
* templates — the project owner's customisations take precedence.
|
|
321
|
+
*
|
|
322
|
+
* @param projectRoot Absolute path to the project root.
|
|
323
|
+
* @param created Array to push "created: ..." log entries into.
|
|
324
|
+
* @param skipped Array to push "skipped: ..." log entries into.
|
|
325
|
+
*/
|
|
326
|
+
export async function installGitHubTemplates(projectRoot, created, skipped) {
|
|
327
|
+
// Only apply when a .git directory is present (i.e. this is a git repo)
|
|
328
|
+
if (!existsSync(join(projectRoot, '.git'))) {
|
|
329
|
+
return;
|
|
330
|
+
}
|
|
331
|
+
const githubDir = join(projectRoot, '.github');
|
|
332
|
+
const issueTemplateDir = join(githubDir, 'ISSUE_TEMPLATE');
|
|
333
|
+
// Locate bundled templates shipped alongside the package
|
|
334
|
+
const packageRoot = getPackageRoot();
|
|
335
|
+
const templateSrcDir = join(packageRoot, 'templates', 'github');
|
|
336
|
+
if (!existsSync(templateSrcDir)) {
|
|
337
|
+
// Templates not bundled — skip silently (e.g. development builds)
|
|
338
|
+
return;
|
|
339
|
+
}
|
|
340
|
+
// Ensure .github/ISSUE_TEMPLATE/ directory tree exists
|
|
341
|
+
await mkdir(issueTemplateDir, { recursive: true });
|
|
342
|
+
// ── ISSUE_TEMPLATE files ─────────────────────────────────────────
|
|
343
|
+
const issueSrcDir = join(templateSrcDir, 'ISSUE_TEMPLATE');
|
|
344
|
+
if (existsSync(issueSrcDir)) {
|
|
345
|
+
const issueFiles = readdirSync(issueSrcDir);
|
|
346
|
+
for (const file of issueFiles) {
|
|
347
|
+
const dest = join(issueTemplateDir, file);
|
|
348
|
+
if (existsSync(dest)) {
|
|
349
|
+
skipped.push(`.github/ISSUE_TEMPLATE/${file}`);
|
|
350
|
+
continue;
|
|
351
|
+
}
|
|
352
|
+
const content = readFileSync(join(issueSrcDir, file), 'utf-8');
|
|
353
|
+
await writeFile(dest, content, 'utf-8');
|
|
354
|
+
created.push(`.github/ISSUE_TEMPLATE/${file}`);
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
// ── pull_request_template.md ─────────────────────────────────────
|
|
358
|
+
const prTemplateSrc = join(templateSrcDir, 'pull_request_template.md');
|
|
359
|
+
const prTemplateDest = join(githubDir, 'pull_request_template.md');
|
|
360
|
+
if (existsSync(prTemplateSrc)) {
|
|
361
|
+
if (existsSync(prTemplateDest)) {
|
|
362
|
+
skipped.push('.github/pull_request_template.md');
|
|
363
|
+
}
|
|
364
|
+
else {
|
|
365
|
+
const content = readFileSync(prTemplateSrc, 'utf-8');
|
|
366
|
+
await writeFile(prTemplateDest, content, 'utf-8');
|
|
367
|
+
created.push('.github/pull_request_template.md');
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
// ── Public API ───────────────────────────────────────────────────────
|
|
372
|
+
/**
|
|
373
|
+
* Run update-docs only: refresh all injections without reinitializing.
|
|
374
|
+
* Re-injects CLEO-INJECTION.md into all detected agent instruction files.
|
|
375
|
+
*
|
|
376
|
+
* @task T4686
|
|
377
|
+
*/
|
|
378
|
+
export async function updateDocs() {
|
|
379
|
+
const cleoDir = getCleoDirAbsolute();
|
|
380
|
+
const projRoot = getProjectRoot();
|
|
381
|
+
const created = [];
|
|
382
|
+
const warnings = [];
|
|
383
|
+
// Re-inject into all provider instruction files (and AGENTS.md hub)
|
|
384
|
+
try {
|
|
385
|
+
const result = await ensureInjection(projRoot);
|
|
386
|
+
if (result.action !== 'skipped') {
|
|
387
|
+
created.push(`injection: ${result.details ?? result.action}`);
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
catch (err) {
|
|
391
|
+
warnings.push(`CAAMP injection: ${err instanceof Error ? err.message : String(err)}`);
|
|
392
|
+
}
|
|
393
|
+
return {
|
|
394
|
+
initialized: true,
|
|
395
|
+
directory: cleoDir,
|
|
396
|
+
created,
|
|
397
|
+
skipped: [],
|
|
398
|
+
warnings,
|
|
399
|
+
updateDocsOnly: true,
|
|
400
|
+
};
|
|
401
|
+
}
|
|
402
|
+
/**
|
|
403
|
+
* Run full project initialization.
|
|
404
|
+
*
|
|
405
|
+
* Creates the .cleo/ directory structure, installs schemas, templates,
|
|
406
|
+
* agent definitions, skills, and registers with NEXUS.
|
|
407
|
+
*
|
|
408
|
+
* @task T4681
|
|
409
|
+
* @task T4682
|
|
410
|
+
* @task T4684
|
|
411
|
+
* @task T4685
|
|
412
|
+
* @task T4686
|
|
413
|
+
* @task T4687
|
|
414
|
+
* @task T4689
|
|
415
|
+
* @task T4706
|
|
416
|
+
* @task T4707
|
|
417
|
+
*/
|
|
418
|
+
export async function initProject(opts = {}) {
|
|
419
|
+
const cleoDir = getCleoDirAbsolute();
|
|
420
|
+
const projRoot = getProjectRoot();
|
|
421
|
+
// Guard: fail if project already initialized (unless --force)
|
|
422
|
+
const alreadyInitialized = existsSync(cleoDir) &&
|
|
423
|
+
(existsSync(join(cleoDir, 'tasks.db')) || existsSync(join(cleoDir, 'config.json')));
|
|
424
|
+
if (alreadyInitialized && !opts.force) {
|
|
425
|
+
throw new CleoError(ExitCode.GENERAL_ERROR, 'Project already initialized. DANGER ZONE: use --force to wipe and re-init.', { fix: 'cleo init --force' });
|
|
426
|
+
}
|
|
427
|
+
const force = !!opts.force;
|
|
428
|
+
const created = [];
|
|
429
|
+
const skipped = [];
|
|
430
|
+
const warnings = [];
|
|
431
|
+
// Phase 5 — classify the directory BEFORE creating any files so the
|
|
432
|
+
// classification reflects the real pre-init state of the directory.
|
|
433
|
+
let classification;
|
|
434
|
+
try {
|
|
435
|
+
classification = classifyProject(projRoot);
|
|
436
|
+
}
|
|
437
|
+
catch (err) {
|
|
438
|
+
warnings.push(`Project classification failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
439
|
+
}
|
|
440
|
+
// T4681: Create .cleo/ directory structure
|
|
441
|
+
const structureResult = await ensureCleoStructure(projRoot);
|
|
442
|
+
if (structureResult.action === 'created') {
|
|
443
|
+
created.push('.cleo/ directory structure');
|
|
444
|
+
}
|
|
445
|
+
// T4681: Create config.json
|
|
446
|
+
const configResult = await ensureConfig(projRoot, { force });
|
|
447
|
+
if (configResult.action === 'skipped') {
|
|
448
|
+
skipped.push('config.json');
|
|
449
|
+
}
|
|
450
|
+
else {
|
|
451
|
+
created.push('config.json');
|
|
452
|
+
}
|
|
453
|
+
// Initialize SQLite database (tasks, sessions, archive, audit log all live here)
|
|
454
|
+
try {
|
|
455
|
+
const { getDb } = await import('./store/sqlite.js');
|
|
456
|
+
await getDb(join(cleoDir, '..'));
|
|
457
|
+
created.push('tasks.db');
|
|
458
|
+
}
|
|
459
|
+
catch (err) {
|
|
460
|
+
// SQLite init failure is not fatal — will be created on first access
|
|
461
|
+
created.push(`tasks.db (deferred: ${err instanceof Error ? err.message : String(err)})`);
|
|
462
|
+
}
|
|
463
|
+
// Initialize brain.db for BRAIN memory system
|
|
464
|
+
try {
|
|
465
|
+
const brainResult = await ensureBrainDb(projRoot);
|
|
466
|
+
if (brainResult.action === 'created') {
|
|
467
|
+
created.push('brain.db');
|
|
468
|
+
}
|
|
469
|
+
}
|
|
470
|
+
catch (err) {
|
|
471
|
+
created.push(`brain.db (deferred: ${err instanceof Error ? err.message : String(err)})`);
|
|
472
|
+
}
|
|
473
|
+
// Initialize signaldock.db for local agent messaging infrastructure (T223)
|
|
474
|
+
try {
|
|
475
|
+
const { ensureSignaldockDb } = await import('./store/signaldock-sqlite.js');
|
|
476
|
+
const sdResult = await ensureSignaldockDb(projRoot);
|
|
477
|
+
if (sdResult.action === 'created') {
|
|
478
|
+
created.push('signaldock.db');
|
|
479
|
+
}
|
|
480
|
+
}
|
|
481
|
+
catch (err) {
|
|
482
|
+
// Non-fatal — signaldock.db will be created on first agent operation
|
|
483
|
+
created.push(`signaldock.db (deferred: ${err instanceof Error ? err.message : String(err)})`);
|
|
484
|
+
}
|
|
485
|
+
// T4681: Create .cleo/.gitignore (respect force flag)
|
|
486
|
+
if (force) {
|
|
487
|
+
// When force is set, always overwrite — ensureGitignore does content-comparison only
|
|
488
|
+
const gitignoreResult = await ensureGitignore(projRoot);
|
|
489
|
+
if (gitignoreResult.action === 'skipped') {
|
|
490
|
+
skipped.push('.gitignore');
|
|
491
|
+
}
|
|
492
|
+
else {
|
|
493
|
+
created.push('.gitignore');
|
|
494
|
+
}
|
|
495
|
+
}
|
|
496
|
+
else {
|
|
497
|
+
const gitignorePath = join(cleoDir, '.gitignore');
|
|
498
|
+
if (existsSync(gitignorePath)) {
|
|
499
|
+
skipped.push('.gitignore');
|
|
500
|
+
}
|
|
501
|
+
else {
|
|
502
|
+
const gitignoreResult = await ensureGitignore(projRoot);
|
|
503
|
+
if (gitignoreResult.action !== 'skipped') {
|
|
504
|
+
created.push('.gitignore');
|
|
505
|
+
}
|
|
506
|
+
else {
|
|
507
|
+
skipped.push('.gitignore');
|
|
508
|
+
}
|
|
509
|
+
}
|
|
510
|
+
}
|
|
511
|
+
// Remove legacy sequence files if they exist (migration)
|
|
512
|
+
const legacySequencePath = join(cleoDir, '.sequence');
|
|
513
|
+
try {
|
|
514
|
+
await unlink(legacySequencePath);
|
|
515
|
+
}
|
|
516
|
+
catch {
|
|
517
|
+
/* ignore if absent */
|
|
518
|
+
}
|
|
519
|
+
const legacySequenceJsonPath = join(cleoDir, '.sequence.json');
|
|
520
|
+
try {
|
|
521
|
+
await unlink(legacySequenceJsonPath);
|
|
522
|
+
}
|
|
523
|
+
catch {
|
|
524
|
+
/* ignore if absent */
|
|
525
|
+
}
|
|
526
|
+
// T4872: Isolated .cleo/.git checkpoint repository
|
|
527
|
+
try {
|
|
528
|
+
const gitRepoResult = await ensureCleoGitRepo(projRoot);
|
|
529
|
+
if (gitRepoResult.action === 'created') {
|
|
530
|
+
created.push('.cleo/.git (isolated checkpoint repository)');
|
|
531
|
+
}
|
|
532
|
+
}
|
|
533
|
+
catch (err) {
|
|
534
|
+
warnings.push(`Could not initialize .cleo/.git: ${err instanceof Error ? err.message : String(err)}`);
|
|
535
|
+
}
|
|
536
|
+
// T4700: Migrate legacy agent-output directories before proceeding
|
|
537
|
+
try {
|
|
538
|
+
const migrationResult = migrateAgentOutputs(projRoot, cleoDir);
|
|
539
|
+
if (migrationResult.migrated) {
|
|
540
|
+
created.push(`agent-outputs migration: ${migrationResult.summary}`);
|
|
541
|
+
}
|
|
542
|
+
}
|
|
543
|
+
catch {
|
|
544
|
+
warnings.push('Agent-outputs migration failed (best-effort, run cleo upgrade to retry)');
|
|
545
|
+
}
|
|
546
|
+
// T4681: Schema files (~/.cleo/schemas/)
|
|
547
|
+
try {
|
|
548
|
+
const schemaResult = ensureGlobalSchemas({ force });
|
|
549
|
+
const total = schemaResult.installed + schemaResult.updated;
|
|
550
|
+
if (total > 0) {
|
|
551
|
+
created.push(`schemas/ (${total} files)`);
|
|
552
|
+
}
|
|
553
|
+
}
|
|
554
|
+
catch (err) {
|
|
555
|
+
warnings.push(`Schema installation: ${err instanceof Error ? err.message : String(err)}`);
|
|
556
|
+
}
|
|
557
|
+
// Git hooks (commit-msg, pre-commit, pre-push)
|
|
558
|
+
try {
|
|
559
|
+
const hooksResult = await ensureGitHooks(projRoot, { force });
|
|
560
|
+
if (hooksResult.action === 'created') {
|
|
561
|
+
created.push(hooksResult.details ?? 'git hooks installed');
|
|
562
|
+
}
|
|
563
|
+
else if (hooksResult.action === 'skipped' && hooksResult.details?.includes('No .git/')) {
|
|
564
|
+
warnings.push(hooksResult.details);
|
|
565
|
+
}
|
|
566
|
+
else if (hooksResult.action === 'skipped' &&
|
|
567
|
+
hooksResult.details?.includes('not found in package root')) {
|
|
568
|
+
warnings.push(hooksResult.details);
|
|
569
|
+
}
|
|
570
|
+
else if (hooksResult.action === 'repaired' && hooksResult.details?.includes('error')) {
|
|
571
|
+
// Hook errors reported via details in 'repaired' action
|
|
572
|
+
const match = hooksResult.details.match(/Installed (\d+)/);
|
|
573
|
+
if (match && parseInt(match[1], 10) > 0) {
|
|
574
|
+
created.push(`git hooks (${match[1]} installed)`);
|
|
575
|
+
}
|
|
576
|
+
warnings.push(hooksResult.details);
|
|
577
|
+
}
|
|
578
|
+
}
|
|
579
|
+
catch (err) {
|
|
580
|
+
warnings.push(`Git hook installation: ${err instanceof Error ? err.message : String(err)}`);
|
|
581
|
+
}
|
|
582
|
+
// T4684: Project info (.cleo/project-info.json)
|
|
583
|
+
const projectInfoResult = await ensureProjectInfo(projRoot, { force });
|
|
584
|
+
if (projectInfoResult.action === 'skipped') {
|
|
585
|
+
skipped.push('project-info.json');
|
|
586
|
+
}
|
|
587
|
+
else {
|
|
588
|
+
created.push('project-info.json');
|
|
589
|
+
}
|
|
590
|
+
// Project context detection (always run during init)
|
|
591
|
+
try {
|
|
592
|
+
const detectResult = await ensureProjectContext(projRoot, { force: !!opts.detect });
|
|
593
|
+
if (detectResult.action !== 'skipped') {
|
|
594
|
+
created.push('project-context.json');
|
|
595
|
+
}
|
|
596
|
+
}
|
|
597
|
+
catch (err) {
|
|
598
|
+
warnings.push(`Project detection failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
599
|
+
}
|
|
600
|
+
// Codebase analysis and brain.db storage (brownfield auto-mapping)
|
|
601
|
+
if (opts.mapCodebase) {
|
|
602
|
+
try {
|
|
603
|
+
const { mapCodebase } = await import('./codebase-map/index.js');
|
|
604
|
+
const mapResult = await mapCodebase(projRoot, { storeToBrain: true });
|
|
605
|
+
created.push(`codebase-map: ${mapResult.stack.languages.length} languages, ${mapResult.architecture.layers.length} layers analyzed`);
|
|
606
|
+
}
|
|
607
|
+
catch (err) {
|
|
608
|
+
warnings.push(`Codebase mapping: ${err instanceof Error ? err.message : String(err)}`);
|
|
609
|
+
}
|
|
610
|
+
}
|
|
611
|
+
// Generate memory-bridge.md from brain.db BEFORE injection so AGENTS.md can reference it
|
|
612
|
+
try {
|
|
613
|
+
const bridgeResult = await writeMemoryBridge(projRoot);
|
|
614
|
+
if (bridgeResult.written) {
|
|
615
|
+
created.push('memory-bridge.md');
|
|
616
|
+
}
|
|
617
|
+
}
|
|
618
|
+
catch (err) {
|
|
619
|
+
warnings.push(`Memory bridge: ${err instanceof Error ? err.message : String(err)}`);
|
|
620
|
+
}
|
|
621
|
+
// T4682: Inject into agent instruction files via CAAMP (AGENTS.md hub pattern)
|
|
622
|
+
try {
|
|
623
|
+
const injectionResult = await ensureInjection(projRoot);
|
|
624
|
+
if (injectionResult.action !== 'skipped') {
|
|
625
|
+
// Parse the details to get individual file actions for backward-compatible output
|
|
626
|
+
if (injectionResult.details) {
|
|
627
|
+
created.push(`injection: ${injectionResult.details}`);
|
|
628
|
+
}
|
|
629
|
+
}
|
|
630
|
+
else if (injectionResult.details) {
|
|
631
|
+
warnings.push(injectionResult.details);
|
|
632
|
+
}
|
|
633
|
+
}
|
|
634
|
+
catch (err) {
|
|
635
|
+
warnings.push(`CAAMP injection: ${err instanceof Error ? err.message : String(err)}`);
|
|
636
|
+
}
|
|
637
|
+
// ADR-029: Contributor project dev channel setup
|
|
638
|
+
try {
|
|
639
|
+
const { ensureContributorMcp } = await import('./scaffold.js');
|
|
640
|
+
const devResult = await ensureContributorMcp(projRoot);
|
|
641
|
+
if (devResult.action !== 'skipped') {
|
|
642
|
+
created.push(`contributor dev channel: ${devResult.details ?? devResult.action}`);
|
|
643
|
+
}
|
|
644
|
+
}
|
|
645
|
+
catch (err) {
|
|
646
|
+
warnings.push(`Contributor dev channel: ${err instanceof Error ? err.message : String(err)}`);
|
|
647
|
+
}
|
|
648
|
+
// T4685: Agent definition (cleo-subagent)
|
|
649
|
+
await initAgentDefinition(created, warnings);
|
|
650
|
+
// Note: Core skills installation is global-only (bootstrapGlobalCleo / installSkillsGlobally).
|
|
651
|
+
// Skills are NOT installed during project-level init — they are installed once globally.
|
|
652
|
+
// T4684: NEXUS registration (reconcile-based handshake, T5368)
|
|
653
|
+
await initNexusRegistration(projRoot, created, warnings);
|
|
654
|
+
// T5240: Adapter discovery, activation, and install
|
|
655
|
+
try {
|
|
656
|
+
const { AdapterManager } = await import('./adapters/index.js');
|
|
657
|
+
const mgr = AdapterManager.getInstance(projRoot);
|
|
658
|
+
const manifests = mgr.discover();
|
|
659
|
+
if (manifests.length > 0) {
|
|
660
|
+
created.push(`adapters: ${manifests.length} adapter(s) discovered`);
|
|
661
|
+
const detected = mgr.detectActive();
|
|
662
|
+
if (detected.length > 0) {
|
|
663
|
+
created.push(`adapters: active provider detected (${detected.join(', ')})`);
|
|
664
|
+
// Activate and install detected adapters
|
|
665
|
+
for (const adapterId of detected) {
|
|
666
|
+
try {
|
|
667
|
+
const adapter = await mgr.activate(adapterId);
|
|
668
|
+
const installResult = await adapter.install.install({
|
|
669
|
+
projectDir: projRoot,
|
|
670
|
+
});
|
|
671
|
+
if (installResult.success) {
|
|
672
|
+
created.push(`adapter install (${adapterId}): installed`);
|
|
673
|
+
}
|
|
674
|
+
else {
|
|
675
|
+
warnings.push(`adapter install (${adapterId}): failed`);
|
|
676
|
+
}
|
|
677
|
+
}
|
|
678
|
+
catch (err) {
|
|
679
|
+
warnings.push(`adapter activate/install (${adapterId}): ${err instanceof Error ? err.message : String(err)}`);
|
|
680
|
+
}
|
|
681
|
+
}
|
|
682
|
+
}
|
|
683
|
+
}
|
|
684
|
+
}
|
|
685
|
+
catch (err) {
|
|
686
|
+
warnings.push(`Adapter discovery: ${err instanceof Error ? err.message : String(err)}`);
|
|
687
|
+
}
|
|
688
|
+
// GitHub issue/PR templates (.github/ directory)
|
|
689
|
+
try {
|
|
690
|
+
await installGitHubTemplates(projRoot, created, skipped);
|
|
691
|
+
}
|
|
692
|
+
catch (err) {
|
|
693
|
+
warnings.push(`GitHub templates: ${err instanceof Error ? err.message : String(err)}`);
|
|
694
|
+
}
|
|
695
|
+
// Remove .cleo/ from root .gitignore if present
|
|
696
|
+
const rootGitignoreResult = await removeCleoFromRootGitignore(projRoot);
|
|
697
|
+
if (rootGitignoreResult.removed) {
|
|
698
|
+
warnings.push('.cleo/ was found in root .gitignore and has been removed. CLEO uses .cleo/.gitignore for selective tracking.');
|
|
699
|
+
}
|
|
700
|
+
// T283: Optional install of canonical CleoOS seed agent personas
|
|
701
|
+
if (opts.installSeedAgents) {
|
|
702
|
+
try {
|
|
703
|
+
const seedDir = await resolveSeedAgentsDir();
|
|
704
|
+
if (seedDir && existsSync(seedDir)) {
|
|
705
|
+
const targetDir = join(projRoot, '.cleo', 'agents');
|
|
706
|
+
await mkdir(targetDir, { recursive: true });
|
|
707
|
+
const seeds = readdirSync(seedDir).filter((f) => f.endsWith('.cant'));
|
|
708
|
+
let installed = 0;
|
|
709
|
+
for (const seed of seeds) {
|
|
710
|
+
const dst = join(targetDir, seed);
|
|
711
|
+
if (!existsSync(dst)) {
|
|
712
|
+
await copyFile(join(seedDir, seed), dst);
|
|
713
|
+
installed++;
|
|
714
|
+
}
|
|
715
|
+
}
|
|
716
|
+
if (installed > 0) {
|
|
717
|
+
created.push(`seed-agents: ${installed} canonical .cant personas installed`);
|
|
718
|
+
}
|
|
719
|
+
}
|
|
720
|
+
else {
|
|
721
|
+
warnings.push('seed-agents install: bundled seed-agents/ directory not found');
|
|
722
|
+
}
|
|
723
|
+
}
|
|
724
|
+
catch (err) {
|
|
725
|
+
warnings.push(`seed-agents install failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
726
|
+
}
|
|
727
|
+
}
|
|
728
|
+
// ────────────────────────────────────────────────────────────────────
|
|
729
|
+
// Phase 5 — Finalize classification report + CleoOS hub bootstrap
|
|
730
|
+
// (Classification already ran at the TOP of init, before file creation)
|
|
731
|
+
// ────────────────────────────────────────────────────────────────────
|
|
732
|
+
if (classification) {
|
|
733
|
+
created.push(`classification: ${classification.kind} (${classification.signals.length} signals)`);
|
|
734
|
+
}
|
|
735
|
+
// Ensure the CleoOS Hub exists globally (idempotent — only writes once)
|
|
736
|
+
try {
|
|
737
|
+
const hubResult = await ensureCleoOsHub();
|
|
738
|
+
if (hubResult.action === 'created') {
|
|
739
|
+
created.push(`cleoos-hub: ${hubResult.details ?? 'scaffolded'}`);
|
|
740
|
+
}
|
|
741
|
+
}
|
|
742
|
+
catch (err) {
|
|
743
|
+
warnings.push(`CleoOS hub scaffold failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
744
|
+
}
|
|
745
|
+
// Context anchoring: when brownfield and --map-codebase was NOT already run,
|
|
746
|
+
// surface a hint so the operator knows they can anchor the baseline in BRAIN.
|
|
747
|
+
// (We do NOT auto-run mapCodebase here — it's opt-in to avoid blocking init.)
|
|
748
|
+
if (classification?.kind === 'brownfield' && !opts.mapCodebase) {
|
|
749
|
+
warnings.push('Brownfield detected — run `cleo init --map-codebase` to anchor the existing codebase in BRAIN (Phase 5 context anchoring).');
|
|
750
|
+
}
|
|
751
|
+
// LAFS next-step guidance for autonomous agents
|
|
752
|
+
const nextSteps = classification?.kind === 'greenfield'
|
|
753
|
+
? [
|
|
754
|
+
{
|
|
755
|
+
action: 'Start the session and record your first research findings',
|
|
756
|
+
command: 'cleo session start --scope global',
|
|
757
|
+
},
|
|
758
|
+
{
|
|
759
|
+
action: 'Create the seed epic for Vision/PRD research',
|
|
760
|
+
command: 'cleo add "Project vision and initial scope" --type epic',
|
|
761
|
+
},
|
|
762
|
+
{
|
|
763
|
+
action: 'Invoke the Conductor Loop once the seed epic is present',
|
|
764
|
+
command: 'pi /cleo:auto <seedEpicId>',
|
|
765
|
+
},
|
|
766
|
+
]
|
|
767
|
+
: [
|
|
768
|
+
{
|
|
769
|
+
action: 'Anchor the existing codebase in BRAIN as baseline context',
|
|
770
|
+
command: 'cleo init --map-codebase',
|
|
771
|
+
},
|
|
772
|
+
{
|
|
773
|
+
action: 'Review the detected project context',
|
|
774
|
+
command: 'cleo admin paths',
|
|
775
|
+
},
|
|
776
|
+
{
|
|
777
|
+
action: 'Start a session scoped to the work you want to continue',
|
|
778
|
+
command: 'cleo session start --scope global',
|
|
779
|
+
},
|
|
780
|
+
];
|
|
781
|
+
return {
|
|
782
|
+
initialized: true,
|
|
783
|
+
directory: cleoDir,
|
|
784
|
+
created,
|
|
785
|
+
skipped,
|
|
786
|
+
warnings,
|
|
787
|
+
classification: classification
|
|
788
|
+
? {
|
|
789
|
+
kind: classification.kind,
|
|
790
|
+
signalCount: classification.signals.length,
|
|
791
|
+
topLevelFileCount: classification.topLevelFileCount,
|
|
792
|
+
hasGit: classification.hasGit,
|
|
793
|
+
}
|
|
794
|
+
: undefined,
|
|
795
|
+
nextSteps,
|
|
796
|
+
};
|
|
797
|
+
}
|
|
798
|
+
/**
|
|
799
|
+
* Check if auto-init is enabled via environment variable.
|
|
800
|
+
* @task T4789
|
|
801
|
+
*/
|
|
802
|
+
export function isAutoInitEnabled() {
|
|
803
|
+
return process.env.CLEO_AUTO_INIT === 'true';
|
|
804
|
+
}
|
|
805
|
+
/**
|
|
806
|
+
* Check if a project is initialized and auto-init if configured.
|
|
807
|
+
* Returns { initialized: true } if ready, throws otherwise.
|
|
808
|
+
* @task T4789
|
|
809
|
+
*/
|
|
810
|
+
export async function ensureInitialized(projectRoot) {
|
|
811
|
+
const root = projectRoot ?? getProjectRoot();
|
|
812
|
+
const cleoDir = join(root, '.cleo');
|
|
813
|
+
const isInit = existsSync(cleoDir) &&
|
|
814
|
+
(existsSync(join(cleoDir, 'tasks.db')) || existsSync(join(cleoDir, 'config.json')));
|
|
815
|
+
if (isInit) {
|
|
816
|
+
return { initialized: true };
|
|
817
|
+
}
|
|
818
|
+
if (isAutoInitEnabled()) {
|
|
819
|
+
await initProject({ name: basename(root) });
|
|
820
|
+
return { initialized: true };
|
|
821
|
+
}
|
|
822
|
+
throw new Error('CLEO project not initialized. Run system.init or set CLEO_AUTO_INIT=true');
|
|
823
|
+
}
|
|
824
|
+
/**
|
|
825
|
+
* Get the current CLEO/project version.
|
|
826
|
+
* Checks VERSION file, then package.json.
|
|
827
|
+
* @task T4789
|
|
828
|
+
*/
|
|
829
|
+
export async function getVersion(projectRoot) {
|
|
830
|
+
const root = projectRoot ?? getProjectRoot();
|
|
831
|
+
// Try VERSION file
|
|
832
|
+
const versionPaths = [join(root, 'VERSION'), join(root, '..', 'VERSION')];
|
|
833
|
+
for (const versionPath of versionPaths) {
|
|
834
|
+
try {
|
|
835
|
+
const content = await readFile(versionPath, 'utf-8');
|
|
836
|
+
const version = content.trim();
|
|
837
|
+
if (version) {
|
|
838
|
+
return { version };
|
|
839
|
+
}
|
|
840
|
+
}
|
|
841
|
+
catch {
|
|
842
|
+
// Try next path
|
|
843
|
+
}
|
|
844
|
+
}
|
|
845
|
+
// Fallback: package.json
|
|
846
|
+
const pkg = await readJson(join(root, 'package.json'));
|
|
847
|
+
if (pkg?.version) {
|
|
848
|
+
return { version: pkg.version };
|
|
849
|
+
}
|
|
850
|
+
return { version: '0.0.0' };
|
|
851
|
+
}
|
|
852
|
+
//# sourceMappingURL=init.js.map
|