@amodalai/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/LICENSE +21 -0
- package/dist/.last_build +0 -0
- package/dist/src/amodal-config.d.ts +194 -0
- package/dist/src/amodal-config.js +326 -0
- package/dist/src/amodal-config.js.map +1 -0
- package/dist/src/audit/audit-logger.d.ts +52 -0
- package/dist/src/audit/audit-logger.js +137 -0
- package/dist/src/audit/audit-logger.js.map +1 -0
- package/dist/src/audit/audit-outputs.d.ts +34 -0
- package/dist/src/audit/audit-outputs.js +73 -0
- package/dist/src/audit/audit-outputs.js.map +1 -0
- package/dist/src/audit/audit-redact.d.ts +14 -0
- package/dist/src/audit/audit-redact.js +55 -0
- package/dist/src/audit/audit-redact.js.map +1 -0
- package/dist/src/audit/audit-types.d.ts +122 -0
- package/dist/src/audit/audit-types.js +64 -0
- package/dist/src/audit/audit-types.js.map +1 -0
- package/dist/src/audit/index.d.ts +10 -0
- package/dist/src/audit/index.js +10 -0
- package/dist/src/audit/index.js.map +1 -0
- package/dist/src/eval/eval-cost.d.ts +33 -0
- package/dist/src/eval/eval-cost.js +73 -0
- package/dist/src/eval/eval-cost.js.map +1 -0
- package/dist/src/eval/eval-diff.d.ts +11 -0
- package/dist/src/eval/eval-diff.js +97 -0
- package/dist/src/eval/eval-diff.js.map +1 -0
- package/dist/src/eval/eval-formatter.d.ts +23 -0
- package/dist/src/eval/eval-formatter.js +221 -0
- package/dist/src/eval/eval-formatter.js.map +1 -0
- package/dist/src/eval/eval-judge.d.ts +26 -0
- package/dist/src/eval/eval-judge.js +76 -0
- package/dist/src/eval/eval-judge.js.map +1 -0
- package/dist/src/eval/eval-run-builder.d.ts +25 -0
- package/dist/src/eval/eval-run-builder.js +78 -0
- package/dist/src/eval/eval-run-builder.js.map +1 -0
- package/dist/src/eval/eval-runner.d.ts +36 -0
- package/dist/src/eval/eval-runner.js +92 -0
- package/dist/src/eval/eval-runner.js.map +1 -0
- package/dist/src/eval/eval-session-provider.d.ts +40 -0
- package/dist/src/eval/eval-session-provider.js +46 -0
- package/dist/src/eval/eval-session-provider.js.map +1 -0
- package/dist/src/eval/eval-types.d.ts +146 -0
- package/dist/src/eval/eval-types.js +7 -0
- package/dist/src/eval/eval-types.js.map +1 -0
- package/dist/src/eval/experiment-runner.d.ts +16 -0
- package/dist/src/eval/experiment-runner.js +73 -0
- package/dist/src/eval/experiment-runner.js.map +1 -0
- package/dist/src/eval/experiment-types.d.ts +56 -0
- package/dist/src/eval/experiment-types.js +7 -0
- package/dist/src/eval/experiment-types.js.map +1 -0
- package/dist/src/eval/index.d.ts +22 -0
- package/dist/src/eval/index.js +18 -0
- package/dist/src/eval/index.js.map +1 -0
- package/dist/src/eval/multi-model-runner.d.ts +42 -0
- package/dist/src/eval/multi-model-runner.js +70 -0
- package/dist/src/eval/multi-model-runner.js.map +1 -0
- package/dist/src/eval/platform-eval-client.d.ts +105 -0
- package/dist/src/eval/platform-eval-client.js +155 -0
- package/dist/src/eval/platform-eval-client.js.map +1 -0
- package/dist/src/index.d.ts +41 -0
- package/dist/src/index.js +68 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/knowledge/index.d.ts +11 -0
- package/dist/src/knowledge/index.js +12 -0
- package/dist/src/knowledge/index.js.map +1 -0
- package/dist/src/knowledge/kb-formatter.d.ts +15 -0
- package/dist/src/knowledge/kb-formatter.js +78 -0
- package/dist/src/knowledge/kb-formatter.js.map +1 -0
- package/dist/src/knowledge/kb-index.d.ts +27 -0
- package/dist/src/knowledge/kb-index.js +66 -0
- package/dist/src/knowledge/kb-index.js.map +1 -0
- package/dist/src/knowledge/kb-types.d.ts +54 -0
- package/dist/src/knowledge/kb-types.js +7 -0
- package/dist/src/knowledge/kb-types.js.map +1 -0
- package/dist/src/knowledge/knowledge-store.d.ts +56 -0
- package/dist/src/knowledge/knowledge-store.js +141 -0
- package/dist/src/knowledge/knowledge-store.js.map +1 -0
- package/dist/src/knowledge/load-knowledge.d.ts +30 -0
- package/dist/src/knowledge/load-knowledge.js +161 -0
- package/dist/src/knowledge/load-knowledge.js.map +1 -0
- package/dist/src/knowledge/propose-kb-update.d.ts +32 -0
- package/dist/src/knowledge/propose-kb-update.js +148 -0
- package/dist/src/knowledge/propose-kb-update.js.map +1 -0
- package/dist/src/knowledge/propose-knowledge.d.ts +34 -0
- package/dist/src/knowledge/propose-knowledge.js +163 -0
- package/dist/src/knowledge/propose-knowledge.js.map +1 -0
- package/dist/src/mcp/index.d.ts +7 -0
- package/dist/src/mcp/index.js +7 -0
- package/dist/src/mcp/index.js.map +1 -0
- package/dist/src/mcp/mcp-manager.d.ts +96 -0
- package/dist/src/mcp/mcp-manager.js +192 -0
- package/dist/src/mcp/mcp-manager.js.map +1 -0
- package/dist/src/packages/config-deps.d.ts +20 -0
- package/dist/src/packages/config-deps.js +77 -0
- package/dist/src/packages/config-deps.js.map +1 -0
- package/dist/src/packages/env-file.d.ts +28 -0
- package/dist/src/packages/env-file.js +143 -0
- package/dist/src/packages/env-file.js.map +1 -0
- package/dist/src/packages/frontmatter.d.ts +28 -0
- package/dist/src/packages/frontmatter.js +77 -0
- package/dist/src/packages/frontmatter.js.map +1 -0
- package/dist/src/packages/index.d.ts +16 -0
- package/dist/src/packages/index.js +17 -0
- package/dist/src/packages/index.js.map +1 -0
- package/dist/src/packages/lock-file.d.ts +35 -0
- package/dist/src/packages/lock-file.js +117 -0
- package/dist/src/packages/lock-file.js.map +1 -0
- package/dist/src/packages/manifest-reader.d.ts +19 -0
- package/dist/src/packages/manifest-reader.js +91 -0
- package/dist/src/packages/manifest-reader.js.map +1 -0
- package/dist/src/packages/merge-engine.d.ts +63 -0
- package/dist/src/packages/merge-engine.js +357 -0
- package/dist/src/packages/merge-engine.js.map +1 -0
- package/dist/src/packages/npm-context.d.ts +56 -0
- package/dist/src/packages/npm-context.js +235 -0
- package/dist/src/packages/npm-context.js.map +1 -0
- package/dist/src/packages/npm-registry.d.ts +35 -0
- package/dist/src/packages/npm-registry.js +107 -0
- package/dist/src/packages/npm-registry.js.map +1 -0
- package/dist/src/packages/package-error.d.ts +16 -0
- package/dist/src/packages/package-error.js +17 -0
- package/dist/src/packages/package-error.js.map +1 -0
- package/dist/src/packages/package-types.d.ts +477 -0
- package/dist/src/packages/package-types.js +156 -0
- package/dist/src/packages/package-types.js.map +1 -0
- package/dist/src/packages/resolver.d.ts +41 -0
- package/dist/src/packages/resolver.js +353 -0
- package/dist/src/packages/resolver.js.map +1 -0
- package/dist/src/platform/config-builder.d.ts +24 -0
- package/dist/src/platform/config-builder.js +70 -0
- package/dist/src/platform/config-builder.js.map +1 -0
- package/dist/src/platform/index.d.ts +8 -0
- package/dist/src/platform/index.js +9 -0
- package/dist/src/platform/index.js.map +1 -0
- package/dist/src/platform/platform-client.d.ts +160 -0
- package/dist/src/platform/platform-client.js +486 -0
- package/dist/src/platform/platform-client.js.map +1 -0
- package/dist/src/platform/platform-types.d.ts +81 -0
- package/dist/src/platform/platform-types.js +18 -0
- package/dist/src/platform/platform-types.js.map +1 -0
- package/dist/src/providers/content-generator/google-to-llm.d.ts +87 -0
- package/dist/src/providers/content-generator/google-to-llm.js +226 -0
- package/dist/src/providers/content-generator/google-to-llm.js.map +1 -0
- package/dist/src/providers/content-generator/index.d.ts +10 -0
- package/dist/src/providers/content-generator/index.js +9 -0
- package/dist/src/providers/content-generator/index.js.map +1 -0
- package/dist/src/providers/content-generator/llm-to-google.d.ts +59 -0
- package/dist/src/providers/content-generator/llm-to-google.js +178 -0
- package/dist/src/providers/content-generator/llm-to-google.js.map +1 -0
- package/dist/src/providers/content-generator/multi-provider-content-generator.d.ts +61 -0
- package/dist/src/providers/content-generator/multi-provider-content-generator.js +144 -0
- package/dist/src/providers/content-generator/multi-provider-content-generator.js.map +1 -0
- package/dist/src/providers/runtime/anthropic-provider.d.ts +18 -0
- package/dist/src/providers/runtime/anthropic-provider.js +253 -0
- package/dist/src/providers/runtime/anthropic-provider.js.map +1 -0
- package/dist/src/providers/runtime/azure-provider.d.ts +25 -0
- package/dist/src/providers/runtime/azure-provider.js +206 -0
- package/dist/src/providers/runtime/azure-provider.js.map +1 -0
- package/dist/src/providers/runtime/bedrock-provider.d.ts +22 -0
- package/dist/src/providers/runtime/bedrock-provider.js +276 -0
- package/dist/src/providers/runtime/bedrock-provider.js.map +1 -0
- package/dist/src/providers/runtime/failover-provider.d.ts +30 -0
- package/dist/src/providers/runtime/failover-provider.js +124 -0
- package/dist/src/providers/runtime/failover-provider.js.map +1 -0
- package/dist/src/providers/runtime/google-provider.d.ts +17 -0
- package/dist/src/providers/runtime/google-provider.js +239 -0
- package/dist/src/providers/runtime/google-provider.js.map +1 -0
- package/dist/src/providers/runtime/index.d.ts +16 -0
- package/dist/src/providers/runtime/index.js +16 -0
- package/dist/src/providers/runtime/index.js.map +1 -0
- package/dist/src/providers/runtime/openai-provider.d.ts +21 -0
- package/dist/src/providers/runtime/openai-provider.js +266 -0
- package/dist/src/providers/runtime/openai-provider.js.map +1 -0
- package/dist/src/providers/runtime/provider-errors.d.ts +39 -0
- package/dist/src/providers/runtime/provider-errors.js +50 -0
- package/dist/src/providers/runtime/provider-errors.js.map +1 -0
- package/dist/src/providers/runtime/provider-factory.d.ts +19 -0
- package/dist/src/providers/runtime/provider-factory.js +45 -0
- package/dist/src/providers/runtime/provider-factory.js.map +1 -0
- package/dist/src/providers/runtime/runtime-provider-types.d.ts +63 -0
- package/dist/src/providers/runtime/runtime-provider-types.js +7 -0
- package/dist/src/providers/runtime/runtime-provider-types.js.map +1 -0
- package/dist/src/providers/runtime/streaming-types.d.ts +40 -0
- package/dist/src/providers/runtime/streaming-types.js +7 -0
- package/dist/src/providers/runtime/streaming-types.js.map +1 -0
- package/dist/src/repo/config-schema.d.ts +238 -0
- package/dist/src/repo/config-schema.js +155 -0
- package/dist/src/repo/config-schema.js.map +1 -0
- package/dist/src/repo/connection-schemas.d.ts +449 -0
- package/dist/src/repo/connection-schemas.js +109 -0
- package/dist/src/repo/connection-schemas.js.map +1 -0
- package/dist/src/repo/connection-types.d.ts +29 -0
- package/dist/src/repo/connection-types.js +7 -0
- package/dist/src/repo/connection-types.js.map +1 -0
- package/dist/src/repo/drift-detector.d.ts +26 -0
- package/dist/src/repo/drift-detector.js +66 -0
- package/dist/src/repo/drift-detector.js.map +1 -0
- package/dist/src/repo/graphql-drift-detector.d.ts +27 -0
- package/dist/src/repo/graphql-drift-detector.js +66 -0
- package/dist/src/repo/graphql-drift-detector.js.map +1 -0
- package/dist/src/repo/graphql-parser.d.ts +30 -0
- package/dist/src/repo/graphql-parser.js +125 -0
- package/dist/src/repo/graphql-parser.js.map +1 -0
- package/dist/src/repo/graphql-surface-parser.d.ts +20 -0
- package/dist/src/repo/graphql-surface-parser.js +74 -0
- package/dist/src/repo/graphql-surface-parser.js.map +1 -0
- package/dist/src/repo/index.d.ts +30 -0
- package/dist/src/repo/index.js +29 -0
- package/dist/src/repo/index.js.map +1 -0
- package/dist/src/repo/local-reader.d.ts +10 -0
- package/dist/src/repo/local-reader.js +299 -0
- package/dist/src/repo/local-reader.js.map +1 -0
- package/dist/src/repo/openapi-parser.d.ts +35 -0
- package/dist/src/repo/openapi-parser.js +93 -0
- package/dist/src/repo/openapi-parser.js.map +1 -0
- package/dist/src/repo/parsers.d.ts +91 -0
- package/dist/src/repo/parsers.js +454 -0
- package/dist/src/repo/parsers.js.map +1 -0
- package/dist/src/repo/platform-reader.d.ts +10 -0
- package/dist/src/repo/platform-reader.js +206 -0
- package/dist/src/repo/platform-reader.js.map +1 -0
- package/dist/src/repo/repo-loader.d.ts +14 -0
- package/dist/src/repo/repo-loader.js +25 -0
- package/dist/src/repo/repo-loader.js.map +1 -0
- package/dist/src/repo/repo-types.d.ts +159 -0
- package/dist/src/repo/repo-types.js +17 -0
- package/dist/src/repo/repo-types.js.map +1 -0
- package/dist/src/repo/spec-syncer.d.ts +30 -0
- package/dist/src/repo/spec-syncer.js +85 -0
- package/dist/src/repo/spec-syncer.js.map +1 -0
- package/dist/src/repo/store-loader.d.ts +19 -0
- package/dist/src/repo/store-loader.js +94 -0
- package/dist/src/repo/store-loader.js.map +1 -0
- package/dist/src/repo/store-schemas.d.ts +313 -0
- package/dist/src/repo/store-schemas.js +103 -0
- package/dist/src/repo/store-schemas.js.map +1 -0
- package/dist/src/repo/store-tool-schema.d.ts +29 -0
- package/dist/src/repo/store-tool-schema.js +103 -0
- package/dist/src/repo/store-tool-schema.js.map +1 -0
- package/dist/src/repo/store-types.d.ts +91 -0
- package/dist/src/repo/store-types.js +7 -0
- package/dist/src/repo/store-types.js.map +1 -0
- package/dist/src/repo/surface-parser.d.ts +17 -0
- package/dist/src/repo/surface-parser.js +75 -0
- package/dist/src/repo/surface-parser.js.map +1 -0
- package/dist/src/repo/tool-loader.d.ts +33 -0
- package/dist/src/repo/tool-loader.js +240 -0
- package/dist/src/repo/tool-loader.js.map +1 -0
- package/dist/src/repo/tool-types.d.ts +205 -0
- package/dist/src/repo/tool-types.js +61 -0
- package/dist/src/repo/tool-types.js.map +1 -0
- package/dist/src/roles/index.d.ts +7 -0
- package/dist/src/roles/index.js +8 -0
- package/dist/src/roles/index.js.map +1 -0
- package/dist/src/roles/role-filter.d.ts +33 -0
- package/dist/src/roles/role-filter.js +55 -0
- package/dist/src/roles/role-filter.js.map +1 -0
- package/dist/src/roles/role-types.d.ts +76 -0
- package/dist/src/roles/role-types.js +38 -0
- package/dist/src/roles/role-types.js.map +1 -0
- package/dist/src/runtime/connection-bridge.d.ts +19 -0
- package/dist/src/runtime/connection-bridge.js +103 -0
- package/dist/src/runtime/connection-bridge.js.map +1 -0
- package/dist/src/runtime/context-compiler.d.ts +35 -0
- package/dist/src/runtime/context-compiler.js +183 -0
- package/dist/src/runtime/context-compiler.js.map +1 -0
- package/dist/src/runtime/default-prompt.d.ts +28 -0
- package/dist/src/runtime/default-prompt.js +71 -0
- package/dist/src/runtime/default-prompt.js.map +1 -0
- package/dist/src/runtime/explore-tool.d.ts +96 -0
- package/dist/src/runtime/explore-tool.js +111 -0
- package/dist/src/runtime/explore-tool.js.map +1 -0
- package/dist/src/runtime/index.d.ts +26 -0
- package/dist/src/runtime/index.js +19 -0
- package/dist/src/runtime/index.js.map +1 -0
- package/dist/src/runtime/output-pipeline.d.ts +62 -0
- package/dist/src/runtime/output-pipeline.js +69 -0
- package/dist/src/runtime/output-pipeline.js.map +1 -0
- package/dist/src/runtime/plan-mode.d.ts +39 -0
- package/dist/src/runtime/plan-mode.js +81 -0
- package/dist/src/runtime/plan-mode.js.map +1 -0
- package/dist/src/runtime/preference-client.d.ts +39 -0
- package/dist/src/runtime/preference-client.js +70 -0
- package/dist/src/runtime/preference-client.js.map +1 -0
- package/dist/src/runtime/preference-detector.d.ts +22 -0
- package/dist/src/runtime/preference-detector.js +95 -0
- package/dist/src/runtime/preference-detector.js.map +1 -0
- package/dist/src/runtime/request-integration.d.ts +18 -0
- package/dist/src/runtime/request-integration.js +36 -0
- package/dist/src/runtime/request-integration.js.map +1 -0
- package/dist/src/runtime/runtime-types.d.ts +48 -0
- package/dist/src/runtime/runtime-types.js +7 -0
- package/dist/src/runtime/runtime-types.js.map +1 -0
- package/dist/src/runtime/session-setup.d.ts +53 -0
- package/dist/src/runtime/session-setup.js +90 -0
- package/dist/src/runtime/session-setup.js.map +1 -0
- package/dist/src/runtime/telemetry-client.d.ts +39 -0
- package/dist/src/runtime/telemetry-client.js +87 -0
- package/dist/src/runtime/telemetry-client.js.map +1 -0
- package/dist/src/runtime/telemetry-hooks.d.ts +47 -0
- package/dist/src/runtime/telemetry-hooks.js +115 -0
- package/dist/src/runtime/telemetry-hooks.js.map +1 -0
- package/dist/src/runtime/token-allocator.d.ts +34 -0
- package/dist/src/runtime/token-allocator.js +86 -0
- package/dist/src/runtime/token-allocator.js.map +1 -0
- package/dist/src/runtime/user-context.d.ts +49 -0
- package/dist/src/runtime/user-context.js +135 -0
- package/dist/src/runtime/user-context.js.map +1 -0
- package/dist/src/sdk.d.ts +57 -0
- package/dist/src/sdk.js +377 -0
- package/dist/src/sdk.js.map +1 -0
- package/dist/src/security/action-gate.d.ts +23 -0
- package/dist/src/security/action-gate.js +78 -0
- package/dist/src/security/action-gate.js.map +1 -0
- package/dist/src/security/field-scrubber.d.ts +27 -0
- package/dist/src/security/field-scrubber.js +152 -0
- package/dist/src/security/field-scrubber.js.map +1 -0
- package/dist/src/security/index.d.ts +14 -0
- package/dist/src/security/index.js +15 -0
- package/dist/src/security/index.js.map +1 -0
- package/dist/src/security/leak-detector.d.ts +23 -0
- package/dist/src/security/leak-detector.js +51 -0
- package/dist/src/security/leak-detector.js.map +1 -0
- package/dist/src/security/output-guard.d.ts +33 -0
- package/dist/src/security/output-guard.js +118 -0
- package/dist/src/security/output-guard.js.map +1 -0
- package/dist/src/security/pattern-scanner.d.ts +19 -0
- package/dist/src/security/pattern-scanner.js +66 -0
- package/dist/src/security/pattern-scanner.js.map +1 -0
- package/dist/src/security/scope-checker.d.ts +27 -0
- package/dist/src/security/scope-checker.js +52 -0
- package/dist/src/security/scope-checker.js.map +1 -0
- package/dist/src/security/scrub-tracker.d.ts +21 -0
- package/dist/src/security/scrub-tracker.js +39 -0
- package/dist/src/security/scrub-tracker.js.map +1 -0
- package/dist/src/security/security-types.d.ts +69 -0
- package/dist/src/security/security-types.js +17 -0
- package/dist/src/security/security-types.js.map +1 -0
- package/dist/src/security/threshold-evaluator.d.ts +13 -0
- package/dist/src/security/threshold-evaluator.js +44 -0
- package/dist/src/security/threshold-evaluator.js.map +1 -0
- package/dist/src/snapshot/index.d.ts +8 -0
- package/dist/src/snapshot/index.js +9 -0
- package/dist/src/snapshot/index.js.map +1 -0
- package/dist/src/snapshot/snapshot-builder.d.ts +37 -0
- package/dist/src/snapshot/snapshot-builder.js +152 -0
- package/dist/src/snapshot/snapshot-builder.js.map +1 -0
- package/dist/src/snapshot/snapshot-loader.d.ts +29 -0
- package/dist/src/snapshot/snapshot-loader.js +188 -0
- package/dist/src/snapshot/snapshot-loader.js.map +1 -0
- package/dist/src/snapshot/snapshot-types.d.ts +1940 -0
- package/dist/src/snapshot/snapshot-types.js +145 -0
- package/dist/src/snapshot/snapshot-types.js.map +1 -0
- package/dist/src/stores/index.d.ts +6 -0
- package/dist/src/stores/index.js +7 -0
- package/dist/src/stores/index.js.map +1 -0
- package/dist/src/stores/store-backend.d.ts +135 -0
- package/dist/src/stores/store-backend.js +7 -0
- package/dist/src/stores/store-backend.js.map +1 -0
- package/dist/src/templates/connections.d.ts +14 -0
- package/dist/src/templates/connections.js +7 -0
- package/dist/src/templates/connections.js.map +1 -0
- package/dist/src/templates/index.d.ts +7 -0
- package/dist/src/templates/index.js +8 -0
- package/dist/src/templates/index.js.map +1 -0
- package/dist/src/templates/template-resolver.d.ts +45 -0
- package/dist/src/templates/template-resolver.js +121 -0
- package/dist/src/templates/template-resolver.js.map +1 -0
- package/dist/src/tool-context.d.ts +33 -0
- package/dist/src/tool-context.js +7 -0
- package/dist/src/tool-context.js.map +1 -0
- package/dist/src/tool-registration.d.ts +14 -0
- package/dist/src/tool-registration.js +51 -0
- package/dist/src/tool-registration.js.map +1 -0
- package/dist/src/tools/amodal-tool-errors.d.ts +24 -0
- package/dist/src/tools/amodal-tool-errors.js +28 -0
- package/dist/src/tools/amodal-tool-errors.js.map +1 -0
- package/dist/src/tools/amodal-tool-names.d.ts +14 -0
- package/dist/src/tools/amodal-tool-names.js +15 -0
- package/dist/src/tools/amodal-tool-names.js.map +1 -0
- package/dist/src/tools/chain-tool-registry.d.ts +20 -0
- package/dist/src/tools/chain-tool-registry.js +49 -0
- package/dist/src/tools/chain-tool-registry.js.map +1 -0
- package/dist/src/tools/chain-tool-types.d.ts +190 -0
- package/dist/src/tools/chain-tool-types.js +50 -0
- package/dist/src/tools/chain-tool-types.js.map +1 -0
- package/dist/src/tools/chain-tool.d.ts +34 -0
- package/dist/src/tools/chain-tool.js +294 -0
- package/dist/src/tools/chain-tool.js.map +1 -0
- package/dist/src/tools/custom-tool-registrar.d.ts +8 -0
- package/dist/src/tools/custom-tool-registrar.js +10 -0
- package/dist/src/tools/custom-tool-registrar.js.map +1 -0
- package/dist/src/tools/definitions/amodal-tools.d.ts +9 -0
- package/dist/src/tools/definitions/amodal-tools.js +192 -0
- package/dist/src/tools/definitions/amodal-tools.js.map +1 -0
- package/dist/src/tools/function-tool-registry.d.ts +22 -0
- package/dist/src/tools/function-tool-registry.js +45 -0
- package/dist/src/tools/function-tool-registry.js.map +1 -0
- package/dist/src/tools/function-tool-types.d.ts +76 -0
- package/dist/src/tools/function-tool-types.js +27 -0
- package/dist/src/tools/function-tool-types.js.map +1 -0
- package/dist/src/tools/function-tool.d.ts +34 -0
- package/dist/src/tools/function-tool.js +97 -0
- package/dist/src/tools/function-tool.js.map +1 -0
- package/dist/src/tools/http-tool-registry.d.ts +20 -0
- package/dist/src/tools/http-tool-registry.js +34 -0
- package/dist/src/tools/http-tool-registry.js.map +1 -0
- package/dist/src/tools/http-tool-types.d.ts +92 -0
- package/dist/src/tools/http-tool-types.js +44 -0
- package/dist/src/tools/http-tool-types.js.map +1 -0
- package/dist/src/tools/http-tool.d.ts +32 -0
- package/dist/src/tools/http-tool.js +176 -0
- package/dist/src/tools/http-tool.js.map +1 -0
- package/dist/src/tools/merge-template.d.ts +33 -0
- package/dist/src/tools/merge-template.js +65 -0
- package/dist/src/tools/merge-template.js.map +1 -0
- package/dist/src/tools/request-tool-types.d.ts +46 -0
- package/dist/src/tools/request-tool-types.js +20 -0
- package/dist/src/tools/request-tool-types.js.map +1 -0
- package/dist/src/tools/request-tool.d.ts +29 -0
- package/dist/src/tools/request-tool.js +268 -0
- package/dist/src/tools/request-tool.js.map +1 -0
- package/dist/src/tools/store-query-tool.d.ts +29 -0
- package/dist/src/tools/store-query-tool.js +82 -0
- package/dist/src/tools/store-query-tool.js.map +1 -0
- package/dist/src/tools/store-write-tool.d.ts +26 -0
- package/dist/src/tools/store-write-tool.js +84 -0
- package/dist/src/tools/store-write-tool.js.map +1 -0
- package/dist/src/tools/tool-definition-types.d.ts +21 -0
- package/dist/src/tools/tool-definition-types.js +7 -0
- package/dist/src/tools/tool-definition-types.js.map +1 -0
- package/dist/src/tools/tool-utils.d.ts +29 -0
- package/dist/src/tools/tool-utils.js +66 -0
- package/dist/src/tools/tool-utils.js.map +1 -0
- package/dist/src/versions/bundle-loader.d.ts +37 -0
- package/dist/src/versions/bundle-loader.js +99 -0
- package/dist/src/versions/bundle-loader.js.map +1 -0
- package/dist/src/versions/dependency-manager.d.ts +54 -0
- package/dist/src/versions/dependency-manager.js +132 -0
- package/dist/src/versions/dependency-manager.js.map +1 -0
- package/dist/src/versions/handler-loader.d.ts +27 -0
- package/dist/src/versions/handler-loader.js +62 -0
- package/dist/src/versions/handler-loader.js.map +1 -0
- package/dist/src/versions/index.d.ts +10 -0
- package/dist/src/versions/index.js +11 -0
- package/dist/src/versions/index.js.map +1 -0
- package/dist/src/versions/version-bundle-types.d.ts +1278 -0
- package/dist/src/versions/version-bundle-types.js +207 -0
- package/dist/src/versions/version-bundle-types.js.map +1 -0
- package/dist/src/versions/version-manager.d.ts +89 -0
- package/dist/src/versions/version-manager.js +124 -0
- package/dist/src/versions/version-manager.js.map +1 -0
- package/dist/src/widgets/index.d.ts +8 -0
- package/dist/src/widgets/index.js +8 -0
- package/dist/src/widgets/index.js.map +1 -0
- package/dist/src/widgets/present-tool.d.ts +21 -0
- package/dist/src/widgets/present-tool.js +107 -0
- package/dist/src/widgets/present-tool.js.map +1 -0
- package/dist/src/widgets/widget-types.d.ts +78 -0
- package/dist/src/widgets/widget-types.js +28 -0
- package/dist/src/widgets/widget-types.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +50 -0
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { ThresholdEvaluator } from './threshold-evaluator.js';
|
|
7
|
+
/**
|
|
8
|
+
* Controls write operations based on confirmation tiers from access config.
|
|
9
|
+
*/
|
|
10
|
+
export class ActionGate {
|
|
11
|
+
accessConfigs;
|
|
12
|
+
isDelegated;
|
|
13
|
+
thresholdEvaluator;
|
|
14
|
+
constructor(config) {
|
|
15
|
+
this.accessConfigs = config.accessConfigs;
|
|
16
|
+
this.isDelegated = config.isDelegated;
|
|
17
|
+
this.thresholdEvaluator = new ThresholdEvaluator();
|
|
18
|
+
}
|
|
19
|
+
evaluate(endpointPath, connectionName, params) {
|
|
20
|
+
const accessConfig = this.accessConfigs.get(connectionName);
|
|
21
|
+
if (!accessConfig) {
|
|
22
|
+
return {
|
|
23
|
+
decision: 'allow',
|
|
24
|
+
endpointPath,
|
|
25
|
+
escalated: false,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
const endpoint = accessConfig['endpoints'][endpointPath];
|
|
29
|
+
if (!endpoint) {
|
|
30
|
+
return {
|
|
31
|
+
decision: 'allow',
|
|
32
|
+
endpointPath,
|
|
33
|
+
escalated: false,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
// Base tier from confirm field
|
|
37
|
+
let decision = this.resolveBaseTier(endpoint.confirm);
|
|
38
|
+
let reason = endpoint.reason;
|
|
39
|
+
let escalated = false;
|
|
40
|
+
// Threshold evaluation
|
|
41
|
+
if (endpoint.thresholds &&
|
|
42
|
+
endpoint.thresholds.length > 0 &&
|
|
43
|
+
params) {
|
|
44
|
+
const thresholdResult = this.thresholdEvaluator.evaluate(endpoint.thresholds, params);
|
|
45
|
+
if (thresholdResult !== null) {
|
|
46
|
+
const escalatedDecision = this.escalateDecision(decision, thresholdResult);
|
|
47
|
+
if (escalatedDecision !== decision) {
|
|
48
|
+
decision = escalatedDecision;
|
|
49
|
+
escalated = true;
|
|
50
|
+
reason = `Threshold escalation: ${reason ?? 'parameter exceeded limit'}`;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
// Delegation escalation
|
|
55
|
+
if (this.isDelegated && accessConfig.delegations?.escalateConfirm) {
|
|
56
|
+
if (decision === 'confirm') {
|
|
57
|
+
decision = 'review';
|
|
58
|
+
escalated = true;
|
|
59
|
+
reason = `Delegated agent escalation: ${reason ?? 'confirm → review'}`;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return { decision, reason, escalated, endpointPath };
|
|
63
|
+
}
|
|
64
|
+
resolveBaseTier(confirm) {
|
|
65
|
+
if (confirm === undefined)
|
|
66
|
+
return 'allow';
|
|
67
|
+
if (confirm === true)
|
|
68
|
+
return 'confirm';
|
|
69
|
+
return confirm;
|
|
70
|
+
}
|
|
71
|
+
escalateDecision(current, escalation) {
|
|
72
|
+
const hierarchy = ['allow', 'confirm', 'review', 'never'];
|
|
73
|
+
const currentIdx = hierarchy.indexOf(current);
|
|
74
|
+
const escalationIdx = hierarchy.indexOf(escalation);
|
|
75
|
+
return escalationIdx > currentIdx ? escalation : current;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=action-gate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"action-gate.js","sourceRoot":"","sources":["../../../src/security/action-gate.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import type { AccessConfig } from '../repo/connection-schemas.js';
|
|
7
|
+
import type { ScrubResult } from './security-types.js';
|
|
8
|
+
import type { ScrubTracker } from './scrub-tracker.js';
|
|
9
|
+
export interface FieldScrubberConfig {
|
|
10
|
+
accessConfigs: Map<string, AccessConfig>;
|
|
11
|
+
userRoles: string[];
|
|
12
|
+
tracker: ScrubTracker;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Intercepts API responses and strips restricted fields before
|
|
16
|
+
* the data reaches the LLM context.
|
|
17
|
+
*/
|
|
18
|
+
export declare class FieldScrubber {
|
|
19
|
+
private readonly accessConfigs;
|
|
20
|
+
private readonly userRoles;
|
|
21
|
+
private readonly tracker;
|
|
22
|
+
constructor(config: FieldScrubberConfig);
|
|
23
|
+
scrub(data: unknown, endpointPath: string, connectionName: string): ScrubResult;
|
|
24
|
+
private findRestriction;
|
|
25
|
+
private hasRole;
|
|
26
|
+
private walkAndScrub;
|
|
27
|
+
}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* Intercepts API responses and strips restricted fields before
|
|
8
|
+
* the data reaches the LLM context.
|
|
9
|
+
*/
|
|
10
|
+
export class FieldScrubber {
|
|
11
|
+
accessConfigs;
|
|
12
|
+
userRoles;
|
|
13
|
+
tracker;
|
|
14
|
+
constructor(config) {
|
|
15
|
+
this.accessConfigs = config.accessConfigs;
|
|
16
|
+
this.userRoles = config.userRoles;
|
|
17
|
+
this.tracker = config.tracker;
|
|
18
|
+
}
|
|
19
|
+
scrub(data, endpointPath, connectionName) {
|
|
20
|
+
const accessConfig = this.accessConfigs.get(connectionName);
|
|
21
|
+
if (!accessConfig) {
|
|
22
|
+
return { data, records: [], strippedCount: 0, redactableCount: 0 };
|
|
23
|
+
}
|
|
24
|
+
const endpoint = accessConfig['endpoints'][endpointPath];
|
|
25
|
+
if (!endpoint) {
|
|
26
|
+
return { data, records: [], strippedCount: 0, redactableCount: 0 };
|
|
27
|
+
}
|
|
28
|
+
const entityTypes = new Set(endpoint.returns);
|
|
29
|
+
const restrictions = (accessConfig.fieldRestrictions ?? []).filter((r) => entityTypes.has(r.entity));
|
|
30
|
+
if (restrictions.length === 0) {
|
|
31
|
+
return { data, records: [], strippedCount: 0, redactableCount: 0 };
|
|
32
|
+
}
|
|
33
|
+
const restrictionsByEntity = new Map();
|
|
34
|
+
for (const r of restrictions) {
|
|
35
|
+
const existing = restrictionsByEntity.get(r.entity) ?? [];
|
|
36
|
+
existing.push(r);
|
|
37
|
+
restrictionsByEntity.set(r.entity, existing);
|
|
38
|
+
}
|
|
39
|
+
const records = [];
|
|
40
|
+
let strippedCount = 0;
|
|
41
|
+
let redactableCount = 0;
|
|
42
|
+
const scrubbed = this.walkAndScrub(data, restrictionsByEntity, connectionName, records);
|
|
43
|
+
for (const record of records) {
|
|
44
|
+
if (record.policy === 'never_retrieve') {
|
|
45
|
+
strippedCount++;
|
|
46
|
+
}
|
|
47
|
+
else if (record.policy === 'retrieve_but_redact') {
|
|
48
|
+
redactableCount++;
|
|
49
|
+
}
|
|
50
|
+
else if (record.policy === 'role_gated') {
|
|
51
|
+
if (!this.hasRole(this.findRestriction(restrictions, record))) {
|
|
52
|
+
strippedCount++;
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
redactableCount++;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
this.tracker.addRecords(records);
|
|
60
|
+
return { data: scrubbed, records, strippedCount, redactableCount };
|
|
61
|
+
}
|
|
62
|
+
findRestriction(restrictions, record) {
|
|
63
|
+
return restrictions.find((r) => r.entity === record.entity && r.field === record.field);
|
|
64
|
+
}
|
|
65
|
+
hasRole(restriction) {
|
|
66
|
+
if (!restriction)
|
|
67
|
+
return false;
|
|
68
|
+
const allowed = restriction.allowedRoles;
|
|
69
|
+
if (!allowed || allowed.length === 0)
|
|
70
|
+
return false;
|
|
71
|
+
return this.userRoles.some((role) => allowed.includes(role));
|
|
72
|
+
}
|
|
73
|
+
walkAndScrub(data, restrictionsByEntity, connectionName, records, entityHint) {
|
|
74
|
+
if (data === null || data === undefined)
|
|
75
|
+
return data;
|
|
76
|
+
if (Array.isArray(data)) {
|
|
77
|
+
return data.map((item) => this.walkAndScrub(item, restrictionsByEntity, connectionName, records, entityHint));
|
|
78
|
+
}
|
|
79
|
+
if (typeof data === 'object') {
|
|
80
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-type-assertion -- SDK boundary: data is verified object
|
|
81
|
+
const obj = data;
|
|
82
|
+
const result = {};
|
|
83
|
+
for (const key of Object.keys(obj)) {
|
|
84
|
+
const value = obj[key];
|
|
85
|
+
// Determine entity hint from key name
|
|
86
|
+
const singularKey = depluralize(key);
|
|
87
|
+
const childEntityHint = restrictionsByEntity.has(singularKey)
|
|
88
|
+
? singularKey
|
|
89
|
+
: restrictionsByEntity.has(key)
|
|
90
|
+
? key
|
|
91
|
+
: entityHint;
|
|
92
|
+
// Check if this field is restricted for the current entity
|
|
93
|
+
if (entityHint) {
|
|
94
|
+
const entityRestrictions = restrictionsByEntity.get(entityHint);
|
|
95
|
+
if (entityRestrictions) {
|
|
96
|
+
const restriction = entityRestrictions.find((r) => r.field === key);
|
|
97
|
+
if (restriction) {
|
|
98
|
+
const strValue = String(value ?? '');
|
|
99
|
+
const record = {
|
|
100
|
+
value: strValue,
|
|
101
|
+
entity: restriction.entity,
|
|
102
|
+
field: restriction.field,
|
|
103
|
+
sensitivity: restriction.sensitivity,
|
|
104
|
+
policy: restriction.policy,
|
|
105
|
+
connectionName,
|
|
106
|
+
timestamp: Date.now(),
|
|
107
|
+
};
|
|
108
|
+
if (restriction.policy === 'never_retrieve') {
|
|
109
|
+
records.push(record);
|
|
110
|
+
continue; // strip field entirely
|
|
111
|
+
}
|
|
112
|
+
else if (restriction.policy === 'retrieve_but_redact') {
|
|
113
|
+
records.push(record);
|
|
114
|
+
result[key] = value; // keep for now, output guard redacts
|
|
115
|
+
}
|
|
116
|
+
else if (restriction.policy === 'role_gated') {
|
|
117
|
+
if (this.hasRole(restriction)) {
|
|
118
|
+
records.push(record);
|
|
119
|
+
result[key] = value; // keep, redactable
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
records.push(record);
|
|
123
|
+
continue; // strip — no role access
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
continue;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
// Recurse into nested objects/arrays
|
|
131
|
+
if (typeof value === 'object' && value !== null) {
|
|
132
|
+
result[key] = this.walkAndScrub(value, restrictionsByEntity, connectionName, records, Array.isArray(value) ? singularKey : childEntityHint);
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
result[key] = value;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
return result;
|
|
139
|
+
}
|
|
140
|
+
return data;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Naive depluralize: strip trailing 's'.
|
|
145
|
+
*/
|
|
146
|
+
function depluralize(key) {
|
|
147
|
+
if (key.endsWith('s') && key.length > 1) {
|
|
148
|
+
return key.slice(0, -1);
|
|
149
|
+
}
|
|
150
|
+
return key;
|
|
151
|
+
}
|
|
152
|
+
//# sourceMappingURL=field-scrubber.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"field-scrubber.js","sourceRoot":"","sources":["../../../src/security/field-scrubber.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
export * from './security-types.js';
|
|
7
|
+
export * from './scrub-tracker.js';
|
|
8
|
+
export * from './field-scrubber.js';
|
|
9
|
+
export * from './pattern-scanner.js';
|
|
10
|
+
export * from './leak-detector.js';
|
|
11
|
+
export * from './scope-checker.js';
|
|
12
|
+
export * from './output-guard.js';
|
|
13
|
+
export * from './threshold-evaluator.js';
|
|
14
|
+
export * from './action-gate.js';
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
export * from './security-types.js';
|
|
7
|
+
export * from './scrub-tracker.js';
|
|
8
|
+
export * from './field-scrubber.js';
|
|
9
|
+
export * from './pattern-scanner.js';
|
|
10
|
+
export * from './leak-detector.js';
|
|
11
|
+
export * from './scope-checker.js';
|
|
12
|
+
export * from './output-guard.js';
|
|
13
|
+
export * from './threshold-evaluator.js';
|
|
14
|
+
export * from './action-gate.js';
|
|
15
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/security/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,mBAAmB,CAAC;AAClC,cAAc,0BAA0B,CAAC;AACzC,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import type { ScrubRecord } from './security-types.js';
|
|
7
|
+
import type { ScrubTracker } from './scrub-tracker.js';
|
|
8
|
+
/**
|
|
9
|
+
* A detected leak of a previously scrubbed value.
|
|
10
|
+
*/
|
|
11
|
+
export interface LeakMatch {
|
|
12
|
+
record: ScrubRecord;
|
|
13
|
+
matchedText: string;
|
|
14
|
+
contextual: boolean;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Compares agent output against tracked scrubbed values to detect leaks.
|
|
18
|
+
*/
|
|
19
|
+
export declare class LeakDetector {
|
|
20
|
+
private readonly tracker;
|
|
21
|
+
constructor(tracker: ScrubTracker);
|
|
22
|
+
detect(text: string): LeakMatch[];
|
|
23
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* Compares agent output against tracked scrubbed values to detect leaks.
|
|
8
|
+
*/
|
|
9
|
+
export class LeakDetector {
|
|
10
|
+
tracker;
|
|
11
|
+
constructor(tracker) {
|
|
12
|
+
this.tracker = tracker;
|
|
13
|
+
}
|
|
14
|
+
detect(text) {
|
|
15
|
+
const matches = [];
|
|
16
|
+
const records = this.tracker.getAllRecords();
|
|
17
|
+
for (const record of records) {
|
|
18
|
+
if (record.value.length < 2)
|
|
19
|
+
continue;
|
|
20
|
+
const index = text.indexOf(record.value);
|
|
21
|
+
if (index === -1)
|
|
22
|
+
continue;
|
|
23
|
+
if (record.sensitivity === 'pii_name') {
|
|
24
|
+
// Only flag pii_name if near entity name/ID context
|
|
25
|
+
const contextStart = Math.max(0, index - 200);
|
|
26
|
+
const contextEnd = Math.min(text.length, index + record.value.length + 200);
|
|
27
|
+
const context = text.slice(contextStart, contextEnd);
|
|
28
|
+
const hasEntityContext = context.toLowerCase().includes(record.entity.toLowerCase()) ||
|
|
29
|
+
(record.entityId !== undefined &&
|
|
30
|
+
context.includes(record.entityId));
|
|
31
|
+
if (hasEntityContext) {
|
|
32
|
+
matches.push({
|
|
33
|
+
record,
|
|
34
|
+
matchedText: record.value,
|
|
35
|
+
contextual: true,
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
// pii_identifier, financial, etc.: always flag
|
|
41
|
+
matches.push({
|
|
42
|
+
record,
|
|
43
|
+
matchedText: record.value,
|
|
44
|
+
contextual: false,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return matches;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=leak-detector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"leak-detector.js","sourceRoot":"","sources":["../../../src/security/leak-detector.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAcH;;GAEG;AACH,MAAM,OAAO,YAAY;IACN,OAAO,CAAe;IAEvC,YAAY,OAAqB;QAC/B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED,MAAM,CAAC,IAAY;QACjB,MAAM,OAAO,GAAgB,EAAE,CAAC;QAChC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;QAE7C,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;gBAAE,SAAS;YAEtC,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACzC,IAAI,KAAK,KAAK,CAAC,CAAC;gBAAE,SAAS;YAE3B,IAAI,MAAM,CAAC,WAAW,KAAK,UAAU,EAAE,CAAC;gBACtC,oDAAoD;gBACpD,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,GAAG,GAAG,CAAC,CAAC;gBAC9C,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC;gBAC5E,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;gBAErD,MAAM,gBAAgB,GACpB,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;oBAC3D,CAAC,MAAM,CAAC,QAAQ,KAAK,SAAS;wBAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;gBAEvC,IAAI,gBAAgB,EAAE,CAAC;oBACrB,OAAO,CAAC,IAAI,CAAC;wBACX,MAAM;wBACN,WAAW,EAAE,MAAM,CAAC,KAAK;wBACzB,UAAU,EAAE,IAAI;qBACjB,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,+CAA+C;gBAC/C,OAAO,CAAC,IAAI,CAAC;oBACX,MAAM;oBACN,WAAW,EAAE,MAAM,CAAC,KAAK;oBACzB,UAAU,EAAE,KAAK;iBAClB,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;CACF"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import type { AccessConfig } from '../repo/connection-schemas.js';
|
|
7
|
+
import type { ScrubTracker } from './scrub-tracker.js';
|
|
8
|
+
import type { GuardResult } from './security-types.js';
|
|
9
|
+
import type { ScopeCheckerContext } from './scope-checker.js';
|
|
10
|
+
export interface OutputGuardConfig {
|
|
11
|
+
tracker: ScrubTracker;
|
|
12
|
+
accessConfigs: Map<string, AccessConfig>;
|
|
13
|
+
userRoles: string[];
|
|
14
|
+
scopeContext?: ScopeCheckerContext;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Orchestrates four output guard stages to filter agent responses
|
|
18
|
+
* before the user sees them.
|
|
19
|
+
*/
|
|
20
|
+
export declare class OutputGuard {
|
|
21
|
+
private readonly tracker;
|
|
22
|
+
private readonly userRoles;
|
|
23
|
+
private readonly patternScanner;
|
|
24
|
+
private readonly leakDetector;
|
|
25
|
+
private readonly scopeChecker;
|
|
26
|
+
constructor(config: OutputGuardConfig);
|
|
27
|
+
guard(output: string): GuardResult;
|
|
28
|
+
/**
|
|
29
|
+
* Look up the original restriction for a scrub record.
|
|
30
|
+
* Returns a minimal object with allowedRoles for the role check.
|
|
31
|
+
*/
|
|
32
|
+
private findRestrictionForRecord;
|
|
33
|
+
}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { PatternScanner } from './pattern-scanner.js';
|
|
7
|
+
import { LeakDetector } from './leak-detector.js';
|
|
8
|
+
import { ScopeChecker } from './scope-checker.js';
|
|
9
|
+
/**
|
|
10
|
+
* Orchestrates four output guard stages to filter agent responses
|
|
11
|
+
* before the user sees them.
|
|
12
|
+
*/
|
|
13
|
+
export class OutputGuard {
|
|
14
|
+
tracker;
|
|
15
|
+
userRoles;
|
|
16
|
+
patternScanner;
|
|
17
|
+
leakDetector;
|
|
18
|
+
scopeChecker;
|
|
19
|
+
constructor(config) {
|
|
20
|
+
this.tracker = config.tracker;
|
|
21
|
+
this.userRoles = config.userRoles;
|
|
22
|
+
this.patternScanner = new PatternScanner();
|
|
23
|
+
this.leakDetector = new LeakDetector(config.tracker);
|
|
24
|
+
this.scopeChecker = config.scopeContext
|
|
25
|
+
? new ScopeChecker(config.scopeContext)
|
|
26
|
+
: null;
|
|
27
|
+
}
|
|
28
|
+
guard(output) {
|
|
29
|
+
const findings = [];
|
|
30
|
+
let text = output;
|
|
31
|
+
let modified = false;
|
|
32
|
+
// Stage 1: Field redaction — replace retrieve_but_redact and denied role_gated values
|
|
33
|
+
const redactableRecords = this.tracker.getAllRecords().filter((r) => {
|
|
34
|
+
if (r.policy === 'retrieve_but_redact')
|
|
35
|
+
return true;
|
|
36
|
+
if (r.policy === 'role_gated') {
|
|
37
|
+
// Check if user lacks role
|
|
38
|
+
const restriction = this.findRestrictionForRecord(r);
|
|
39
|
+
if (!restriction)
|
|
40
|
+
return true; // conservative
|
|
41
|
+
const allowed = restriction.allowedRoles;
|
|
42
|
+
if (!allowed || allowed.length === 0)
|
|
43
|
+
return true;
|
|
44
|
+
return !this.userRoles.some((role) => allowed.includes(role));
|
|
45
|
+
}
|
|
46
|
+
return false;
|
|
47
|
+
});
|
|
48
|
+
for (const record of redactableRecords) {
|
|
49
|
+
if (record.value.length < 2)
|
|
50
|
+
continue;
|
|
51
|
+
if (text.includes(record.value)) {
|
|
52
|
+
text = text.split(record.value).join('[REDACTED]');
|
|
53
|
+
modified = true;
|
|
54
|
+
findings.push({
|
|
55
|
+
type: 'field_redaction',
|
|
56
|
+
description: `Redacted ${record.sensitivity} field "${record.field}" from ${record.entity}`,
|
|
57
|
+
severity: 'info',
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
// Stage 2: Pattern scan — regex for SSN/CC/bank patterns
|
|
62
|
+
const patterns = this.patternScanner.scan(text);
|
|
63
|
+
for (const p of patterns) {
|
|
64
|
+
text = text.split(p.match).join('[REDACTED]');
|
|
65
|
+
modified = true;
|
|
66
|
+
findings.push({
|
|
67
|
+
type: 'pattern_match',
|
|
68
|
+
description: `Detected ${p.pattern} pattern`,
|
|
69
|
+
location: `index ${p.index}`,
|
|
70
|
+
severity: 'critical',
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
// Stage 3: Leak detection — compare against tracker values
|
|
74
|
+
const leaks = this.leakDetector.detect(text);
|
|
75
|
+
for (const leak of leaks) {
|
|
76
|
+
const severity = leak.record.sensitivity === 'pii_identifier' ? 'critical' : 'warning';
|
|
77
|
+
if (severity === 'critical') {
|
|
78
|
+
text = text.split(leak.matchedText).join('[REDACTED]');
|
|
79
|
+
modified = true;
|
|
80
|
+
}
|
|
81
|
+
findings.push({
|
|
82
|
+
type: 'leak_detected',
|
|
83
|
+
description: `Leaked ${leak.record.sensitivity} value for ${leak.record.entity}.${leak.record.field}`,
|
|
84
|
+
severity,
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
// Stage 4: Scope check — flag unqualified aggregates
|
|
88
|
+
if (this.scopeChecker) {
|
|
89
|
+
const violations = this.scopeChecker.check(text);
|
|
90
|
+
for (const v of violations) {
|
|
91
|
+
findings.push({
|
|
92
|
+
type: 'scope_violation',
|
|
93
|
+
description: `Unqualified aggregate for "${v.entity}" — expected: ${v.expectedQualification}`,
|
|
94
|
+
location: v.snippet,
|
|
95
|
+
severity: 'warning',
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
const blocked = findings.some((f) => f.severity === 'critical');
|
|
100
|
+
return { output: text, modified, findings, blocked };
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Look up the original restriction for a scrub record.
|
|
104
|
+
* Returns a minimal object with allowedRoles for the role check.
|
|
105
|
+
*/
|
|
106
|
+
findRestrictionForRecord(record) {
|
|
107
|
+
const accessConfig = this.tracker
|
|
108
|
+
.getAllRecords()
|
|
109
|
+
.find((r) => r.entity === record.entity &&
|
|
110
|
+
r.field === record.field &&
|
|
111
|
+
r.connectionName === record.connectionName);
|
|
112
|
+
// We don't have direct access to the restriction, but we stored policy
|
|
113
|
+
// For role_gated, we need the original restriction's allowedRoles
|
|
114
|
+
// Since we only have the record, treat missing roles as denied (conservative)
|
|
115
|
+
return accessConfig ? { allowedRoles: [] } : undefined;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=output-guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"output-guard.js","sourceRoot":"","sources":["../../../src/security/output-guard.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* A match found by the pattern scanner.
|
|
8
|
+
*/
|
|
9
|
+
export interface PatternMatch {
|
|
10
|
+
pattern: string;
|
|
11
|
+
match: string;
|
|
12
|
+
index: number;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Regex-based PII pattern detection.
|
|
16
|
+
*/
|
|
17
|
+
export declare class PatternScanner {
|
|
18
|
+
scan(text: string): PatternMatch[];
|
|
19
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* Luhn check for credit card validation.
|
|
8
|
+
*/
|
|
9
|
+
function passesLuhn(digits) {
|
|
10
|
+
let sum = 0;
|
|
11
|
+
let alternate = false;
|
|
12
|
+
for (let i = digits.length - 1; i >= 0; i--) {
|
|
13
|
+
let n = parseInt(digits[i], 10);
|
|
14
|
+
if (alternate) {
|
|
15
|
+
n *= 2;
|
|
16
|
+
if (n > 9) {
|
|
17
|
+
n -= 9;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
sum += n;
|
|
21
|
+
alternate = !alternate;
|
|
22
|
+
}
|
|
23
|
+
return sum % 10 === 0;
|
|
24
|
+
}
|
|
25
|
+
const SSN_PATTERN = /\b\d{3}-\d{2}-\d{4}\b/g;
|
|
26
|
+
const CC_PATTERN = /\b(\d[\d\s-]{8,22}\d)\b/g;
|
|
27
|
+
const BANK_ACCOUNT_KEYWORD = /\b(?:account|routing|acct|aba)\b/i;
|
|
28
|
+
/**
|
|
29
|
+
* Regex-based PII pattern detection.
|
|
30
|
+
*/
|
|
31
|
+
export class PatternScanner {
|
|
32
|
+
scan(text) {
|
|
33
|
+
const matches = [];
|
|
34
|
+
// SSN
|
|
35
|
+
let m;
|
|
36
|
+
const ssnRe = new RegExp(SSN_PATTERN.source, 'g');
|
|
37
|
+
while ((m = ssnRe.exec(text)) !== null) {
|
|
38
|
+
matches.push({ pattern: 'ssn', match: m[0], index: m.index });
|
|
39
|
+
}
|
|
40
|
+
// Credit card (13-19 digits with Luhn)
|
|
41
|
+
const ccRe = new RegExp(CC_PATTERN.source, 'g');
|
|
42
|
+
while ((m = ccRe.exec(text)) !== null) {
|
|
43
|
+
const raw = m[0];
|
|
44
|
+
const digits = raw.replace(/[\s-]/g, '');
|
|
45
|
+
if (digits.length >= 13 && digits.length <= 19 && passesLuhn(digits)) {
|
|
46
|
+
matches.push({ pattern: 'credit_card', match: raw, index: m.index });
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
// Bank account (8-17 digits near keywords)
|
|
50
|
+
const bankRe = /\b(\d{8,17})\b/g;
|
|
51
|
+
while ((m = bankRe.exec(text)) !== null) {
|
|
52
|
+
const start = Math.max(0, m.index - 100);
|
|
53
|
+
const end = Math.min(text.length, m.index + m[0].length + 100);
|
|
54
|
+
const context = text.slice(start, end);
|
|
55
|
+
if (BANK_ACCOUNT_KEYWORD.test(context)) {
|
|
56
|
+
matches.push({
|
|
57
|
+
pattern: 'bank_account',
|
|
58
|
+
match: m[0],
|
|
59
|
+
index: m.index,
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return matches;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=pattern-scanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pattern-scanner.js","sourceRoot":"","sources":["../../../src/security/pattern-scanner.ts"],"names":[],"mappings":"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"}
|