aiyou-dev 3.5.15
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/.claude/agents/analysis/analyze-code-quality.md +179 -0
- package/.claude/agents/analysis/code-analyzer.md +210 -0
- package/.claude/agents/analysis/code-review/analyze-code-quality.md +179 -0
- package/.claude/agents/architecture/arch-system-design.md +157 -0
- package/.claude/agents/architecture/system-design/arch-system-design.md +155 -0
- package/.claude/agents/browser/browser-agent.yaml +182 -0
- package/.claude/agents/consensus/byzantine-coordinator.md +63 -0
- package/.claude/agents/consensus/crdt-synchronizer.md +997 -0
- package/.claude/agents/consensus/gossip-coordinator.md +63 -0
- package/.claude/agents/consensus/performance-benchmarker.md +851 -0
- package/.claude/agents/consensus/quorum-manager.md +823 -0
- package/.claude/agents/consensus/raft-manager.md +63 -0
- package/.claude/agents/consensus/security-manager.md +622 -0
- package/.claude/agents/core/coder.md +453 -0
- package/.claude/agents/core/planner.md +375 -0
- package/.claude/agents/core/researcher.md +369 -0
- package/.claude/agents/core/reviewer.md +520 -0
- package/.claude/agents/core/tester.md +512 -0
- package/.claude/agents/custom/test-long-runner.md +44 -0
- package/.claude/agents/data/data-ml-model.md +445 -0
- package/.claude/agents/data/ml/data-ml-model.md +193 -0
- package/.claude/agents/development/backend/dev-backend-api.md +142 -0
- package/.claude/agents/development/dev-backend-api.md +345 -0
- package/.claude/agents/devops/ci-cd/ops-cicd-github.md +164 -0
- package/.claude/agents/devops/ops-cicd-github.md +165 -0
- package/.claude/agents/documentation/api-docs/docs-api-openapi.md +174 -0
- package/.claude/agents/documentation/docs-api-openapi.md +355 -0
- package/.claude/agents/flow-nexus/app-store.md +88 -0
- package/.claude/agents/flow-nexus/authentication.md +69 -0
- package/.claude/agents/flow-nexus/challenges.md +81 -0
- package/.claude/agents/flow-nexus/neural-network.md +88 -0
- package/.claude/agents/flow-nexus/payments.md +83 -0
- package/.claude/agents/flow-nexus/sandbox.md +76 -0
- package/.claude/agents/flow-nexus/swarm.md +76 -0
- package/.claude/agents/flow-nexus/user-tools.md +96 -0
- package/.claude/agents/flow-nexus/workflow.md +84 -0
- package/.claude/agents/github/code-review-swarm.md +377 -0
- package/.claude/agents/github/github-modes.md +173 -0
- package/.claude/agents/github/issue-tracker.md +576 -0
- package/.claude/agents/github/multi-repo-swarm.md +553 -0
- package/.claude/agents/github/pr-manager.md +438 -0
- package/.claude/agents/github/project-board-sync.md +509 -0
- package/.claude/agents/github/release-manager.md +605 -0
- package/.claude/agents/github/release-swarm.md +583 -0
- package/.claude/agents/github/repo-architect.md +398 -0
- package/.claude/agents/github/swarm-issue.md +573 -0
- package/.claude/agents/github/swarm-pr.md +428 -0
- package/.claude/agents/github/sync-coordinator.md +452 -0
- package/.claude/agents/github/workflow-automation.md +903 -0
- package/.claude/agents/goal/agent.md +816 -0
- package/.claude/agents/goal/goal-planner.md +73 -0
- package/.claude/agents/optimization/benchmark-suite.md +665 -0
- package/.claude/agents/optimization/load-balancer.md +431 -0
- package/.claude/agents/optimization/performance-monitor.md +672 -0
- package/.claude/agents/optimization/resource-allocator.md +674 -0
- package/.claude/agents/optimization/topology-optimizer.md +808 -0
- package/.claude/agents/payments/agentic-payments.md +126 -0
- package/.claude/agents/sona/sona-learning-optimizer.md +74 -0
- package/.claude/agents/sparc/architecture.md +699 -0
- package/.claude/agents/sparc/pseudocode.md +520 -0
- package/.claude/agents/sparc/refinement.md +802 -0
- package/.claude/agents/sparc/specification.md +478 -0
- package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +225 -0
- package/.claude/agents/specialized/spec-mobile-react-native.md +227 -0
- package/.claude/agents/sublinear/consensus-coordinator.md +338 -0
- package/.claude/agents/sublinear/matrix-optimizer.md +185 -0
- package/.claude/agents/sublinear/pagerank-analyzer.md +299 -0
- package/.claude/agents/sublinear/performance-optimizer.md +368 -0
- package/.claude/agents/sublinear/trading-predictor.md +246 -0
- package/.claude/agents/swarm/adaptive-coordinator.md +1127 -0
- package/.claude/agents/swarm/hierarchical-coordinator.md +710 -0
- package/.claude/agents/swarm/mesh-coordinator.md +963 -0
- package/.claude/agents/templates/automation-smart-agent.md +205 -0
- package/.claude/agents/templates/base-template-generator.md +268 -0
- package/.claude/agents/templates/coordinator-swarm-init.md +90 -0
- package/.claude/agents/templates/github-pr-manager.md +177 -0
- package/.claude/agents/templates/implementer-sparc-coder.md +259 -0
- package/.claude/agents/templates/memory-coordinator.md +187 -0
- package/.claude/agents/templates/orchestrator-task.md +139 -0
- package/.claude/agents/templates/performance-analyzer.md +199 -0
- package/.claude/agents/templates/sparc-coordinator.md +514 -0
- package/.claude/agents/testing/production-validator.md +395 -0
- package/.claude/agents/testing/tdd-london-swarm.md +244 -0
- package/.claude/agents/v3/adr-architect.md +184 -0
- package/.claude/agents/v3/aidefence-guardian.md +282 -0
- package/.claude/agents/v3/claims-authorizer.md +208 -0
- package/.claude/agents/v3/collective-intelligence-coordinator.md +993 -0
- package/.claude/agents/v3/ddd-domain-expert.md +220 -0
- package/.claude/agents/v3/injection-analyst.md +236 -0
- package/.claude/agents/v3/memory-specialist.md +995 -0
- package/.claude/agents/v3/performance-engineer.md +1233 -0
- package/.claude/agents/v3/pii-detector.md +151 -0
- package/.claude/agents/v3/reasoningbank-learner.md +213 -0
- package/.claude/agents/v3/security-architect-aidefence.md +410 -0
- package/.claude/agents/v3/security-architect.md +867 -0
- package/.claude/agents/v3/security-auditor.md +771 -0
- package/.claude/agents/v3/sparc-orchestrator.md +182 -0
- package/.claude/agents/v3/swarm-memory-manager.md +157 -0
- package/.claude/agents/v3/v3-integration-architect.md +205 -0
- package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +54 -0
- package/.claude/commands/analysis/README.md +9 -0
- package/.claude/commands/analysis/bottleneck-detect.md +162 -0
- package/.claude/commands/analysis/performance-bottlenecks.md +59 -0
- package/.claude/commands/analysis/performance-report.md +25 -0
- package/.claude/commands/analysis/token-efficiency.md +45 -0
- package/.claude/commands/analysis/token-usage.md +25 -0
- package/.claude/commands/automation/README.md +9 -0
- package/.claude/commands/automation/auto-agent.md +122 -0
- package/.claude/commands/automation/self-healing.md +106 -0
- package/.claude/commands/automation/session-memory.md +90 -0
- package/.claude/commands/automation/smart-agents.md +73 -0
- package/.claude/commands/automation/smart-spawn.md +25 -0
- package/.claude/commands/automation/workflow-select.md +25 -0
- package/.claude/commands/claude-flow-help.md +103 -0
- package/.claude/commands/claude-flow-memory.md +107 -0
- package/.claude/commands/claude-flow-swarm.md +205 -0
- package/.claude/commands/github/README.md +11 -0
- package/.claude/commands/github/code-review-swarm.md +514 -0
- package/.claude/commands/github/code-review.md +25 -0
- package/.claude/commands/github/github-modes.md +147 -0
- package/.claude/commands/github/github-swarm.md +121 -0
- package/.claude/commands/github/issue-tracker.md +292 -0
- package/.claude/commands/github/issue-triage.md +25 -0
- package/.claude/commands/github/multi-repo-swarm.md +519 -0
- package/.claude/commands/github/pr-enhance.md +26 -0
- package/.claude/commands/github/pr-manager.md +170 -0
- package/.claude/commands/github/project-board-sync.md +471 -0
- package/.claude/commands/github/release-manager.md +338 -0
- package/.claude/commands/github/release-swarm.md +544 -0
- package/.claude/commands/github/repo-analyze.md +25 -0
- package/.claude/commands/github/repo-architect.md +367 -0
- package/.claude/commands/github/swarm-issue.md +482 -0
- package/.claude/commands/github/swarm-pr.md +285 -0
- package/.claude/commands/github/sync-coordinator.md +301 -0
- package/.claude/commands/github/workflow-automation.md +442 -0
- package/.claude/commands/hooks/README.md +11 -0
- package/.claude/commands/hooks/overview.md +58 -0
- package/.claude/commands/hooks/post-edit.md +117 -0
- package/.claude/commands/hooks/post-task.md +112 -0
- package/.claude/commands/hooks/pre-edit.md +113 -0
- package/.claude/commands/hooks/pre-task.md +111 -0
- package/.claude/commands/hooks/session-end.md +118 -0
- package/.claude/commands/hooks/setup.md +103 -0
- package/.claude/commands/monitoring/README.md +9 -0
- package/.claude/commands/monitoring/agent-metrics.md +25 -0
- package/.claude/commands/monitoring/agents.md +44 -0
- package/.claude/commands/monitoring/real-time-view.md +25 -0
- package/.claude/commands/monitoring/status.md +46 -0
- package/.claude/commands/monitoring/swarm-monitor.md +25 -0
- package/.claude/commands/optimization/README.md +9 -0
- package/.claude/commands/optimization/auto-topology.md +62 -0
- package/.claude/commands/optimization/cache-manage.md +25 -0
- package/.claude/commands/optimization/parallel-execute.md +25 -0
- package/.claude/commands/optimization/parallel-execution.md +50 -0
- package/.claude/commands/optimization/topology-optimize.md +25 -0
- package/.claude/commands/sparc/analyzer.md +52 -0
- package/.claude/commands/sparc/architect.md +53 -0
- package/.claude/commands/sparc/ask.md +97 -0
- package/.claude/commands/sparc/batch-executor.md +54 -0
- package/.claude/commands/sparc/code.md +89 -0
- package/.claude/commands/sparc/coder.md +54 -0
- package/.claude/commands/sparc/debug.md +83 -0
- package/.claude/commands/sparc/debugger.md +54 -0
- package/.claude/commands/sparc/designer.md +53 -0
- package/.claude/commands/sparc/devops.md +109 -0
- package/.claude/commands/sparc/docs-writer.md +80 -0
- package/.claude/commands/sparc/documenter.md +54 -0
- package/.claude/commands/sparc/innovator.md +54 -0
- package/.claude/commands/sparc/integration.md +83 -0
- package/.claude/commands/sparc/mcp.md +117 -0
- package/.claude/commands/sparc/memory-manager.md +54 -0
- package/.claude/commands/sparc/optimizer.md +54 -0
- package/.claude/commands/sparc/orchestrator.md +132 -0
- package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -0
- package/.claude/commands/sparc/refinement-optimization-mode.md +83 -0
- package/.claude/commands/sparc/researcher.md +54 -0
- package/.claude/commands/sparc/reviewer.md +54 -0
- package/.claude/commands/sparc/security-review.md +80 -0
- package/.claude/commands/sparc/sparc-modes.md +174 -0
- package/.claude/commands/sparc/sparc.md +111 -0
- package/.claude/commands/sparc/spec-pseudocode.md +80 -0
- package/.claude/commands/sparc/supabase-admin.md +348 -0
- package/.claude/commands/sparc/swarm-coordinator.md +54 -0
- package/.claude/commands/sparc/tdd.md +54 -0
- package/.claude/commands/sparc/tester.md +54 -0
- package/.claude/commands/sparc/tutorial.md +79 -0
- package/.claude/commands/sparc/workflow-manager.md +54 -0
- package/.claude/helpers/README.md +97 -0
- package/.claude/helpers/adr-compliance.sh +186 -0
- package/.claude/helpers/auto-commit.sh +178 -0
- package/.claude/helpers/auto-memory-hook.mjs +365 -0
- package/.claude/helpers/checkpoint-manager.sh +251 -0
- package/.claude/helpers/daemon-manager.sh +252 -0
- package/.claude/helpers/ddd-tracker.sh +144 -0
- package/.claude/helpers/github-safe.js +106 -0
- package/.claude/helpers/github-setup.sh +28 -0
- package/.claude/helpers/guidance-hook.sh +13 -0
- package/.claude/helpers/guidance-hooks.sh +102 -0
- package/.claude/helpers/health-monitor.sh +108 -0
- package/.claude/helpers/hook-handler.cjs +271 -0
- package/.claude/helpers/intelligence.cjs +916 -0
- package/.claude/helpers/learning-hooks.sh +329 -0
- package/.claude/helpers/learning-optimizer.sh +127 -0
- package/.claude/helpers/learning-service.mjs +1144 -0
- package/.claude/helpers/memory.js +83 -0
- package/.claude/helpers/metrics-db.mjs +488 -0
- package/.claude/helpers/pattern-consolidator.sh +86 -0
- package/.claude/helpers/perf-worker.sh +160 -0
- package/.claude/helpers/post-commit +16 -0
- package/.claude/helpers/pre-commit +26 -0
- package/.claude/helpers/quick-start.sh +19 -0
- package/.claude/helpers/router.js +66 -0
- package/.claude/helpers/security-scanner.sh +127 -0
- package/.claude/helpers/session.js +135 -0
- package/.claude/helpers/setup-mcp.sh +18 -0
- package/.claude/helpers/standard-checkpoint-hooks.sh +189 -0
- package/.claude/helpers/statusline-hook.sh +21 -0
- package/.claude/helpers/statusline.cjs +758 -0
- package/.claude/helpers/statusline.js +316 -0
- package/.claude/helpers/swarm-comms.sh +353 -0
- package/.claude/helpers/swarm-hooks.sh +761 -0
- package/.claude/helpers/swarm-monitor.sh +211 -0
- package/.claude/helpers/sync-v3-metrics.sh +245 -0
- package/.claude/helpers/update-v3-progress.sh +166 -0
- package/.claude/helpers/v3-quick-status.sh +58 -0
- package/.claude/helpers/v3.sh +111 -0
- package/.claude/helpers/validate-v3-config.sh +216 -0
- package/.claude/helpers/worker-manager.sh +170 -0
- package/.claude/settings.json +319 -0
- package/.claude/settings.local.json +18 -0
- package/.claude/skills/agentdb-advanced/SKILL.md +550 -0
- package/.claude/skills/agentdb-learning/SKILL.md +545 -0
- package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -0
- package/.claude/skills/agentdb-optimization/SKILL.md +509 -0
- package/.claude/skills/agentdb-vector-search/SKILL.md +339 -0
- package/.claude/skills/browser/SKILL.md +204 -0
- package/.claude/skills/github-code-review/SKILL.md +1140 -0
- package/.claude/skills/github-multi-repo/SKILL.md +874 -0
- package/.claude/skills/github-project-management/SKILL.md +1277 -0
- package/.claude/skills/github-release-management/SKILL.md +1081 -0
- package/.claude/skills/github-workflow-automation/SKILL.md +1065 -0
- package/.claude/skills/hooks-automation/SKILL.md +1201 -0
- package/.claude/skills/pair-programming/SKILL.md +1202 -0
- package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -0
- package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -0
- package/.claude/skills/skill-builder/SKILL.md +910 -0
- package/.claude/skills/sparc-methodology/SKILL.md +1115 -0
- package/.claude/skills/stream-chain/SKILL.md +563 -0
- package/.claude/skills/swarm-advanced/SKILL.md +973 -0
- package/.claude/skills/swarm-orchestration/SKILL.md +179 -0
- package/.claude/skills/v3-cli-modernization/SKILL.md +872 -0
- package/.claude/skills/v3-core-implementation/SKILL.md +797 -0
- package/.claude/skills/v3-ddd-architecture/SKILL.md +442 -0
- package/.claude/skills/v3-integration-deep/SKILL.md +241 -0
- package/.claude/skills/v3-mcp-optimization/SKILL.md +777 -0
- package/.claude/skills/v3-memory-unification/SKILL.md +174 -0
- package/.claude/skills/v3-performance-optimization/SKILL.md +390 -0
- package/.claude/skills/v3-security-overhaul/SKILL.md +82 -0
- package/.claude/skills/v3-swarm-coordination/SKILL.md +340 -0
- package/.claude/skills/verification-quality/SKILL.md +649 -0
- package/.claude-plugin/README.md +720 -0
- package/.claude-plugin/docs/INSTALLATION.md +261 -0
- package/.claude-plugin/docs/PLUGIN_SUMMARY.md +361 -0
- package/.claude-plugin/docs/QUICKSTART.md +361 -0
- package/.claude-plugin/docs/STRUCTURE.md +128 -0
- package/.claude-plugin/hooks/hooks.json +74 -0
- package/.claude-plugin/marketplace.json +96 -0
- package/.claude-plugin/plugin.json +71 -0
- package/.claude-plugin/scripts/install.sh +234 -0
- package/.claude-plugin/scripts/uninstall.sh +36 -0
- package/.claude-plugin/scripts/verify.sh +108 -0
- package/LICENSE +24 -0
- package/README.md +99 -0
- package/bin/cli.js +11 -0
- package/bin/npx-repair.js +7 -0
- package/bin/npx-safe-launch.js +9 -0
- package/package.json +131 -0
- package/v3/@aiyou-dev/cli/bin/cli.js +156 -0
- package/v3/@aiyou-dev/cli/bin/mcp-server.js +189 -0
- package/v3/@aiyou-dev/cli/bin/preinstall.cjs +2 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/gguf-engine.d.ts +91 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/gguf-engine.js +425 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/ruvllm-bridge.d.ts +102 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/ruvllm-bridge.js +292 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/rvfa-builder.d.ts +44 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/rvfa-builder.js +329 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/rvfa-distribution.d.ts +97 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/rvfa-distribution.js +370 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/rvfa-format.d.ts +111 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/rvfa-format.js +393 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/rvfa-runner.d.ts +69 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/rvfa-runner.js +237 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/rvfa-signing.d.ts +123 -0
- package/v3/@aiyou-dev/cli/dist/src/appliance/rvfa-signing.js +347 -0
- package/v3/@aiyou-dev/cli/dist/src/benchmarks/pretrain/index.d.ts +58 -0
- package/v3/@aiyou-dev/cli/dist/src/benchmarks/pretrain/index.js +404 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/agent.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/agent.js +819 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/analyze.d.ts +19 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/analyze.js +1823 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/appliance-advanced.d.ts +9 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/appliance-advanced.js +215 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/appliance.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/appliance.js +406 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/benchmark.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/benchmark.js +459 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/claims.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/claims.js +373 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/completions.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/completions.js +539 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/config.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/config.js +406 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/daemon.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/daemon.js +609 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/deployment.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/deployment.js +289 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/doctor.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/doctor.js +602 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/embeddings.d.ts +18 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/embeddings.js +1576 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/gcc.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/gcc.js +197 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/guidance.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/guidance.js +560 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/hive-mind.d.ts +11 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/hive-mind.js +1230 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/hooks.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/hooks.js +3759 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/index.d.ts +114 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/index.js +375 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/init.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/init.js +976 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/issues.d.ts +21 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/issues.js +567 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/mcp.d.ts +11 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/mcp.js +715 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/memory.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/memory.js +1292 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/migrate.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/migrate.js +410 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/neural.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/neural.js +1448 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/performance.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/performance.js +579 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/plugins.d.ts +11 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/plugins.js +820 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/process.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/process.js +641 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/progress.d.ts +11 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/progress.js +259 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/providers.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/providers.js +232 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/route.d.ts +16 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/route.js +813 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/backup.d.ts +11 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/backup.js +746 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/benchmark.d.ts +11 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/benchmark.js +480 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/import.d.ts +18 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/import.js +349 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/index.d.ts +29 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/index.js +129 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/init.d.ts +11 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/init.js +431 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/migrate.d.ts +11 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/migrate.js +481 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/optimize.d.ts +11 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/optimize.js +503 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/setup.d.ts +18 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/setup.js +765 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/status.d.ts +11 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/ruvector/status.js +456 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/security.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/security.js +575 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/session.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/session.js +750 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/start.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/start.js +418 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/status.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/status.js +591 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/swarm.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/swarm.js +748 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/task.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/task.js +671 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/transfer-store.d.ts +13 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/transfer-store.js +428 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/update.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/update.js +276 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/workflow.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/commands/workflow.js +617 -0
- package/v3/@aiyou-dev/cli/dist/src/config-adapter.d.ts +15 -0
- package/v3/@aiyou-dev/cli/dist/src/config-adapter.js +186 -0
- package/v3/@aiyou-dev/cli/dist/src/gcc/core.d.ts +98 -0
- package/v3/@aiyou-dev/cli/dist/src/gcc/core.js +504 -0
- package/v3/@aiyou-dev/cli/dist/src/gcc/index.d.ts +10 -0
- package/v3/@aiyou-dev/cli/dist/src/gcc/index.js +9 -0
- package/v3/@aiyou-dev/cli/dist/src/gcc/toon-bridge.d.ts +19 -0
- package/v3/@aiyou-dev/cli/dist/src/gcc/toon-bridge.js +51 -0
- package/v3/@aiyou-dev/cli/dist/src/index.d.ts +76 -0
- package/v3/@aiyou-dev/cli/dist/src/index.js +470 -0
- package/v3/@aiyou-dev/cli/dist/src/infrastructure/in-memory-repositories.d.ts +68 -0
- package/v3/@aiyou-dev/cli/dist/src/infrastructure/in-memory-repositories.js +264 -0
- package/v3/@aiyou-dev/cli/dist/src/init/claudemd-generator.d.ts +25 -0
- package/v3/@aiyou-dev/cli/dist/src/init/claudemd-generator.js +525 -0
- package/v3/@aiyou-dev/cli/dist/src/init/executor.d.ts +41 -0
- package/v3/@aiyou-dev/cli/dist/src/init/executor.js +1767 -0
- package/v3/@aiyou-dev/cli/dist/src/init/gemini-config-generator.d.ts +24 -0
- package/v3/@aiyou-dev/cli/dist/src/init/gemini-config-generator.js +89 -0
- package/v3/@aiyou-dev/cli/dist/src/init/geminimd-generator.d.ts +15 -0
- package/v3/@aiyou-dev/cli/dist/src/init/geminimd-generator.js +222 -0
- package/v3/@aiyou-dev/cli/dist/src/init/helpers-generator.d.ts +60 -0
- package/v3/@aiyou-dev/cli/dist/src/init/helpers-generator.js +1166 -0
- package/v3/@aiyou-dev/cli/dist/src/init/index.d.ts +13 -0
- package/v3/@aiyou-dev/cli/dist/src/init/index.js +15 -0
- package/v3/@aiyou-dev/cli/dist/src/init/mcp-generator.d.ts +26 -0
- package/v3/@aiyou-dev/cli/dist/src/init/mcp-generator.js +116 -0
- package/v3/@aiyou-dev/cli/dist/src/init/settings-generator.d.ts +14 -0
- package/v3/@aiyou-dev/cli/dist/src/init/settings-generator.js +437 -0
- package/v3/@aiyou-dev/cli/dist/src/init/statusline-generator.d.ts +28 -0
- package/v3/@aiyou-dev/cli/dist/src/init/statusline-generator.js +817 -0
- package/v3/@aiyou-dev/cli/dist/src/init/types.d.ts +291 -0
- package/v3/@aiyou-dev/cli/dist/src/init/types.js +260 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-client.d.ts +92 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-client.js +241 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-server.d.ts +161 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-server.js +627 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/agent-tools.d.ts +9 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/agent-tools.js +549 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/agentdb-tools.d.ts +30 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/agentdb-tools.js +557 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/analyze-tools.d.ts +38 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/analyze-tools.js +317 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/auto-install.d.ts +83 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/auto-install.js +131 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/browser-tools.d.ts +13 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/browser-tools.js +550 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/claims-tools.d.ts +12 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/claims-tools.js +732 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/config-tools.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/config-tools.js +343 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/coordination-tools.d.ts +13 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/coordination-tools.js +486 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/daa-tools.d.ts +13 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/daa-tools.js +426 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/embeddings-tools.d.ts +9 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/embeddings-tools.js +782 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/gcc-tools.d.ts +9 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/gcc-tools.js +152 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/github-tools.d.ts +13 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/github-tools.js +373 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/hive-mind-tools.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/hive-mind-tools.js +583 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/hooks-tools.d.ts +44 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/hooks-tools.js +2969 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/index.d.ts +24 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/index.js +23 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/memory-tools.d.ts +14 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/memory-tools.js +499 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/neural-tools.d.ts +16 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/neural-tools.js +461 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/performance-tools.d.ts +16 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/performance-tools.js +534 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/progress-tools.d.ts +14 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/progress-tools.js +348 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/security-tools.d.ts +18 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/security-tools.js +434 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/session-tools.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/session-tools.js +315 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/swarm-tools.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/swarm-tools.js +102 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/system-tools.d.ts +13 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/system-tools.js +417 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/task-tools.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/task-tools.js +338 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/terminal-tools.d.ts +13 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/terminal-tools.js +246 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/transfer-tools.d.ts +14 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/transfer-tools.js +396 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/types.d.ts +31 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/types.js +7 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/workflow-tools.d.ts +8 -0
- package/v3/@aiyou-dev/cli/dist/src/mcp-tools/workflow-tools.js +572 -0
- package/v3/@aiyou-dev/cli/dist/src/memory/ewc-consolidation.d.ts +271 -0
- package/v3/@aiyou-dev/cli/dist/src/memory/ewc-consolidation.js +542 -0
- package/v3/@aiyou-dev/cli/dist/src/memory/intelligence.d.ts +285 -0
- package/v3/@aiyou-dev/cli/dist/src/memory/intelligence.js +794 -0
- package/v3/@aiyou-dev/cli/dist/src/memory/memory-bridge.d.ts +407 -0
- package/v3/@aiyou-dev/cli/dist/src/memory/memory-bridge.js +1494 -0
- package/v3/@aiyou-dev/cli/dist/src/memory/memory-initializer.d.ts +405 -0
- package/v3/@aiyou-dev/cli/dist/src/memory/memory-initializer.js +2105 -0
- package/v3/@aiyou-dev/cli/dist/src/memory/sona-optimizer.d.ts +227 -0
- package/v3/@aiyou-dev/cli/dist/src/memory/sona-optimizer.js +633 -0
- package/v3/@aiyou-dev/cli/dist/src/output.d.ts +133 -0
- package/v3/@aiyou-dev/cli/dist/src/output.js +514 -0
- package/v3/@aiyou-dev/cli/dist/src/parser.d.ts +41 -0
- package/v3/@aiyou-dev/cli/dist/src/parser.js +377 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/manager.d.ts +133 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/manager.js +400 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/store/discovery.d.ts +88 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/store/discovery.js +1147 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/store/index.d.ts +76 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/store/index.js +141 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/store/search.d.ts +46 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/store/search.js +230 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/store/types.d.ts +274 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/store/types.js +7 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/tests/demo-plugin-store.d.ts +7 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/tests/demo-plugin-store.js +126 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/tests/standalone-test.d.ts +12 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/tests/standalone-test.js +188 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/tests/test-plugin-store.d.ts +7 -0
- package/v3/@aiyou-dev/cli/dist/src/plugins/tests/test-plugin-store.js +206 -0
- package/v3/@aiyou-dev/cli/dist/src/production/circuit-breaker.d.ts +101 -0
- package/v3/@aiyou-dev/cli/dist/src/production/circuit-breaker.js +241 -0
- package/v3/@aiyou-dev/cli/dist/src/production/error-handler.d.ts +92 -0
- package/v3/@aiyou-dev/cli/dist/src/production/error-handler.js +299 -0
- package/v3/@aiyou-dev/cli/dist/src/production/index.d.ts +23 -0
- package/v3/@aiyou-dev/cli/dist/src/production/index.js +18 -0
- package/v3/@aiyou-dev/cli/dist/src/production/monitoring.d.ts +161 -0
- package/v3/@aiyou-dev/cli/dist/src/production/monitoring.js +356 -0
- package/v3/@aiyou-dev/cli/dist/src/production/rate-limiter.d.ts +80 -0
- package/v3/@aiyou-dev/cli/dist/src/production/rate-limiter.js +201 -0
- package/v3/@aiyou-dev/cli/dist/src/production/retry.d.ts +48 -0
- package/v3/@aiyou-dev/cli/dist/src/production/retry.js +179 -0
- package/v3/@aiyou-dev/cli/dist/src/prompt.d.ts +44 -0
- package/v3/@aiyou-dev/cli/dist/src/prompt.js +501 -0
- package/v3/@aiyou-dev/cli/dist/src/runtime/headless.d.ts +60 -0
- package/v3/@aiyou-dev/cli/dist/src/runtime/headless.js +284 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/ast-analyzer.d.ts +67 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/ast-analyzer.js +277 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/coverage-router.d.ts +160 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/coverage-router.js +529 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/coverage-tools.d.ts +33 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/coverage-tools.js +157 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/diff-classifier.d.ts +175 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/diff-classifier.js +698 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/enhanced-model-router.d.ts +146 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/enhanced-model-router.js +529 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/flash-attention.d.ts +195 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/flash-attention.js +643 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/graph-analyzer.d.ts +187 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/graph-analyzer.js +929 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/index.d.ts +34 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/index.js +60 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/lora-adapter.d.ts +218 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/lora-adapter.js +455 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/model-router.d.ts +220 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/model-router.js +488 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/moe-router.d.ts +206 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/moe-router.js +626 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/q-learning-router.d.ts +211 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/q-learning-router.js +681 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/semantic-router.d.ts +77 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/semantic-router.js +178 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/vector-db.d.ts +69 -0
- package/v3/@aiyou-dev/cli/dist/src/ruvector/vector-db.js +243 -0
- package/v3/@aiyou-dev/cli/dist/src/services/agentic-flow-bridge.d.ts +50 -0
- package/v3/@aiyou-dev/cli/dist/src/services/agentic-flow-bridge.js +95 -0
- package/v3/@aiyou-dev/cli/dist/src/services/claim-service.d.ts +204 -0
- package/v3/@aiyou-dev/cli/dist/src/services/claim-service.js +818 -0
- package/v3/@aiyou-dev/cli/dist/src/services/container-worker-pool.d.ts +197 -0
- package/v3/@aiyou-dev/cli/dist/src/services/container-worker-pool.js +583 -0
- package/v3/@aiyou-dev/cli/dist/src/services/headless-worker-executor.d.ts +304 -0
- package/v3/@aiyou-dev/cli/dist/src/services/headless-worker-executor.js +999 -0
- package/v3/@aiyou-dev/cli/dist/src/services/index.d.ts +13 -0
- package/v3/@aiyou-dev/cli/dist/src/services/index.js +11 -0
- package/v3/@aiyou-dev/cli/dist/src/services/registry-api.d.ts +58 -0
- package/v3/@aiyou-dev/cli/dist/src/services/registry-api.js +146 -0
- package/v3/@aiyou-dev/cli/dist/src/services/ruvector-training.d.ts +214 -0
- package/v3/@aiyou-dev/cli/dist/src/services/ruvector-training.js +497 -0
- package/v3/@aiyou-dev/cli/dist/src/services/worker-daemon.d.ts +203 -0
- package/v3/@aiyou-dev/cli/dist/src/services/worker-daemon.js +756 -0
- package/v3/@aiyou-dev/cli/dist/src/services/worker-queue.d.ts +194 -0
- package/v3/@aiyou-dev/cli/dist/src/services/worker-queue.js +513 -0
- package/v3/@aiyou-dev/cli/dist/src/suggest.d.ts +53 -0
- package/v3/@aiyou-dev/cli/dist/src/suggest.js +200 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/anonymization/index.d.ts +25 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/anonymization/index.js +175 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/deploy-seraphine.d.ts +13 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/deploy-seraphine.js +205 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/export.d.ts +25 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/export.js +113 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/index.d.ts +12 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/index.js +31 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/ipfs/client.d.ts +109 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/ipfs/client.js +307 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/ipfs/upload.d.ts +95 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/ipfs/upload.js +411 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/models/seraphine.d.ts +72 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/models/seraphine.js +373 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/serialization/cfp.d.ts +49 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/serialization/cfp.js +183 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/storage/gcs.d.ts +82 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/storage/gcs.js +256 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/storage/index.d.ts +6 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/storage/index.js +6 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/discovery.d.ts +84 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/discovery.js +382 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/download.d.ts +70 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/download.js +334 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/index.d.ts +84 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/index.js +153 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/publish.d.ts +76 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/publish.js +294 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/registry.d.ts +58 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/registry.js +285 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/search.d.ts +54 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/search.js +232 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/tests/standalone-test.d.ts +12 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/tests/standalone-test.js +190 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/types.d.ts +193 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/store/types.js +6 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/test-seraphine.d.ts +6 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/test-seraphine.js +105 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/tests/test-store.d.ts +7 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/tests/test-store.js +214 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/types.d.ts +245 -0
- package/v3/@aiyou-dev/cli/dist/src/transfer/types.js +6 -0
- package/v3/@aiyou-dev/cli/dist/src/types.d.ts +198 -0
- package/v3/@aiyou-dev/cli/dist/src/types.js +38 -0
- package/v3/@aiyou-dev/cli/dist/src/update/checker.d.ts +34 -0
- package/v3/@aiyou-dev/cli/dist/src/update/checker.js +190 -0
- package/v3/@aiyou-dev/cli/dist/src/update/executor.d.ts +32 -0
- package/v3/@aiyou-dev/cli/dist/src/update/executor.js +181 -0
- package/v3/@aiyou-dev/cli/dist/src/update/index.d.ts +33 -0
- package/v3/@aiyou-dev/cli/dist/src/update/index.js +64 -0
- package/v3/@aiyou-dev/cli/dist/src/update/rate-limiter.d.ts +20 -0
- package/v3/@aiyou-dev/cli/dist/src/update/rate-limiter.js +96 -0
- package/v3/@aiyou-dev/cli/dist/src/update/validator.d.ts +17 -0
- package/v3/@aiyou-dev/cli/dist/src/update/validator.js +123 -0
- package/v3/@aiyou-dev/cli/package.json +111 -0
- package/v3/@aiyou-dev/guidance/dist/adversarial.d.ts +284 -0
- package/v3/@aiyou-dev/guidance/dist/adversarial.js +572 -0
- package/v3/@aiyou-dev/guidance/dist/analyzer.d.ts +530 -0
- package/v3/@aiyou-dev/guidance/dist/analyzer.js +2518 -0
- package/v3/@aiyou-dev/guidance/dist/artifacts.d.ts +283 -0
- package/v3/@aiyou-dev/guidance/dist/artifacts.js +356 -0
- package/v3/@aiyou-dev/guidance/dist/authority.d.ts +290 -0
- package/v3/@aiyou-dev/guidance/dist/authority.js +558 -0
- package/v3/@aiyou-dev/guidance/dist/capabilities.d.ts +209 -0
- package/v3/@aiyou-dev/guidance/dist/capabilities.js +485 -0
- package/v3/@aiyou-dev/guidance/dist/coherence.d.ts +233 -0
- package/v3/@aiyou-dev/guidance/dist/coherence.js +372 -0
- package/v3/@aiyou-dev/guidance/dist/compiler.d.ts +87 -0
- package/v3/@aiyou-dev/guidance/dist/compiler.js +419 -0
- package/v3/@aiyou-dev/guidance/dist/conformance-kit.d.ts +225 -0
- package/v3/@aiyou-dev/guidance/dist/conformance-kit.js +629 -0
- package/v3/@aiyou-dev/guidance/dist/continue-gate.d.ts +214 -0
- package/v3/@aiyou-dev/guidance/dist/continue-gate.js +353 -0
- package/v3/@aiyou-dev/guidance/dist/crypto-utils.d.ts +17 -0
- package/v3/@aiyou-dev/guidance/dist/crypto-utils.js +24 -0
- package/v3/@aiyou-dev/guidance/dist/evolution.d.ts +282 -0
- package/v3/@aiyou-dev/guidance/dist/evolution.js +500 -0
- package/v3/@aiyou-dev/guidance/dist/gates.d.ts +79 -0
- package/v3/@aiyou-dev/guidance/dist/gates.js +302 -0
- package/v3/@aiyou-dev/guidance/dist/gateway.d.ts +206 -0
- package/v3/@aiyou-dev/guidance/dist/gateway.js +452 -0
- package/v3/@aiyou-dev/guidance/dist/generators.d.ts +153 -0
- package/v3/@aiyou-dev/guidance/dist/generators.js +682 -0
- package/v3/@aiyou-dev/guidance/dist/headless.d.ts +177 -0
- package/v3/@aiyou-dev/guidance/dist/headless.js +342 -0
- package/v3/@aiyou-dev/guidance/dist/hooks.d.ts +154 -0
- package/v3/@aiyou-dev/guidance/dist/hooks.js +361 -0
- package/v3/@aiyou-dev/guidance/dist/index.d.ts +205 -0
- package/v3/@aiyou-dev/guidance/dist/index.js +321 -0
- package/v3/@aiyou-dev/guidance/dist/ledger.d.ts +162 -0
- package/v3/@aiyou-dev/guidance/dist/ledger.js +375 -0
- package/v3/@aiyou-dev/guidance/dist/manifest-validator.d.ts +289 -0
- package/v3/@aiyou-dev/guidance/dist/manifest-validator.js +838 -0
- package/v3/@aiyou-dev/guidance/dist/memory-gate.d.ts +222 -0
- package/v3/@aiyou-dev/guidance/dist/memory-gate.js +382 -0
- package/v3/@aiyou-dev/guidance/dist/meta-governance.d.ts +265 -0
- package/v3/@aiyou-dev/guidance/dist/meta-governance.js +348 -0
- package/v3/@aiyou-dev/guidance/dist/optimizer.d.ts +104 -0
- package/v3/@aiyou-dev/guidance/dist/optimizer.js +329 -0
- package/v3/@aiyou-dev/guidance/dist/persistence.d.ts +189 -0
- package/v3/@aiyou-dev/guidance/dist/persistence.js +464 -0
- package/v3/@aiyou-dev/guidance/dist/proof.d.ts +185 -0
- package/v3/@aiyou-dev/guidance/dist/proof.js +238 -0
- package/v3/@aiyou-dev/guidance/dist/retriever.d.ts +116 -0
- package/v3/@aiyou-dev/guidance/dist/retriever.js +394 -0
- package/v3/@aiyou-dev/guidance/dist/ruvbot-integration.d.ts +370 -0
- package/v3/@aiyou-dev/guidance/dist/ruvbot-integration.js +738 -0
- package/v3/@aiyou-dev/guidance/dist/temporal.d.ts +426 -0
- package/v3/@aiyou-dev/guidance/dist/temporal.js +658 -0
- package/v3/@aiyou-dev/guidance/dist/trust.d.ts +283 -0
- package/v3/@aiyou-dev/guidance/dist/trust.js +473 -0
- package/v3/@aiyou-dev/guidance/dist/truth-anchors.d.ts +276 -0
- package/v3/@aiyou-dev/guidance/dist/truth-anchors.js +488 -0
- package/v3/@aiyou-dev/guidance/dist/types.d.ts +378 -0
- package/v3/@aiyou-dev/guidance/dist/types.js +10 -0
- package/v3/@aiyou-dev/guidance/dist/uncertainty.d.ts +372 -0
- package/v3/@aiyou-dev/guidance/dist/uncertainty.js +619 -0
- package/v3/@aiyou-dev/guidance/dist/wasm-kernel.d.ts +48 -0
- package/v3/@aiyou-dev/guidance/dist/wasm-kernel.js +158 -0
- package/v3/@aiyou-dev/guidance/package.json +198 -0
- package/v3/@aiyou-dev/shared/dist/core/config/defaults.d.ts +41 -0
- package/v3/@aiyou-dev/shared/dist/core/config/defaults.js +186 -0
- package/v3/@aiyou-dev/shared/dist/core/config/index.d.ts +8 -0
- package/v3/@aiyou-dev/shared/dist/core/config/index.js +12 -0
- package/v3/@aiyou-dev/shared/dist/core/config/loader.d.ts +45 -0
- package/v3/@aiyou-dev/shared/dist/core/config/loader.js +222 -0
- package/v3/@aiyou-dev/shared/dist/core/config/schema.d.ts +1134 -0
- package/v3/@aiyou-dev/shared/dist/core/config/schema.js +158 -0
- package/v3/@aiyou-dev/shared/dist/core/config/validator.d.ts +92 -0
- package/v3/@aiyou-dev/shared/dist/core/config/validator.js +147 -0
- package/v3/@aiyou-dev/shared/dist/core/event-bus.d.ts +31 -0
- package/v3/@aiyou-dev/shared/dist/core/event-bus.js +197 -0
- package/v3/@aiyou-dev/shared/dist/core/index.d.ts +15 -0
- package/v3/@aiyou-dev/shared/dist/core/index.js +19 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/agent.interface.d.ts +200 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/agent.interface.js +6 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/coordinator.interface.d.ts +310 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/coordinator.interface.js +7 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/event.interface.d.ts +224 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/event.interface.js +46 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/index.d.ts +10 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/index.js +15 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/memory.interface.d.ts +298 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/memory.interface.js +7 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/task.interface.d.ts +185 -0
- package/v3/@aiyou-dev/shared/dist/core/interfaces/task.interface.js +6 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/event-coordinator.d.ts +35 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/event-coordinator.js +101 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/health-monitor.d.ts +60 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/health-monitor.js +166 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/index.d.ts +46 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/index.js +64 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/lifecycle-manager.d.ts +56 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/lifecycle-manager.js +195 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/session-manager.d.ts +83 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/session-manager.js +193 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/task-manager.d.ts +49 -0
- package/v3/@aiyou-dev/shared/dist/core/orchestrator/task-manager.js +253 -0
- package/v3/@aiyou-dev/shared/dist/events/domain-events.d.ts +282 -0
- package/v3/@aiyou-dev/shared/dist/events/domain-events.js +165 -0
- package/v3/@aiyou-dev/shared/dist/events/event-store.d.ts +126 -0
- package/v3/@aiyou-dev/shared/dist/events/event-store.js +416 -0
- package/v3/@aiyou-dev/shared/dist/events/event-store.test.d.ts +8 -0
- package/v3/@aiyou-dev/shared/dist/events/event-store.test.js +293 -0
- package/v3/@aiyou-dev/shared/dist/events/example-usage.d.ts +10 -0
- package/v3/@aiyou-dev/shared/dist/events/example-usage.js +193 -0
- package/v3/@aiyou-dev/shared/dist/events/index.d.ts +21 -0
- package/v3/@aiyou-dev/shared/dist/events/index.js +22 -0
- package/v3/@aiyou-dev/shared/dist/events/projections.d.ts +177 -0
- package/v3/@aiyou-dev/shared/dist/events/projections.js +421 -0
- package/v3/@aiyou-dev/shared/dist/events/rvf-event-log.d.ts +82 -0
- package/v3/@aiyou-dev/shared/dist/events/rvf-event-log.js +340 -0
- package/v3/@aiyou-dev/shared/dist/events/state-reconstructor.d.ts +101 -0
- package/v3/@aiyou-dev/shared/dist/events/state-reconstructor.js +263 -0
- package/v3/@aiyou-dev/shared/dist/events.d.ts +80 -0
- package/v3/@aiyou-dev/shared/dist/events.js +249 -0
- package/v3/@aiyou-dev/shared/dist/hooks/example-usage.d.ts +42 -0
- package/v3/@aiyou-dev/shared/dist/hooks/example-usage.js +351 -0
- package/v3/@aiyou-dev/shared/dist/hooks/executor.d.ts +100 -0
- package/v3/@aiyou-dev/shared/dist/hooks/executor.js +264 -0
- package/v3/@aiyou-dev/shared/dist/hooks/hooks.test.d.ts +9 -0
- package/v3/@aiyou-dev/shared/dist/hooks/hooks.test.js +322 -0
- package/v3/@aiyou-dev/shared/dist/hooks/index.d.ts +52 -0
- package/v3/@aiyou-dev/shared/dist/hooks/index.js +51 -0
- package/v3/@aiyou-dev/shared/dist/hooks/registry.d.ts +133 -0
- package/v3/@aiyou-dev/shared/dist/hooks/registry.js +277 -0
- package/v3/@aiyou-dev/shared/dist/hooks/safety/bash-safety.d.ts +105 -0
- package/v3/@aiyou-dev/shared/dist/hooks/safety/bash-safety.js +481 -0
- package/v3/@aiyou-dev/shared/dist/hooks/safety/file-organization.d.ts +144 -0
- package/v3/@aiyou-dev/shared/dist/hooks/safety/file-organization.js +328 -0
- package/v3/@aiyou-dev/shared/dist/hooks/safety/git-commit.d.ts +158 -0
- package/v3/@aiyou-dev/shared/dist/hooks/safety/git-commit.js +450 -0
- package/v3/@aiyou-dev/shared/dist/hooks/safety/index.d.ts +17 -0
- package/v3/@aiyou-dev/shared/dist/hooks/safety/index.js +17 -0
- package/v3/@aiyou-dev/shared/dist/hooks/session-hooks.d.ts +234 -0
- package/v3/@aiyou-dev/shared/dist/hooks/session-hooks.js +334 -0
- package/v3/@aiyou-dev/shared/dist/hooks/task-hooks.d.ts +163 -0
- package/v3/@aiyou-dev/shared/dist/hooks/task-hooks.js +326 -0
- package/v3/@aiyou-dev/shared/dist/hooks/types.d.ts +267 -0
- package/v3/@aiyou-dev/shared/dist/hooks/types.js +62 -0
- package/v3/@aiyou-dev/shared/dist/hooks/verify-exports.test.d.ts +9 -0
- package/v3/@aiyou-dev/shared/dist/hooks/verify-exports.test.js +93 -0
- package/v3/@aiyou-dev/shared/dist/index.d.ts +20 -0
- package/v3/@aiyou-dev/shared/dist/index.js +50 -0
- package/v3/@aiyou-dev/shared/dist/mcp/connection-pool.d.ts +98 -0
- package/v3/@aiyou-dev/shared/dist/mcp/connection-pool.js +364 -0
- package/v3/@aiyou-dev/shared/dist/mcp/index.d.ts +69 -0
- package/v3/@aiyou-dev/shared/dist/mcp/index.js +84 -0
- package/v3/@aiyou-dev/shared/dist/mcp/server.d.ts +166 -0
- package/v3/@aiyou-dev/shared/dist/mcp/server.js +593 -0
- package/v3/@aiyou-dev/shared/dist/mcp/session-manager.d.ts +136 -0
- package/v3/@aiyou-dev/shared/dist/mcp/session-manager.js +335 -0
- package/v3/@aiyou-dev/shared/dist/mcp/tool-registry.d.ts +178 -0
- package/v3/@aiyou-dev/shared/dist/mcp/tool-registry.js +439 -0
- package/v3/@aiyou-dev/shared/dist/mcp/transport/http.d.ts +104 -0
- package/v3/@aiyou-dev/shared/dist/mcp/transport/http.js +476 -0
- package/v3/@aiyou-dev/shared/dist/mcp/transport/index.d.ts +102 -0
- package/v3/@aiyou-dev/shared/dist/mcp/transport/index.js +238 -0
- package/v3/@aiyou-dev/shared/dist/mcp/transport/stdio.d.ts +104 -0
- package/v3/@aiyou-dev/shared/dist/mcp/transport/stdio.js +263 -0
- package/v3/@aiyou-dev/shared/dist/mcp/transport/websocket.d.ts +133 -0
- package/v3/@aiyou-dev/shared/dist/mcp/transport/websocket.js +396 -0
- package/v3/@aiyou-dev/shared/dist/mcp/types.d.ts +438 -0
- package/v3/@aiyou-dev/shared/dist/mcp/types.js +54 -0
- package/v3/@aiyou-dev/shared/dist/plugin-interface.d.ts +544 -0
- package/v3/@aiyou-dev/shared/dist/plugin-interface.js +23 -0
- package/v3/@aiyou-dev/shared/dist/plugin-loader.d.ts +139 -0
- package/v3/@aiyou-dev/shared/dist/plugin-loader.js +434 -0
- package/v3/@aiyou-dev/shared/dist/plugin-registry.d.ts +183 -0
- package/v3/@aiyou-dev/shared/dist/plugin-registry.js +457 -0
- package/v3/@aiyou-dev/shared/dist/plugins/index.d.ts +10 -0
- package/v3/@aiyou-dev/shared/dist/plugins/index.js +10 -0
- package/v3/@aiyou-dev/shared/dist/plugins/official/hive-mind-plugin.d.ts +106 -0
- package/v3/@aiyou-dev/shared/dist/plugins/official/hive-mind-plugin.js +241 -0
- package/v3/@aiyou-dev/shared/dist/plugins/official/index.d.ts +10 -0
- package/v3/@aiyou-dev/shared/dist/plugins/official/index.js +10 -0
- package/v3/@aiyou-dev/shared/dist/plugins/official/maestro-plugin.d.ts +121 -0
- package/v3/@aiyou-dev/shared/dist/plugins/official/maestro-plugin.js +355 -0
- package/v3/@aiyou-dev/shared/dist/plugins/types.d.ts +93 -0
- package/v3/@aiyou-dev/shared/dist/plugins/types.js +9 -0
- package/v3/@aiyou-dev/shared/dist/resilience/bulkhead.d.ts +105 -0
- package/v3/@aiyou-dev/shared/dist/resilience/bulkhead.js +206 -0
- package/v3/@aiyou-dev/shared/dist/resilience/circuit-breaker.d.ts +132 -0
- package/v3/@aiyou-dev/shared/dist/resilience/circuit-breaker.js +233 -0
- package/v3/@aiyou-dev/shared/dist/resilience/index.d.ts +19 -0
- package/v3/@aiyou-dev/shared/dist/resilience/index.js +19 -0
- package/v3/@aiyou-dev/shared/dist/resilience/rate-limiter.d.ts +168 -0
- package/v3/@aiyou-dev/shared/dist/resilience/rate-limiter.js +314 -0
- package/v3/@aiyou-dev/shared/dist/resilience/retry.d.ts +91 -0
- package/v3/@aiyou-dev/shared/dist/resilience/retry.js +159 -0
- package/v3/@aiyou-dev/shared/dist/security/index.d.ts +10 -0
- package/v3/@aiyou-dev/shared/dist/security/index.js +12 -0
- package/v3/@aiyou-dev/shared/dist/security/input-validation.d.ts +73 -0
- package/v3/@aiyou-dev/shared/dist/security/input-validation.js +201 -0
- package/v3/@aiyou-dev/shared/dist/security/secure-random.d.ts +92 -0
- package/v3/@aiyou-dev/shared/dist/security/secure-random.js +142 -0
- package/v3/@aiyou-dev/shared/dist/services/index.d.ts +7 -0
- package/v3/@aiyou-dev/shared/dist/services/index.js +7 -0
- package/v3/@aiyou-dev/shared/dist/services/v3-progress.service.d.ts +124 -0
- package/v3/@aiyou-dev/shared/dist/services/v3-progress.service.js +402 -0
- package/v3/@aiyou-dev/shared/dist/types/agent.types.d.ts +137 -0
- package/v3/@aiyou-dev/shared/dist/types/agent.types.js +6 -0
- package/v3/@aiyou-dev/shared/dist/types/index.d.ts +11 -0
- package/v3/@aiyou-dev/shared/dist/types/index.js +17 -0
- package/v3/@aiyou-dev/shared/dist/types/mcp.types.d.ts +266 -0
- package/v3/@aiyou-dev/shared/dist/types/mcp.types.js +7 -0
- package/v3/@aiyou-dev/shared/dist/types/memory.types.d.ts +236 -0
- package/v3/@aiyou-dev/shared/dist/types/memory.types.js +7 -0
- package/v3/@aiyou-dev/shared/dist/types/swarm.types.d.ts +186 -0
- package/v3/@aiyou-dev/shared/dist/types/swarm.types.js +65 -0
- package/v3/@aiyou-dev/shared/dist/types/task.types.d.ts +178 -0
- package/v3/@aiyou-dev/shared/dist/types/task.types.js +32 -0
- package/v3/@aiyou-dev/shared/dist/types.d.ts +197 -0
- package/v3/@aiyou-dev/shared/dist/types.js +21 -0
- package/v3/@aiyou-dev/shared/dist/utils/secure-logger.d.ts +69 -0
- package/v3/@aiyou-dev/shared/dist/utils/secure-logger.js +208 -0
- package/v3/@aiyou-dev/shared/package.json +42 -0
|
@@ -0,0 +1,209 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Capability Algebra
|
|
3
|
+
*
|
|
4
|
+
* All permissions become typed objects that can be composed, restricted,
|
|
5
|
+
* delegated, revoked, and reasoned about. Supports delegation chains,
|
|
6
|
+
* attestations, constraint evaluation, and set-theoretic composition
|
|
7
|
+
* (intersection for actions, union for constraints).
|
|
8
|
+
*
|
|
9
|
+
* @module @aiyou-dev/guidance/capabilities
|
|
10
|
+
*/
|
|
11
|
+
/**
|
|
12
|
+
* Scope categories for capabilities
|
|
13
|
+
*/
|
|
14
|
+
export type CapabilityScope = 'tool' | 'memory' | 'network' | 'file' | 'model' | 'system';
|
|
15
|
+
/**
|
|
16
|
+
* Constraint applied to a capability
|
|
17
|
+
*/
|
|
18
|
+
export interface CapabilityConstraint {
|
|
19
|
+
/** Constraint type */
|
|
20
|
+
type: 'rate-limit' | 'budget' | 'time-window' | 'condition' | 'scope-restriction';
|
|
21
|
+
/** Type-specific parameters */
|
|
22
|
+
params: Record<string, unknown>;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Cryptographic attestation for a capability
|
|
26
|
+
*/
|
|
27
|
+
export interface Attestation {
|
|
28
|
+
/** ID of the attesting agent or authority */
|
|
29
|
+
attesterId: string;
|
|
30
|
+
/** When the attestation was made (ms since epoch) */
|
|
31
|
+
attestedAt: number;
|
|
32
|
+
/** Claim being attested (e.g., "agent passed security audit") */
|
|
33
|
+
claim: string;
|
|
34
|
+
/** Optional evidence supporting the claim */
|
|
35
|
+
evidence: string | null;
|
|
36
|
+
/** Signature over the claim (hex-encoded) */
|
|
37
|
+
signature: string;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* A typed permission object representing a granted capability
|
|
41
|
+
*/
|
|
42
|
+
export interface Capability {
|
|
43
|
+
/** Unique capability identifier (UUID) */
|
|
44
|
+
id: string;
|
|
45
|
+
/** Scope category */
|
|
46
|
+
scope: CapabilityScope;
|
|
47
|
+
/** Target resource (tool name, namespace, path pattern, etc.) */
|
|
48
|
+
resource: string;
|
|
49
|
+
/** Allowed actions (e.g., 'read', 'write', 'execute', 'delete') */
|
|
50
|
+
actions: string[];
|
|
51
|
+
/** Active constraints on this capability */
|
|
52
|
+
constraints: CapabilityConstraint[];
|
|
53
|
+
/** Agent or authority that granted this capability */
|
|
54
|
+
grantedBy: string;
|
|
55
|
+
/** Agent this capability is granted to */
|
|
56
|
+
grantedTo: string;
|
|
57
|
+
/** When the capability was granted (ms since epoch) */
|
|
58
|
+
grantedAt: number;
|
|
59
|
+
/** When the capability expires, or null for no expiry */
|
|
60
|
+
expiresAt: number | null;
|
|
61
|
+
/** Whether this capability can be delegated to sub-agents */
|
|
62
|
+
delegatable: boolean;
|
|
63
|
+
/** Whether this capability has been revoked */
|
|
64
|
+
revoked: boolean;
|
|
65
|
+
/** When the capability was revoked, or null if not revoked */
|
|
66
|
+
revokedAt: number | null;
|
|
67
|
+
/** Attestations attached to this capability */
|
|
68
|
+
attestations: Attestation[];
|
|
69
|
+
/** Parent capability ID for delegation chains, or null for root grants */
|
|
70
|
+
parentCapabilityId: string | null;
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Result of evaluating a capability check
|
|
74
|
+
*/
|
|
75
|
+
export interface CapabilityCheckResult {
|
|
76
|
+
/** Whether the requested action is allowed */
|
|
77
|
+
allowed: boolean;
|
|
78
|
+
/** Capabilities that matched the check criteria */
|
|
79
|
+
capabilities: Capability[];
|
|
80
|
+
/** Human-readable reason for the decision */
|
|
81
|
+
reason: string;
|
|
82
|
+
/** Active constraints that applied during evaluation */
|
|
83
|
+
constraints: CapabilityConstraint[];
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Capability Algebra
|
|
87
|
+
*
|
|
88
|
+
* Manages the lifecycle of typed capabilities: granting, restricting,
|
|
89
|
+
* delegating, revoking, attesting, checking, and composing permissions.
|
|
90
|
+
* All mutations produce new capability objects; the original is never
|
|
91
|
+
* modified in place (except for revocation which is a state change).
|
|
92
|
+
*/
|
|
93
|
+
export declare class CapabilityAlgebra {
|
|
94
|
+
/** All capabilities indexed by ID */
|
|
95
|
+
private readonly capabilities;
|
|
96
|
+
/** Index: agentId -> set of capability IDs */
|
|
97
|
+
private readonly agentIndex;
|
|
98
|
+
/** Index: parentCapabilityId -> set of child capability IDs */
|
|
99
|
+
private readonly delegationIndex;
|
|
100
|
+
/**
|
|
101
|
+
* Grant a new root capability.
|
|
102
|
+
*
|
|
103
|
+
* Creates a capability with no parent (it is a root grant from an
|
|
104
|
+
* authority to an agent).
|
|
105
|
+
*/
|
|
106
|
+
grant(params: {
|
|
107
|
+
scope: CapabilityScope;
|
|
108
|
+
resource: string;
|
|
109
|
+
actions: string[];
|
|
110
|
+
grantedBy: string;
|
|
111
|
+
grantedTo: string;
|
|
112
|
+
constraints?: CapabilityConstraint[];
|
|
113
|
+
expiresAt?: number | null;
|
|
114
|
+
delegatable?: boolean;
|
|
115
|
+
}): Capability;
|
|
116
|
+
/**
|
|
117
|
+
* Restrict a capability, producing a new capability with tighter constraints.
|
|
118
|
+
*
|
|
119
|
+
* Restrictions can only narrow permissions, never widen them:
|
|
120
|
+
* - Actions can only be removed, never added
|
|
121
|
+
* - Constraints can only be added, never removed
|
|
122
|
+
* - Expiry can only be shortened, never extended
|
|
123
|
+
* - Delegatable can only be set to false, never promoted to true
|
|
124
|
+
*/
|
|
125
|
+
restrict(capability: Capability, restrictions: Partial<Capability>): Capability;
|
|
126
|
+
/**
|
|
127
|
+
* Delegate a capability to another agent.
|
|
128
|
+
*
|
|
129
|
+
* Creates a child capability with the new grantedTo agent. The parent
|
|
130
|
+
* capability must have delegatable=true. Optional further restrictions
|
|
131
|
+
* can be applied during delegation.
|
|
132
|
+
*
|
|
133
|
+
* @throws Error if the capability is not delegatable
|
|
134
|
+
*/
|
|
135
|
+
delegate(capability: Capability, toAgentId: string, restrictions?: Partial<Capability>): Capability;
|
|
136
|
+
/**
|
|
137
|
+
* Expire a capability immediately by setting expiresAt to now.
|
|
138
|
+
*/
|
|
139
|
+
expire(capabilityId: string): void;
|
|
140
|
+
/**
|
|
141
|
+
* Revoke a capability and cascade revocation to all delegated children.
|
|
142
|
+
*/
|
|
143
|
+
revoke(capabilityId: string, _reason?: string): void;
|
|
144
|
+
/**
|
|
145
|
+
* Add an attestation to a capability.
|
|
146
|
+
*/
|
|
147
|
+
attest(capabilityId: string, attestation: Omit<Attestation, 'attestedAt'>): void;
|
|
148
|
+
/**
|
|
149
|
+
* Check whether an agent is allowed to perform an action on a resource.
|
|
150
|
+
*
|
|
151
|
+
* Finds all non-revoked, non-expired capabilities for the agent that
|
|
152
|
+
* match the requested scope and resource, checks if the requested action
|
|
153
|
+
* is allowed, and verifies all constraints are satisfied.
|
|
154
|
+
*/
|
|
155
|
+
check(agentId: string, scope: CapabilityScope, resource: string, action: string, context?: Record<string, unknown>): CapabilityCheckResult;
|
|
156
|
+
/**
|
|
157
|
+
* Get all capabilities granted to a specific agent.
|
|
158
|
+
*/
|
|
159
|
+
getCapabilities(agentId: string): Capability[];
|
|
160
|
+
/**
|
|
161
|
+
* Get a capability by ID.
|
|
162
|
+
*/
|
|
163
|
+
getCapability(id: string): Capability | undefined;
|
|
164
|
+
/**
|
|
165
|
+
* Get the full delegation chain from root to the given capability.
|
|
166
|
+
*
|
|
167
|
+
* Returns an array ordered from the root ancestor to the given capability.
|
|
168
|
+
*/
|
|
169
|
+
getDelegationChain(capabilityId: string): Capability[];
|
|
170
|
+
/**
|
|
171
|
+
* Compose two capabilities via intersection.
|
|
172
|
+
*
|
|
173
|
+
* - Actions = intersection of both action sets
|
|
174
|
+
* - Constraints = union of both constraint sets
|
|
175
|
+
* - Expiry = the tighter (earlier) of the two
|
|
176
|
+
* - Delegatable = true only if both are delegatable
|
|
177
|
+
* - Scope and resource must match; throws if they differ
|
|
178
|
+
*
|
|
179
|
+
* @throws Error if scope or resource do not match
|
|
180
|
+
*/
|
|
181
|
+
compose(cap1: Capability, cap2: Capability): Capability;
|
|
182
|
+
/**
|
|
183
|
+
* Check if inner's permission set is a subset of outer's.
|
|
184
|
+
*
|
|
185
|
+
* Returns true if:
|
|
186
|
+
* - inner.scope === outer.scope
|
|
187
|
+
* - inner.resource === outer.resource
|
|
188
|
+
* - Every action in inner is present in outer
|
|
189
|
+
* - inner.expiresAt is <= outer.expiresAt (or outer has no expiry)
|
|
190
|
+
*/
|
|
191
|
+
isSubset(inner: Capability, outer: Capability): boolean;
|
|
192
|
+
/**
|
|
193
|
+
* Evaluate whether all constraints on a capability are satisfied.
|
|
194
|
+
*/
|
|
195
|
+
private satisfiesConstraints;
|
|
196
|
+
/**
|
|
197
|
+
* Cascade revocation to all delegated children of a capability.
|
|
198
|
+
*/
|
|
199
|
+
private cascadeRevoke;
|
|
200
|
+
/**
|
|
201
|
+
* Store a capability and update indices.
|
|
202
|
+
*/
|
|
203
|
+
private store;
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* Create a CapabilityAlgebra instance
|
|
207
|
+
*/
|
|
208
|
+
export declare function createCapabilityAlgebra(): CapabilityAlgebra;
|
|
209
|
+
//# sourceMappingURL=capabilities.d.ts.map
|
|
@@ -0,0 +1,485 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Capability Algebra
|
|
3
|
+
*
|
|
4
|
+
* All permissions become typed objects that can be composed, restricted,
|
|
5
|
+
* delegated, revoked, and reasoned about. Supports delegation chains,
|
|
6
|
+
* attestations, constraint evaluation, and set-theoretic composition
|
|
7
|
+
* (intersection for actions, union for constraints).
|
|
8
|
+
*
|
|
9
|
+
* @module @aiyou-dev/guidance/capabilities
|
|
10
|
+
*/
|
|
11
|
+
import { randomUUID } from 'node:crypto';
|
|
12
|
+
// ============================================================================
|
|
13
|
+
// Capability Algebra
|
|
14
|
+
// ============================================================================
|
|
15
|
+
/**
|
|
16
|
+
* Capability Algebra
|
|
17
|
+
*
|
|
18
|
+
* Manages the lifecycle of typed capabilities: granting, restricting,
|
|
19
|
+
* delegating, revoking, attesting, checking, and composing permissions.
|
|
20
|
+
* All mutations produce new capability objects; the original is never
|
|
21
|
+
* modified in place (except for revocation which is a state change).
|
|
22
|
+
*/
|
|
23
|
+
export class CapabilityAlgebra {
|
|
24
|
+
/** All capabilities indexed by ID */
|
|
25
|
+
capabilities = new Map();
|
|
26
|
+
/** Index: agentId -> set of capability IDs */
|
|
27
|
+
agentIndex = new Map();
|
|
28
|
+
/** Index: parentCapabilityId -> set of child capability IDs */
|
|
29
|
+
delegationIndex = new Map();
|
|
30
|
+
// =========================================================================
|
|
31
|
+
// Public API
|
|
32
|
+
// =========================================================================
|
|
33
|
+
/**
|
|
34
|
+
* Grant a new root capability.
|
|
35
|
+
*
|
|
36
|
+
* Creates a capability with no parent (it is a root grant from an
|
|
37
|
+
* authority to an agent).
|
|
38
|
+
*/
|
|
39
|
+
grant(params) {
|
|
40
|
+
const capability = {
|
|
41
|
+
id: randomUUID(),
|
|
42
|
+
scope: params.scope,
|
|
43
|
+
resource: params.resource,
|
|
44
|
+
actions: [...params.actions],
|
|
45
|
+
constraints: params.constraints ? [...params.constraints] : [],
|
|
46
|
+
grantedBy: params.grantedBy,
|
|
47
|
+
grantedTo: params.grantedTo,
|
|
48
|
+
grantedAt: Date.now(),
|
|
49
|
+
expiresAt: params.expiresAt ?? null,
|
|
50
|
+
delegatable: params.delegatable ?? false,
|
|
51
|
+
revoked: false,
|
|
52
|
+
revokedAt: null,
|
|
53
|
+
attestations: [],
|
|
54
|
+
parentCapabilityId: null,
|
|
55
|
+
};
|
|
56
|
+
this.store(capability);
|
|
57
|
+
return capability;
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Restrict a capability, producing a new capability with tighter constraints.
|
|
61
|
+
*
|
|
62
|
+
* Restrictions can only narrow permissions, never widen them:
|
|
63
|
+
* - Actions can only be removed, never added
|
|
64
|
+
* - Constraints can only be added, never removed
|
|
65
|
+
* - Expiry can only be shortened, never extended
|
|
66
|
+
* - Delegatable can only be set to false, never promoted to true
|
|
67
|
+
*/
|
|
68
|
+
restrict(capability, restrictions) {
|
|
69
|
+
const restricted = {
|
|
70
|
+
...capability,
|
|
71
|
+
id: randomUUID(),
|
|
72
|
+
grantedAt: Date.now(),
|
|
73
|
+
attestations: [],
|
|
74
|
+
parentCapabilityId: capability.id,
|
|
75
|
+
};
|
|
76
|
+
// Actions: only allow narrowing (intersection with original)
|
|
77
|
+
if (restrictions.actions) {
|
|
78
|
+
const originalSet = new Set(capability.actions);
|
|
79
|
+
restricted.actions = restrictions.actions.filter(a => originalSet.has(a));
|
|
80
|
+
}
|
|
81
|
+
// Constraints: only allow adding more (union)
|
|
82
|
+
if (restrictions.constraints) {
|
|
83
|
+
restricted.constraints = [
|
|
84
|
+
...capability.constraints,
|
|
85
|
+
...restrictions.constraints,
|
|
86
|
+
];
|
|
87
|
+
}
|
|
88
|
+
// Expiry: only allow shortening (pick earlier)
|
|
89
|
+
if (restrictions.expiresAt !== undefined) {
|
|
90
|
+
if (restrictions.expiresAt !== null) {
|
|
91
|
+
if (capability.expiresAt === null) {
|
|
92
|
+
restricted.expiresAt = restrictions.expiresAt;
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
restricted.expiresAt = Math.min(capability.expiresAt, restrictions.expiresAt);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
// If restriction tries to set null (no expiry) but original has expiry, keep original
|
|
99
|
+
}
|
|
100
|
+
// Delegatable: can only be downgraded to false
|
|
101
|
+
if (restrictions.delegatable !== undefined) {
|
|
102
|
+
if (!restrictions.delegatable) {
|
|
103
|
+
restricted.delegatable = false;
|
|
104
|
+
}
|
|
105
|
+
// Cannot promote to delegatable if original is not
|
|
106
|
+
}
|
|
107
|
+
this.store(restricted);
|
|
108
|
+
return restricted;
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Delegate a capability to another agent.
|
|
112
|
+
*
|
|
113
|
+
* Creates a child capability with the new grantedTo agent. The parent
|
|
114
|
+
* capability must have delegatable=true. Optional further restrictions
|
|
115
|
+
* can be applied during delegation.
|
|
116
|
+
*
|
|
117
|
+
* @throws Error if the capability is not delegatable
|
|
118
|
+
*/
|
|
119
|
+
delegate(capability, toAgentId, restrictions) {
|
|
120
|
+
if (!capability.delegatable) {
|
|
121
|
+
throw new Error(`Capability ${capability.id} is not delegatable`);
|
|
122
|
+
}
|
|
123
|
+
if (capability.revoked) {
|
|
124
|
+
throw new Error(`Cannot delegate revoked capability ${capability.id}`);
|
|
125
|
+
}
|
|
126
|
+
if (capability.expiresAt !== null && capability.expiresAt <= Date.now()) {
|
|
127
|
+
throw new Error(`Cannot delegate expired capability ${capability.id}`);
|
|
128
|
+
}
|
|
129
|
+
const delegated = {
|
|
130
|
+
...capability,
|
|
131
|
+
id: randomUUID(),
|
|
132
|
+
grantedBy: capability.grantedTo,
|
|
133
|
+
grantedTo: toAgentId,
|
|
134
|
+
grantedAt: Date.now(),
|
|
135
|
+
attestations: [],
|
|
136
|
+
parentCapabilityId: capability.id,
|
|
137
|
+
};
|
|
138
|
+
// Apply optional further restrictions
|
|
139
|
+
if (restrictions?.actions) {
|
|
140
|
+
const originalSet = new Set(capability.actions);
|
|
141
|
+
delegated.actions = restrictions.actions.filter(a => originalSet.has(a));
|
|
142
|
+
}
|
|
143
|
+
if (restrictions?.constraints) {
|
|
144
|
+
delegated.constraints = [
|
|
145
|
+
...capability.constraints,
|
|
146
|
+
...restrictions.constraints,
|
|
147
|
+
];
|
|
148
|
+
}
|
|
149
|
+
if (restrictions?.expiresAt !== undefined && restrictions.expiresAt !== null) {
|
|
150
|
+
if (capability.expiresAt === null) {
|
|
151
|
+
delegated.expiresAt = restrictions.expiresAt;
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
delegated.expiresAt = Math.min(capability.expiresAt, restrictions.expiresAt);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
if (restrictions?.delegatable === false) {
|
|
158
|
+
delegated.delegatable = false;
|
|
159
|
+
}
|
|
160
|
+
this.store(delegated);
|
|
161
|
+
// Track delegation relationship
|
|
162
|
+
const children = this.delegationIndex.get(capability.id) ?? new Set();
|
|
163
|
+
children.add(delegated.id);
|
|
164
|
+
this.delegationIndex.set(capability.id, children);
|
|
165
|
+
return delegated;
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Expire a capability immediately by setting expiresAt to now.
|
|
169
|
+
*/
|
|
170
|
+
expire(capabilityId) {
|
|
171
|
+
const capability = this.capabilities.get(capabilityId);
|
|
172
|
+
if (!capability)
|
|
173
|
+
return;
|
|
174
|
+
capability.expiresAt = Date.now();
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Revoke a capability and cascade revocation to all delegated children.
|
|
178
|
+
*/
|
|
179
|
+
revoke(capabilityId, _reason) {
|
|
180
|
+
const capability = this.capabilities.get(capabilityId);
|
|
181
|
+
if (!capability)
|
|
182
|
+
return;
|
|
183
|
+
capability.revoked = true;
|
|
184
|
+
capability.revokedAt = Date.now();
|
|
185
|
+
this.cascadeRevoke(capabilityId);
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Add an attestation to a capability.
|
|
189
|
+
*/
|
|
190
|
+
attest(capabilityId, attestation) {
|
|
191
|
+
const capability = this.capabilities.get(capabilityId);
|
|
192
|
+
if (!capability)
|
|
193
|
+
return;
|
|
194
|
+
capability.attestations.push({
|
|
195
|
+
...attestation,
|
|
196
|
+
attestedAt: Date.now(),
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Check whether an agent is allowed to perform an action on a resource.
|
|
201
|
+
*
|
|
202
|
+
* Finds all non-revoked, non-expired capabilities for the agent that
|
|
203
|
+
* match the requested scope and resource, checks if the requested action
|
|
204
|
+
* is allowed, and verifies all constraints are satisfied.
|
|
205
|
+
*/
|
|
206
|
+
check(agentId, scope, resource, action, context) {
|
|
207
|
+
const agentCapIds = this.agentIndex.get(agentId);
|
|
208
|
+
if (!agentCapIds || agentCapIds.size === 0) {
|
|
209
|
+
return {
|
|
210
|
+
allowed: false,
|
|
211
|
+
capabilities: [],
|
|
212
|
+
reason: `No capabilities found for agent "${agentId}"`,
|
|
213
|
+
constraints: [],
|
|
214
|
+
};
|
|
215
|
+
}
|
|
216
|
+
const now = Date.now();
|
|
217
|
+
const matchingCapabilities = [];
|
|
218
|
+
const activeConstraints = [];
|
|
219
|
+
for (const capId of agentCapIds) {
|
|
220
|
+
const cap = this.capabilities.get(capId);
|
|
221
|
+
if (!cap)
|
|
222
|
+
continue;
|
|
223
|
+
// Skip revoked
|
|
224
|
+
if (cap.revoked)
|
|
225
|
+
continue;
|
|
226
|
+
// Skip expired
|
|
227
|
+
if (cap.expiresAt !== null && cap.expiresAt <= now)
|
|
228
|
+
continue;
|
|
229
|
+
// Match scope and resource
|
|
230
|
+
if (cap.scope !== scope)
|
|
231
|
+
continue;
|
|
232
|
+
if (cap.resource !== resource && cap.resource !== '*')
|
|
233
|
+
continue;
|
|
234
|
+
// Check action
|
|
235
|
+
if (!cap.actions.includes(action) && !cap.actions.includes('*'))
|
|
236
|
+
continue;
|
|
237
|
+
// Check constraints
|
|
238
|
+
if (!this.satisfiesConstraints(cap, context))
|
|
239
|
+
continue;
|
|
240
|
+
matchingCapabilities.push(cap);
|
|
241
|
+
activeConstraints.push(...cap.constraints);
|
|
242
|
+
}
|
|
243
|
+
if (matchingCapabilities.length === 0) {
|
|
244
|
+
return {
|
|
245
|
+
allowed: false,
|
|
246
|
+
capabilities: [],
|
|
247
|
+
reason: `No matching capability for agent "${agentId}" to "${action}" on ${scope}:${resource}`,
|
|
248
|
+
constraints: [],
|
|
249
|
+
};
|
|
250
|
+
}
|
|
251
|
+
return {
|
|
252
|
+
allowed: true,
|
|
253
|
+
capabilities: matchingCapabilities,
|
|
254
|
+
reason: `Allowed by ${matchingCapabilities.length} capability(ies)`,
|
|
255
|
+
constraints: activeConstraints,
|
|
256
|
+
};
|
|
257
|
+
}
|
|
258
|
+
/**
|
|
259
|
+
* Get all capabilities granted to a specific agent.
|
|
260
|
+
*/
|
|
261
|
+
getCapabilities(agentId) {
|
|
262
|
+
const capIds = this.agentIndex.get(agentId);
|
|
263
|
+
if (!capIds)
|
|
264
|
+
return [];
|
|
265
|
+
const result = [];
|
|
266
|
+
for (const id of capIds) {
|
|
267
|
+
const cap = this.capabilities.get(id);
|
|
268
|
+
if (cap)
|
|
269
|
+
result.push(cap);
|
|
270
|
+
}
|
|
271
|
+
return result;
|
|
272
|
+
}
|
|
273
|
+
/**
|
|
274
|
+
* Get a capability by ID.
|
|
275
|
+
*/
|
|
276
|
+
getCapability(id) {
|
|
277
|
+
return this.capabilities.get(id);
|
|
278
|
+
}
|
|
279
|
+
/**
|
|
280
|
+
* Get the full delegation chain from root to the given capability.
|
|
281
|
+
*
|
|
282
|
+
* Returns an array ordered from the root ancestor to the given capability.
|
|
283
|
+
*/
|
|
284
|
+
getDelegationChain(capabilityId) {
|
|
285
|
+
const chain = [];
|
|
286
|
+
let current = this.capabilities.get(capabilityId);
|
|
287
|
+
while (current) {
|
|
288
|
+
chain.unshift(current);
|
|
289
|
+
if (current.parentCapabilityId === null)
|
|
290
|
+
break;
|
|
291
|
+
current = this.capabilities.get(current.parentCapabilityId);
|
|
292
|
+
}
|
|
293
|
+
return chain;
|
|
294
|
+
}
|
|
295
|
+
/**
|
|
296
|
+
* Compose two capabilities via intersection.
|
|
297
|
+
*
|
|
298
|
+
* - Actions = intersection of both action sets
|
|
299
|
+
* - Constraints = union of both constraint sets
|
|
300
|
+
* - Expiry = the tighter (earlier) of the two
|
|
301
|
+
* - Delegatable = true only if both are delegatable
|
|
302
|
+
* - Scope and resource must match; throws if they differ
|
|
303
|
+
*
|
|
304
|
+
* @throws Error if scope or resource do not match
|
|
305
|
+
*/
|
|
306
|
+
compose(cap1, cap2) {
|
|
307
|
+
if (cap1.scope !== cap2.scope) {
|
|
308
|
+
throw new Error(`Cannot compose capabilities with different scopes: "${cap1.scope}" vs "${cap2.scope}"`);
|
|
309
|
+
}
|
|
310
|
+
if (cap1.resource !== cap2.resource) {
|
|
311
|
+
throw new Error(`Cannot compose capabilities with different resources: "${cap1.resource}" vs "${cap2.resource}"`);
|
|
312
|
+
}
|
|
313
|
+
// Actions: intersection
|
|
314
|
+
const actionSet1 = new Set(cap1.actions);
|
|
315
|
+
const intersectedActions = cap2.actions.filter(a => actionSet1.has(a));
|
|
316
|
+
// Constraints: union
|
|
317
|
+
const combinedConstraints = [...cap1.constraints, ...cap2.constraints];
|
|
318
|
+
// Expiry: tightest
|
|
319
|
+
let expiresAt = null;
|
|
320
|
+
if (cap1.expiresAt !== null && cap2.expiresAt !== null) {
|
|
321
|
+
expiresAt = Math.min(cap1.expiresAt, cap2.expiresAt);
|
|
322
|
+
}
|
|
323
|
+
else if (cap1.expiresAt !== null) {
|
|
324
|
+
expiresAt = cap1.expiresAt;
|
|
325
|
+
}
|
|
326
|
+
else if (cap2.expiresAt !== null) {
|
|
327
|
+
expiresAt = cap2.expiresAt;
|
|
328
|
+
}
|
|
329
|
+
const composed = {
|
|
330
|
+
id: randomUUID(),
|
|
331
|
+
scope: cap1.scope,
|
|
332
|
+
resource: cap1.resource,
|
|
333
|
+
actions: intersectedActions,
|
|
334
|
+
constraints: combinedConstraints,
|
|
335
|
+
grantedBy: cap1.grantedBy,
|
|
336
|
+
grantedTo: cap1.grantedTo,
|
|
337
|
+
grantedAt: Date.now(),
|
|
338
|
+
expiresAt,
|
|
339
|
+
delegatable: cap1.delegatable && cap2.delegatable,
|
|
340
|
+
revoked: false,
|
|
341
|
+
revokedAt: null,
|
|
342
|
+
attestations: [],
|
|
343
|
+
parentCapabilityId: null,
|
|
344
|
+
};
|
|
345
|
+
this.store(composed);
|
|
346
|
+
return composed;
|
|
347
|
+
}
|
|
348
|
+
/**
|
|
349
|
+
* Check if inner's permission set is a subset of outer's.
|
|
350
|
+
*
|
|
351
|
+
* Returns true if:
|
|
352
|
+
* - inner.scope === outer.scope
|
|
353
|
+
* - inner.resource === outer.resource
|
|
354
|
+
* - Every action in inner is present in outer
|
|
355
|
+
* - inner.expiresAt is <= outer.expiresAt (or outer has no expiry)
|
|
356
|
+
*/
|
|
357
|
+
isSubset(inner, outer) {
|
|
358
|
+
if (inner.scope !== outer.scope)
|
|
359
|
+
return false;
|
|
360
|
+
if (inner.resource !== outer.resource)
|
|
361
|
+
return false;
|
|
362
|
+
const outerActions = new Set(outer.actions);
|
|
363
|
+
for (const action of inner.actions) {
|
|
364
|
+
if (!outerActions.has(action))
|
|
365
|
+
return false;
|
|
366
|
+
}
|
|
367
|
+
// Expiry: inner must expire no later than outer (or outer has no expiry)
|
|
368
|
+
if (outer.expiresAt !== null) {
|
|
369
|
+
if (inner.expiresAt === null)
|
|
370
|
+
return false; // inner never expires but outer does
|
|
371
|
+
if (inner.expiresAt > outer.expiresAt)
|
|
372
|
+
return false;
|
|
373
|
+
}
|
|
374
|
+
return true;
|
|
375
|
+
}
|
|
376
|
+
// =========================================================================
|
|
377
|
+
// Private Methods
|
|
378
|
+
// =========================================================================
|
|
379
|
+
/**
|
|
380
|
+
* Evaluate whether all constraints on a capability are satisfied.
|
|
381
|
+
*/
|
|
382
|
+
satisfiesConstraints(capability, context) {
|
|
383
|
+
for (const constraint of capability.constraints) {
|
|
384
|
+
switch (constraint.type) {
|
|
385
|
+
case 'time-window': {
|
|
386
|
+
const now = Date.now();
|
|
387
|
+
const start = constraint.params['start'];
|
|
388
|
+
const end = constraint.params['end'];
|
|
389
|
+
if (start !== undefined && now < start)
|
|
390
|
+
return false;
|
|
391
|
+
if (end !== undefined && now > end)
|
|
392
|
+
return false;
|
|
393
|
+
break;
|
|
394
|
+
}
|
|
395
|
+
case 'rate-limit': {
|
|
396
|
+
// Rate-limit constraints are informational; enforcement is external.
|
|
397
|
+
// If context provides current usage, check it.
|
|
398
|
+
if (context) {
|
|
399
|
+
const max = constraint.params['max'];
|
|
400
|
+
const current = context['currentUsage'];
|
|
401
|
+
if (max !== undefined && current !== undefined && current >= max) {
|
|
402
|
+
return false;
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
break;
|
|
406
|
+
}
|
|
407
|
+
case 'budget': {
|
|
408
|
+
if (context) {
|
|
409
|
+
const limit = constraint.params['limit'];
|
|
410
|
+
const used = context['budgetUsed'];
|
|
411
|
+
if (limit !== undefined && used !== undefined && used >= limit) {
|
|
412
|
+
return false;
|
|
413
|
+
}
|
|
414
|
+
}
|
|
415
|
+
break;
|
|
416
|
+
}
|
|
417
|
+
case 'condition': {
|
|
418
|
+
// Condition constraints require a truthy context value at the specified key
|
|
419
|
+
const key = constraint.params['key'];
|
|
420
|
+
const expectedValue = constraint.params['value'];
|
|
421
|
+
if (key && context) {
|
|
422
|
+
if (expectedValue !== undefined) {
|
|
423
|
+
if (context[key] !== expectedValue)
|
|
424
|
+
return false;
|
|
425
|
+
}
|
|
426
|
+
else {
|
|
427
|
+
if (!context[key])
|
|
428
|
+
return false;
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
break;
|
|
432
|
+
}
|
|
433
|
+
case 'scope-restriction': {
|
|
434
|
+
// Scope restrictions limit to specific sub-resources
|
|
435
|
+
const allowedPattern = constraint.params['pattern'];
|
|
436
|
+
if (allowedPattern && context) {
|
|
437
|
+
const targetResource = context['targetResource'];
|
|
438
|
+
if (targetResource && !targetResource.startsWith(allowedPattern)) {
|
|
439
|
+
return false;
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
break;
|
|
443
|
+
}
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
return true;
|
|
447
|
+
}
|
|
448
|
+
/**
|
|
449
|
+
* Cascade revocation to all delegated children of a capability.
|
|
450
|
+
*/
|
|
451
|
+
cascadeRevoke(capabilityId) {
|
|
452
|
+
const children = this.delegationIndex.get(capabilityId);
|
|
453
|
+
if (!children)
|
|
454
|
+
return;
|
|
455
|
+
const now = Date.now();
|
|
456
|
+
for (const childId of children) {
|
|
457
|
+
const child = this.capabilities.get(childId);
|
|
458
|
+
if (child && !child.revoked) {
|
|
459
|
+
child.revoked = true;
|
|
460
|
+
child.revokedAt = now;
|
|
461
|
+
// Recurse into grandchildren
|
|
462
|
+
this.cascadeRevoke(childId);
|
|
463
|
+
}
|
|
464
|
+
}
|
|
465
|
+
}
|
|
466
|
+
/**
|
|
467
|
+
* Store a capability and update indices.
|
|
468
|
+
*/
|
|
469
|
+
store(capability) {
|
|
470
|
+
this.capabilities.set(capability.id, capability);
|
|
471
|
+
const agentCaps = this.agentIndex.get(capability.grantedTo) ?? new Set();
|
|
472
|
+
agentCaps.add(capability.id);
|
|
473
|
+
this.agentIndex.set(capability.grantedTo, agentCaps);
|
|
474
|
+
}
|
|
475
|
+
}
|
|
476
|
+
// ============================================================================
|
|
477
|
+
// Factory
|
|
478
|
+
// ============================================================================
|
|
479
|
+
/**
|
|
480
|
+
* Create a CapabilityAlgebra instance
|
|
481
|
+
*/
|
|
482
|
+
export function createCapabilityAlgebra() {
|
|
483
|
+
return new CapabilityAlgebra();
|
|
484
|
+
}
|
|
485
|
+
//# sourceMappingURL=capabilities.js.map
|