@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,33 @@
|
|
|
1
|
+
import type { RailConfig, TopicRailConfig, CompetitorRailConfig, EscalationRailConfig, ComplianceRailConfig } from "../engine/domain/safety-config.js";
|
|
2
|
+
import type { PolicyResult, SafetyDirection } from "./types.js";
|
|
3
|
+
/** Interface for a policy rail that evaluates messages */
|
|
4
|
+
export interface PolicyRail {
|
|
5
|
+
evaluate(text: string, direction: SafetyDirection): PolicyResult;
|
|
6
|
+
}
|
|
7
|
+
/** Case-insensitive keyword match against block/escalate arrays */
|
|
8
|
+
export declare class TopicRail implements PolicyRail {
|
|
9
|
+
private readonly config;
|
|
10
|
+
constructor(config: TopicRailConfig);
|
|
11
|
+
evaluate(text: string, _direction: SafetyDirection): PolicyResult;
|
|
12
|
+
}
|
|
13
|
+
/** Checks for competitor names in message */
|
|
14
|
+
export declare class CompetitorRail implements PolicyRail {
|
|
15
|
+
private readonly config;
|
|
16
|
+
constructor(config: CompetitorRailConfig);
|
|
17
|
+
evaluate(text: string, _direction: SafetyDirection): PolicyResult;
|
|
18
|
+
}
|
|
19
|
+
/** Always allowed, but sets escalate flag when triggers match */
|
|
20
|
+
export declare class EscalationRail implements PolicyRail {
|
|
21
|
+
private readonly config;
|
|
22
|
+
constructor(config: EscalationRailConfig);
|
|
23
|
+
evaluate(text: string, _direction: SafetyDirection): PolicyResult;
|
|
24
|
+
}
|
|
25
|
+
/** On output: checks required present + forbid absent. On input: always allowed */
|
|
26
|
+
export declare class ComplianceRail implements PolicyRail {
|
|
27
|
+
private readonly config;
|
|
28
|
+
constructor(config: ComplianceRailConfig);
|
|
29
|
+
evaluate(text: string, direction: SafetyDirection): PolicyResult;
|
|
30
|
+
}
|
|
31
|
+
/** Factory: creates the appropriate rail from config */
|
|
32
|
+
export declare function createRail(config: RailConfig): PolicyRail;
|
|
33
|
+
//# sourceMappingURL=rails.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rails.d.ts","sourceRoot":"","sources":["../../src/safety/rails.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,eAAe,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;AACvJ,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAEhE,0DAA0D;AAC1D,MAAM,WAAW,UAAU;IACzB,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,eAAe,GAAG,YAAY,CAAC;CAClE;AAED,mEAAmE;AACnE,qBAAa,SAAU,YAAW,UAAU;IAC1C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAkB;gBAE7B,MAAM,EAAE,eAAe;IAInC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,eAAe,GAAG,YAAY;CAgClE;AAED,6CAA6C;AAC7C,qBAAa,cAAe,YAAW,UAAU;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAuB;gBAElC,MAAM,EAAE,oBAAoB;IAIxC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,eAAe,GAAG,YAAY;CAgBlE;AAED,iEAAiE;AACjE,qBAAa,cAAe,YAAW,UAAU;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAuB;gBAElC,MAAM,EAAE,oBAAoB;IAIxC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,eAAe,GAAG,YAAY;CAgBlE;AAED,mFAAmF;AACnF,qBAAa,cAAe,YAAW,UAAU;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAuB;gBAElC,MAAM,EAAE,oBAAoB;IAIxC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,eAAe,GAAG,YAAY;CAqCjE;AAED,wDAAwD;AACxD,wBAAgB,UAAU,CAAC,MAAM,EAAE,UAAU,GAAG,UAAU,CAWzD"}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
// Policy Rails: topic, competitor, escalation, compliance guardrails
|
|
2
|
+
/** Case-insensitive keyword match against block/escalate arrays */
|
|
3
|
+
export class TopicRail {
|
|
4
|
+
config;
|
|
5
|
+
constructor(config) {
|
|
6
|
+
this.config = config;
|
|
7
|
+
}
|
|
8
|
+
evaluate(text, _direction) {
|
|
9
|
+
const lower = text.toLowerCase();
|
|
10
|
+
// Check blocked topics
|
|
11
|
+
if (this.config.block) {
|
|
12
|
+
for (const topic of this.config.block) {
|
|
13
|
+
if (lower.includes(topic.toLowerCase())) {
|
|
14
|
+
return {
|
|
15
|
+
allowed: false,
|
|
16
|
+
railType: "topic",
|
|
17
|
+
reason: `Blocked topic detected: ${topic}`,
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
// Check escalation topics
|
|
23
|
+
if (this.config.escalate) {
|
|
24
|
+
for (const topic of this.config.escalate) {
|
|
25
|
+
if (lower.includes(topic.toLowerCase())) {
|
|
26
|
+
return {
|
|
27
|
+
allowed: true,
|
|
28
|
+
railType: "topic",
|
|
29
|
+
reason: `Escalation topic detected: ${topic}`,
|
|
30
|
+
escalate: true,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return { allowed: true, railType: "topic" };
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
/** Checks for competitor names in message */
|
|
39
|
+
export class CompetitorRail {
|
|
40
|
+
config;
|
|
41
|
+
constructor(config) {
|
|
42
|
+
this.config = config;
|
|
43
|
+
}
|
|
44
|
+
evaluate(text, _direction) {
|
|
45
|
+
const lower = text.toLowerCase();
|
|
46
|
+
for (const competitor of this.config.competitors) {
|
|
47
|
+
if (lower.includes(competitor.toLowerCase())) {
|
|
48
|
+
return {
|
|
49
|
+
allowed: false,
|
|
50
|
+
railType: "competitor",
|
|
51
|
+
reason: `Competitor mentioned: ${competitor}`,
|
|
52
|
+
suggestion: this.config.response,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return { allowed: true, railType: "competitor" };
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
/** Always allowed, but sets escalate flag when triggers match */
|
|
60
|
+
export class EscalationRail {
|
|
61
|
+
config;
|
|
62
|
+
constructor(config) {
|
|
63
|
+
this.config = config;
|
|
64
|
+
}
|
|
65
|
+
evaluate(text, _direction) {
|
|
66
|
+
const lower = text.toLowerCase();
|
|
67
|
+
for (const trigger of this.config.triggers) {
|
|
68
|
+
if (lower.includes(trigger.toLowerCase())) {
|
|
69
|
+
return {
|
|
70
|
+
allowed: true,
|
|
71
|
+
railType: "escalation",
|
|
72
|
+
reason: `Escalation trigger detected: ${trigger}`,
|
|
73
|
+
escalate: true,
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
return { allowed: true, railType: "escalation" };
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/** On output: checks required present + forbid absent. On input: always allowed */
|
|
81
|
+
export class ComplianceRail {
|
|
82
|
+
config;
|
|
83
|
+
constructor(config) {
|
|
84
|
+
this.config = config;
|
|
85
|
+
}
|
|
86
|
+
evaluate(text, direction) {
|
|
87
|
+
// Compliance only applies to output
|
|
88
|
+
if (direction === "input") {
|
|
89
|
+
return { allowed: true, railType: "compliance" };
|
|
90
|
+
}
|
|
91
|
+
// Check forbidden phrases
|
|
92
|
+
if (this.config.forbid) {
|
|
93
|
+
const lower = text.toLowerCase();
|
|
94
|
+
for (const phrase of this.config.forbid) {
|
|
95
|
+
if (lower.includes(phrase.toLowerCase())) {
|
|
96
|
+
return {
|
|
97
|
+
allowed: false,
|
|
98
|
+
railType: "compliance",
|
|
99
|
+
reason: `Forbidden phrase detected: ${phrase}`,
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
// Check required phrases
|
|
105
|
+
if (this.config.required) {
|
|
106
|
+
const lower = text.toLowerCase();
|
|
107
|
+
for (const phrase of this.config.required) {
|
|
108
|
+
if (!lower.includes(phrase.toLowerCase())) {
|
|
109
|
+
return {
|
|
110
|
+
allowed: false,
|
|
111
|
+
railType: "compliance",
|
|
112
|
+
reason: `Required phrase missing: ${phrase}`,
|
|
113
|
+
suggestion: `Include: "${phrase}"`,
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
return { allowed: true, railType: "compliance" };
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
/** Factory: creates the appropriate rail from config */
|
|
122
|
+
export function createRail(config) {
|
|
123
|
+
switch (config.type) {
|
|
124
|
+
case "topic":
|
|
125
|
+
return new TopicRail(config);
|
|
126
|
+
case "competitor":
|
|
127
|
+
return new CompetitorRail(config);
|
|
128
|
+
case "escalation":
|
|
129
|
+
return new EscalationRail(config);
|
|
130
|
+
case "compliance":
|
|
131
|
+
return new ComplianceRail(config);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
//# sourceMappingURL=rails.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rails.js","sourceRoot":"","sources":["../../src/safety/rails.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { SafetyConfig } from "../engine/domain/safety-config.js";
|
|
2
|
+
import type { SafetyDirection, SafetyPipelineResult } from "./types.js";
|
|
3
|
+
import type { PiiDeepScanProvider } from "./pii-scanner.js";
|
|
4
|
+
import type { ContentDeepScanProvider } from "./content-classifier.js";
|
|
5
|
+
export interface SafetyPipelineOptions {
|
|
6
|
+
readonly piiProvider?: PiiDeepScanProvider;
|
|
7
|
+
readonly contentProvider?: ContentDeepScanProvider;
|
|
8
|
+
}
|
|
9
|
+
export interface SafetyMetrics {
|
|
10
|
+
readonly scansInput: number;
|
|
11
|
+
readonly scansOutput: number;
|
|
12
|
+
readonly blocksInput: number;
|
|
13
|
+
readonly blocksOutput: number;
|
|
14
|
+
readonly piiDetections: number;
|
|
15
|
+
readonly contentBlocks: number;
|
|
16
|
+
readonly policyEvaluations: number;
|
|
17
|
+
}
|
|
18
|
+
export declare class SafetyPipeline {
|
|
19
|
+
private readonly config;
|
|
20
|
+
private readonly piiScanner?;
|
|
21
|
+
private readonly contentClassifier?;
|
|
22
|
+
private readonly rails;
|
|
23
|
+
private _scansInput;
|
|
24
|
+
private _scansOutput;
|
|
25
|
+
private _blocksInput;
|
|
26
|
+
private _blocksOutput;
|
|
27
|
+
private _piiDetections;
|
|
28
|
+
private _contentBlocks;
|
|
29
|
+
private _policyEvaluations;
|
|
30
|
+
constructor(config: SafetyConfig);
|
|
31
|
+
get metrics(): SafetyMetrics;
|
|
32
|
+
/**
|
|
33
|
+
* Evaluate text through the full safety pipeline.
|
|
34
|
+
* Order: PII scan -> content classification -> policy rails.
|
|
35
|
+
* Short-circuits on block: if PII blocks, content/rails don't run.
|
|
36
|
+
* Redacted text carries forward through subsequent steps.
|
|
37
|
+
*/
|
|
38
|
+
evaluate(text: string, direction: SafetyDirection, options?: SafetyPipelineOptions): Promise<SafetyPipelineResult>;
|
|
39
|
+
private evaluateContentAndRails;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=safety-pipeline.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"safety-pipeline.d.ts","sourceRoot":"","sources":["../../src/safety/safety-pipeline.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AACtE,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAgB,MAAM,YAAY,CAAC;AAEtF,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAE5D,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAIvE,MAAM,WAAW,qBAAqB;IACpC,QAAQ,CAAC,WAAW,CAAC,EAAE,mBAAmB,CAAC;IAC3C,QAAQ,CAAC,eAAe,CAAC,EAAE,uBAAuB,CAAC;CACpD;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,iBAAiB,EAAE,MAAM,CAAC;CACpC;AAED,qBAAa,cAAc;IACzB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAe;IACtC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAa;IACzC,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAoB;IACvD,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAwB;IAE9C,OAAO,CAAC,WAAW,CAAK;IACxB,OAAO,CAAC,YAAY,CAAK;IACzB,OAAO,CAAC,YAAY,CAAK;IACzB,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,cAAc,CAAK;IAC3B,OAAO,CAAC,cAAc,CAAK;IAC3B,OAAO,CAAC,kBAAkB,CAAK;gBAEnB,MAAM,EAAE,YAAY;IAchC,IAAI,OAAO,IAAI,aAAa,CAU3B;IAED;;;;;OAKG;IACG,QAAQ,CACZ,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE,eAAe,EAC1B,OAAO,CAAC,EAAE,qBAAqB,GAC9B,OAAO,CAAC,oBAAoB,CAAC;YA0ElB,uBAAuB;CA8CtC"}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
// Safety Pipeline: orchestrates PII scanning, content classification, and policy rails
|
|
2
|
+
import { PiiScanner } from "./pii-scanner.js";
|
|
3
|
+
import { ContentClassifier } from "./content-classifier.js";
|
|
4
|
+
import { createRail } from "./rails.js";
|
|
5
|
+
export class SafetyPipeline {
|
|
6
|
+
config;
|
|
7
|
+
piiScanner;
|
|
8
|
+
contentClassifier;
|
|
9
|
+
rails;
|
|
10
|
+
_scansInput = 0;
|
|
11
|
+
_scansOutput = 0;
|
|
12
|
+
_blocksInput = 0;
|
|
13
|
+
_blocksOutput = 0;
|
|
14
|
+
_piiDetections = 0;
|
|
15
|
+
_contentBlocks = 0;
|
|
16
|
+
_policyEvaluations = 0;
|
|
17
|
+
constructor(config) {
|
|
18
|
+
this.config = config;
|
|
19
|
+
if (config.pii) {
|
|
20
|
+
this.piiScanner = new PiiScanner(config.pii);
|
|
21
|
+
}
|
|
22
|
+
if (config.content?.enabled) {
|
|
23
|
+
this.contentClassifier = new ContentClassifier(config.content);
|
|
24
|
+
}
|
|
25
|
+
this.rails = (config.rails ?? []).map(createRail);
|
|
26
|
+
}
|
|
27
|
+
get metrics() {
|
|
28
|
+
return {
|
|
29
|
+
scansInput: this._scansInput,
|
|
30
|
+
scansOutput: this._scansOutput,
|
|
31
|
+
blocksInput: this._blocksInput,
|
|
32
|
+
blocksOutput: this._blocksOutput,
|
|
33
|
+
piiDetections: this._piiDetections,
|
|
34
|
+
contentBlocks: this._contentBlocks,
|
|
35
|
+
policyEvaluations: this._policyEvaluations,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Evaluate text through the full safety pipeline.
|
|
40
|
+
* Order: PII scan -> content classification -> policy rails.
|
|
41
|
+
* Short-circuits on block: if PII blocks, content/rails don't run.
|
|
42
|
+
* Redacted text carries forward through subsequent steps.
|
|
43
|
+
*/
|
|
44
|
+
async evaluate(text, direction, options) {
|
|
45
|
+
if (direction === "input") {
|
|
46
|
+
this._scansInput++;
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
this._scansOutput++;
|
|
50
|
+
}
|
|
51
|
+
let currentText = text;
|
|
52
|
+
const policyResults = [];
|
|
53
|
+
// 1. PII scan
|
|
54
|
+
if (this.piiScanner) {
|
|
55
|
+
const piiResult = await this.piiScanner.scan(currentText, options?.piiProvider);
|
|
56
|
+
if (piiResult.matches.length > 0) {
|
|
57
|
+
this._piiDetections++;
|
|
58
|
+
const action = this.config.pii.action;
|
|
59
|
+
if (action === "block") {
|
|
60
|
+
if (direction === "input") {
|
|
61
|
+
this._blocksInput++;
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
this._blocksOutput++;
|
|
65
|
+
}
|
|
66
|
+
return {
|
|
67
|
+
allowed: false,
|
|
68
|
+
pii: piiResult,
|
|
69
|
+
policyResults: [],
|
|
70
|
+
blockReason: `PII detected: ${piiResult.matches.map((m) => m.type).join(", ")}`,
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
if (action === "redact") {
|
|
74
|
+
currentText = this.piiScanner.redact(currentText, piiResult.matches);
|
|
75
|
+
const result = await this.evaluateContentAndRails(currentText, direction, options, policyResults);
|
|
76
|
+
if (!result.allowed) {
|
|
77
|
+
if (direction === "input") {
|
|
78
|
+
this._blocksInput++;
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
this._blocksOutput++;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return {
|
|
85
|
+
...result,
|
|
86
|
+
redactedText: currentText,
|
|
87
|
+
pii: piiResult,
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
// action === "detect" -- just record, continue with original text
|
|
91
|
+
const result = await this.evaluateContentAndRails(currentText, direction, options, policyResults);
|
|
92
|
+
if (!result.allowed) {
|
|
93
|
+
if (direction === "input") {
|
|
94
|
+
this._blocksInput++;
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
this._blocksOutput++;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return { ...result, pii: piiResult };
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
// No PII found or no PII config -- continue to content + rails
|
|
104
|
+
const result = await this.evaluateContentAndRails(currentText, direction, options, policyResults);
|
|
105
|
+
if (!result.allowed) {
|
|
106
|
+
if (direction === "input") {
|
|
107
|
+
this._blocksInput++;
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
this._blocksOutput++;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
return result;
|
|
114
|
+
}
|
|
115
|
+
async evaluateContentAndRails(text, direction, options, policyResults) {
|
|
116
|
+
// 2. Content classification
|
|
117
|
+
let contentResult;
|
|
118
|
+
if (this.contentClassifier) {
|
|
119
|
+
contentResult = await this.contentClassifier.classify(text, options?.contentProvider);
|
|
120
|
+
const violations = this.contentClassifier.evaluateThresholds(contentResult.scores);
|
|
121
|
+
const blocked = violations.some((v) => v.action === "block");
|
|
122
|
+
if (blocked) {
|
|
123
|
+
this._contentBlocks++;
|
|
124
|
+
return {
|
|
125
|
+
allowed: false,
|
|
126
|
+
content: contentResult,
|
|
127
|
+
policyResults,
|
|
128
|
+
blockReason: `Content policy violated: ${violations.filter((v) => v.action === "block").map((v) => v.category).join(", ")}`,
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
// 3. Policy rails -- evaluate all, short-circuit on first block
|
|
133
|
+
for (const rail of this.rails) {
|
|
134
|
+
this._policyEvaluations++;
|
|
135
|
+
const result = rail.evaluate(text, direction);
|
|
136
|
+
policyResults.push(result);
|
|
137
|
+
if (!result.allowed) {
|
|
138
|
+
return {
|
|
139
|
+
allowed: false,
|
|
140
|
+
content: contentResult,
|
|
141
|
+
policyResults,
|
|
142
|
+
blockReason: result.reason ?? `Blocked by ${result.railType} rail`,
|
|
143
|
+
};
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
return {
|
|
147
|
+
allowed: true,
|
|
148
|
+
...(contentResult ? { content: contentResult } : {}),
|
|
149
|
+
policyResults,
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
//# sourceMappingURL=safety-pipeline.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"safety-pipeline.js","sourceRoot":"","sources":["../../src/safety/safety-pipeline.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { PiiType, ContentCategory, RailType } from "../engine/domain/safety-config.js";
|
|
2
|
+
export interface PiiMatch {
|
|
3
|
+
readonly type: PiiType;
|
|
4
|
+
readonly value: string;
|
|
5
|
+
readonly startIndex: number;
|
|
6
|
+
readonly endIndex: number;
|
|
7
|
+
}
|
|
8
|
+
export interface PiiScanResult {
|
|
9
|
+
readonly matches: readonly PiiMatch[];
|
|
10
|
+
readonly tier: "heuristic" | "deep";
|
|
11
|
+
readonly scannedAt: Date;
|
|
12
|
+
}
|
|
13
|
+
export interface ContentScore {
|
|
14
|
+
readonly category: ContentCategory;
|
|
15
|
+
readonly confidence: number;
|
|
16
|
+
}
|
|
17
|
+
export interface ContentClassificationResult {
|
|
18
|
+
readonly scores: readonly ContentScore[];
|
|
19
|
+
readonly tier: "heuristic" | "deep";
|
|
20
|
+
readonly scannedAt: Date;
|
|
21
|
+
}
|
|
22
|
+
export interface PolicyResult {
|
|
23
|
+
readonly allowed: boolean;
|
|
24
|
+
readonly railType: RailType;
|
|
25
|
+
readonly reason?: string;
|
|
26
|
+
readonly suggestion?: string;
|
|
27
|
+
readonly escalate?: boolean;
|
|
28
|
+
}
|
|
29
|
+
export type SafetyDirection = "input" | "output";
|
|
30
|
+
export interface SafetyPipelineResult {
|
|
31
|
+
readonly allowed: boolean;
|
|
32
|
+
readonly redactedText?: string;
|
|
33
|
+
readonly pii?: PiiScanResult;
|
|
34
|
+
readonly content?: ContentClassificationResult;
|
|
35
|
+
readonly policyResults: readonly PolicyResult[];
|
|
36
|
+
readonly blockReason?: string;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/safety/types.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAC;AAE5F,MAAM,WAAW,QAAQ;IACvB,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC;IACvB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,OAAO,EAAE,SAAS,QAAQ,EAAE,CAAC;IACtC,QAAQ,CAAC,IAAI,EAAE,WAAW,GAAG,MAAM,CAAC;IACpC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC;CAC1B;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,QAAQ,EAAE,eAAe,CAAC;IACnC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;CAC7B;AAED,MAAM,WAAW,2BAA2B;IAC1C,QAAQ,CAAC,MAAM,EAAE,SAAS,YAAY,EAAE,CAAC;IACzC,QAAQ,CAAC,IAAI,EAAE,WAAW,GAAG,MAAM,CAAC;IACpC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC;CAC1B;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC5B,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,UAAU,CAAC,EAAE,MAAM,CAAC;IAC7B,QAAQ,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;CAC7B;AAED,MAAM,MAAM,eAAe,GAAG,OAAO,GAAG,QAAQ,CAAC;AAEjD,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,GAAG,CAAC,EAAE,aAAa,CAAC;IAC7B,QAAQ,CAAC,OAAO,CAAC,EAAE,2BAA2B,CAAC;IAC/C,QAAQ,CAAC,aAAa,EAAE,SAAS,YAAY,EAAE,CAAC;IAChD,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC;CAC/B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/safety/types.ts"],"names":[],"mappings":"AAAA,gGAAgG"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/** Filesystem access policy */
|
|
2
|
+
export type FsPolicy = "read-only" | "read-write" | "none";
|
|
3
|
+
/** Network access policy */
|
|
4
|
+
export type NetPolicy = "none" | "package-managers" | "documentation" | "full";
|
|
5
|
+
/** Sandbox configuration per agent */
|
|
6
|
+
export interface SandboxConfig {
|
|
7
|
+
readonly fsPolicy: FsPolicy;
|
|
8
|
+
readonly netPolicy: NetPolicy;
|
|
9
|
+
readonly allowedPaths: readonly string[];
|
|
10
|
+
readonly deniedPaths: readonly string[];
|
|
11
|
+
readonly allowedDomains: readonly string[];
|
|
12
|
+
}
|
|
13
|
+
export { SandboxPolicy, createPolicy, createTenantSandbox, ROLE_PRESETS } from "./policies.js";
|
|
14
|
+
export { PathValidator, isSubPath } from "./path-validator.js";
|
|
15
|
+
export type { ValidationResult } from "./path-validator.js";
|
|
16
|
+
export { NetworkFilter, PACKAGE_MANAGER_DOMAINS, DOCUMENTATION_DOMAINS, } from "./network-filter.js";
|
|
17
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/sandbox/index.ts"],"names":[],"mappings":"AAAA,+BAA+B;AAC/B,MAAM,MAAM,QAAQ,GAAG,WAAW,GAAG,YAAY,GAAG,MAAM,CAAC;AAE3D,4BAA4B;AAC5B,MAAM,MAAM,SAAS,GAAG,MAAM,GAAG,kBAAkB,GAAG,eAAe,GAAG,MAAM,CAAC;AAE/E,sCAAsC;AACtC,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC5B,QAAQ,CAAC,SAAS,EAAE,SAAS,CAAC;IAC9B,QAAQ,CAAC,YAAY,EAAE,SAAS,MAAM,EAAE,CAAC;IACzC,QAAQ,CAAC,WAAW,EAAE,SAAS,MAAM,EAAE,CAAC;IACxC,QAAQ,CAAC,cAAc,EAAE,SAAS,MAAM,EAAE,CAAC;CAC5C;AAED,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,mBAAmB,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC/F,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAC/D,YAAY,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EACL,aAAa,EACb,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { SandboxPolicy, createPolicy, createTenantSandbox, ROLE_PRESETS } from "./policies.js";
|
|
2
|
+
export { PathValidator, isSubPath } from "./path-validator.js";
|
|
3
|
+
export { NetworkFilter, PACKAGE_MANAGER_DOMAINS, DOCUMENTATION_DOMAINS, } from "./network-filter.js";
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/sandbox/index.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,mBAAmB,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC/F,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAE/D,OAAO,EACL,aAAa,EACb,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { SandboxPolicy } from "./policies.js";
|
|
2
|
+
import type { ValidationResult } from "./path-validator.js";
|
|
3
|
+
export declare const PACKAGE_MANAGER_DOMAINS: readonly ["registry.npmjs.org", "pypi.org", "proxy.golang.org", "plugins.gradle.org", "repo.maven.apache.org", "crates.io"];
|
|
4
|
+
export declare const DOCUMENTATION_DOMAINS: readonly ["docs.python.org", "developer.mozilla.org", "pkg.go.dev", "docs.oracle.com", "react.dev", "nodejs.org", "bun.sh"];
|
|
5
|
+
export declare class NetworkFilter {
|
|
6
|
+
private readonly _policy;
|
|
7
|
+
constructor({ policy }: {
|
|
8
|
+
policy: SandboxPolicy;
|
|
9
|
+
});
|
|
10
|
+
validateUrl(url: string): ValidationResult;
|
|
11
|
+
validateDomain(domain: string): ValidationResult;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=network-filter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"network-filter.d.ts","sourceRoot":"","sources":["../../src/sandbox/network-filter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAE5D,eAAO,MAAM,uBAAuB,6HAO1B,CAAC;AAEX,eAAO,MAAM,qBAAqB,6HAQxB,CAAC;AAEX,qBAAa,aAAa;IACxB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAgB;gBAE5B,EAAE,MAAM,EAAE,EAAE;QAAE,MAAM,EAAE,aAAa,CAAA;KAAE;IAIjD,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,gBAAgB;IAa1C,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,gBAAgB;CAMjD"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
export const PACKAGE_MANAGER_DOMAINS = [
|
|
2
|
+
"registry.npmjs.org",
|
|
3
|
+
"pypi.org",
|
|
4
|
+
"proxy.golang.org",
|
|
5
|
+
"plugins.gradle.org",
|
|
6
|
+
"repo.maven.apache.org",
|
|
7
|
+
"crates.io",
|
|
8
|
+
];
|
|
9
|
+
export const DOCUMENTATION_DOMAINS = [
|
|
10
|
+
"docs.python.org",
|
|
11
|
+
"developer.mozilla.org",
|
|
12
|
+
"pkg.go.dev",
|
|
13
|
+
"docs.oracle.com",
|
|
14
|
+
"react.dev",
|
|
15
|
+
"nodejs.org",
|
|
16
|
+
"bun.sh",
|
|
17
|
+
];
|
|
18
|
+
export class NetworkFilter {
|
|
19
|
+
_policy;
|
|
20
|
+
constructor({ policy }) {
|
|
21
|
+
this._policy = policy;
|
|
22
|
+
}
|
|
23
|
+
validateUrl(url) {
|
|
24
|
+
let hostname;
|
|
25
|
+
try {
|
|
26
|
+
hostname = new URL(url).hostname;
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
return { allowed: false, reason: `Invalid URL: ${url}` };
|
|
30
|
+
}
|
|
31
|
+
if (this._policy.canAccess(hostname)) {
|
|
32
|
+
return { allowed: true };
|
|
33
|
+
}
|
|
34
|
+
return { allowed: false, reason: `Network access denied: ${hostname}` };
|
|
35
|
+
}
|
|
36
|
+
validateDomain(domain) {
|
|
37
|
+
if (this._policy.canAccess(domain)) {
|
|
38
|
+
return { allowed: true };
|
|
39
|
+
}
|
|
40
|
+
return { allowed: false, reason: `Domain access denied: ${domain}` };
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=network-filter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"network-filter.js","sourceRoot":"","sources":["../../src/sandbox/network-filter.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,MAAM,uBAAuB,GAAG;IACrC,oBAAoB;IACpB,UAAU;IACV,kBAAkB;IAClB,oBAAoB;IACpB,uBAAuB;IACvB,WAAW;CACH,CAAC;AAEX,MAAM,CAAC,MAAM,qBAAqB,GAAG;IACnC,iBAAiB;IACjB,uBAAuB;IACvB,YAAY;IACZ,iBAAiB;IACjB,WAAW;IACX,YAAY;IACZ,QAAQ;CACA,CAAC;AAEX,MAAM,OAAO,aAAa;IACP,OAAO,CAAgB;IAExC,YAAY,EAAE,MAAM,EAA6B;QAC/C,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;IACxB,CAAC;IAED,WAAW,CAAC,GAAW;QACrB,IAAI,QAAgB,CAAC;QACrB,IAAI,CAAC;YACH,QAAQ,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC;QACnC,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,gBAAgB,GAAG,EAAE,EAAE,CAAC;QAC3D,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC;YACrC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAC3B,CAAC;QACD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,0BAA0B,QAAQ,EAAE,EAAE,CAAC;IAC1E,CAAC;IAED,cAAc,CAAC,MAAc;QAC3B,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC;YACnC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAC3B,CAAC;QACD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,yBAAyB,MAAM,EAAE,EAAE,CAAC;IACvE,CAAC;CACF"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { SandboxPolicy } from "./policies.js";
|
|
2
|
+
export interface ValidationResult {
|
|
3
|
+
allowed: boolean;
|
|
4
|
+
reason?: string;
|
|
5
|
+
}
|
|
6
|
+
export declare function isSubPath(child: string, parent: string): boolean;
|
|
7
|
+
export declare class PathValidator {
|
|
8
|
+
private readonly _policy;
|
|
9
|
+
constructor({ policy }: {
|
|
10
|
+
policy: SandboxPolicy;
|
|
11
|
+
});
|
|
12
|
+
validateRead(filePath: string): ValidationResult;
|
|
13
|
+
validateWrite(filePath: string): ValidationResult;
|
|
14
|
+
validateExecute(command: string, _cwd: string): ValidationResult;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=path-validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"path-validator.d.ts","sourceRoot":"","sources":["../../src/sandbox/path-validator.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAEnD,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAYD,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAQhE;AAED,qBAAa,aAAa;IACxB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAgB;gBAE5B,EAAE,MAAM,EAAE,EAAE;QAAE,MAAM,EAAE,aAAa,CAAA;KAAE;IAIjD,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,gBAAgB;IAOhD,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,gBAAgB;IAOjD,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,gBAAgB;CAWjE"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { resolve } from "node:path";
|
|
2
|
+
const DANGEROUS_PATTERNS = [
|
|
3
|
+
/\brm\s+-rf\s+[\/\\]/,
|
|
4
|
+
/\bchmod\b/,
|
|
5
|
+
/\bchown\b/,
|
|
6
|
+
/\bsudo\b/,
|
|
7
|
+
/\bmkfs\b/,
|
|
8
|
+
/\bdd\s+if=/,
|
|
9
|
+
/\bformat\s+[a-z]:/i,
|
|
10
|
+
];
|
|
11
|
+
export function isSubPath(child, parent) {
|
|
12
|
+
const resolvedChild = resolve(child);
|
|
13
|
+
const resolvedParent = resolve(parent);
|
|
14
|
+
return (resolvedChild.startsWith(resolvedParent + "/") ||
|
|
15
|
+
resolvedChild.startsWith(resolvedParent + "\\") ||
|
|
16
|
+
resolvedChild === resolvedParent);
|
|
17
|
+
}
|
|
18
|
+
export class PathValidator {
|
|
19
|
+
_policy;
|
|
20
|
+
constructor({ policy }) {
|
|
21
|
+
this._policy = policy;
|
|
22
|
+
}
|
|
23
|
+
validateRead(filePath) {
|
|
24
|
+
if (this._policy.canRead(filePath)) {
|
|
25
|
+
return { allowed: true };
|
|
26
|
+
}
|
|
27
|
+
return { allowed: false, reason: `Read access denied: ${filePath}` };
|
|
28
|
+
}
|
|
29
|
+
validateWrite(filePath) {
|
|
30
|
+
if (this._policy.canWrite(filePath)) {
|
|
31
|
+
return { allowed: true };
|
|
32
|
+
}
|
|
33
|
+
return { allowed: false, reason: `Write access denied: ${filePath}` };
|
|
34
|
+
}
|
|
35
|
+
validateExecute(command, _cwd) {
|
|
36
|
+
for (const pattern of DANGEROUS_PATTERNS) {
|
|
37
|
+
if (pattern.test(command)) {
|
|
38
|
+
return {
|
|
39
|
+
allowed: false,
|
|
40
|
+
reason: `Dangerous command blocked: ${command}`,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
return { allowed: true };
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=path-validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"path-validator.js","sourceRoot":"","sources":["../../src/sandbox/path-validator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAQpC,MAAM,kBAAkB,GAAG;IACzB,qBAAqB;IACrB,WAAW;IACX,WAAW;IACX,UAAU;IACV,UAAU;IACV,YAAY;IACZ,oBAAoB;CACZ,CAAC;AAEX,MAAM,UAAU,SAAS,CAAC,KAAa,EAAE,MAAc;IACrD,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;IACrC,MAAM,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACvC,OAAO,CACL,aAAa,CAAC,UAAU,CAAC,cAAc,GAAG,GAAG,CAAC;QAC9C,aAAa,CAAC,UAAU,CAAC,cAAc,GAAG,IAAI,CAAC;QAC/C,aAAa,KAAK,cAAc,CACjC,CAAC;AACJ,CAAC;AAED,MAAM,OAAO,aAAa;IACP,OAAO,CAAgB;IAExC,YAAY,EAAE,MAAM,EAA6B;QAC/C,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;IACxB,CAAC;IAED,YAAY,CAAC,QAAgB;QAC3B,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAC3B,CAAC;QACD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,uBAAuB,QAAQ,EAAE,EAAE,CAAC;IACvE,CAAC;IAED,aAAa,CAAC,QAAgB;QAC5B,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;YACpC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAC3B,CAAC;QACD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,wBAAwB,QAAQ,EAAE,EAAE,CAAC;IACxE,CAAC;IAED,eAAe,CAAC,OAAe,EAAE,IAAY;QAC3C,KAAK,MAAM,OAAO,IAAI,kBAAkB,EAAE,CAAC;YACzC,IAAI,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;gBAC1B,OAAO;oBACL,OAAO,EAAE,KAAK;oBACd,MAAM,EAAE,8BAA8B,OAAO,EAAE;iBAChD,CAAC;YACJ,CAAC;QACH,CAAC;QACD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC3B,CAAC;CACF"}
|