@soleri/core 2.12.0 → 8.0.0
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/data/flows/build.flow.yaml +128 -0
- package/data/flows/deliver.flow.yaml +110 -0
- package/data/flows/design.flow.yaml +108 -0
- package/data/flows/enhance.flow.yaml +90 -0
- package/data/flows/explore.flow.yaml +84 -0
- package/data/flows/fix.flow.yaml +90 -0
- package/data/flows/plan.flow.yaml +87 -0
- package/data/flows/review.flow.yaml +90 -0
- package/dist/agency/agency-manager.d.ts +27 -1
- package/dist/agency/agency-manager.d.ts.map +1 -1
- package/dist/agency/agency-manager.js +180 -9
- package/dist/agency/agency-manager.js.map +1 -1
- package/dist/agency/default-rules.d.ts +7 -0
- package/dist/agency/default-rules.d.ts.map +1 -0
- package/dist/agency/default-rules.js +79 -0
- package/dist/agency/default-rules.js.map +1 -0
- package/dist/agency/types.d.ts +48 -0
- package/dist/agency/types.d.ts.map +1 -1
- package/dist/brain/brain.d.ts +17 -2
- package/dist/brain/brain.d.ts.map +1 -1
- package/dist/brain/brain.js +118 -8
- package/dist/brain/brain.js.map +1 -1
- package/dist/brain/intelligence.d.ts.map +1 -1
- package/dist/brain/intelligence.js +16 -2
- package/dist/brain/intelligence.js.map +1 -1
- package/dist/brain/knowledge-synthesizer.d.ts +37 -0
- package/dist/brain/knowledge-synthesizer.d.ts.map +1 -0
- package/dist/brain/knowledge-synthesizer.js +161 -0
- package/dist/brain/knowledge-synthesizer.js.map +1 -0
- package/dist/brain/learning-radar.d.ts +96 -0
- package/dist/brain/learning-radar.d.ts.map +1 -0
- package/dist/brain/learning-radar.js +202 -0
- package/dist/brain/learning-radar.js.map +1 -0
- package/dist/brain/types.d.ts +15 -0
- package/dist/brain/types.d.ts.map +1 -1
- package/dist/capabilities/chain-mapping.d.ts +21 -0
- package/dist/capabilities/chain-mapping.d.ts.map +1 -0
- package/dist/capabilities/chain-mapping.js +86 -0
- package/dist/capabilities/chain-mapping.js.map +1 -0
- package/dist/capabilities/index.d.ts +10 -0
- package/dist/capabilities/index.d.ts.map +1 -0
- package/dist/capabilities/index.js +8 -0
- package/dist/capabilities/index.js.map +1 -0
- package/dist/capabilities/registry.d.ts +95 -0
- package/dist/capabilities/registry.d.ts.map +1 -0
- package/dist/capabilities/registry.js +227 -0
- package/dist/capabilities/registry.js.map +1 -0
- package/dist/capabilities/types.d.ts +106 -0
- package/dist/capabilities/types.d.ts.map +1 -0
- package/dist/capabilities/types.js +12 -0
- package/dist/capabilities/types.js.map +1 -0
- package/dist/context/context-engine.d.ts.map +1 -1
- package/dist/context/context-engine.js +82 -17
- package/dist/context/context-engine.js.map +1 -1
- package/dist/context/types.d.ts +5 -0
- package/dist/context/types.d.ts.map +1 -1
- package/dist/control/intent-router.d.ts +12 -1
- package/dist/control/intent-router.d.ts.map +1 -1
- package/dist/control/intent-router.js +126 -2
- package/dist/control/intent-router.js.map +1 -1
- package/dist/control/types.d.ts +17 -0
- package/dist/control/types.d.ts.map +1 -1
- package/dist/curator/classifier.d.ts +18 -0
- package/dist/curator/classifier.d.ts.map +1 -0
- package/dist/curator/classifier.js +61 -0
- package/dist/curator/classifier.js.map +1 -0
- package/dist/curator/quality-gate.d.ts +29 -0
- package/dist/curator/quality-gate.d.ts.map +1 -0
- package/dist/curator/quality-gate.js +88 -0
- package/dist/curator/quality-gate.js.map +1 -0
- package/dist/domain-packs/index.d.ts +8 -0
- package/dist/domain-packs/index.d.ts.map +1 -0
- package/dist/domain-packs/index.js +8 -0
- package/dist/domain-packs/index.js.map +1 -0
- package/dist/domain-packs/inject-rules.d.ts +24 -0
- package/dist/domain-packs/inject-rules.d.ts.map +1 -0
- package/dist/domain-packs/inject-rules.js +65 -0
- package/dist/domain-packs/inject-rules.js.map +1 -0
- package/dist/domain-packs/knowledge-installer.d.ts +27 -0
- package/dist/domain-packs/knowledge-installer.d.ts.map +1 -0
- package/dist/domain-packs/knowledge-installer.js +89 -0
- package/dist/domain-packs/knowledge-installer.js.map +1 -0
- package/dist/domain-packs/loader.d.ts +28 -0
- package/dist/domain-packs/loader.d.ts.map +1 -0
- package/dist/domain-packs/loader.js +105 -0
- package/dist/domain-packs/loader.js.map +1 -0
- package/dist/domain-packs/pack-runtime.d.ts +80 -0
- package/dist/domain-packs/pack-runtime.d.ts.map +1 -0
- package/dist/domain-packs/pack-runtime.js +36 -0
- package/dist/domain-packs/pack-runtime.js.map +1 -0
- package/dist/domain-packs/skills-installer.d.ts +21 -0
- package/dist/domain-packs/skills-installer.d.ts.map +1 -0
- package/dist/domain-packs/skills-installer.js +38 -0
- package/dist/domain-packs/skills-installer.js.map +1 -0
- package/dist/domain-packs/token-resolver.d.ts +37 -0
- package/dist/domain-packs/token-resolver.d.ts.map +1 -0
- package/dist/domain-packs/token-resolver.js +109 -0
- package/dist/domain-packs/token-resolver.js.map +1 -0
- package/dist/domain-packs/types.d.ts +91 -0
- package/dist/domain-packs/types.d.ts.map +1 -0
- package/dist/domain-packs/types.js +122 -0
- package/dist/domain-packs/types.js.map +1 -0
- package/dist/engine/bin/soleri-engine.d.ts +12 -0
- package/dist/engine/bin/soleri-engine.d.ts.map +1 -0
- package/dist/engine/bin/soleri-engine.js +184 -0
- package/dist/engine/bin/soleri-engine.js.map +1 -0
- package/dist/engine/core-ops.d.ts +27 -0
- package/dist/engine/core-ops.d.ts.map +1 -0
- package/dist/engine/core-ops.js +159 -0
- package/dist/engine/core-ops.js.map +1 -0
- package/dist/engine/index.d.ts +19 -0
- package/dist/engine/index.d.ts.map +1 -0
- package/dist/engine/index.js +17 -0
- package/dist/engine/index.js.map +1 -0
- package/dist/engine/register-engine.d.ts +54 -0
- package/dist/engine/register-engine.d.ts.map +1 -0
- package/dist/engine/register-engine.js +270 -0
- package/dist/engine/register-engine.js.map +1 -0
- package/dist/engine/test-helpers.d.ts +30 -0
- package/dist/engine/test-helpers.d.ts.map +1 -0
- package/dist/engine/test-helpers.js +59 -0
- package/dist/engine/test-helpers.js.map +1 -0
- package/dist/events/event-bus.d.ts +30 -0
- package/dist/events/event-bus.d.ts.map +1 -0
- package/dist/events/event-bus.js +51 -0
- package/dist/events/event-bus.js.map +1 -0
- package/dist/flows/chain-runner.d.ts +46 -0
- package/dist/flows/chain-runner.d.ts.map +1 -0
- package/dist/flows/chain-runner.js +271 -0
- package/dist/flows/chain-runner.js.map +1 -0
- package/dist/flows/chain-types.d.ts +103 -0
- package/dist/flows/chain-types.d.ts.map +1 -0
- package/dist/flows/chain-types.js +23 -0
- package/dist/flows/chain-types.js.map +1 -0
- package/dist/flows/context-router.d.ts +39 -0
- package/dist/flows/context-router.d.ts.map +1 -0
- package/dist/flows/context-router.js +206 -0
- package/dist/flows/context-router.js.map +1 -0
- package/dist/flows/dispatch-registry.d.ts +24 -0
- package/dist/flows/dispatch-registry.d.ts.map +1 -0
- package/dist/flows/dispatch-registry.js +70 -0
- package/dist/flows/dispatch-registry.js.map +1 -0
- package/dist/flows/epilogue.d.ts +24 -0
- package/dist/flows/epilogue.d.ts.map +1 -0
- package/dist/flows/epilogue.js +52 -0
- package/dist/flows/epilogue.js.map +1 -0
- package/dist/flows/executor.d.ts +25 -0
- package/dist/flows/executor.d.ts.map +1 -0
- package/dist/flows/executor.js +153 -0
- package/dist/flows/executor.js.map +1 -0
- package/dist/flows/gate-evaluator.d.ts +26 -0
- package/dist/flows/gate-evaluator.d.ts.map +1 -0
- package/dist/flows/gate-evaluator.js +162 -0
- package/dist/flows/gate-evaluator.js.map +1 -0
- package/dist/flows/index.d.ts +14 -0
- package/dist/flows/index.d.ts.map +1 -0
- package/dist/flows/index.js +20 -0
- package/dist/flows/index.js.map +1 -0
- package/dist/flows/loader.d.ts +17 -0
- package/dist/flows/loader.d.ts.map +1 -0
- package/dist/flows/loader.js +61 -0
- package/dist/flows/loader.js.map +1 -0
- package/dist/flows/plan-builder.d.ts +40 -0
- package/dist/flows/plan-builder.d.ts.map +1 -0
- package/dist/flows/plan-builder.js +213 -0
- package/dist/flows/plan-builder.js.map +1 -0
- package/dist/flows/probes.d.ts +11 -0
- package/dist/flows/probes.d.ts.map +1 -0
- package/dist/flows/probes.js +62 -0
- package/dist/flows/probes.js.map +1 -0
- package/dist/flows/types.d.ts +950 -0
- package/dist/flows/types.d.ts.map +1 -0
- package/dist/flows/types.js +105 -0
- package/dist/flows/types.js.map +1 -0
- package/dist/health/doctor-checks.d.ts +15 -0
- package/dist/health/doctor-checks.d.ts.map +1 -0
- package/dist/health/doctor-checks.js +98 -0
- package/dist/health/doctor-checks.js.map +1 -0
- package/dist/index.d.ts +11 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +10 -1
- package/dist/index.js.map +1 -1
- package/dist/intake/text-ingester.d.ts +52 -0
- package/dist/intake/text-ingester.d.ts.map +1 -0
- package/dist/intake/text-ingester.js +181 -0
- package/dist/intake/text-ingester.js.map +1 -0
- package/dist/intelligence/loader.d.ts +19 -0
- package/dist/intelligence/loader.d.ts.map +1 -1
- package/dist/intelligence/loader.js +35 -0
- package/dist/intelligence/loader.js.map +1 -1
- package/dist/intelligence/types.d.ts +1 -0
- package/dist/intelligence/types.d.ts.map +1 -1
- package/dist/llm/llm-client.d.ts.map +1 -1
- package/dist/llm/llm-client.js +37 -1
- package/dist/llm/llm-client.js.map +1 -1
- package/dist/llm/oauth-discovery.d.ts +26 -0
- package/dist/llm/oauth-discovery.d.ts.map +1 -0
- package/dist/llm/oauth-discovery.js +149 -0
- package/dist/llm/oauth-discovery.js.map +1 -0
- package/dist/packs/types.d.ts +58 -19
- package/dist/packs/types.d.ts.map +1 -1
- package/dist/packs/types.js +14 -0
- package/dist/packs/types.js.map +1 -1
- package/dist/planning/evidence-collector.d.ts +41 -0
- package/dist/planning/evidence-collector.d.ts.map +1 -0
- package/dist/planning/evidence-collector.js +194 -0
- package/dist/planning/evidence-collector.js.map +1 -0
- package/dist/planning/planner.d.ts +4 -0
- package/dist/planning/planner.d.ts.map +1 -1
- package/dist/planning/planner.js +11 -0
- package/dist/planning/planner.js.map +1 -1
- package/dist/playbooks/generic/onboarding.d.ts +9 -0
- package/dist/playbooks/generic/onboarding.d.ts.map +1 -0
- package/dist/playbooks/generic/onboarding.js +74 -0
- package/dist/playbooks/generic/onboarding.js.map +1 -0
- package/dist/playbooks/playbook-registry.d.ts.map +1 -1
- package/dist/playbooks/playbook-registry.js +2 -0
- package/dist/playbooks/playbook-registry.js.map +1 -1
- package/dist/queue/job-queue.d.ts +92 -0
- package/dist/queue/job-queue.d.ts.map +1 -0
- package/dist/queue/job-queue.js +180 -0
- package/dist/queue/job-queue.js.map +1 -0
- package/dist/queue/pipeline-runner.d.ts +62 -0
- package/dist/queue/pipeline-runner.d.ts.map +1 -0
- package/dist/queue/pipeline-runner.js +126 -0
- package/dist/queue/pipeline-runner.js.map +1 -0
- package/dist/runtime/admin-extra-ops.d.ts.map +1 -1
- package/dist/runtime/admin-extra-ops.js +15 -9
- package/dist/runtime/admin-extra-ops.js.map +1 -1
- package/dist/runtime/admin-ops.js +4 -4
- package/dist/runtime/admin-ops.js.map +1 -1
- package/dist/runtime/admin-setup-ops.d.ts +20 -0
- package/dist/runtime/admin-setup-ops.d.ts.map +1 -0
- package/dist/runtime/admin-setup-ops.js +583 -0
- package/dist/runtime/admin-setup-ops.js.map +1 -0
- package/dist/runtime/capture-ops.d.ts.map +1 -1
- package/dist/runtime/capture-ops.js +33 -1
- package/dist/runtime/capture-ops.js.map +1 -1
- package/dist/runtime/chain-ops.d.ts +9 -0
- package/dist/runtime/chain-ops.d.ts.map +1 -0
- package/dist/runtime/chain-ops.js +107 -0
- package/dist/runtime/chain-ops.js.map +1 -0
- package/dist/runtime/claude-md-helpers.d.ts +65 -0
- package/dist/runtime/claude-md-helpers.d.ts.map +1 -0
- package/dist/runtime/claude-md-helpers.js +173 -0
- package/dist/runtime/claude-md-helpers.js.map +1 -0
- package/dist/runtime/curator-extra-ops.d.ts +3 -2
- package/dist/runtime/curator-extra-ops.d.ts.map +1 -1
- package/dist/runtime/curator-extra-ops.js +81 -3
- package/dist/runtime/curator-extra-ops.js.map +1 -1
- package/dist/runtime/domain-ops.d.ts +21 -5
- package/dist/runtime/domain-ops.d.ts.map +1 -1
- package/dist/runtime/domain-ops.js +64 -6
- package/dist/runtime/domain-ops.js.map +1 -1
- package/dist/runtime/facades/admin-facade.d.ts.map +1 -1
- package/dist/runtime/facades/admin-facade.js +4 -0
- package/dist/runtime/facades/admin-facade.js.map +1 -1
- package/dist/runtime/facades/agency-facade.d.ts.map +1 -1
- package/dist/runtime/facades/agency-facade.js +64 -0
- package/dist/runtime/facades/agency-facade.js.map +1 -1
- package/dist/runtime/facades/brain-facade.d.ts.map +1 -1
- package/dist/runtime/facades/brain-facade.js +122 -1
- package/dist/runtime/facades/brain-facade.js.map +1 -1
- package/dist/runtime/facades/cognee-facade.d.ts.map +1 -1
- package/dist/runtime/facades/cognee-facade.js +3 -1
- package/dist/runtime/facades/cognee-facade.js.map +1 -1
- package/dist/runtime/facades/control-facade.d.ts.map +1 -1
- package/dist/runtime/facades/control-facade.js +42 -0
- package/dist/runtime/facades/control-facade.js.map +1 -1
- package/dist/runtime/facades/index.d.ts.map +1 -1
- package/dist/runtime/facades/index.js +10 -6
- package/dist/runtime/facades/index.js.map +1 -1
- package/dist/runtime/facades/memory-facade.d.ts.map +1 -1
- package/dist/runtime/facades/memory-facade.js +20 -2
- package/dist/runtime/facades/memory-facade.js.map +1 -1
- package/dist/runtime/facades/plan-facade.d.ts.map +1 -1
- package/dist/runtime/facades/plan-facade.js +2 -0
- package/dist/runtime/facades/plan-facade.js.map +1 -1
- package/dist/runtime/facades/vault-facade.d.ts.map +1 -1
- package/dist/runtime/facades/vault-facade.js +27 -5
- package/dist/runtime/facades/vault-facade.js.map +1 -1
- package/dist/runtime/intake-ops.d.ts +7 -5
- package/dist/runtime/intake-ops.d.ts.map +1 -1
- package/dist/runtime/intake-ops.js +98 -5
- package/dist/runtime/intake-ops.js.map +1 -1
- package/dist/runtime/memory-extra-ops.d.ts +6 -3
- package/dist/runtime/memory-extra-ops.d.ts.map +1 -1
- package/dist/runtime/memory-extra-ops.js +292 -4
- package/dist/runtime/memory-extra-ops.js.map +1 -1
- package/dist/runtime/orchestrate-ops.d.ts +8 -7
- package/dist/runtime/orchestrate-ops.d.ts.map +1 -1
- package/dist/runtime/orchestrate-ops.js +217 -61
- package/dist/runtime/orchestrate-ops.js.map +1 -1
- package/dist/runtime/planning-extra-ops.d.ts.map +1 -1
- package/dist/runtime/planning-extra-ops.js +85 -0
- package/dist/runtime/planning-extra-ops.js.map +1 -1
- package/dist/runtime/playbook-ops.js +1 -1
- package/dist/runtime/playbook-ops.js.map +1 -1
- package/dist/runtime/runtime.d.ts.map +1 -1
- package/dist/runtime/runtime.js +165 -18
- package/dist/runtime/runtime.js.map +1 -1
- package/dist/runtime/session-briefing.d.ts +23 -0
- package/dist/runtime/session-briefing.d.ts.map +1 -0
- package/dist/runtime/session-briefing.js +140 -0
- package/dist/runtime/session-briefing.js.map +1 -0
- package/dist/runtime/types.d.ts +29 -2
- package/dist/runtime/types.d.ts.map +1 -1
- package/dist/runtime/vault-linking-ops.d.ts +13 -0
- package/dist/runtime/vault-linking-ops.d.ts.map +1 -0
- package/dist/runtime/vault-linking-ops.js +365 -0
- package/dist/runtime/vault-linking-ops.js.map +1 -0
- package/dist/vault/linking.d.ts +46 -0
- package/dist/vault/linking.d.ts.map +1 -0
- package/dist/vault/linking.js +275 -0
- package/dist/vault/linking.js.map +1 -0
- package/dist/vault/vault-types.d.ts +37 -0
- package/dist/vault/vault-types.d.ts.map +1 -1
- package/dist/vault/vault.d.ts +37 -0
- package/dist/vault/vault.d.ts.map +1 -1
- package/dist/vault/vault.js +152 -9
- package/dist/vault/vault.js.map +1 -1
- package/package.json +4 -1
- package/src/__tests__/admin-extra-ops.test.ts +1 -1
- package/src/__tests__/admin-ops.test.ts +2 -1
- package/src/__tests__/admin-setup-ops.test.ts +355 -0
- package/src/__tests__/async-infrastructure.test.ts +307 -0
- package/src/__tests__/cognee-client-gaps.test.ts +474 -0
- package/src/__tests__/cognee-hybrid-search.test.ts +492 -0
- package/src/__tests__/cognee-sync-manager-deep.test.ts +654 -0
- package/src/__tests__/cognee-sync-manager.test.ts +1 -0
- package/src/__tests__/core-ops.test.ts +9 -61
- package/src/__tests__/curator-extra-ops.test.ts +6 -2
- package/src/__tests__/curator-pipeline-e2e.test.ts +358 -0
- package/src/__tests__/domain-packs.test.ts +421 -0
- package/src/__tests__/flows.test.ts +604 -0
- package/src/__tests__/memory-extra-ops.test.ts +2 -2
- package/src/__tests__/planning-extra-ops.test.ts +2 -2
- package/src/__tests__/playbook-registry.test.ts +2 -2
- package/src/__tests__/playbook-seeder.test.ts +8 -8
- package/src/__tests__/playbook.test.ts +5 -5
- package/src/__tests__/second-brain-features.test.ts +583 -0
- package/src/__tests__/token-resolver.test.ts +79 -0
- package/src/agency/agency-manager.ts +217 -9
- package/src/agency/default-rules.ts +83 -0
- package/src/agency/types.ts +61 -0
- package/src/brain/brain.ts +110 -8
- package/src/brain/intelligence.ts +21 -2
- package/src/brain/knowledge-synthesizer.ts +218 -0
- package/src/brain/learning-radar.ts +340 -0
- package/src/brain/types.ts +16 -0
- package/src/capabilities/chain-mapping.ts +93 -0
- package/src/capabilities/index.ts +21 -0
- package/src/capabilities/registry.ts +290 -0
- package/src/capabilities/types.ts +143 -0
- package/src/context/context-engine.ts +114 -15
- package/src/context/types.ts +5 -0
- package/src/control/intent-router.ts +153 -2
- package/src/control/types.ts +10 -0
- package/src/curator/classifier.ts +88 -0
- package/src/curator/quality-gate.ts +129 -0
- package/src/domain-packs/index.ts +27 -0
- package/src/domain-packs/inject-rules.ts +74 -0
- package/src/domain-packs/knowledge-installer.ts +116 -0
- package/src/domain-packs/loader.ts +124 -0
- package/src/domain-packs/pack-runtime.ts +99 -0
- package/src/domain-packs/skills-installer.ts +56 -0
- package/src/domain-packs/token-resolver.ts +126 -0
- package/src/domain-packs/types.ts +229 -0
- package/src/engine/__tests__/register-engine.test.ts +104 -0
- package/src/engine/bin/soleri-engine.ts +218 -0
- package/src/engine/core-ops.ts +178 -0
- package/src/engine/index.ts +19 -0
- package/src/engine/register-engine.ts +385 -0
- package/src/engine/test-helpers.ts +83 -0
- package/src/events/event-bus.ts +58 -0
- package/src/flows/chain-runner.ts +369 -0
- package/src/flows/chain-types.ts +57 -0
- package/src/flows/context-router.ts +257 -0
- package/src/flows/dispatch-registry.ts +80 -0
- package/src/flows/epilogue.ts +65 -0
- package/src/flows/executor.ts +182 -0
- package/src/flows/gate-evaluator.ts +171 -0
- package/src/flows/index.ts +52 -0
- package/src/flows/loader.ts +63 -0
- package/src/flows/plan-builder.ts +250 -0
- package/src/flows/probes.ts +70 -0
- package/src/flows/types.ts +217 -0
- package/src/health/doctor-checks.ts +115 -0
- package/src/index.ts +68 -1
- package/src/intake/text-ingester.ts +234 -0
- package/src/intelligence/loader.ts +38 -0
- package/src/intelligence/types.ts +1 -0
- package/src/llm/llm-client.ts +38 -1
- package/src/llm/oauth-discovery.ts +169 -0
- package/src/packs/types.ts +19 -0
- package/src/planning/evidence-collector.ts +247 -0
- package/src/planning/planner.ts +11 -0
- package/src/playbooks/generic/onboarding.ts +79 -0
- package/src/playbooks/playbook-registry.ts +2 -0
- package/src/queue/job-queue.ts +281 -0
- package/src/queue/pipeline-runner.ts +149 -0
- package/src/runtime/admin-extra-ops.ts +14 -8
- package/src/runtime/admin-ops.ts +4 -4
- package/src/runtime/admin-setup-ops.ts +664 -0
- package/src/runtime/capture-ops.ts +40 -1
- package/src/runtime/chain-ops.ts +121 -0
- package/src/runtime/claude-md-helpers.ts +236 -0
- package/src/runtime/curator-extra-ops.ts +86 -3
- package/src/runtime/domain-ops.ts +71 -5
- package/src/runtime/facades/admin-facade.ts +4 -0
- package/src/runtime/facades/agency-facade.ts +68 -0
- package/src/runtime/facades/brain-facade.ts +142 -1
- package/src/runtime/facades/cognee-facade.ts +3 -1
- package/src/runtime/facades/control-facade.ts +45 -0
- package/src/runtime/facades/index.ts +12 -6
- package/src/runtime/facades/memory-facade.ts +20 -2
- package/src/runtime/facades/plan-facade.ts +2 -0
- package/src/runtime/facades/vault-facade.ts +30 -5
- package/src/runtime/intake-ops.ts +107 -5
- package/src/runtime/memory-extra-ops.ts +312 -4
- package/src/runtime/orchestrate-ops.ts +261 -65
- package/src/runtime/planning-extra-ops.ts +94 -0
- package/src/runtime/playbook-ops.ts +1 -1
- package/src/runtime/runtime.ts +164 -19
- package/src/runtime/session-briefing.ts +161 -0
- package/src/runtime/types.ts +29 -2
- package/src/runtime/vault-linking-ops.ts +452 -0
- package/src/vault/linking.ts +333 -0
- package/src/vault/vault-types.ts +46 -0
- package/src/vault/vault.ts +173 -11
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Domain Pack loader — resolves, validates, and dependency-sorts domain packs.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { validateDomainPack } from './types.js';
|
|
6
|
+
import type { DomainPack, DomainPackManifest, DomainPackRef } from './types.js';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Load a single domain pack from an npm package.
|
|
10
|
+
*
|
|
11
|
+
* @param packageName - npm package name (e.g., '@soleri/domain-design')
|
|
12
|
+
* @returns Validated DomainPackManifest
|
|
13
|
+
* @throws If package cannot be imported or fails validation
|
|
14
|
+
*/
|
|
15
|
+
export async function loadDomainPack(packageName: string): Promise<DomainPackManifest> {
|
|
16
|
+
let mod: Record<string, unknown>;
|
|
17
|
+
try {
|
|
18
|
+
mod = await import(packageName);
|
|
19
|
+
} catch (err) {
|
|
20
|
+
throw new Error(
|
|
21
|
+
`Failed to import domain pack "${packageName}": ${err instanceof Error ? err.message : String(err)}`, { cause: err },
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
// Support both default export and named 'pack' export
|
|
26
|
+
const packCandidate = mod.default ?? mod.pack;
|
|
27
|
+
if (!packCandidate) {
|
|
28
|
+
throw new Error(`Domain pack "${packageName}" has no default or named "pack" export.`);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
const result = validateDomainPack(packCandidate);
|
|
32
|
+
if (!result.success) {
|
|
33
|
+
throw new Error(`Domain pack "${packageName}" failed validation: ${result.errors.message}`);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
return {
|
|
37
|
+
...result.data,
|
|
38
|
+
packageName,
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Load all domain packs from AgentConfig refs.
|
|
44
|
+
*
|
|
45
|
+
* @param refs - Array of DomainPackRef from agent config
|
|
46
|
+
* @returns Validated and dependency-sorted packs
|
|
47
|
+
*/
|
|
48
|
+
export async function loadDomainPacksFromConfig(
|
|
49
|
+
refs: DomainPackRef[],
|
|
50
|
+
): Promise<DomainPackManifest[]> {
|
|
51
|
+
const packs = await Promise.all(refs.map((ref) => loadDomainPack(ref.package)));
|
|
52
|
+
return resolveDependencies(packs);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Topological sort of domain packs by their `requires` field.
|
|
57
|
+
*
|
|
58
|
+
* @param packs - Array of domain packs (validated)
|
|
59
|
+
* @returns Sorted array (dependencies before dependents)
|
|
60
|
+
* @throws On circular dependencies or missing dependencies
|
|
61
|
+
*/
|
|
62
|
+
export function resolveDependencies<T extends DomainPack>(packs: T[]): T[] {
|
|
63
|
+
const byName = new Map<string, T>();
|
|
64
|
+
for (const pack of packs) {
|
|
65
|
+
byName.set(pack.name, pack);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
// Check for missing dependencies
|
|
69
|
+
for (const pack of packs) {
|
|
70
|
+
if (pack.requires) {
|
|
71
|
+
for (const dep of pack.requires) {
|
|
72
|
+
if (!byName.has(dep)) {
|
|
73
|
+
throw new Error(
|
|
74
|
+
`Domain pack "${pack.name}" requires "${dep}" but it was not found in the loaded packs.`,
|
|
75
|
+
);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
// Kahn's algorithm for topological sort
|
|
82
|
+
const inDegree = new Map<string, number>();
|
|
83
|
+
const adjList = new Map<string, string[]>();
|
|
84
|
+
|
|
85
|
+
for (const pack of packs) {
|
|
86
|
+
inDegree.set(pack.name, 0);
|
|
87
|
+
adjList.set(pack.name, []);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
for (const pack of packs) {
|
|
91
|
+
if (pack.requires) {
|
|
92
|
+
for (const dep of pack.requires) {
|
|
93
|
+
adjList.get(dep)!.push(pack.name);
|
|
94
|
+
inDegree.set(pack.name, (inDegree.get(pack.name) ?? 0) + 1);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
const queue: string[] = [];
|
|
100
|
+
for (const [name, degree] of inDegree) {
|
|
101
|
+
if (degree === 0) queue.push(name);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
const sorted: T[] = [];
|
|
105
|
+
while (queue.length > 0) {
|
|
106
|
+
const current = queue.shift()!;
|
|
107
|
+
sorted.push(byName.get(current)!);
|
|
108
|
+
|
|
109
|
+
for (const dependent of adjList.get(current) ?? []) {
|
|
110
|
+
const newDegree = (inDegree.get(dependent) ?? 1) - 1;
|
|
111
|
+
inDegree.set(dependent, newDegree);
|
|
112
|
+
if (newDegree === 0) queue.push(dependent);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
if (sorted.length !== packs.length) {
|
|
117
|
+
const remaining = packs
|
|
118
|
+
.filter((p) => !sorted.some((s) => s.name === p.name))
|
|
119
|
+
.map((p) => p.name);
|
|
120
|
+
throw new Error(`Circular dependency detected among domain packs: ${remaining.join(', ')}`);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
return sorted;
|
|
124
|
+
}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PackRuntime — the subset of AgentRuntime available to domain packs.
|
|
3
|
+
*
|
|
4
|
+
* Domain packs receive this via onActivate(runtime). It exposes only what
|
|
5
|
+
* packs need: vault search, project registry, and session store.
|
|
6
|
+
* Packs should NOT depend on the full AgentRuntime interface.
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
import type { Vault } from '../vault/vault.js';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Minimal project context for token resolution.
|
|
13
|
+
* Matches the shape of ProjectRegistry entries.
|
|
14
|
+
*/
|
|
15
|
+
export interface PackProjectContext {
|
|
16
|
+
id: string;
|
|
17
|
+
name: string;
|
|
18
|
+
path: string;
|
|
19
|
+
colors?: {
|
|
20
|
+
[scale: string]: {
|
|
21
|
+
scale: Record<string, string>;
|
|
22
|
+
base: string;
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
semanticTokens?: Record<string, string>;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Session check for tool chaining (contrast → component create).
|
|
30
|
+
*/
|
|
31
|
+
export interface PackCheckContext {
|
|
32
|
+
id: string;
|
|
33
|
+
type: string;
|
|
34
|
+
data: Record<string, unknown>;
|
|
35
|
+
timestamp: number;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* The runtime interface domain packs receive via onActivate.
|
|
40
|
+
*
|
|
41
|
+
* Designed for graceful degradation: packs work without runtime
|
|
42
|
+
* (simplified mode), but gain full power when connected.
|
|
43
|
+
*/
|
|
44
|
+
export interface PackRuntime {
|
|
45
|
+
/** Vault for knowledge search and capture */
|
|
46
|
+
vault: Vault;
|
|
47
|
+
|
|
48
|
+
/** Get a registered project by ID (for token resolution) */
|
|
49
|
+
getProject(projectId: string): PackProjectContext | undefined;
|
|
50
|
+
|
|
51
|
+
/** List all registered projects */
|
|
52
|
+
listProjects(): Array<{ id: string; name: string; path: string }>;
|
|
53
|
+
|
|
54
|
+
/** Create a session check (for tool chaining) */
|
|
55
|
+
createCheck(type: string, data: Record<string, unknown>): string;
|
|
56
|
+
|
|
57
|
+
/** Validate a session check */
|
|
58
|
+
validateCheck(checkId: string, expectedType: string): PackCheckContext | null;
|
|
59
|
+
|
|
60
|
+
/** Validate and consume a session check (single-use) */
|
|
61
|
+
validateAndConsume(checkId: string, expectedType: string): PackCheckContext | null;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Create a PackRuntime from an AgentRuntime.
|
|
66
|
+
*
|
|
67
|
+
* This adapter extracts the subset of runtime that packs need,
|
|
68
|
+
* avoiding tight coupling to the full AgentRuntime interface.
|
|
69
|
+
*/
|
|
70
|
+
export function createPackRuntime(runtime: {
|
|
71
|
+
vault: Vault;
|
|
72
|
+
projectRegistry: {
|
|
73
|
+
getProject(id: string): PackProjectContext | undefined;
|
|
74
|
+
listProjects(): Array<{ id: string; name: string; path: string }>;
|
|
75
|
+
};
|
|
76
|
+
sessionStore?: {
|
|
77
|
+
createCheck(type: string, data: Record<string, unknown>): string;
|
|
78
|
+
validateCheck(id: string, type: string): PackCheckContext | null;
|
|
79
|
+
validateAndConsume(id: string, type: string): PackCheckContext | null;
|
|
80
|
+
};
|
|
81
|
+
}): PackRuntime {
|
|
82
|
+
return {
|
|
83
|
+
vault: runtime.vault,
|
|
84
|
+
getProject: (id) => runtime.projectRegistry.getProject(id),
|
|
85
|
+
listProjects: () => runtime.projectRegistry.listProjects(),
|
|
86
|
+
createCheck: (type, data) => {
|
|
87
|
+
if (!runtime.sessionStore) throw new Error('Session store not available');
|
|
88
|
+
return runtime.sessionStore.createCheck(type, data);
|
|
89
|
+
},
|
|
90
|
+
validateCheck: (id, type) => {
|
|
91
|
+
if (!runtime.sessionStore) return null;
|
|
92
|
+
return runtime.sessionStore.validateCheck(id, type);
|
|
93
|
+
},
|
|
94
|
+
validateAndConsume: (id, type) => {
|
|
95
|
+
if (!runtime.sessionStore) return null;
|
|
96
|
+
return runtime.sessionStore.validateAndConsume(id, type);
|
|
97
|
+
},
|
|
98
|
+
};
|
|
99
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Skills installer for domain packs.
|
|
3
|
+
*
|
|
4
|
+
* Copies skill .md files from the pack to the agent's skills directory.
|
|
5
|
+
* Does not overwrite existing skills unless force flag is set.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { existsSync, copyFileSync, mkdirSync } from 'node:fs';
|
|
9
|
+
import { join, resolve } from 'node:path';
|
|
10
|
+
import type { DomainPack } from './types.js';
|
|
11
|
+
|
|
12
|
+
export interface SkillsInstallResult {
|
|
13
|
+
installed: number;
|
|
14
|
+
skipped: number;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Install skills from a domain pack.
|
|
19
|
+
*
|
|
20
|
+
* @param pack - The domain pack with skills
|
|
21
|
+
* @param targetDir - Agent's skills directory
|
|
22
|
+
* @param rootDir - Absolute path to the pack's root directory
|
|
23
|
+
* @param force - Overwrite existing skills if true
|
|
24
|
+
*/
|
|
25
|
+
export function installSkills(
|
|
26
|
+
pack: DomainPack,
|
|
27
|
+
targetDir: string,
|
|
28
|
+
rootDir: string,
|
|
29
|
+
force = false,
|
|
30
|
+
): SkillsInstallResult {
|
|
31
|
+
const result: SkillsInstallResult = { installed: 0, skipped: 0 };
|
|
32
|
+
|
|
33
|
+
if (!pack.skills || pack.skills.length === 0) return result;
|
|
34
|
+
|
|
35
|
+
mkdirSync(targetDir, { recursive: true });
|
|
36
|
+
|
|
37
|
+
for (const skill of pack.skills) {
|
|
38
|
+
const sourcePath = resolve(rootDir, skill.path);
|
|
39
|
+
const targetPath = join(targetDir, `${skill.name}.md`);
|
|
40
|
+
|
|
41
|
+
if (!existsSync(sourcePath)) {
|
|
42
|
+
result.skipped++;
|
|
43
|
+
continue;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
if (existsSync(targetPath) && !force) {
|
|
47
|
+
result.skipped++;
|
|
48
|
+
continue;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
copyFileSync(sourcePath, targetPath);
|
|
52
|
+
result.installed++;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
return result;
|
|
56
|
+
}
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TokenResolver — resolves design token names to hex values.
|
|
3
|
+
*
|
|
4
|
+
* Ported from Salvador MCP src/registry/token-resolver.ts.
|
|
5
|
+
* Supports: #HEX passthrough, SCALE[SHADE] (e.g., PRIMARY[500]),
|
|
6
|
+
* Tailwind classes (bg-primary-500), semantic tokens (text-inverse),
|
|
7
|
+
* and named colors (white, black).
|
|
8
|
+
*
|
|
9
|
+
* Stateless — create per-invocation with a ProjectContext.
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import type { PackProjectContext } from './pack-runtime.js';
|
|
13
|
+
|
|
14
|
+
const NAMED_COLORS: Record<string, string> = {
|
|
15
|
+
white: '#FFFFFF',
|
|
16
|
+
black: '#000000',
|
|
17
|
+
transparent: '#00000000',
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Resolve a token or color reference to a hex value.
|
|
22
|
+
*
|
|
23
|
+
* @param tokenOrHex - Token name, hex value, or color reference
|
|
24
|
+
* @param project - Project context with color scales and semantic tokens
|
|
25
|
+
* @returns Uppercase hex string (e.g., "#DC0000")
|
|
26
|
+
* @throws If the token cannot be resolved
|
|
27
|
+
*/
|
|
28
|
+
export function resolveToken(tokenOrHex: string, project: PackProjectContext): string {
|
|
29
|
+
// Passthrough hex values
|
|
30
|
+
if (tokenOrHex.startsWith('#')) {
|
|
31
|
+
return tokenOrHex.toUpperCase();
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// Named colors
|
|
35
|
+
const named = NAMED_COLORS[tokenOrHex.toLowerCase()];
|
|
36
|
+
if (named) return named;
|
|
37
|
+
|
|
38
|
+
// Semantic tokens (e.g., "text-inverse", "bg-surface")
|
|
39
|
+
if (project.semanticTokens) {
|
|
40
|
+
const semantic = project.semanticTokens[tokenOrHex];
|
|
41
|
+
if (semantic) return semantic.toUpperCase();
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
// SCALE[SHADE] format (e.g., "PRIMARY[500]", "neutral[900]")
|
|
45
|
+
const scaleMatch = tokenOrHex.match(/^(\w+)\[(\d+)\]$/);
|
|
46
|
+
if (scaleMatch) {
|
|
47
|
+
const [, scaleName, shade] = scaleMatch;
|
|
48
|
+
return resolveScale(scaleName.toLowerCase(), shade, project);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// Tailwind-style: bg-primary-500, text-neutral-700
|
|
52
|
+
const tailwindMatch = tokenOrHex.match(/^(?:bg|text|border|ring|fill|stroke)-(\w+)-(\d+)$/);
|
|
53
|
+
if (tailwindMatch) {
|
|
54
|
+
const [, scaleName, shade] = tailwindMatch;
|
|
55
|
+
return resolveScale(scaleName, shade, project);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
throw new Error(`Cannot resolve token: "${tokenOrHex}"`);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
function resolveScale(scaleName: string, shade: string, project: PackProjectContext): string {
|
|
62
|
+
if (!project.colors) {
|
|
63
|
+
throw new Error(`Project "${project.name}" has no color scales`);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
const scale = project.colors[scaleName];
|
|
67
|
+
if (!scale) {
|
|
68
|
+
const available = Object.keys(project.colors).join(', ');
|
|
69
|
+
throw new Error(`Unknown color scale "${scaleName}". Available: ${available}`);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const hex = scale.scale[shade];
|
|
73
|
+
if (!hex) {
|
|
74
|
+
const available = Object.keys(scale.scale).join(', ');
|
|
75
|
+
throw new Error(`Unknown shade "${shade}" in scale "${scaleName}". Available: ${available}`);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
return hex.toUpperCase();
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* List all tokens available in a project.
|
|
83
|
+
*
|
|
84
|
+
* @param project - Project context
|
|
85
|
+
* @returns Array of { token, hex, scale } for all scale + semantic tokens
|
|
86
|
+
*/
|
|
87
|
+
export function listProjectTokens(
|
|
88
|
+
project: PackProjectContext,
|
|
89
|
+
): Array<{ token: string; hex: string; scale: string }> {
|
|
90
|
+
const tokens: Array<{ token: string; hex: string; scale: string }> = [];
|
|
91
|
+
|
|
92
|
+
// Scale tokens
|
|
93
|
+
if (project.colors) {
|
|
94
|
+
for (const [scaleName, scaleData] of Object.entries(project.colors)) {
|
|
95
|
+
for (const [shade, hex] of Object.entries(scaleData.scale)) {
|
|
96
|
+
tokens.push({
|
|
97
|
+
token: `${scaleName}-${shade}`,
|
|
98
|
+
hex: hex.toUpperCase(),
|
|
99
|
+
scale: scaleName,
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
// Semantic tokens
|
|
106
|
+
if (project.semanticTokens) {
|
|
107
|
+
for (const [name, hex] of Object.entries(project.semanticTokens)) {
|
|
108
|
+
tokens.push({ token: name, hex: hex.toUpperCase(), scale: 'semantic' });
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
return tokens;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
* Build a reverse index: hex → token name.
|
|
117
|
+
* Useful for detecting hardcoded colors.
|
|
118
|
+
*/
|
|
119
|
+
export function buildReverseIndex(project: PackProjectContext): Map<string, string> {
|
|
120
|
+
const index = new Map<string, string>();
|
|
121
|
+
const tokens = listProjectTokens(project);
|
|
122
|
+
for (const t of tokens) {
|
|
123
|
+
index.set(t.hex.toUpperCase(), t.token);
|
|
124
|
+
}
|
|
125
|
+
return index;
|
|
126
|
+
}
|
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Domain Pack types — the contract for plug-and-play domain intelligence.
|
|
3
|
+
*
|
|
4
|
+
* A DomainPack is an npm package that bundles:
|
|
5
|
+
* - Custom ops with real algorithmic logic (e.g., WCAG contrast checking)
|
|
6
|
+
* - Optional standalone facades (one pack can register multiple MCP tools)
|
|
7
|
+
* - Tiered knowledge (canonical/curated/captured)
|
|
8
|
+
* - CLAUDE.md behavioral rules
|
|
9
|
+
* - Skills
|
|
10
|
+
*
|
|
11
|
+
* One pack = one npm package, can register multiple facades.
|
|
12
|
+
*/
|
|
13
|
+
|
|
14
|
+
import { z } from 'zod';
|
|
15
|
+
import type { OpDefinition, FacadeConfig } from '../facades/types.js';
|
|
16
|
+
import type { AgentRuntime } from '../runtime/types.js';
|
|
17
|
+
import type { PackRuntime } from './pack-runtime.js';
|
|
18
|
+
|
|
19
|
+
// ---------------------------------------------------------------------------
|
|
20
|
+
// Reserved names — packs cannot claim these as facade names
|
|
21
|
+
// ---------------------------------------------------------------------------
|
|
22
|
+
|
|
23
|
+
export const SEMANTIC_FACADE_NAMES: ReadonlyArray<string> = [
|
|
24
|
+
'vault',
|
|
25
|
+
'plan',
|
|
26
|
+
'brain',
|
|
27
|
+
'memory',
|
|
28
|
+
'admin',
|
|
29
|
+
'curator',
|
|
30
|
+
'loop',
|
|
31
|
+
'orchestrate',
|
|
32
|
+
'control',
|
|
33
|
+
'cognee',
|
|
34
|
+
'governance',
|
|
35
|
+
'context',
|
|
36
|
+
'agency',
|
|
37
|
+
'chat',
|
|
38
|
+
'playbook',
|
|
39
|
+
] as const;
|
|
40
|
+
|
|
41
|
+
// ---------------------------------------------------------------------------
|
|
42
|
+
// Knowledge Manifest — tiered knowledge with different lifecycle rules
|
|
43
|
+
// ---------------------------------------------------------------------------
|
|
44
|
+
|
|
45
|
+
/** Three-tier knowledge structure. Each tier has different lifecycle rules. */
|
|
46
|
+
export interface KnowledgeManifest {
|
|
47
|
+
/** Immutable rules and axioms. Never overwritten by curator. Highest search authority. */
|
|
48
|
+
canonical?: string;
|
|
49
|
+
/** Patterns and anti-patterns. Curator can groom, deduplicate, enrich. */
|
|
50
|
+
curated?: string;
|
|
51
|
+
/** Seed learnings. Rarely shipped — normally emerges from agent usage. */
|
|
52
|
+
captured?: string;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
// ---------------------------------------------------------------------------
|
|
56
|
+
// Skill Definition (for pack-bundled skills)
|
|
57
|
+
// ---------------------------------------------------------------------------
|
|
58
|
+
|
|
59
|
+
export interface PackSkillDefinition {
|
|
60
|
+
/** Skill file name (without .md extension) */
|
|
61
|
+
name: string;
|
|
62
|
+
/** Path to the .md skill file relative to the pack */
|
|
63
|
+
path: string;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// ---------------------------------------------------------------------------
|
|
67
|
+
// DomainPack — the main interface
|
|
68
|
+
// ---------------------------------------------------------------------------
|
|
69
|
+
|
|
70
|
+
/** The contract every domain pack must implement. */
|
|
71
|
+
export interface DomainPack {
|
|
72
|
+
/** Unique pack name (e.g., 'design', 'security-intelligence') */
|
|
73
|
+
name: string;
|
|
74
|
+
/** Semver version */
|
|
75
|
+
version: string;
|
|
76
|
+
/** Domains this pack claims. Ops inject into these domain facades. */
|
|
77
|
+
domains: string[];
|
|
78
|
+
/** Custom operations with real logic — injected into claimed domain facades. */
|
|
79
|
+
ops: OpDefinition[];
|
|
80
|
+
/** Additional standalone facades (one pack can register multiple MCP tools). */
|
|
81
|
+
facades?: FacadeConfig[];
|
|
82
|
+
/** Tiered knowledge to install into the agent's vault. */
|
|
83
|
+
knowledge?: KnowledgeManifest;
|
|
84
|
+
/** CLAUDE.md behavioral rules fragment (markdown). */
|
|
85
|
+
rules?: string;
|
|
86
|
+
/** Skills to install into the agent's skills directory. */
|
|
87
|
+
skills?: PackSkillDefinition[];
|
|
88
|
+
/** Capability handler factory — returns handlers for declared capabilities */
|
|
89
|
+
capabilities?: (
|
|
90
|
+
runtime: PackRuntime,
|
|
91
|
+
) => Map<string, import('../capabilities/types.js').CapabilityHandler>;
|
|
92
|
+
/** Other packs this pack depends on (by name). */
|
|
93
|
+
requires?: string[];
|
|
94
|
+
/** Called after pack is installed (one-time setup). */
|
|
95
|
+
onInstall?: (runtime: AgentRuntime) => Promise<void>;
|
|
96
|
+
/** Called each time the agent starts (runtime initialization). */
|
|
97
|
+
onActivate?: (runtime: AgentRuntime) => Promise<void>;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
// ---------------------------------------------------------------------------
|
|
101
|
+
// DomainPackRef — lightweight reference for AgentConfig
|
|
102
|
+
// ---------------------------------------------------------------------------
|
|
103
|
+
|
|
104
|
+
/** Reference to a domain pack in agent configuration. */
|
|
105
|
+
export interface DomainPackRef {
|
|
106
|
+
/** Display name */
|
|
107
|
+
name: string;
|
|
108
|
+
/** npm package name (e.g., '@soleri/domain-design') */
|
|
109
|
+
package: string;
|
|
110
|
+
/** Optional version constraint */
|
|
111
|
+
version?: string;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
// ---------------------------------------------------------------------------
|
|
115
|
+
// DomainPackManifest — validated and resolved pack
|
|
116
|
+
// ---------------------------------------------------------------------------
|
|
117
|
+
|
|
118
|
+
/** A DomainPack that has been validated and resolved. */
|
|
119
|
+
export interface DomainPackManifest extends DomainPack {
|
|
120
|
+
/** Resolved from npm package name */
|
|
121
|
+
packageName: string;
|
|
122
|
+
/** Absolute path to the pack's root directory */
|
|
123
|
+
rootDir?: string;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
// ---------------------------------------------------------------------------
|
|
127
|
+
// Validation
|
|
128
|
+
// ---------------------------------------------------------------------------
|
|
129
|
+
|
|
130
|
+
const knowledgeManifestSchema = z.object({
|
|
131
|
+
canonical: z.string().optional(),
|
|
132
|
+
curated: z.string().optional(),
|
|
133
|
+
captured: z.string().optional(),
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
const packSkillSchema = z.object({
|
|
137
|
+
name: z.string(),
|
|
138
|
+
path: z.string(),
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
/** Zod schema for validating DomainPack structure (data fields only). */
|
|
142
|
+
const domainPackSchema = z.object({
|
|
143
|
+
name: z.string().min(1),
|
|
144
|
+
version: z.string().min(1),
|
|
145
|
+
domains: z.array(z.string().min(1)).min(1),
|
|
146
|
+
ops: z.array(
|
|
147
|
+
z.object({
|
|
148
|
+
name: z.string().min(1),
|
|
149
|
+
description: z.string(),
|
|
150
|
+
auth: z.enum(['read', 'write', 'admin']),
|
|
151
|
+
handler: z.function(),
|
|
152
|
+
schema: z.any().optional(),
|
|
153
|
+
hot: z.boolean().optional(),
|
|
154
|
+
}),
|
|
155
|
+
),
|
|
156
|
+
facades: z
|
|
157
|
+
.array(
|
|
158
|
+
z.object({
|
|
159
|
+
name: z.string().min(1),
|
|
160
|
+
description: z.string(),
|
|
161
|
+
ops: z.array(z.any()),
|
|
162
|
+
}),
|
|
163
|
+
)
|
|
164
|
+
.optional(),
|
|
165
|
+
knowledge: knowledgeManifestSchema.optional(),
|
|
166
|
+
rules: z.string().optional(),
|
|
167
|
+
skills: z.array(packSkillSchema).optional(),
|
|
168
|
+
requires: z.array(z.string()).optional(),
|
|
169
|
+
onInstall: z.function().optional(),
|
|
170
|
+
onActivate: z.function().optional(),
|
|
171
|
+
});
|
|
172
|
+
|
|
173
|
+
export type ValidateResult =
|
|
174
|
+
| { success: true; data: DomainPack }
|
|
175
|
+
| { success: false; errors: z.ZodError };
|
|
176
|
+
|
|
177
|
+
/**
|
|
178
|
+
* Validate an unknown value as a DomainPack.
|
|
179
|
+
*
|
|
180
|
+
* Beyond Zod shape validation, also checks:
|
|
181
|
+
* - Op names are unique within the pack
|
|
182
|
+
* - Facade names don't collide with semantic facades
|
|
183
|
+
*/
|
|
184
|
+
export function validateDomainPack(value: unknown): ValidateResult {
|
|
185
|
+
const parsed = domainPackSchema.safeParse(value);
|
|
186
|
+
if (!parsed.success) {
|
|
187
|
+
return { success: false, errors: parsed.error };
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
const pack = parsed.data as DomainPack;
|
|
191
|
+
|
|
192
|
+
// Check for duplicate op names
|
|
193
|
+
const opNames = new Set<string>();
|
|
194
|
+
for (const op of pack.ops) {
|
|
195
|
+
if (opNames.has(op.name)) {
|
|
196
|
+
return {
|
|
197
|
+
success: false,
|
|
198
|
+
errors: new z.ZodError([
|
|
199
|
+
{
|
|
200
|
+
code: 'custom',
|
|
201
|
+
path: ['ops'],
|
|
202
|
+
message: `Duplicate op name: "${op.name}"`,
|
|
203
|
+
},
|
|
204
|
+
]),
|
|
205
|
+
};
|
|
206
|
+
}
|
|
207
|
+
opNames.add(op.name);
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
// Check facade name collisions with semantic facades
|
|
211
|
+
if (pack.facades) {
|
|
212
|
+
for (const facade of pack.facades) {
|
|
213
|
+
if (SEMANTIC_FACADE_NAMES.includes(facade.name)) {
|
|
214
|
+
return {
|
|
215
|
+
success: false,
|
|
216
|
+
errors: new z.ZodError([
|
|
217
|
+
{
|
|
218
|
+
code: 'custom',
|
|
219
|
+
path: ['facades'],
|
|
220
|
+
message: `Facade name "${facade.name}" collides with semantic facade. Reserved names: ${SEMANTIC_FACADE_NAMES.join(', ')}`,
|
|
221
|
+
},
|
|
222
|
+
]),
|
|
223
|
+
};
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
return { success: true, data: pack };
|
|
229
|
+
}
|