@kilnai/core 0.1.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/dist/agents/circuit-breaker.d.ts +26 -0
- package/dist/agents/circuit-breaker.d.ts.map +1 -0
- package/dist/agents/circuit-breaker.js +90 -0
- package/dist/agents/circuit-breaker.js.map +1 -0
- package/dist/agents/context-compressor.d.ts +13 -0
- package/dist/agents/context-compressor.d.ts.map +1 -0
- package/dist/agents/context-compressor.js +21 -0
- package/dist/agents/context-compressor.js.map +1 -0
- package/dist/agents/index.d.ts +68 -0
- package/dist/agents/index.d.ts.map +1 -0
- package/dist/agents/index.js +13 -0
- package/dist/agents/index.js.map +1 -0
- package/dist/agents/infrastructure/anthropic.d.ts +24 -0
- package/dist/agents/infrastructure/anthropic.d.ts.map +1 -0
- package/dist/agents/infrastructure/anthropic.js +226 -0
- package/dist/agents/infrastructure/anthropic.js.map +1 -0
- package/dist/agents/infrastructure/deepseek.d.ts +10 -0
- package/dist/agents/infrastructure/deepseek.d.ts.map +1 -0
- package/dist/agents/infrastructure/deepseek.js +14 -0
- package/dist/agents/infrastructure/deepseek.js.map +1 -0
- package/dist/agents/infrastructure/ollama.d.ts +20 -0
- package/dist/agents/infrastructure/ollama.d.ts.map +1 -0
- package/dist/agents/infrastructure/ollama.js +128 -0
- package/dist/agents/infrastructure/ollama.js.map +1 -0
- package/dist/agents/infrastructure/openai-compat.d.ts +25 -0
- package/dist/agents/infrastructure/openai-compat.d.ts.map +1 -0
- package/dist/agents/infrastructure/openai-compat.js +211 -0
- package/dist/agents/infrastructure/openai-compat.js.map +1 -0
- package/dist/agents/infrastructure/openai.d.ts +12 -0
- package/dist/agents/infrastructure/openai.d.ts.map +1 -0
- package/dist/agents/infrastructure/openai.js +16 -0
- package/dist/agents/infrastructure/openai.js.map +1 -0
- package/dist/agents/infrastructure/retry.d.ts +10 -0
- package/dist/agents/infrastructure/retry.d.ts.map +1 -0
- package/dist/agents/infrastructure/retry.js +22 -0
- package/dist/agents/infrastructure/retry.js.map +1 -0
- package/dist/agents/mcp-client.d.ts +22 -0
- package/dist/agents/mcp-client.d.ts.map +1 -0
- package/dist/agents/mcp-client.js +104 -0
- package/dist/agents/mcp-client.js.map +1 -0
- package/dist/agents/model-pricing.d.ts +9 -0
- package/dist/agents/model-pricing.d.ts.map +1 -0
- package/dist/agents/model-pricing.js +17 -0
- package/dist/agents/model-pricing.js.map +1 -0
- package/dist/agents/provider-registry.d.ts +25 -0
- package/dist/agents/provider-registry.d.ts.map +1 -0
- package/dist/agents/provider-registry.js +62 -0
- package/dist/agents/provider-registry.js.map +1 -0
- package/dist/agents/tool-cache.d.ts +13 -0
- package/dist/agents/tool-cache.d.ts.map +1 -0
- package/dist/agents/tool-cache.js +52 -0
- package/dist/agents/tool-cache.js.map +1 -0
- package/dist/agents/tool-rag.d.ts +15 -0
- package/dist/agents/tool-rag.d.ts.map +1 -0
- package/dist/agents/tool-rag.js +92 -0
- package/dist/agents/tool-rag.js.map +1 -0
- package/dist/agents/tool-registry.d.ts +29 -0
- package/dist/agents/tool-registry.d.ts.map +1 -0
- package/dist/agents/tool-registry.js +64 -0
- package/dist/agents/tool-registry.js.map +1 -0
- package/dist/cost/cost-tracker.d.ts +27 -0
- package/dist/cost/cost-tracker.d.ts.map +1 -0
- package/dist/cost/cost-tracker.js +103 -0
- package/dist/cost/cost-tracker.js.map +1 -0
- package/dist/cost/index.d.ts +30 -0
- package/dist/cost/index.d.ts.map +1 -0
- package/dist/cost/index.js +2 -0
- package/dist/cost/index.js.map +1 -0
- package/dist/domain/domain-package-adapter.d.ts +13 -0
- package/dist/domain/domain-package-adapter.d.ts.map +1 -0
- package/dist/domain/domain-package-adapter.js +66 -0
- package/dist/domain/domain-package-adapter.js.map +1 -0
- package/dist/domain/domain-registry.d.ts +26 -0
- package/dist/domain/domain-registry.d.ts.map +1 -0
- package/dist/domain/domain-registry.js +119 -0
- package/dist/domain/domain-registry.js.map +1 -0
- package/dist/domain/index.d.ts +22 -0
- package/dist/domain/index.d.ts.map +1 -0
- package/dist/domain/index.js +30 -0
- package/dist/domain/index.js.map +1 -0
- package/dist/domain/yaml-parser.d.ts +18 -0
- package/dist/domain/yaml-parser.d.ts.map +1 -0
- package/dist/domain/yaml-parser.js +47 -0
- package/dist/domain/yaml-parser.js.map +1 -0
- package/dist/domain/yaml-schema.d.ts +26 -0
- package/dist/domain/yaml-schema.d.ts.map +1 -0
- package/dist/domain/yaml-schema.js +66 -0
- package/dist/domain/yaml-schema.js.map +1 -0
- package/dist/engine/composites/app.d.ts +39 -0
- package/dist/engine/composites/app.d.ts.map +1 -0
- package/dist/engine/composites/app.js +125 -0
- package/dist/engine/composites/app.js.map +1 -0
- package/dist/engine/composites/router.d.ts +20 -0
- package/dist/engine/composites/router.d.ts.map +1 -0
- package/dist/engine/composites/router.js +31 -0
- package/dist/engine/composites/router.js.map +1 -0
- package/dist/engine/composites/team.d.ts +36 -0
- package/dist/engine/composites/team.d.ts.map +1 -0
- package/dist/engine/composites/team.js +100 -0
- package/dist/engine/composites/team.js.map +1 -0
- package/dist/engine/domain/a2a-config.d.ts +53 -0
- package/dist/engine/domain/a2a-config.d.ts.map +1 -0
- package/dist/engine/domain/a2a-config.js +32 -0
- package/dist/engine/domain/a2a-config.js.map +1 -0
- package/dist/engine/domain/agent.d.ts +18 -0
- package/dist/engine/domain/agent.d.ts.map +1 -0
- package/dist/engine/domain/agent.js +4 -0
- package/dist/engine/domain/agent.js.map +1 -0
- package/dist/engine/domain/capability.d.ts +24 -0
- package/dist/engine/domain/capability.d.ts.map +1 -0
- package/dist/engine/domain/capability.js +3 -0
- package/dist/engine/domain/capability.js.map +1 -0
- package/dist/engine/domain/channel.d.ts +37 -0
- package/dist/engine/domain/channel.d.ts.map +1 -0
- package/dist/engine/domain/channel.js +4 -0
- package/dist/engine/domain/channel.js.map +1 -0
- package/dist/engine/domain/chunker.d.ts +22 -0
- package/dist/engine/domain/chunker.d.ts.map +1 -0
- package/dist/engine/domain/chunker.js +3 -0
- package/dist/engine/domain/chunker.js.map +1 -0
- package/dist/engine/domain/content.d.ts +57 -0
- package/dist/engine/domain/content.d.ts.map +1 -0
- package/dist/engine/domain/content.js +63 -0
- package/dist/engine/domain/content.js.map +1 -0
- package/dist/engine/domain/cron.d.ts +15 -0
- package/dist/engine/domain/cron.d.ts.map +1 -0
- package/dist/engine/domain/cron.js +114 -0
- package/dist/engine/domain/cron.js.map +1 -0
- package/dist/engine/domain/embedding.d.ts +9 -0
- package/dist/engine/domain/embedding.d.ts.map +1 -0
- package/dist/engine/domain/embedding.js +4 -0
- package/dist/engine/domain/embedding.js.map +1 -0
- package/dist/engine/domain/eval-config.d.ts +36 -0
- package/dist/engine/domain/eval-config.d.ts.map +1 -0
- package/dist/engine/domain/eval-config.js +155 -0
- package/dist/engine/domain/eval-config.js.map +1 -0
- package/dist/engine/domain/knowledge-config.d.ts +34 -0
- package/dist/engine/domain/knowledge-config.d.ts.map +1 -0
- package/dist/engine/domain/knowledge-config.js +62 -0
- package/dist/engine/domain/knowledge-config.js.map +1 -0
- package/dist/engine/domain/mcp-config.d.ts +15 -0
- package/dist/engine/domain/mcp-config.d.ts.map +1 -0
- package/dist/engine/domain/mcp-config.js +26 -0
- package/dist/engine/domain/mcp-config.js.map +1 -0
- package/dist/engine/domain/memory.d.ts +17 -0
- package/dist/engine/domain/memory.d.ts.map +1 -0
- package/dist/engine/domain/memory.js +4 -0
- package/dist/engine/domain/memory.js.map +1 -0
- package/dist/engine/domain/modality.d.ts +5 -0
- package/dist/engine/domain/modality.d.ts.map +1 -0
- package/dist/engine/domain/modality.js +19 -0
- package/dist/engine/domain/modality.js.map +1 -0
- package/dist/engine/domain/orchestrator-config.d.ts +11 -0
- package/dist/engine/domain/orchestrator-config.d.ts.map +1 -0
- package/dist/engine/domain/orchestrator-config.js +4 -0
- package/dist/engine/domain/orchestrator-config.js.map +1 -0
- package/dist/engine/domain/prompt-assembler.d.ts +32 -0
- package/dist/engine/domain/prompt-assembler.d.ts.map +1 -0
- package/dist/engine/domain/prompt-assembler.js +60 -0
- package/dist/engine/domain/prompt-assembler.js.map +1 -0
- package/dist/engine/domain/safety-config.d.ts +51 -0
- package/dist/engine/domain/safety-config.d.ts.map +1 -0
- package/dist/engine/domain/safety-config.js +74 -0
- package/dist/engine/domain/safety-config.js.map +1 -0
- package/dist/engine/domain/speech-config.d.ts +53 -0
- package/dist/engine/domain/speech-config.d.ts.map +1 -0
- package/dist/engine/domain/speech-config.js +26 -0
- package/dist/engine/domain/speech-config.js.map +1 -0
- package/dist/engine/domain/task.d.ts +16 -0
- package/dist/engine/domain/task.d.ts.map +1 -0
- package/dist/engine/domain/task.js +4 -0
- package/dist/engine/domain/task.js.map +1 -0
- package/dist/engine/domain/tool-selection-config.d.ts +12 -0
- package/dist/engine/domain/tool-selection-config.d.ts.map +1 -0
- package/dist/engine/domain/tool-selection-config.js +22 -0
- package/dist/engine/domain/tool-selection-config.js.map +1 -0
- package/dist/engine/domain/trigger.d.ts +43 -0
- package/dist/engine/domain/trigger.d.ts.map +1 -0
- package/dist/engine/domain/trigger.js +39 -0
- package/dist/engine/domain/trigger.js.map +1 -0
- package/dist/engine/domain/vector-store.d.ts +27 -0
- package/dist/engine/domain/vector-store.d.ts.map +1 -0
- package/dist/engine/domain/vector-store.js +3 -0
- package/dist/engine/domain/vector-store.js.map +1 -0
- package/dist/engine/domain/workflow.d.ts +11 -0
- package/dist/engine/domain/workflow.d.ts.map +1 -0
- package/dist/engine/domain/workflow.js +4 -0
- package/dist/engine/domain/workflow.js.map +1 -0
- package/dist/engine/error-catalog.d.ts +8 -0
- package/dist/engine/error-catalog.d.ts.map +1 -0
- package/dist/engine/error-catalog.js +335 -0
- package/dist/engine/error-catalog.js.map +1 -0
- package/dist/engine/errors.d.ts +18 -0
- package/dist/engine/errors.d.ts.map +1 -0
- package/dist/engine/errors.js +20 -0
- package/dist/engine/errors.js.map +1 -0
- package/dist/engine/gateway/delegation-config.d.ts +52 -0
- package/dist/engine/gateway/delegation-config.d.ts.map +1 -0
- package/dist/engine/gateway/delegation-config.js +48 -0
- package/dist/engine/gateway/delegation-config.js.map +1 -0
- package/dist/engine/gateway/gateway-config.d.ts +33 -0
- package/dist/engine/gateway/gateway-config.d.ts.map +1 -0
- package/dist/engine/gateway/gateway-config.js +61 -0
- package/dist/engine/gateway/gateway-config.js.map +1 -0
- package/dist/engine/gateway/gateway-loader.d.ts +10 -0
- package/dist/engine/gateway/gateway-loader.d.ts.map +1 -0
- package/dist/engine/gateway/gateway-loader.js +150 -0
- package/dist/engine/gateway/gateway-loader.js.map +1 -0
- package/dist/engine/gateway/mode-b-config.d.ts +44 -0
- package/dist/engine/gateway/mode-b-config.d.ts.map +1 -0
- package/dist/engine/gateway/mode-b-config.js +45 -0
- package/dist/engine/gateway/mode-b-config.js.map +1 -0
- package/dist/engine/gateway/mode-b-loader.d.ts +14 -0
- package/dist/engine/gateway/mode-b-loader.d.ts.map +1 -0
- package/dist/engine/gateway/mode-b-loader.js +104 -0
- package/dist/engine/gateway/mode-b-loader.js.map +1 -0
- package/dist/engine/gateway/observability-config.d.ts +19 -0
- package/dist/engine/gateway/observability-config.d.ts.map +1 -0
- package/dist/engine/gateway/observability-config.js +27 -0
- package/dist/engine/gateway/observability-config.js.map +1 -0
- package/dist/engine/gateway/tenant-config.d.ts +59 -0
- package/dist/engine/gateway/tenant-config.d.ts.map +1 -0
- package/dist/engine/gateway/tenant-config.js +44 -0
- package/dist/engine/gateway/tenant-config.js.map +1 -0
- package/dist/engine/index.d.ts +49 -0
- package/dist/engine/index.d.ts.map +1 -0
- package/dist/engine/index.js +27 -0
- package/dist/engine/index.js.map +1 -0
- package/dist/engine/loader/app-loader.d.ts +18 -0
- package/dist/engine/loader/app-loader.d.ts.map +1 -0
- package/dist/engine/loader/app-loader.js +947 -0
- package/dist/engine/loader/app-loader.js.map +1 -0
- package/dist/engine/loader/preset-loader.d.ts +13 -0
- package/dist/engine/loader/preset-loader.d.ts.map +1 -0
- package/dist/engine/loader/preset-loader.js +51 -0
- package/dist/engine/loader/preset-loader.js.map +1 -0
- package/dist/eval/dataset-loader.d.ts +3 -0
- package/dist/eval/dataset-loader.d.ts.map +1 -0
- package/dist/eval/dataset-loader.js +70 -0
- package/dist/eval/dataset-loader.js.map +1 -0
- package/dist/eval/experiment-comparator.d.ts +16 -0
- package/dist/eval/experiment-comparator.d.ts.map +1 -0
- package/dist/eval/experiment-comparator.js +34 -0
- package/dist/eval/experiment-comparator.js.map +1 -0
- package/dist/eval/experiment-runner.d.ts +20 -0
- package/dist/eval/experiment-runner.d.ts.map +1 -0
- package/dist/eval/experiment-runner.js +54 -0
- package/dist/eval/experiment-runner.js.map +1 -0
- package/dist/eval/index.d.ts +21 -0
- package/dist/eval/index.d.ts.map +1 -0
- package/dist/eval/index.js +19 -0
- package/dist/eval/index.js.map +1 -0
- package/dist/eval/scorer-factory.d.ts +4 -0
- package/dist/eval/scorer-factory.d.ts.map +1 -0
- package/dist/eval/scorer-factory.js +67 -0
- package/dist/eval/scorer-factory.js.map +1 -0
- package/dist/eval/scorers/coherence-scorer.d.ts +8 -0
- package/dist/eval/scorers/coherence-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/coherence-scorer.js +22 -0
- package/dist/eval/scorers/coherence-scorer.js.map +1 -0
- package/dist/eval/scorers/composite-scorer.d.ts +8 -0
- package/dist/eval/scorers/composite-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/composite-scorer.js +19 -0
- package/dist/eval/scorers/composite-scorer.js.map +1 -0
- package/dist/eval/scorers/contains-scorer.d.ts +8 -0
- package/dist/eval/scorers/contains-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/contains-scorer.js +30 -0
- package/dist/eval/scorers/contains-scorer.js.map +1 -0
- package/dist/eval/scorers/cost-scorer.d.ts +8 -0
- package/dist/eval/scorers/cost-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/cost-scorer.js +19 -0
- package/dist/eval/scorers/cost-scorer.js.map +1 -0
- package/dist/eval/scorers/custom-prompt-scorer.d.ts +9 -0
- package/dist/eval/scorers/custom-prompt-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/custom-prompt-scorer.js +24 -0
- package/dist/eval/scorers/custom-prompt-scorer.js.map +1 -0
- package/dist/eval/scorers/exact-match-scorer.d.ts +6 -0
- package/dist/eval/scorers/exact-match-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/exact-match-scorer.js +16 -0
- package/dist/eval/scorers/exact-match-scorer.js.map +1 -0
- package/dist/eval/scorers/faithfulness-scorer.d.ts +8 -0
- package/dist/eval/scorers/faithfulness-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/faithfulness-scorer.js +27 -0
- package/dist/eval/scorers/faithfulness-scorer.js.map +1 -0
- package/dist/eval/scorers/hallucination-scorer.d.ts +8 -0
- package/dist/eval/scorers/hallucination-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/hallucination-scorer.js +31 -0
- package/dist/eval/scorers/hallucination-scorer.js.map +1 -0
- package/dist/eval/scorers/json-validity-scorer.d.ts +8 -0
- package/dist/eval/scorers/json-validity-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/json-validity-scorer.js +32 -0
- package/dist/eval/scorers/json-validity-scorer.js.map +1 -0
- package/dist/eval/scorers/latency-scorer.d.ts +8 -0
- package/dist/eval/scorers/latency-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/latency-scorer.js +19 -0
- package/dist/eval/scorers/latency-scorer.js.map +1 -0
- package/dist/eval/scorers/length-scorer.d.ts +9 -0
- package/dist/eval/scorers/length-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/length-scorer.js +26 -0
- package/dist/eval/scorers/length-scorer.js.map +1 -0
- package/dist/eval/scorers/parse-llm-response.d.ts +5 -0
- package/dist/eval/scorers/parse-llm-response.d.ts.map +1 -0
- package/dist/eval/scorers/parse-llm-response.js +13 -0
- package/dist/eval/scorers/parse-llm-response.js.map +1 -0
- package/dist/eval/scorers/relevance-scorer.d.ts +8 -0
- package/dist/eval/scorers/relevance-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/relevance-scorer.js +23 -0
- package/dist/eval/scorers/relevance-scorer.js.map +1 -0
- package/dist/eval/scorers/toxicity-scorer.d.ts +8 -0
- package/dist/eval/scorers/toxicity-scorer.d.ts.map +1 -0
- package/dist/eval/scorers/toxicity-scorer.js +26 -0
- package/dist/eval/scorers/toxicity-scorer.js.map +1 -0
- package/dist/eval/types.d.ts +51 -0
- package/dist/eval/types.d.ts.map +1 -0
- package/dist/eval/types.js +3 -0
- package/dist/eval/types.js.map +1 -0
- package/dist/events/event-bus.d.ts +36 -0
- package/dist/events/event-bus.d.ts.map +1 -0
- package/dist/events/event-bus.js +116 -0
- package/dist/events/event-bus.js.map +1 -0
- package/dist/events/event-store.d.ts +11 -0
- package/dist/events/event-store.d.ts.map +1 -0
- package/dist/events/event-store.js +2 -0
- package/dist/events/event-store.js.map +1 -0
- package/dist/events/index.d.ts +295 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +48 -0
- package/dist/events/index.js.map +1 -0
- package/dist/events/trace.d.ts +30 -0
- package/dist/events/trace.d.ts.map +1 -0
- package/dist/events/trace.js +45 -0
- package/dist/events/trace.js.map +1 -0
- package/dist/index.d.ts +58 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +42 -0
- package/dist/index.js.map +1 -0
- package/dist/knowledge/index.d.ts +10 -0
- package/dist/knowledge/index.d.ts.map +1 -0
- package/dist/knowledge/index.js +9 -0
- package/dist/knowledge/index.js.map +1 -0
- package/dist/knowledge/infrastructure/memory-vector-store.d.ts +12 -0
- package/dist/knowledge/infrastructure/memory-vector-store.d.ts.map +1 -0
- package/dist/knowledge/infrastructure/memory-vector-store.js +71 -0
- package/dist/knowledge/infrastructure/memory-vector-store.js.map +1 -0
- package/dist/knowledge/infrastructure/ollama-embedding.d.ts +15 -0
- package/dist/knowledge/infrastructure/ollama-embedding.d.ts.map +1 -0
- package/dist/knowledge/infrastructure/ollama-embedding.js +38 -0
- package/dist/knowledge/infrastructure/ollama-embedding.js.map +1 -0
- package/dist/knowledge/infrastructure/openai-embedding.d.ts +18 -0
- package/dist/knowledge/infrastructure/openai-embedding.d.ts.map +1 -0
- package/dist/knowledge/infrastructure/openai-embedding.js +66 -0
- package/dist/knowledge/infrastructure/openai-embedding.js.map +1 -0
- package/dist/knowledge/knowledge-capability.d.ts +15 -0
- package/dist/knowledge/knowledge-capability.d.ts.map +1 -0
- package/dist/knowledge/knowledge-capability.js +36 -0
- package/dist/knowledge/knowledge-capability.js.map +1 -0
- package/dist/knowledge/markdown-chunker.d.ts +8 -0
- package/dist/knowledge/markdown-chunker.d.ts.map +1 -0
- package/dist/knowledge/markdown-chunker.js +146 -0
- package/dist/knowledge/markdown-chunker.js.map +1 -0
- package/dist/knowledge/recursive-chunker.d.ts +8 -0
- package/dist/knowledge/recursive-chunker.d.ts.map +1 -0
- package/dist/knowledge/recursive-chunker.js +73 -0
- package/dist/knowledge/recursive-chunker.js.map +1 -0
- package/dist/knowledge/reranker.d.ts +5 -0
- package/dist/knowledge/reranker.d.ts.map +1 -0
- package/dist/knowledge/reranker.js +3 -0
- package/dist/knowledge/reranker.js.map +1 -0
- package/dist/knowledge/retrieval-pipeline.d.ts +26 -0
- package/dist/knowledge/retrieval-pipeline.d.ts.map +1 -0
- package/dist/knowledge/retrieval-pipeline.js +56 -0
- package/dist/knowledge/retrieval-pipeline.js.map +1 -0
- package/dist/memory/chunk-importer.d.ts +16 -0
- package/dist/memory/chunk-importer.d.ts.map +1 -0
- package/dist/memory/chunk-importer.js +58 -0
- package/dist/memory/chunk-importer.js.map +1 -0
- package/dist/memory/compactor.d.ts +59 -0
- package/dist/memory/compactor.d.ts.map +1 -0
- package/dist/memory/compactor.js +100 -0
- package/dist/memory/compactor.js.map +1 -0
- package/dist/memory/decay-curves.d.ts +33 -0
- package/dist/memory/decay-curves.d.ts.map +1 -0
- package/dist/memory/decay-curves.js +48 -0
- package/dist/memory/decay-curves.js.map +1 -0
- package/dist/memory/developer-identity.d.ts +7 -0
- package/dist/memory/developer-identity.d.ts.map +1 -0
- package/dist/memory/developer-identity.js +20 -0
- package/dist/memory/developer-identity.js.map +1 -0
- package/dist/memory/git-sync-manager.d.ts +28 -0
- package/dist/memory/git-sync-manager.d.ts.map +1 -0
- package/dist/memory/git-sync-manager.js +77 -0
- package/dist/memory/git-sync-manager.js.map +1 -0
- package/dist/memory/index.d.ts +46 -0
- package/dist/memory/index.d.ts.map +1 -0
- package/dist/memory/index.js +11 -0
- package/dist/memory/index.js.map +1 -0
- package/dist/memory/memory-manager.d.ts +34 -0
- package/dist/memory/memory-manager.d.ts.map +1 -0
- package/dist/memory/memory-manager.js +151 -0
- package/dist/memory/memory-manager.js.map +1 -0
- package/dist/memory/project-store.d.ts +28 -0
- package/dist/memory/project-store.d.ts.map +1 -0
- package/dist/memory/project-store.js +159 -0
- package/dist/memory/project-store.js.map +1 -0
- package/dist/memory/sqlite-store.d.ts +41 -0
- package/dist/memory/sqlite-store.d.ts.map +1 -0
- package/dist/memory/sqlite-store.js +320 -0
- package/dist/memory/sqlite-store.js.map +1 -0
- package/dist/observability/index.d.ts +5 -0
- package/dist/observability/index.d.ts.map +1 -0
- package/dist/observability/index.js +3 -0
- package/dist/observability/index.js.map +1 -0
- package/dist/observability/otel-exporter.d.ts +41 -0
- package/dist/observability/otel-exporter.d.ts.map +1 -0
- package/dist/observability/otel-exporter.js +166 -0
- package/dist/observability/otel-exporter.js.map +1 -0
- package/dist/observability/span-mapper.d.ts +24 -0
- package/dist/observability/span-mapper.d.ts.map +1 -0
- package/dist/observability/span-mapper.js +375 -0
- package/dist/observability/span-mapper.js.map +1 -0
- package/dist/orchestrator/checkpoint-store.d.ts +9 -0
- package/dist/orchestrator/checkpoint-store.d.ts.map +1 -0
- package/dist/orchestrator/checkpoint-store.js +2 -0
- package/dist/orchestrator/checkpoint-store.js.map +1 -0
- package/dist/orchestrator/checkpoint-types.d.ts +30 -0
- package/dist/orchestrator/checkpoint-types.d.ts.map +1 -0
- package/dist/orchestrator/checkpoint-types.js +2 -0
- package/dist/orchestrator/checkpoint-types.js.map +1 -0
- package/dist/orchestrator/guardrails.d.ts +23 -0
- package/dist/orchestrator/guardrails.d.ts.map +1 -0
- package/dist/orchestrator/guardrails.js +136 -0
- package/dist/orchestrator/guardrails.js.map +1 -0
- package/dist/orchestrator/index.d.ts +45 -0
- package/dist/orchestrator/index.d.ts.map +1 -0
- package/dist/orchestrator/index.js +8 -0
- package/dist/orchestrator/index.js.map +1 -0
- package/dist/orchestrator/interrupt.d.ts +20 -0
- package/dist/orchestrator/interrupt.d.ts.map +1 -0
- package/dist/orchestrator/interrupt.js +4 -0
- package/dist/orchestrator/interrupt.js.map +1 -0
- package/dist/orchestrator/orchestrator.d.ts +170 -0
- package/dist/orchestrator/orchestrator.d.ts.map +1 -0
- package/dist/orchestrator/orchestrator.js +509 -0
- package/dist/orchestrator/orchestrator.js.map +1 -0
- package/dist/orchestrator/phase-machine.d.ts +48 -0
- package/dist/orchestrator/phase-machine.d.ts.map +1 -0
- package/dist/orchestrator/phase-machine.js +176 -0
- package/dist/orchestrator/phase-machine.js.map +1 -0
- package/dist/orchestrator/schemas.d.ts +145 -0
- package/dist/orchestrator/schemas.d.ts.map +1 -0
- package/dist/orchestrator/schemas.js +126 -0
- package/dist/orchestrator/schemas.js.map +1 -0
- package/dist/orchestrator/sqlite-checkpoint-store.d.ts +15 -0
- package/dist/orchestrator/sqlite-checkpoint-store.d.ts.map +1 -0
- package/dist/orchestrator/sqlite-checkpoint-store.js +98 -0
- package/dist/orchestrator/sqlite-checkpoint-store.js.map +1 -0
- package/dist/orchestrator/strategies/index.d.ts +28 -0
- package/dist/orchestrator/strategies/index.d.ts.map +1 -0
- package/dist/orchestrator/strategies/index.js +20 -0
- package/dist/orchestrator/strategies/index.js.map +1 -0
- package/dist/orchestrator/strategies/sequential-strategy.d.ts +13 -0
- package/dist/orchestrator/strategies/sequential-strategy.d.ts.map +1 -0
- package/dist/orchestrator/strategies/sequential-strategy.js +29 -0
- package/dist/orchestrator/strategies/sequential-strategy.js.map +1 -0
- package/dist/orchestrator/strategies/supervisor-strategy.d.ts +43 -0
- package/dist/orchestrator/strategies/supervisor-strategy.d.ts.map +1 -0
- package/dist/orchestrator/strategies/supervisor-strategy.js +118 -0
- package/dist/orchestrator/strategies/supervisor-strategy.js.map +1 -0
- package/dist/orchestrator/strategies/swarm-strategy.d.ts +36 -0
- package/dist/orchestrator/strategies/swarm-strategy.d.ts.map +1 -0
- package/dist/orchestrator/strategies/swarm-strategy.js +126 -0
- package/dist/orchestrator/strategies/swarm-strategy.js.map +1 -0
- package/dist/package/index.d.ts +7 -0
- package/dist/package/index.d.ts.map +1 -0
- package/dist/package/index.js +6 -0
- package/dist/package/index.js.map +1 -0
- package/dist/package/security.d.ts +18 -0
- package/dist/package/security.d.ts.map +1 -0
- package/dist/package/security.js +110 -0
- package/dist/package/security.js.map +1 -0
- package/dist/package/types.d.ts +34 -0
- package/dist/package/types.d.ts.map +1 -0
- package/dist/package/types.js +4 -0
- package/dist/package/types.js.map +1 -0
- package/dist/package/yaml-parser.d.ts +22 -0
- package/dist/package/yaml-parser.d.ts.map +1 -0
- package/dist/package/yaml-parser.js +109 -0
- package/dist/package/yaml-parser.js.map +1 -0
- package/dist/package/yaml-schema.d.ts +42 -0
- package/dist/package/yaml-schema.d.ts.map +1 -0
- package/dist/package/yaml-schema.js +141 -0
- package/dist/package/yaml-schema.js.map +1 -0
- package/dist/safety/content-classifier.d.ts +31 -0
- package/dist/safety/content-classifier.d.ts.map +1 -0
- package/dist/safety/content-classifier.js +107 -0
- package/dist/safety/content-classifier.js.map +1 -0
- package/dist/safety/index.d.ts +10 -0
- package/dist/safety/index.d.ts.map +1 -0
- package/dist/safety/index.js +10 -0
- package/dist/safety/index.js.map +1 -0
- package/dist/safety/pii-scanner.d.ts +26 -0
- package/dist/safety/pii-scanner.d.ts.map +1 -0
- package/dist/safety/pii-scanner.js +82 -0
- package/dist/safety/pii-scanner.js.map +1 -0
- package/dist/safety/rails.d.ts +33 -0
- package/dist/safety/rails.d.ts.map +1 -0
- package/dist/safety/rails.js +134 -0
- package/dist/safety/rails.js.map +1 -0
- package/dist/safety/safety-pipeline.d.ts +41 -0
- package/dist/safety/safety-pipeline.d.ts.map +1 -0
- package/dist/safety/safety-pipeline.js +153 -0
- package/dist/safety/safety-pipeline.js.map +1 -0
- package/dist/safety/types.d.ts +38 -0
- package/dist/safety/types.d.ts.map +1 -0
- package/dist/safety/types.js +3 -0
- package/dist/safety/types.js.map +1 -0
- package/dist/sandbox/index.d.ts +17 -0
- package/dist/sandbox/index.d.ts.map +1 -0
- package/dist/sandbox/index.js +4 -0
- package/dist/sandbox/index.js.map +1 -0
- package/dist/sandbox/network-filter.d.ts +13 -0
- package/dist/sandbox/network-filter.d.ts.map +1 -0
- package/dist/sandbox/network-filter.js +43 -0
- package/dist/sandbox/network-filter.js.map +1 -0
- package/dist/sandbox/path-validator.d.ts +16 -0
- package/dist/sandbox/path-validator.d.ts.map +1 -0
- package/dist/sandbox/path-validator.js +47 -0
- package/dist/sandbox/path-validator.js.map +1 -0
- package/dist/sandbox/policies.d.ts +38 -0
- package/dist/sandbox/policies.d.ts.map +1 -0
- package/dist/sandbox/policies.js +145 -0
- package/dist/sandbox/policies.js.map +1 -0
- package/dist/security/audit-log.d.ts +17 -0
- package/dist/security/audit-log.d.ts.map +1 -0
- package/dist/security/audit-log.js +214 -0
- package/dist/security/audit-log.js.map +1 -0
- package/dist/security/guardian.d.ts +24 -0
- package/dist/security/guardian.d.ts.map +1 -0
- package/dist/security/guardian.js +177 -0
- package/dist/security/guardian.js.map +1 -0
- package/dist/security/index.d.ts +10 -0
- package/dist/security/index.d.ts.map +1 -0
- package/dist/security/index.js +7 -0
- package/dist/security/index.js.map +1 -0
- package/dist/security/prompt-scanner.d.ts +23 -0
- package/dist/security/prompt-scanner.d.ts.map +1 -0
- package/dist/security/prompt-scanner.js +376 -0
- package/dist/security/prompt-scanner.js.map +1 -0
- package/dist/security/secret-store.d.ts +18 -0
- package/dist/security/secret-store.d.ts.map +1 -0
- package/dist/security/secret-store.js +123 -0
- package/dist/security/secret-store.js.map +1 -0
- package/dist/security/self-audit.d.ts +33 -0
- package/dist/security/self-audit.d.ts.map +1 -0
- package/dist/security/self-audit.js +142 -0
- package/dist/security/self-audit.js.map +1 -0
- package/dist/security/types.d.ts +107 -0
- package/dist/security/types.d.ts.map +1 -0
- package/dist/security/types.js +3 -0
- package/dist/security/types.js.map +1 -0
- package/dist/skill/index.d.ts +7 -0
- package/dist/skill/index.d.ts.map +1 -0
- package/dist/skill/index.js +4 -0
- package/dist/skill/index.js.map +1 -0
- package/dist/skill/skill-registry.d.ts +26 -0
- package/dist/skill/skill-registry.d.ts.map +1 -0
- package/dist/skill/skill-registry.js +81 -0
- package/dist/skill/skill-registry.js.map +1 -0
- package/dist/skill/types.d.ts +17 -0
- package/dist/skill/types.d.ts.map +1 -0
- package/dist/skill/types.js +2 -0
- package/dist/skill/types.js.map +1 -0
- package/dist/skill/yaml-parser.d.ts +18 -0
- package/dist/skill/yaml-parser.d.ts.map +1 -0
- package/dist/skill/yaml-parser.js +61 -0
- package/dist/skill/yaml-parser.js.map +1 -0
- package/dist/skill/yaml-schema.d.ts +20 -0
- package/dist/skill/yaml-schema.d.ts.map +1 -0
- package/dist/skill/yaml-schema.js +80 -0
- package/dist/skill/yaml-schema.js.map +1 -0
- package/dist/tree/batch-executor.d.ts +28 -0
- package/dist/tree/batch-executor.d.ts.map +1 -0
- package/dist/tree/batch-executor.js +78 -0
- package/dist/tree/batch-executor.js.map +1 -0
- package/dist/tree/index.d.ts +26 -0
- package/dist/tree/index.d.ts.map +1 -0
- package/dist/tree/index.js +3 -0
- package/dist/tree/index.js.map +1 -0
- package/dist/tree/task-tree.d.ts +74 -0
- package/dist/tree/task-tree.d.ts.map +1 -0
- package/dist/tree/task-tree.js +262 -0
- package/dist/tree/task-tree.js.map +1 -0
- package/dist/verification/coverage-parser.d.ts +6 -0
- package/dist/verification/coverage-parser.d.ts.map +1 -0
- package/dist/verification/coverage-parser.js +29 -0
- package/dist/verification/coverage-parser.js.map +1 -0
- package/dist/verification/gate-runner.d.ts +18 -0
- package/dist/verification/gate-runner.d.ts.map +1 -0
- package/dist/verification/gate-runner.js +63 -0
- package/dist/verification/gate-runner.js.map +1 -0
- package/dist/verification/index.d.ts +24 -0
- package/dist/verification/index.d.ts.map +1 -0
- package/dist/verification/index.js +4 -0
- package/dist/verification/index.js.map +1 -0
- package/dist/verification/verification-loop.d.ts +32 -0
- package/dist/verification/verification-loop.d.ts.map +1 -0
- package/dist/verification/verification-loop.js +71 -0
- package/dist/verification/verification-loop.js.map +1 -0
- package/package.json +58 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { SandboxConfig } from "./index.js";
|
|
2
|
+
/** Predefined sandbox configs per agent role. */
|
|
3
|
+
export declare const ROLE_PRESETS: Record<string, SandboxConfig>;
|
|
4
|
+
export declare class SandboxPolicy {
|
|
5
|
+
private readonly _config;
|
|
6
|
+
private readonly _projectPath;
|
|
7
|
+
private readonly _resolvedAllowedPaths;
|
|
8
|
+
private readonly _resolvedDeniedPaths;
|
|
9
|
+
constructor({ config, projectPath, }: {
|
|
10
|
+
config: SandboxConfig;
|
|
11
|
+
projectPath: string;
|
|
12
|
+
});
|
|
13
|
+
canRead(filePath: string): boolean;
|
|
14
|
+
canWrite(filePath: string): boolean;
|
|
15
|
+
private resolvePathAccess;
|
|
16
|
+
canAccess(domain: string): boolean;
|
|
17
|
+
get config(): SandboxConfig;
|
|
18
|
+
get projectPath(): string;
|
|
19
|
+
toJSON(): {
|
|
20
|
+
config: SandboxConfig;
|
|
21
|
+
projectPath: string;
|
|
22
|
+
resolvedAllowedPaths: readonly string[];
|
|
23
|
+
resolvedDeniedPaths: readonly string[];
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
export declare function createPolicy(role: string, projectPath: string, overrides?: Partial<SandboxConfig>): SandboxPolicy;
|
|
27
|
+
/**
|
|
28
|
+
* Create a tenant-scoped filesystem jail.
|
|
29
|
+
* The tenant is allowed read-write access only within `<basePath>/tenants/<tenantId>`.
|
|
30
|
+
* Access to other tenant directories is blocked because only the tenant's own dir is in allowedPaths.
|
|
31
|
+
* The parent `<basePath>/tenants` is explicitly denied to block directory listing of all tenants.
|
|
32
|
+
* Note: allowedPaths is checked after deniedPaths in SandboxPolicy -- so the tenant dir is placed in
|
|
33
|
+
* allowedPaths and the parent-deny ensures other tenants are unreachable even if allowedPaths
|
|
34
|
+
* matching were to fail. The tenant's own dir does NOT start-with a different tenant's allowed path,
|
|
35
|
+
* so cross-tenant access is blocked by the allowedPaths whitelist.
|
|
36
|
+
*/
|
|
37
|
+
export declare function createTenantSandbox(tenantId: string, basePath: string, basePolicy?: SandboxConfig): SandboxConfig;
|
|
38
|
+
//# sourceMappingURL=policies.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policies.d.ts","sourceRoot":"","sources":["../../src/sandbox/policies.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAEhD,iDAAiD;AACjD,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CA2CtD,CAAC;AAEF,qBAAa,aAAa;IACxB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAgB;IACxC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,qBAAqB,CAAoB;IAC1D,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAoB;gBAE7C,EACV,MAAM,EACN,WAAW,GACZ,EAAE;QACD,MAAM,EAAE,aAAa,CAAC;QACtB,WAAW,EAAE,MAAM,CAAC;KACrB;IAcD,OAAO,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO;IAKlC,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO;IAKnC,OAAO,CAAC,iBAAiB;IAsBzB,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAUlC,IAAI,MAAM,IAAI,aAAa,CAE1B;IAED,IAAI,WAAW,IAAI,MAAM,CAExB;IAED,MAAM,IAAI;QACR,MAAM,EAAE,aAAa,CAAC;QACtB,WAAW,EAAE,MAAM,CAAC;QACpB,oBAAoB,EAAE,SAAS,MAAM,EAAE,CAAC;QACxC,mBAAmB,EAAE,SAAS,MAAM,EAAE,CAAC;KACxC;CAQF;AAED,wBAAgB,YAAY,CAC1B,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,EACnB,SAAS,CAAC,EAAE,OAAO,CAAC,aAAa,CAAC,GACjC,aAAa,CAUf;AAED;;;;;;;;;GASG;AACH,wBAAgB,mBAAmB,CACjC,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,MAAM,EAChB,UAAU,CAAC,EAAE,aAAa,GACzB,aAAa,CAUf"}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import { resolve } from "node:path";
|
|
2
|
+
/** Predefined sandbox configs per agent role. */
|
|
3
|
+
export const ROLE_PRESETS = {
|
|
4
|
+
architect: {
|
|
5
|
+
fsPolicy: "read-only",
|
|
6
|
+
netPolicy: "documentation",
|
|
7
|
+
allowedPaths: [],
|
|
8
|
+
deniedPaths: [],
|
|
9
|
+
allowedDomains: ["*"],
|
|
10
|
+
},
|
|
11
|
+
worker: {
|
|
12
|
+
fsPolicy: "read-write",
|
|
13
|
+
netPolicy: "package-managers",
|
|
14
|
+
allowedPaths: [],
|
|
15
|
+
deniedPaths: [
|
|
16
|
+
"/etc",
|
|
17
|
+
"/usr",
|
|
18
|
+
"/bin",
|
|
19
|
+
"/sbin",
|
|
20
|
+
"/var",
|
|
21
|
+
"C:\\Windows",
|
|
22
|
+
"C:\\Program Files",
|
|
23
|
+
],
|
|
24
|
+
allowedDomains: [
|
|
25
|
+
"registry.npmjs.org",
|
|
26
|
+
"pypi.org",
|
|
27
|
+
"proxy.golang.org",
|
|
28
|
+
"plugins.gradle.org",
|
|
29
|
+
"repo.maven.apache.org",
|
|
30
|
+
],
|
|
31
|
+
},
|
|
32
|
+
optimizer: {
|
|
33
|
+
fsPolicy: "read-only",
|
|
34
|
+
netPolicy: "none",
|
|
35
|
+
allowedPaths: [],
|
|
36
|
+
deniedPaths: [],
|
|
37
|
+
allowedDomains: [],
|
|
38
|
+
},
|
|
39
|
+
researcher: {
|
|
40
|
+
fsPolicy: "read-only",
|
|
41
|
+
netPolicy: "full",
|
|
42
|
+
allowedPaths: [],
|
|
43
|
+
deniedPaths: [],
|
|
44
|
+
allowedDomains: ["*"],
|
|
45
|
+
},
|
|
46
|
+
};
|
|
47
|
+
export class SandboxPolicy {
|
|
48
|
+
_config;
|
|
49
|
+
_projectPath;
|
|
50
|
+
_resolvedAllowedPaths;
|
|
51
|
+
_resolvedDeniedPaths;
|
|
52
|
+
constructor({ config, projectPath, }) {
|
|
53
|
+
this._config = config;
|
|
54
|
+
this._projectPath = projectPath;
|
|
55
|
+
// Default allowedPaths to project dir for read-write policies
|
|
56
|
+
const allowed = config.allowedPaths.length === 0 && config.fsPolicy === "read-write"
|
|
57
|
+
? [resolve(projectPath)]
|
|
58
|
+
: config.allowedPaths.map((p) => resolve(p));
|
|
59
|
+
this._resolvedAllowedPaths = allowed;
|
|
60
|
+
this._resolvedDeniedPaths = config.deniedPaths.map((p) => resolve(p));
|
|
61
|
+
}
|
|
62
|
+
canRead(filePath) {
|
|
63
|
+
if (this._config.fsPolicy === "none")
|
|
64
|
+
return false;
|
|
65
|
+
return this.resolvePathAccess(resolve(filePath));
|
|
66
|
+
}
|
|
67
|
+
canWrite(filePath) {
|
|
68
|
+
if (this._config.fsPolicy !== "read-write")
|
|
69
|
+
return false;
|
|
70
|
+
return this.resolvePathAccess(resolve(filePath));
|
|
71
|
+
}
|
|
72
|
+
resolvePathAccess(resolvedPath) {
|
|
73
|
+
const matchedAllow = this._resolvedAllowedPaths
|
|
74
|
+
.filter((a) => resolvedPath.startsWith(a))
|
|
75
|
+
.reduce((best, a) => (best === null || a.length > best.length ? a : best), null);
|
|
76
|
+
const matchedDeny = this._resolvedDeniedPaths
|
|
77
|
+
.filter((d) => resolvedPath.startsWith(d))
|
|
78
|
+
.reduce((best, d) => (best === null || d.length > best.length ? d : best), null);
|
|
79
|
+
if (matchedAllow !== null && matchedDeny !== null) {
|
|
80
|
+
return matchedAllow.length >= matchedDeny.length;
|
|
81
|
+
}
|
|
82
|
+
if (matchedDeny !== null)
|
|
83
|
+
return false;
|
|
84
|
+
if (this._resolvedAllowedPaths.length > 0) {
|
|
85
|
+
return matchedAllow !== null;
|
|
86
|
+
}
|
|
87
|
+
return true;
|
|
88
|
+
}
|
|
89
|
+
canAccess(domain) {
|
|
90
|
+
if (this._config.netPolicy === "none")
|
|
91
|
+
return false;
|
|
92
|
+
if (this._config.netPolicy === "full")
|
|
93
|
+
return true;
|
|
94
|
+
if (this._config.allowedDomains.includes("*"))
|
|
95
|
+
return true;
|
|
96
|
+
return this._config.allowedDomains.some((allowed) => domain === allowed || domain.endsWith(`.${allowed}`));
|
|
97
|
+
}
|
|
98
|
+
get config() {
|
|
99
|
+
return this._config;
|
|
100
|
+
}
|
|
101
|
+
get projectPath() {
|
|
102
|
+
return this._projectPath;
|
|
103
|
+
}
|
|
104
|
+
toJSON() {
|
|
105
|
+
return {
|
|
106
|
+
config: this._config,
|
|
107
|
+
projectPath: this._projectPath,
|
|
108
|
+
resolvedAllowedPaths: this._resolvedAllowedPaths,
|
|
109
|
+
resolvedDeniedPaths: this._resolvedDeniedPaths,
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
export function createPolicy(role, projectPath, overrides) {
|
|
114
|
+
const preset = ROLE_PRESETS[role] ?? ROLE_PRESETS["worker"];
|
|
115
|
+
const config = {
|
|
116
|
+
fsPolicy: overrides?.fsPolicy ?? preset.fsPolicy,
|
|
117
|
+
netPolicy: overrides?.netPolicy ?? preset.netPolicy,
|
|
118
|
+
allowedPaths: overrides?.allowedPaths ?? preset.allowedPaths,
|
|
119
|
+
deniedPaths: overrides?.deniedPaths ?? preset.deniedPaths,
|
|
120
|
+
allowedDomains: overrides?.allowedDomains ?? preset.allowedDomains,
|
|
121
|
+
};
|
|
122
|
+
return new SandboxPolicy({ config, projectPath });
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Create a tenant-scoped filesystem jail.
|
|
126
|
+
* The tenant is allowed read-write access only within `<basePath>/tenants/<tenantId>`.
|
|
127
|
+
* Access to other tenant directories is blocked because only the tenant's own dir is in allowedPaths.
|
|
128
|
+
* The parent `<basePath>/tenants` is explicitly denied to block directory listing of all tenants.
|
|
129
|
+
* Note: allowedPaths is checked after deniedPaths in SandboxPolicy -- so the tenant dir is placed in
|
|
130
|
+
* allowedPaths and the parent-deny ensures other tenants are unreachable even if allowedPaths
|
|
131
|
+
* matching were to fail. The tenant's own dir does NOT start-with a different tenant's allowed path,
|
|
132
|
+
* so cross-tenant access is blocked by the allowedPaths whitelist.
|
|
133
|
+
*/
|
|
134
|
+
export function createTenantSandbox(tenantId, basePath, basePolicy) {
|
|
135
|
+
const tenantDir = resolve(basePath, "tenants", tenantId);
|
|
136
|
+
const tenantsRoot = resolve(basePath, "tenants");
|
|
137
|
+
return {
|
|
138
|
+
fsPolicy: "read-write",
|
|
139
|
+
allowedPaths: [tenantDir],
|
|
140
|
+
deniedPaths: [tenantsRoot],
|
|
141
|
+
netPolicy: basePolicy?.netPolicy ?? "none",
|
|
142
|
+
allowedDomains: basePolicy?.allowedDomains ?? [],
|
|
143
|
+
};
|
|
144
|
+
}
|
|
145
|
+
//# sourceMappingURL=policies.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policies.js","sourceRoot":"","sources":["../../src/sandbox/policies.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { AuditEntry, AuditFilter, AuditChainResult, AuditLog } from "./types.js";
|
|
2
|
+
export declare class JsonlAuditLog implements AuditLog {
|
|
3
|
+
private readonly logPath;
|
|
4
|
+
private readonly hashChaining;
|
|
5
|
+
private lastHash;
|
|
6
|
+
private entryCount;
|
|
7
|
+
constructor(logPath: string, options?: {
|
|
8
|
+
hashChaining?: boolean;
|
|
9
|
+
});
|
|
10
|
+
append(entry: Omit<AuditEntry, "id" | "hash" | "previousHash">): AuditEntry;
|
|
11
|
+
query(filter: AuditFilter): readonly AuditEntry[];
|
|
12
|
+
verifyChain(fromIndex?: number, toIndex?: number): AuditChainResult;
|
|
13
|
+
count(): number;
|
|
14
|
+
private readAllEntries;
|
|
15
|
+
private loadState;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=audit-log.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit-log.d.ts","sourceRoot":"","sources":["../../src/security/audit-log.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAgEtF,qBAAa,aAAc,YAAW,QAAQ;IAC5C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAU;IACvC,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,UAAU,CAAS;gBAEf,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE;QAAE,YAAY,CAAC,EAAE,OAAO,CAAA;KAAE;IAoBjE,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,GAAG,MAAM,GAAG,cAAc,CAAC,GAAG,UAAU;IAuC3E,KAAK,CAAC,MAAM,EAAE,WAAW,GAAG,SAAS,UAAU,EAAE;IA+BjD,WAAW,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,gBAAgB;IAwCnE,KAAK,IAAI,MAAM;IAIf,OAAO,CAAC,cAAc;IAYtB,OAAO,CAAC,SAAS;CAWlB"}
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
// Append-only JSONL audit log with SHA-256 hash chaining for tamper detection
|
|
2
|
+
import { createHash } from "node:crypto";
|
|
3
|
+
import { appendFileSync, readFileSync, existsSync, writeFileSync } from "node:fs";
|
|
4
|
+
import { mkdirSync } from "node:fs";
|
|
5
|
+
import { dirname } from "node:path";
|
|
6
|
+
import { KilnError } from "../engine/errors.js";
|
|
7
|
+
const GENESIS_HASH = "genesis";
|
|
8
|
+
/** Deterministic JSON serialization with sorted keys */
|
|
9
|
+
function canonicalJson(obj) {
|
|
10
|
+
return JSON.stringify(obj, Object.keys(obj).sort());
|
|
11
|
+
}
|
|
12
|
+
/** Compute SHA-256 hash of entry content + previous hash */
|
|
13
|
+
function computeHash(entry, previousHash) {
|
|
14
|
+
const payload = {
|
|
15
|
+
id: entry.id,
|
|
16
|
+
timestamp: entry.timestamp instanceof Date ? entry.timestamp.toISOString() : entry.timestamp,
|
|
17
|
+
action: entry.action,
|
|
18
|
+
actor: entry.actor,
|
|
19
|
+
resource: entry.resource,
|
|
20
|
+
outcome: entry.outcome,
|
|
21
|
+
previousHash,
|
|
22
|
+
};
|
|
23
|
+
if (entry.metadata !== undefined)
|
|
24
|
+
payload["metadata"] = entry.metadata;
|
|
25
|
+
if (entry.tenantId !== undefined)
|
|
26
|
+
payload["tenantId"] = entry.tenantId;
|
|
27
|
+
if (entry.sessionId !== undefined)
|
|
28
|
+
payload["sessionId"] = entry.sessionId;
|
|
29
|
+
const content = canonicalJson(payload);
|
|
30
|
+
return createHash("sha256").update(content).digest("hex");
|
|
31
|
+
}
|
|
32
|
+
/** Serialize an AuditEntry to a JSON line for file storage */
|
|
33
|
+
function serializeEntry(entry) {
|
|
34
|
+
const obj = {
|
|
35
|
+
id: entry.id,
|
|
36
|
+
timestamp: entry.timestamp instanceof Date ? entry.timestamp.toISOString() : entry.timestamp,
|
|
37
|
+
action: entry.action,
|
|
38
|
+
actor: entry.actor,
|
|
39
|
+
resource: entry.resource,
|
|
40
|
+
outcome: entry.outcome,
|
|
41
|
+
};
|
|
42
|
+
if (entry.metadata !== undefined)
|
|
43
|
+
obj["metadata"] = entry.metadata;
|
|
44
|
+
if (entry.tenantId !== undefined)
|
|
45
|
+
obj["tenantId"] = entry.tenantId;
|
|
46
|
+
if (entry.sessionId !== undefined)
|
|
47
|
+
obj["sessionId"] = entry.sessionId;
|
|
48
|
+
if (entry.hash !== undefined)
|
|
49
|
+
obj["hash"] = entry.hash;
|
|
50
|
+
if (entry.previousHash !== undefined)
|
|
51
|
+
obj["previousHash"] = entry.previousHash;
|
|
52
|
+
return JSON.stringify(obj);
|
|
53
|
+
}
|
|
54
|
+
/** Deserialize a JSON line back to an AuditEntry */
|
|
55
|
+
function deserializeEntry(line) {
|
|
56
|
+
const obj = JSON.parse(line);
|
|
57
|
+
return {
|
|
58
|
+
id: obj["id"],
|
|
59
|
+
timestamp: new Date(obj["timestamp"]),
|
|
60
|
+
action: obj["action"],
|
|
61
|
+
actor: obj["actor"],
|
|
62
|
+
resource: obj["resource"],
|
|
63
|
+
outcome: obj["outcome"],
|
|
64
|
+
metadata: obj["metadata"],
|
|
65
|
+
tenantId: obj["tenantId"],
|
|
66
|
+
sessionId: obj["sessionId"],
|
|
67
|
+
hash: obj["hash"],
|
|
68
|
+
previousHash: obj["previousHash"],
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
export class JsonlAuditLog {
|
|
72
|
+
logPath;
|
|
73
|
+
hashChaining;
|
|
74
|
+
lastHash;
|
|
75
|
+
entryCount;
|
|
76
|
+
constructor(logPath, options) {
|
|
77
|
+
this.logPath = logPath;
|
|
78
|
+
this.hashChaining = options?.hashChaining ?? true;
|
|
79
|
+
// Ensure directory exists
|
|
80
|
+
const dir = dirname(logPath);
|
|
81
|
+
mkdirSync(dir, { recursive: true });
|
|
82
|
+
// Initialize from existing file or create empty
|
|
83
|
+
if (existsSync(logPath)) {
|
|
84
|
+
const { count, lastHash } = this.loadState();
|
|
85
|
+
this.entryCount = count;
|
|
86
|
+
this.lastHash = lastHash;
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
writeFileSync(logPath, "", "utf-8");
|
|
90
|
+
this.entryCount = 0;
|
|
91
|
+
this.lastHash = GENESIS_HASH;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
append(entry) {
|
|
95
|
+
const id = crypto.randomUUID();
|
|
96
|
+
const previousHash = this.lastHash;
|
|
97
|
+
const fullEntry = {
|
|
98
|
+
...entry,
|
|
99
|
+
id,
|
|
100
|
+
timestamp: entry.timestamp instanceof Date ? entry.timestamp : new Date(entry.timestamp),
|
|
101
|
+
previousHash: this.hashChaining ? previousHash : undefined,
|
|
102
|
+
hash: undefined,
|
|
103
|
+
};
|
|
104
|
+
const hash = this.hashChaining
|
|
105
|
+
? computeHash(fullEntry, previousHash)
|
|
106
|
+
: undefined;
|
|
107
|
+
const finalEntry = {
|
|
108
|
+
...fullEntry,
|
|
109
|
+
hash,
|
|
110
|
+
};
|
|
111
|
+
try {
|
|
112
|
+
const line = serializeEntry(finalEntry) + "\n";
|
|
113
|
+
appendFileSync(this.logPath, line, "utf-8");
|
|
114
|
+
}
|
|
115
|
+
catch (err) {
|
|
116
|
+
throw new KilnError("AUDIT_WRITE_FAILED", "Failed to write audit log entry", {
|
|
117
|
+
context: { id, action: entry.action },
|
|
118
|
+
cause: err,
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
if (this.hashChaining && hash) {
|
|
122
|
+
this.lastHash = hash;
|
|
123
|
+
}
|
|
124
|
+
this.entryCount++;
|
|
125
|
+
return finalEntry;
|
|
126
|
+
}
|
|
127
|
+
query(filter) {
|
|
128
|
+
const entries = this.readAllEntries();
|
|
129
|
+
let filtered = entries;
|
|
130
|
+
if (filter.action) {
|
|
131
|
+
filtered = filtered.filter((e) => e.action === filter.action);
|
|
132
|
+
}
|
|
133
|
+
if (filter.actor) {
|
|
134
|
+
filtered = filtered.filter((e) => e.actor === filter.actor);
|
|
135
|
+
}
|
|
136
|
+
if (filter.tenantId) {
|
|
137
|
+
filtered = filtered.filter((e) => e.tenantId === filter.tenantId);
|
|
138
|
+
}
|
|
139
|
+
if (filter.outcome) {
|
|
140
|
+
filtered = filtered.filter((e) => e.outcome === filter.outcome);
|
|
141
|
+
}
|
|
142
|
+
if (filter.since) {
|
|
143
|
+
const since = filter.since.getTime();
|
|
144
|
+
filtered = filtered.filter((e) => e.timestamp.getTime() >= since);
|
|
145
|
+
}
|
|
146
|
+
if (filter.until) {
|
|
147
|
+
const until = filter.until.getTime();
|
|
148
|
+
filtered = filtered.filter((e) => e.timestamp.getTime() <= until);
|
|
149
|
+
}
|
|
150
|
+
if (filter.limit !== undefined && filter.limit > 0) {
|
|
151
|
+
filtered = filtered.slice(0, filter.limit);
|
|
152
|
+
}
|
|
153
|
+
return filtered;
|
|
154
|
+
}
|
|
155
|
+
verifyChain(fromIndex, toIndex) {
|
|
156
|
+
if (!this.hashChaining) {
|
|
157
|
+
return { valid: true, entriesChecked: 0 };
|
|
158
|
+
}
|
|
159
|
+
const entries = this.readAllEntries();
|
|
160
|
+
const start = fromIndex ?? 0;
|
|
161
|
+
const end = toIndex !== undefined ? Math.min(toIndex + 1, entries.length) : entries.length;
|
|
162
|
+
if (entries.length === 0) {
|
|
163
|
+
return { valid: true, entriesChecked: 0 };
|
|
164
|
+
}
|
|
165
|
+
for (let i = start; i < end; i++) {
|
|
166
|
+
const entry = entries[i];
|
|
167
|
+
const expectedPreviousHash = i === 0 ? GENESIS_HASH : entries[i - 1].hash;
|
|
168
|
+
if (entry.previousHash !== expectedPreviousHash) {
|
|
169
|
+
return {
|
|
170
|
+
valid: false,
|
|
171
|
+
entriesChecked: i - start + 1,
|
|
172
|
+
brokenAt: i,
|
|
173
|
+
error: `Chain broken at index ${i}: previousHash mismatch`,
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
const recomputedHash = computeHash(entry, expectedPreviousHash);
|
|
177
|
+
if (entry.hash !== recomputedHash) {
|
|
178
|
+
return {
|
|
179
|
+
valid: false,
|
|
180
|
+
entriesChecked: i - start + 1,
|
|
181
|
+
brokenAt: i,
|
|
182
|
+
error: `Chain broken at index ${i}: hash mismatch (tampered entry)`,
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
return { valid: true, entriesChecked: end - start };
|
|
187
|
+
}
|
|
188
|
+
count() {
|
|
189
|
+
return this.entryCount;
|
|
190
|
+
}
|
|
191
|
+
readAllEntries() {
|
|
192
|
+
if (!existsSync(this.logPath))
|
|
193
|
+
return [];
|
|
194
|
+
const content = readFileSync(this.logPath, "utf-8").trim();
|
|
195
|
+
if (content.length === 0)
|
|
196
|
+
return [];
|
|
197
|
+
return content
|
|
198
|
+
.split("\n")
|
|
199
|
+
.filter((line) => line.trim().length > 0)
|
|
200
|
+
.map(deserializeEntry);
|
|
201
|
+
}
|
|
202
|
+
loadState() {
|
|
203
|
+
const entries = this.readAllEntries();
|
|
204
|
+
if (entries.length === 0) {
|
|
205
|
+
return { count: 0, lastHash: GENESIS_HASH };
|
|
206
|
+
}
|
|
207
|
+
const lastEntry = entries[entries.length - 1];
|
|
208
|
+
return {
|
|
209
|
+
count: entries.length,
|
|
210
|
+
lastHash: lastEntry.hash ?? GENESIS_HASH,
|
|
211
|
+
};
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
//# sourceMappingURL=audit-log.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit-log.js","sourceRoot":"","sources":["../../src/security/audit-log.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { EventBus } from "../events/index.js";
|
|
2
|
+
import type { Capability } from "../engine/domain/capability.js";
|
|
3
|
+
import type { ProviderAdapter } from "../agents/index.js";
|
|
4
|
+
import type { AuditLog, GuardianConfig, GuardianReviewResult } from "./types.js";
|
|
5
|
+
export interface GuardianRequest {
|
|
6
|
+
readonly capability: Capability;
|
|
7
|
+
readonly agentName: string;
|
|
8
|
+
readonly arguments: Record<string, unknown>;
|
|
9
|
+
readonly context?: string;
|
|
10
|
+
readonly sessionId?: string;
|
|
11
|
+
readonly tenantId?: string;
|
|
12
|
+
}
|
|
13
|
+
export declare class Guardian {
|
|
14
|
+
private readonly config;
|
|
15
|
+
private readonly provider;
|
|
16
|
+
private readonly eventBus?;
|
|
17
|
+
private readonly auditLog?;
|
|
18
|
+
constructor(config: GuardianConfig, provider: ProviderAdapter, eventBus?: EventBus, auditLog?: AuditLog);
|
|
19
|
+
/** Check if a capability needs Guardian review */
|
|
20
|
+
needsReview(capability: Capability): boolean;
|
|
21
|
+
/** Review a capability execution request */
|
|
22
|
+
review(request: GuardianRequest): Promise<GuardianReviewResult>;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=guardian.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"guardian.d.ts","sourceRoot":"","sources":["../../src/security/guardian.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAyB,MAAM,oBAAoB,CAAC;AAC1E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAE1D,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAEjF,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAC;IAChC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC5C,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;CAC5B;AAsED,qBAAa,QAAQ;IACnB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiB;IACxC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAkB;IAC3C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAW;IACrC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAW;gBAGnC,MAAM,EAAE,cAAc,EACtB,QAAQ,EAAE,eAAe,EACzB,QAAQ,CAAC,EAAE,QAAQ,EACnB,QAAQ,CAAC,EAAE,QAAQ;IAQrB,kDAAkD;IAClD,WAAW,CAAC,UAAU,EAAE,UAAU,GAAG,OAAO;IAY5C,4CAA4C;IACtC,MAAM,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,oBAAoB,CAAC;CAiGtE"}
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
// Guardian: secondary LLM review for destructive capability execution
|
|
2
|
+
import { textParts, extractText } from "../engine/domain/content.js";
|
|
3
|
+
function buildReviewPrompt(request) {
|
|
4
|
+
const { capability, agentName, arguments: args, context } = request;
|
|
5
|
+
return `You are a security reviewer. Evaluate whether this action should be allowed.
|
|
6
|
+
|
|
7
|
+
Action: ${capability.name} - ${capability.description}
|
|
8
|
+
Requested by: ${agentName}
|
|
9
|
+
Arguments: ${JSON.stringify(args)}
|
|
10
|
+
Context: ${context ?? "none"}
|
|
11
|
+
|
|
12
|
+
Safety annotations:
|
|
13
|
+
- Destructive: ${capability.annotations?.destructive}
|
|
14
|
+
- Idempotent: ${capability.annotations?.idempotent}
|
|
15
|
+
|
|
16
|
+
Respond with JSON only:
|
|
17
|
+
{"approved": boolean, "reason": "explanation", "riskLevel": "low" | "medium" | "high" | "critical"}
|
|
18
|
+
|
|
19
|
+
Deny if:
|
|
20
|
+
- Arguments contain paths outside expected scope
|
|
21
|
+
- Arguments contain shell injection patterns
|
|
22
|
+
- The action could cause irreversible data loss
|
|
23
|
+
- The action modifies system-level configuration
|
|
24
|
+
- The arguments seem crafted to bypass safety
|
|
25
|
+
|
|
26
|
+
Approve if:
|
|
27
|
+
- The action is within expected scope
|
|
28
|
+
- Arguments are well-formed and within normal ranges
|
|
29
|
+
- The action is reversible or has safeguards`;
|
|
30
|
+
}
|
|
31
|
+
function parseReviewerResponse(content) {
|
|
32
|
+
try {
|
|
33
|
+
// Strip markdown code fences if present
|
|
34
|
+
const cleaned = content.replace(/```(?:json)?\n?/g, "").trim();
|
|
35
|
+
const parsed = JSON.parse(cleaned);
|
|
36
|
+
if (parsed !== null &&
|
|
37
|
+
typeof parsed === "object" &&
|
|
38
|
+
"approved" in parsed &&
|
|
39
|
+
typeof parsed["approved"] === "boolean" &&
|
|
40
|
+
"reason" in parsed &&
|
|
41
|
+
typeof parsed["reason"] === "string" &&
|
|
42
|
+
"riskLevel" in parsed &&
|
|
43
|
+
typeof parsed["riskLevel"] === "string") {
|
|
44
|
+
return parsed;
|
|
45
|
+
}
|
|
46
|
+
return null;
|
|
47
|
+
}
|
|
48
|
+
catch {
|
|
49
|
+
return null;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
function truncateArgValues(args) {
|
|
53
|
+
const result = {};
|
|
54
|
+
for (const [key, value] of Object.entries(args)) {
|
|
55
|
+
const str = typeof value === "string" ? value : JSON.stringify(value);
|
|
56
|
+
result[key] = str.length > 100 ? str.slice(0, 100) + "..." : str;
|
|
57
|
+
}
|
|
58
|
+
return result;
|
|
59
|
+
}
|
|
60
|
+
export class Guardian {
|
|
61
|
+
config;
|
|
62
|
+
provider;
|
|
63
|
+
eventBus;
|
|
64
|
+
auditLog;
|
|
65
|
+
constructor(config, provider, eventBus, auditLog) {
|
|
66
|
+
this.config = config;
|
|
67
|
+
this.provider = provider;
|
|
68
|
+
this.eventBus = eventBus;
|
|
69
|
+
this.auditLog = auditLog;
|
|
70
|
+
}
|
|
71
|
+
/** Check if a capability needs Guardian review */
|
|
72
|
+
needsReview(capability) {
|
|
73
|
+
if (!this.config.enabled)
|
|
74
|
+
return false;
|
|
75
|
+
if (capability.annotations?.readOnly === true &&
|
|
76
|
+
this.config.bypassForReadOnly === true) {
|
|
77
|
+
return false;
|
|
78
|
+
}
|
|
79
|
+
if (capability.annotations?.destructive === true)
|
|
80
|
+
return true;
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
/** Review a capability execution request */
|
|
84
|
+
async review(request) {
|
|
85
|
+
const startedAt = Date.now();
|
|
86
|
+
const sessionId = request.sessionId ?? "unknown";
|
|
87
|
+
let approved;
|
|
88
|
+
let reason;
|
|
89
|
+
let riskLevel;
|
|
90
|
+
try {
|
|
91
|
+
const prompt = buildReviewPrompt(request);
|
|
92
|
+
const response = await this.provider.createMessage({
|
|
93
|
+
system: "You are a security reviewer that evaluates capability execution requests.",
|
|
94
|
+
messages: [{ role: "user", parts: textParts(prompt) }],
|
|
95
|
+
});
|
|
96
|
+
const parsed = parseReviewerResponse(extractText(response.parts));
|
|
97
|
+
if (parsed === null) {
|
|
98
|
+
// Malformed response -- treat as blockOnError
|
|
99
|
+
if (this.config.blockOnError) {
|
|
100
|
+
approved = false;
|
|
101
|
+
reason = "Guardian reviewer returned malformed response";
|
|
102
|
+
riskLevel = "critical";
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
approved = true;
|
|
106
|
+
reason = "Guardian reviewer returned malformed response, proceeding";
|
|
107
|
+
riskLevel = "high";
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
approved = parsed.approved;
|
|
112
|
+
reason = parsed.reason;
|
|
113
|
+
const validLevels = ["low", "medium", "high", "critical"];
|
|
114
|
+
riskLevel = validLevels.includes(parsed.riskLevel)
|
|
115
|
+
? parsed.riskLevel
|
|
116
|
+
: "high";
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
catch {
|
|
120
|
+
if (this.config.blockOnError) {
|
|
121
|
+
approved = false;
|
|
122
|
+
reason = "Guardian reviewer unavailable";
|
|
123
|
+
riskLevel = "critical";
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
approved = true;
|
|
127
|
+
reason = "Guardian reviewer unavailable, proceeding";
|
|
128
|
+
riskLevel = "high";
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
const reviewDurationMs = Date.now() - startedAt;
|
|
132
|
+
const result = {
|
|
133
|
+
approved,
|
|
134
|
+
reason,
|
|
135
|
+
reviewedBy: this.provider.name,
|
|
136
|
+
reviewDurationMs,
|
|
137
|
+
riskLevel,
|
|
138
|
+
capabilityName: request.capability.name,
|
|
139
|
+
agentName: request.agentName,
|
|
140
|
+
};
|
|
141
|
+
// Emit event
|
|
142
|
+
if (this.eventBus) {
|
|
143
|
+
const event = {
|
|
144
|
+
type: "guardian_reviewed",
|
|
145
|
+
timestamp: new Date(),
|
|
146
|
+
sessionId,
|
|
147
|
+
approved,
|
|
148
|
+
capabilityName: request.capability.name,
|
|
149
|
+
agentName: request.agentName,
|
|
150
|
+
riskLevel,
|
|
151
|
+
reason,
|
|
152
|
+
};
|
|
153
|
+
this.eventBus.emit(event);
|
|
154
|
+
}
|
|
155
|
+
// Audit log
|
|
156
|
+
if (this.auditLog) {
|
|
157
|
+
this.auditLog.append({
|
|
158
|
+
timestamp: new Date(),
|
|
159
|
+
action: approved ? "destructive_approved" : "destructive_blocked",
|
|
160
|
+
actor: request.agentName,
|
|
161
|
+
resource: request.capability.name,
|
|
162
|
+
outcome: approved ? "allowed" : "denied",
|
|
163
|
+
metadata: {
|
|
164
|
+
riskLevel,
|
|
165
|
+
reason,
|
|
166
|
+
reviewedBy: this.provider.name,
|
|
167
|
+
reviewDurationMs,
|
|
168
|
+
arguments: truncateArgValues(request.arguments),
|
|
169
|
+
},
|
|
170
|
+
tenantId: request.tenantId,
|
|
171
|
+
sessionId: request.sessionId,
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
return result;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
//# sourceMappingURL=guardian.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"guardian.js","sourceRoot":"","sources":["../../src/security/guardian.ts"],"names":[],"mappings":"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"}
|