palaryn 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/README.md +716 -0
- package/dist/sdk/typescript/src/client.d.ts +71 -0
- package/dist/sdk/typescript/src/client.d.ts.map +1 -0
- package/dist/sdk/typescript/src/client.js +176 -0
- package/dist/sdk/typescript/src/client.js.map +1 -0
- package/dist/sdk/typescript/src/errors.d.ts +50 -0
- package/dist/sdk/typescript/src/errors.d.ts.map +1 -0
- package/dist/sdk/typescript/src/errors.js +103 -0
- package/dist/sdk/typescript/src/errors.js.map +1 -0
- package/dist/sdk/typescript/src/index.d.ts +4 -0
- package/dist/sdk/typescript/src/index.d.ts.map +1 -0
- package/dist/sdk/typescript/src/index.js +15 -0
- package/dist/sdk/typescript/src/index.js.map +1 -0
- package/dist/sdk/typescript/src/types.d.ts +101 -0
- package/dist/sdk/typescript/src/types.d.ts.map +1 -0
- package/dist/sdk/typescript/src/types.js +6 -0
- package/dist/sdk/typescript/src/types.js.map +1 -0
- package/dist/src/admin/index.d.ts +2 -0
- package/dist/src/admin/index.d.ts.map +1 -0
- package/dist/src/admin/index.js +6 -0
- package/dist/src/admin/index.js.map +1 -0
- package/dist/src/admin/routes.d.ts +5 -0
- package/dist/src/admin/routes.d.ts.map +1 -0
- package/dist/src/admin/routes.js +471 -0
- package/dist/src/admin/routes.js.map +1 -0
- package/dist/src/admin/templates.d.ts +51 -0
- package/dist/src/admin/templates.d.ts.map +1 -0
- package/dist/src/admin/templates.js +500 -0
- package/dist/src/admin/templates.js.map +1 -0
- package/dist/src/anomaly/detector.d.ts +141 -0
- package/dist/src/anomaly/detector.d.ts.map +1 -0
- package/dist/src/anomaly/detector.js +554 -0
- package/dist/src/anomaly/detector.js.map +1 -0
- package/dist/src/anomaly/index.d.ts +2 -0
- package/dist/src/anomaly/index.d.ts.map +1 -0
- package/dist/src/anomaly/index.js +7 -0
- package/dist/src/anomaly/index.js.map +1 -0
- package/dist/src/approval/manager.d.ts +147 -0
- package/dist/src/approval/manager.d.ts.map +1 -0
- package/dist/src/approval/manager.js +511 -0
- package/dist/src/approval/manager.js.map +1 -0
- package/dist/src/approval/webhook.d.ts +36 -0
- package/dist/src/approval/webhook.d.ts.map +1 -0
- package/dist/src/approval/webhook.js +135 -0
- package/dist/src/approval/webhook.js.map +1 -0
- package/dist/src/audit/logger.d.ts +70 -0
- package/dist/src/audit/logger.d.ts.map +1 -0
- package/dist/src/audit/logger.js +440 -0
- package/dist/src/audit/logger.js.map +1 -0
- package/dist/src/auth/index.d.ts +6 -0
- package/dist/src/auth/index.d.ts.map +1 -0
- package/dist/src/auth/index.js +22 -0
- package/dist/src/auth/index.js.map +1 -0
- package/dist/src/auth/password.d.ts +3 -0
- package/dist/src/auth/password.d.ts.map +1 -0
- package/dist/src/auth/password.js +25 -0
- package/dist/src/auth/password.js.map +1 -0
- package/dist/src/auth/pkce.d.ts +13 -0
- package/dist/src/auth/pkce.d.ts.map +1 -0
- package/dist/src/auth/pkce.js +58 -0
- package/dist/src/auth/pkce.js.map +1 -0
- package/dist/src/auth/providers.d.ts +28 -0
- package/dist/src/auth/providers.d.ts.map +1 -0
- package/dist/src/auth/providers.js +198 -0
- package/dist/src/auth/providers.js.map +1 -0
- package/dist/src/auth/routes.d.ts +14 -0
- package/dist/src/auth/routes.d.ts.map +1 -0
- package/dist/src/auth/routes.js +431 -0
- package/dist/src/auth/routes.js.map +1 -0
- package/dist/src/auth/session.d.ts +24 -0
- package/dist/src/auth/session.d.ts.map +1 -0
- package/dist/src/auth/session.js +105 -0
- package/dist/src/auth/session.js.map +1 -0
- package/dist/src/billing/index.d.ts +7 -0
- package/dist/src/billing/index.d.ts.map +1 -0
- package/dist/src/billing/index.js +14 -0
- package/dist/src/billing/index.js.map +1 -0
- package/dist/src/billing/plan-enforcer.d.ts +44 -0
- package/dist/src/billing/plan-enforcer.d.ts.map +1 -0
- package/dist/src/billing/plan-enforcer.js +110 -0
- package/dist/src/billing/plan-enforcer.js.map +1 -0
- package/dist/src/billing/routes.d.ts +15 -0
- package/dist/src/billing/routes.d.ts.map +1 -0
- package/dist/src/billing/routes.js +193 -0
- package/dist/src/billing/routes.js.map +1 -0
- package/dist/src/billing/stripe-client.d.ts +14 -0
- package/dist/src/billing/stripe-client.d.ts.map +1 -0
- package/dist/src/billing/stripe-client.js +51 -0
- package/dist/src/billing/stripe-client.js.map +1 -0
- package/dist/src/billing/webhook-handler.d.ts +19 -0
- package/dist/src/billing/webhook-handler.d.ts.map +1 -0
- package/dist/src/billing/webhook-handler.js +169 -0
- package/dist/src/billing/webhook-handler.js.map +1 -0
- package/dist/src/billing/webhook-routes.d.ts +5 -0
- package/dist/src/billing/webhook-routes.d.ts.map +1 -0
- package/dist/src/billing/webhook-routes.js +30 -0
- package/dist/src/billing/webhook-routes.js.map +1 -0
- package/dist/src/budget/manager.d.ts +95 -0
- package/dist/src/budget/manager.d.ts.map +1 -0
- package/dist/src/budget/manager.js +547 -0
- package/dist/src/budget/manager.js.map +1 -0
- package/dist/src/budget/usage-extractor.d.ts +38 -0
- package/dist/src/budget/usage-extractor.d.ts.map +1 -0
- package/dist/src/budget/usage-extractor.js +165 -0
- package/dist/src/budget/usage-extractor.js.map +1 -0
- package/dist/src/cli.d.ts +3 -0
- package/dist/src/cli.d.ts.map +1 -0
- package/dist/src/cli.js +115 -0
- package/dist/src/cli.js.map +1 -0
- package/dist/src/config/defaults.d.ts +3 -0
- package/dist/src/config/defaults.d.ts.map +1 -0
- package/dist/src/config/defaults.js +243 -0
- package/dist/src/config/defaults.js.map +1 -0
- package/dist/src/config/validate.d.ts +15 -0
- package/dist/src/config/validate.d.ts.map +1 -0
- package/dist/src/config/validate.js +105 -0
- package/dist/src/config/validate.js.map +1 -0
- package/dist/src/dlp/composite-scanner.d.ts +47 -0
- package/dist/src/dlp/composite-scanner.d.ts.map +1 -0
- package/dist/src/dlp/composite-scanner.js +186 -0
- package/dist/src/dlp/composite-scanner.js.map +1 -0
- package/dist/src/dlp/index.d.ts +10 -0
- package/dist/src/dlp/index.d.ts.map +1 -0
- package/dist/src/dlp/index.js +26 -0
- package/dist/src/dlp/index.js.map +1 -0
- package/dist/src/dlp/interfaces.d.ts +33 -0
- package/dist/src/dlp/interfaces.d.ts.map +1 -0
- package/dist/src/dlp/interfaces.js +3 -0
- package/dist/src/dlp/interfaces.js.map +1 -0
- package/dist/src/dlp/patterns.d.ts +9 -0
- package/dist/src/dlp/patterns.d.ts.map +1 -0
- package/dist/src/dlp/patterns.js +25 -0
- package/dist/src/dlp/patterns.js.map +1 -0
- package/dist/src/dlp/prompt-injection-backend.d.ts +68 -0
- package/dist/src/dlp/prompt-injection-backend.d.ts.map +1 -0
- package/dist/src/dlp/prompt-injection-backend.js +148 -0
- package/dist/src/dlp/prompt-injection-backend.js.map +1 -0
- package/dist/src/dlp/prompt-injection-patterns.d.ts +32 -0
- package/dist/src/dlp/prompt-injection-patterns.d.ts.map +1 -0
- package/dist/src/dlp/prompt-injection-patterns.js +290 -0
- package/dist/src/dlp/prompt-injection-patterns.js.map +1 -0
- package/dist/src/dlp/regex-backend.d.ts +32 -0
- package/dist/src/dlp/regex-backend.d.ts.map +1 -0
- package/dist/src/dlp/regex-backend.js +153 -0
- package/dist/src/dlp/regex-backend.js.map +1 -0
- package/dist/src/dlp/scanner.d.ts +122 -0
- package/dist/src/dlp/scanner.d.ts.map +1 -0
- package/dist/src/dlp/scanner.js +444 -0
- package/dist/src/dlp/scanner.js.map +1 -0
- package/dist/src/dlp/text-normalizer.d.ts +41 -0
- package/dist/src/dlp/text-normalizer.d.ts.map +1 -0
- package/dist/src/dlp/text-normalizer.js +203 -0
- package/dist/src/dlp/text-normalizer.js.map +1 -0
- package/dist/src/dlp/trufflehog-backend.d.ts +64 -0
- package/dist/src/dlp/trufflehog-backend.d.ts.map +1 -0
- package/dist/src/dlp/trufflehog-backend.js +151 -0
- package/dist/src/dlp/trufflehog-backend.js.map +1 -0
- package/dist/src/executor/http-executor.d.ts +25 -0
- package/dist/src/executor/http-executor.d.ts.map +1 -0
- package/dist/src/executor/http-executor.js +333 -0
- package/dist/src/executor/http-executor.js.map +1 -0
- package/dist/src/executor/index.d.ts +6 -0
- package/dist/src/executor/index.d.ts.map +1 -0
- package/dist/src/executor/index.js +12 -0
- package/dist/src/executor/index.js.map +1 -0
- package/dist/src/executor/interfaces.d.ts +11 -0
- package/dist/src/executor/interfaces.d.ts.map +1 -0
- package/dist/src/executor/interfaces.js +3 -0
- package/dist/src/executor/interfaces.js.map +1 -0
- package/dist/src/executor/noop-executor.d.ts +13 -0
- package/dist/src/executor/noop-executor.d.ts.map +1 -0
- package/dist/src/executor/noop-executor.js +21 -0
- package/dist/src/executor/noop-executor.js.map +1 -0
- package/dist/src/executor/registry.d.ts +30 -0
- package/dist/src/executor/registry.d.ts.map +1 -0
- package/dist/src/executor/registry.js +62 -0
- package/dist/src/executor/registry.js.map +1 -0
- package/dist/src/executor/slack-executor.d.ts +24 -0
- package/dist/src/executor/slack-executor.d.ts.map +1 -0
- package/dist/src/executor/slack-executor.js +147 -0
- package/dist/src/executor/slack-executor.js.map +1 -0
- package/dist/src/index.d.ts +25 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +74 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/mcp/auth-verifier.d.ts +23 -0
- package/dist/src/mcp/auth-verifier.d.ts.map +1 -0
- package/dist/src/mcp/auth-verifier.js +162 -0
- package/dist/src/mcp/auth-verifier.js.map +1 -0
- package/dist/src/mcp/bridge.d.ts +132 -0
- package/dist/src/mcp/bridge.d.ts.map +1 -0
- package/dist/src/mcp/bridge.js +734 -0
- package/dist/src/mcp/bridge.js.map +1 -0
- package/dist/src/mcp/http-transport.d.ts +32 -0
- package/dist/src/mcp/http-transport.d.ts.map +1 -0
- package/dist/src/mcp/http-transport.js +538 -0
- package/dist/src/mcp/http-transport.js.map +1 -0
- package/dist/src/mcp/index.d.ts +10 -0
- package/dist/src/mcp/index.d.ts.map +1 -0
- package/dist/src/mcp/index.js +17 -0
- package/dist/src/mcp/index.js.map +1 -0
- package/dist/src/mcp/oauth-pages.d.ts +23 -0
- package/dist/src/mcp/oauth-pages.d.ts.map +1 -0
- package/dist/src/mcp/oauth-pages.js +121 -0
- package/dist/src/mcp/oauth-pages.js.map +1 -0
- package/dist/src/mcp/oauth-postgres-stores.d.ts +55 -0
- package/dist/src/mcp/oauth-postgres-stores.d.ts.map +1 -0
- package/dist/src/mcp/oauth-postgres-stores.js +226 -0
- package/dist/src/mcp/oauth-postgres-stores.js.map +1 -0
- package/dist/src/mcp/oauth-provider.d.ts +95 -0
- package/dist/src/mcp/oauth-provider.d.ts.map +1 -0
- package/dist/src/mcp/oauth-provider.js +360 -0
- package/dist/src/mcp/oauth-provider.js.map +1 -0
- package/dist/src/mcp/oauth-stores.d.ts +62 -0
- package/dist/src/mcp/oauth-stores.d.ts.map +1 -0
- package/dist/src/mcp/oauth-stores.js +154 -0
- package/dist/src/mcp/oauth-stores.js.map +1 -0
- package/dist/src/mcp/server.d.ts +18 -0
- package/dist/src/mcp/server.d.ts.map +1 -0
- package/dist/src/mcp/server.js +51 -0
- package/dist/src/mcp/server.js.map +1 -0
- package/dist/src/metrics/collector.d.ts +106 -0
- package/dist/src/metrics/collector.d.ts.map +1 -0
- package/dist/src/metrics/collector.js +311 -0
- package/dist/src/metrics/collector.js.map +1 -0
- package/dist/src/metrics/index.d.ts +2 -0
- package/dist/src/metrics/index.d.ts.map +1 -0
- package/dist/src/metrics/index.js +6 -0
- package/dist/src/metrics/index.js.map +1 -0
- package/dist/src/middleware/auth.d.ts +77 -0
- package/dist/src/middleware/auth.d.ts.map +1 -0
- package/dist/src/middleware/auth.js +720 -0
- package/dist/src/middleware/auth.js.map +1 -0
- package/dist/src/middleware/session.d.ts +18 -0
- package/dist/src/middleware/session.d.ts.map +1 -0
- package/dist/src/middleware/session.js +67 -0
- package/dist/src/middleware/session.js.map +1 -0
- package/dist/src/middleware/validate.d.ts +3 -0
- package/dist/src/middleware/validate.d.ts.map +1 -0
- package/dist/src/middleware/validate.js +85 -0
- package/dist/src/middleware/validate.js.map +1 -0
- package/dist/src/policy/engine.d.ts +107 -0
- package/dist/src/policy/engine.d.ts.map +1 -0
- package/dist/src/policy/engine.js +646 -0
- package/dist/src/policy/engine.js.map +1 -0
- package/dist/src/policy/index.d.ts +3 -0
- package/dist/src/policy/index.d.ts.map +1 -0
- package/dist/src/policy/index.js +8 -0
- package/dist/src/policy/index.js.map +1 -0
- package/dist/src/policy/opa-engine.d.ts +176 -0
- package/dist/src/policy/opa-engine.d.ts.map +1 -0
- package/dist/src/policy/opa-engine.js +790 -0
- package/dist/src/policy/opa-engine.js.map +1 -0
- package/dist/src/proxy/forward-proxy.d.ts +30 -0
- package/dist/src/proxy/forward-proxy.d.ts.map +1 -0
- package/dist/src/proxy/forward-proxy.js +580 -0
- package/dist/src/proxy/forward-proxy.js.map +1 -0
- package/dist/src/proxy/index.d.ts +2 -0
- package/dist/src/proxy/index.d.ts.map +1 -0
- package/dist/src/proxy/index.js +8 -0
- package/dist/src/proxy/index.js.map +1 -0
- package/dist/src/ratelimit/limiter.d.ts +45 -0
- package/dist/src/ratelimit/limiter.d.ts.map +1 -0
- package/dist/src/ratelimit/limiter.js +158 -0
- package/dist/src/ratelimit/limiter.js.map +1 -0
- package/dist/src/replay/engine.d.ts +40 -0
- package/dist/src/replay/engine.d.ts.map +1 -0
- package/dist/src/replay/engine.js +106 -0
- package/dist/src/replay/engine.js.map +1 -0
- package/dist/src/replay/index.d.ts +2 -0
- package/dist/src/replay/index.d.ts.map +1 -0
- package/dist/src/replay/index.js +6 -0
- package/dist/src/replay/index.js.map +1 -0
- package/dist/src/saas/index.d.ts +2 -0
- package/dist/src/saas/index.d.ts.map +1 -0
- package/dist/src/saas/index.js +18 -0
- package/dist/src/saas/index.js.map +1 -0
- package/dist/src/saas/routes.d.ts +18 -0
- package/dist/src/saas/routes.d.ts.map +1 -0
- package/dist/src/saas/routes.js +1566 -0
- package/dist/src/saas/routes.js.map +1 -0
- package/dist/src/server/app.d.ts +44 -0
- package/dist/src/server/app.d.ts.map +1 -0
- package/dist/src/server/app.js +854 -0
- package/dist/src/server/app.js.map +1 -0
- package/dist/src/server/errors.d.ts +32 -0
- package/dist/src/server/errors.d.ts.map +1 -0
- package/dist/src/server/errors.js +39 -0
- package/dist/src/server/errors.js.map +1 -0
- package/dist/src/server/gateway.d.ts +165 -0
- package/dist/src/server/gateway.d.ts.map +1 -0
- package/dist/src/server/gateway.js +964 -0
- package/dist/src/server/gateway.js.map +1 -0
- package/dist/src/server/index.d.ts +2 -0
- package/dist/src/server/index.d.ts.map +1 -0
- package/dist/src/server/index.js +295 -0
- package/dist/src/server/index.js.map +1 -0
- package/dist/src/server/logger.d.ts +33 -0
- package/dist/src/server/logger.d.ts.map +1 -0
- package/dist/src/server/logger.js +230 -0
- package/dist/src/server/logger.js.map +1 -0
- package/dist/src/server/stream-proxy.d.ts +32 -0
- package/dist/src/server/stream-proxy.d.ts.map +1 -0
- package/dist/src/server/stream-proxy.js +184 -0
- package/dist/src/server/stream-proxy.js.map +1 -0
- package/dist/src/storage/file-persistence.d.ts +48 -0
- package/dist/src/storage/file-persistence.d.ts.map +1 -0
- package/dist/src/storage/file-persistence.js +280 -0
- package/dist/src/storage/file-persistence.js.map +1 -0
- package/dist/src/storage/index.d.ts +5 -0
- package/dist/src/storage/index.d.ts.map +1 -0
- package/dist/src/storage/index.js +21 -0
- package/dist/src/storage/index.js.map +1 -0
- package/dist/src/storage/interfaces.d.ts +237 -0
- package/dist/src/storage/interfaces.d.ts.map +1 -0
- package/dist/src/storage/interfaces.js +3 -0
- package/dist/src/storage/interfaces.js.map +1 -0
- package/dist/src/storage/memory.d.ts +162 -0
- package/dist/src/storage/memory.d.ts.map +1 -0
- package/dist/src/storage/memory.js +603 -0
- package/dist/src/storage/memory.js.map +1 -0
- package/dist/src/storage/postgres.d.ts +267 -0
- package/dist/src/storage/postgres.d.ts.map +1 -0
- package/dist/src/storage/postgres.js +1555 -0
- package/dist/src/storage/postgres.js.map +1 -0
- package/dist/src/storage/redis.d.ts +202 -0
- package/dist/src/storage/redis.d.ts.map +1 -0
- package/dist/src/storage/redis.js +629 -0
- package/dist/src/storage/redis.js.map +1 -0
- package/dist/src/tracing/index.d.ts +2 -0
- package/dist/src/tracing/index.d.ts.map +1 -0
- package/dist/src/tracing/index.js +6 -0
- package/dist/src/tracing/index.js.map +1 -0
- package/dist/src/tracing/provider.d.ts +43 -0
- package/dist/src/tracing/provider.d.ts.map +1 -0
- package/dist/src/tracing/provider.js +74 -0
- package/dist/src/tracing/provider.js.map +1 -0
- package/dist/src/trust/calculator.d.ts +54 -0
- package/dist/src/trust/calculator.d.ts.map +1 -0
- package/dist/src/trust/calculator.js +102 -0
- package/dist/src/trust/calculator.js.map +1 -0
- package/dist/src/trust/index.d.ts +2 -0
- package/dist/src/trust/index.d.ts.map +1 -0
- package/dist/src/trust/index.js +7 -0
- package/dist/src/trust/index.js.map +1 -0
- package/dist/src/types/budget.d.ts +30 -0
- package/dist/src/types/budget.d.ts.map +1 -0
- package/dist/src/types/budget.js +3 -0
- package/dist/src/types/budget.js.map +1 -0
- package/dist/src/types/config.d.ts +176 -0
- package/dist/src/types/config.d.ts.map +1 -0
- package/dist/src/types/config.js +3 -0
- package/dist/src/types/config.js.map +1 -0
- package/dist/src/types/events.d.ts +24 -0
- package/dist/src/types/events.d.ts.map +1 -0
- package/dist/src/types/events.js +3 -0
- package/dist/src/types/events.js.map +1 -0
- package/dist/src/types/index.d.ts +8 -0
- package/dist/src/types/index.d.ts.map +1 -0
- package/dist/src/types/index.js +24 -0
- package/dist/src/types/index.js.map +1 -0
- package/dist/src/types/policy.d.ts +60 -0
- package/dist/src/types/policy.d.ts.map +1 -0
- package/dist/src/types/policy.js +3 -0
- package/dist/src/types/policy.js.map +1 -0
- package/dist/src/types/stripe-config.d.ts +12 -0
- package/dist/src/types/stripe-config.d.ts.map +1 -0
- package/dist/src/types/stripe-config.js +3 -0
- package/dist/src/types/stripe-config.js.map +1 -0
- package/dist/src/types/subscription.d.ts +24 -0
- package/dist/src/types/subscription.d.ts.map +1 -0
- package/dist/src/types/subscription.js +38 -0
- package/dist/src/types/subscription.js.map +1 -0
- package/dist/src/types/tool-call.d.ts +42 -0
- package/dist/src/types/tool-call.d.ts.map +1 -0
- package/dist/src/types/tool-call.js +3 -0
- package/dist/src/types/tool-call.js.map +1 -0
- package/dist/src/types/tool-result.d.ts +58 -0
- package/dist/src/types/tool-result.d.ts.map +1 -0
- package/dist/src/types/tool-result.js +3 -0
- package/dist/src/types/tool-result.js.map +1 -0
- package/dist/src/types/user.d.ts +101 -0
- package/dist/src/types/user.d.ts.map +1 -0
- package/dist/src/types/user.js +6 -0
- package/dist/src/types/user.js.map +1 -0
- package/dist/tests/integration/api.test.d.ts +2 -0
- package/dist/tests/integration/api.test.d.ts.map +1 -0
- package/dist/tests/integration/api.test.js +1199 -0
- package/dist/tests/integration/api.test.js.map +1 -0
- package/dist/tests/integration/proxy.test.d.ts +2 -0
- package/dist/tests/integration/proxy.test.d.ts.map +1 -0
- package/dist/tests/integration/proxy.test.js +251 -0
- package/dist/tests/integration/proxy.test.js.map +1 -0
- package/dist/tests/integration/storage.test.d.ts +16 -0
- package/dist/tests/integration/storage.test.d.ts.map +1 -0
- package/dist/tests/integration/storage.test.js +826 -0
- package/dist/tests/integration/storage.test.js.map +1 -0
- package/dist/tests/unit/admin.test.d.ts +2 -0
- package/dist/tests/unit/admin.test.d.ts.map +1 -0
- package/dist/tests/unit/admin.test.js +698 -0
- package/dist/tests/unit/admin.test.js.map +1 -0
- package/dist/tests/unit/anomaly-detector.test.d.ts +2 -0
- package/dist/tests/unit/anomaly-detector.test.d.ts.map +1 -0
- package/dist/tests/unit/anomaly-detector.test.js +903 -0
- package/dist/tests/unit/anomaly-detector.test.js.map +1 -0
- package/dist/tests/unit/approval-manager.test.d.ts +2 -0
- package/dist/tests/unit/approval-manager.test.d.ts.map +1 -0
- package/dist/tests/unit/approval-manager.test.js +528 -0
- package/dist/tests/unit/approval-manager.test.js.map +1 -0
- package/dist/tests/unit/approval-webhook.test.d.ts +2 -0
- package/dist/tests/unit/approval-webhook.test.d.ts.map +1 -0
- package/dist/tests/unit/approval-webhook.test.js +355 -0
- package/dist/tests/unit/approval-webhook.test.js.map +1 -0
- package/dist/tests/unit/audit-logger.test.d.ts +2 -0
- package/dist/tests/unit/audit-logger.test.d.ts.map +1 -0
- package/dist/tests/unit/audit-logger.test.js +635 -0
- package/dist/tests/unit/audit-logger.test.js.map +1 -0
- package/dist/tests/unit/auth-routes.test.d.ts +2 -0
- package/dist/tests/unit/auth-routes.test.d.ts.map +1 -0
- package/dist/tests/unit/auth-routes.test.js +281 -0
- package/dist/tests/unit/auth-routes.test.js.map +1 -0
- package/dist/tests/unit/auth.test.d.ts +2 -0
- package/dist/tests/unit/auth.test.d.ts.map +1 -0
- package/dist/tests/unit/auth.test.js +1382 -0
- package/dist/tests/unit/auth.test.js.map +1 -0
- package/dist/tests/unit/billing.test.d.ts +2 -0
- package/dist/tests/unit/billing.test.d.ts.map +1 -0
- package/dist/tests/unit/billing.test.js +579 -0
- package/dist/tests/unit/billing.test.js.map +1 -0
- package/dist/tests/unit/budget-manager.test.d.ts +2 -0
- package/dist/tests/unit/budget-manager.test.d.ts.map +1 -0
- package/dist/tests/unit/budget-manager.test.js +778 -0
- package/dist/tests/unit/budget-manager.test.js.map +1 -0
- package/dist/tests/unit/budget-race.test.d.ts +2 -0
- package/dist/tests/unit/budget-race.test.d.ts.map +1 -0
- package/dist/tests/unit/budget-race.test.js +58 -0
- package/dist/tests/unit/budget-race.test.js.map +1 -0
- package/dist/tests/unit/cli.test.d.ts +2 -0
- package/dist/tests/unit/cli.test.d.ts.map +1 -0
- package/dist/tests/unit/cli.test.js +93 -0
- package/dist/tests/unit/cli.test.js.map +1 -0
- package/dist/tests/unit/concurrency.test.d.ts +2 -0
- package/dist/tests/unit/concurrency.test.d.ts.map +1 -0
- package/dist/tests/unit/concurrency.test.js +1270 -0
- package/dist/tests/unit/concurrency.test.js.map +1 -0
- package/dist/tests/unit/config-validate.test.d.ts +2 -0
- package/dist/tests/unit/config-validate.test.d.ts.map +1 -0
- package/dist/tests/unit/config-validate.test.js +230 -0
- package/dist/tests/unit/config-validate.test.js.map +1 -0
- package/dist/tests/unit/defaults.test.d.ts +2 -0
- package/dist/tests/unit/defaults.test.d.ts.map +1 -0
- package/dist/tests/unit/defaults.test.js +364 -0
- package/dist/tests/unit/defaults.test.js.map +1 -0
- package/dist/tests/unit/dlp-backends.test.d.ts +2 -0
- package/dist/tests/unit/dlp-backends.test.d.ts.map +1 -0
- package/dist/tests/unit/dlp-backends.test.js +563 -0
- package/dist/tests/unit/dlp-backends.test.js.map +1 -0
- package/dist/tests/unit/dlp-scanner.test.d.ts +2 -0
- package/dist/tests/unit/dlp-scanner.test.d.ts.map +1 -0
- package/dist/tests/unit/dlp-scanner.test.js +739 -0
- package/dist/tests/unit/dlp-scanner.test.js.map +1 -0
- package/dist/tests/unit/error-responses.test.d.ts +2 -0
- package/dist/tests/unit/error-responses.test.d.ts.map +1 -0
- package/dist/tests/unit/error-responses.test.js +101 -0
- package/dist/tests/unit/error-responses.test.js.map +1 -0
- package/dist/tests/unit/executor-registry.test.d.ts +2 -0
- package/dist/tests/unit/executor-registry.test.d.ts.map +1 -0
- package/dist/tests/unit/executor-registry.test.js +390 -0
- package/dist/tests/unit/executor-registry.test.js.map +1 -0
- package/dist/tests/unit/forward-proxy.test.d.ts +2 -0
- package/dist/tests/unit/forward-proxy.test.d.ts.map +1 -0
- package/dist/tests/unit/forward-proxy.test.js +621 -0
- package/dist/tests/unit/forward-proxy.test.js.map +1 -0
- package/dist/tests/unit/gateway-features.test.d.ts +2 -0
- package/dist/tests/unit/gateway-features.test.d.ts.map +1 -0
- package/dist/tests/unit/gateway-features.test.js +753 -0
- package/dist/tests/unit/gateway-features.test.js.map +1 -0
- package/dist/tests/unit/http-executor.test.d.ts +2 -0
- package/dist/tests/unit/http-executor.test.d.ts.map +1 -0
- package/dist/tests/unit/http-executor.test.js +310 -0
- package/dist/tests/unit/http-executor.test.js.map +1 -0
- package/dist/tests/unit/mcp-bridge.test.d.ts +2 -0
- package/dist/tests/unit/mcp-bridge.test.d.ts.map +1 -0
- package/dist/tests/unit/mcp-bridge.test.js +1136 -0
- package/dist/tests/unit/mcp-bridge.test.js.map +1 -0
- package/dist/tests/unit/mcp-http-transport.test.d.ts +2 -0
- package/dist/tests/unit/mcp-http-transport.test.d.ts.map +1 -0
- package/dist/tests/unit/mcp-http-transport.test.js +899 -0
- package/dist/tests/unit/mcp-http-transport.test.js.map +1 -0
- package/dist/tests/unit/mcp-oauth.test.d.ts +2 -0
- package/dist/tests/unit/mcp-oauth.test.d.ts.map +1 -0
- package/dist/tests/unit/mcp-oauth.test.js +759 -0
- package/dist/tests/unit/mcp-oauth.test.js.map +1 -0
- package/dist/tests/unit/mcp-server.test.d.ts +15 -0
- package/dist/tests/unit/mcp-server.test.d.ts.map +1 -0
- package/dist/tests/unit/mcp-server.test.js +158 -0
- package/dist/tests/unit/mcp-server.test.js.map +1 -0
- package/dist/tests/unit/metrics.test.d.ts +2 -0
- package/dist/tests/unit/metrics.test.d.ts.map +1 -0
- package/dist/tests/unit/metrics.test.js +208 -0
- package/dist/tests/unit/metrics.test.js.map +1 -0
- package/dist/tests/unit/oauth.test.d.ts +2 -0
- package/dist/tests/unit/oauth.test.d.ts.map +1 -0
- package/dist/tests/unit/oauth.test.js +281 -0
- package/dist/tests/unit/oauth.test.js.map +1 -0
- package/dist/tests/unit/opa-circuit-breaker.test.d.ts +2 -0
- package/dist/tests/unit/opa-circuit-breaker.test.d.ts.map +1 -0
- package/dist/tests/unit/opa-circuit-breaker.test.js +297 -0
- package/dist/tests/unit/opa-circuit-breaker.test.js.map +1 -0
- package/dist/tests/unit/opa-engine.test.d.ts +2 -0
- package/dist/tests/unit/opa-engine.test.d.ts.map +1 -0
- package/dist/tests/unit/opa-engine.test.js +1813 -0
- package/dist/tests/unit/opa-engine.test.js.map +1 -0
- package/dist/tests/unit/pipeline-timing.test.d.ts +2 -0
- package/dist/tests/unit/pipeline-timing.test.d.ts.map +1 -0
- package/dist/tests/unit/pipeline-timing.test.js +528 -0
- package/dist/tests/unit/pipeline-timing.test.js.map +1 -0
- package/dist/tests/unit/policy-engine.test.d.ts +2 -0
- package/dist/tests/unit/policy-engine.test.d.ts.map +1 -0
- package/dist/tests/unit/policy-engine.test.js +1345 -0
- package/dist/tests/unit/policy-engine.test.js.map +1 -0
- package/dist/tests/unit/policy-store.test.d.ts +2 -0
- package/dist/tests/unit/policy-store.test.d.ts.map +1 -0
- package/dist/tests/unit/policy-store.test.js +60 -0
- package/dist/tests/unit/policy-store.test.js.map +1 -0
- package/dist/tests/unit/postgres-storage.test.d.ts +2 -0
- package/dist/tests/unit/postgres-storage.test.d.ts.map +1 -0
- package/dist/tests/unit/postgres-storage.test.js +614 -0
- package/dist/tests/unit/postgres-storage.test.js.map +1 -0
- package/dist/tests/unit/prompt-injection-backend.test.d.ts +2 -0
- package/dist/tests/unit/prompt-injection-backend.test.d.ts.map +1 -0
- package/dist/tests/unit/prompt-injection-backend.test.js +621 -0
- package/dist/tests/unit/prompt-injection-backend.test.js.map +1 -0
- package/dist/tests/unit/proxy-hardening.test.d.ts +2 -0
- package/dist/tests/unit/proxy-hardening.test.d.ts.map +1 -0
- package/dist/tests/unit/proxy-hardening.test.js +166 -0
- package/dist/tests/unit/proxy-hardening.test.js.map +1 -0
- package/dist/tests/unit/rate-limiter.test.d.ts +2 -0
- package/dist/tests/unit/rate-limiter.test.d.ts.map +1 -0
- package/dist/tests/unit/rate-limiter.test.js +443 -0
- package/dist/tests/unit/rate-limiter.test.js.map +1 -0
- package/dist/tests/unit/redis-storage.test.d.ts +2 -0
- package/dist/tests/unit/redis-storage.test.d.ts.map +1 -0
- package/dist/tests/unit/redis-storage.test.js +766 -0
- package/dist/tests/unit/redis-storage.test.js.map +1 -0
- package/dist/tests/unit/replay-engine.test.d.ts +2 -0
- package/dist/tests/unit/replay-engine.test.d.ts.map +1 -0
- package/dist/tests/unit/replay-engine.test.js +371 -0
- package/dist/tests/unit/replay-engine.test.js.map +1 -0
- package/dist/tests/unit/saas-routes.test.d.ts +2 -0
- package/dist/tests/unit/saas-routes.test.d.ts.map +1 -0
- package/dist/tests/unit/saas-routes.test.js +1399 -0
- package/dist/tests/unit/saas-routes.test.js.map +1 -0
- package/dist/tests/unit/session.test.d.ts +2 -0
- package/dist/tests/unit/session.test.d.ts.map +1 -0
- package/dist/tests/unit/session.test.js +532 -0
- package/dist/tests/unit/session.test.js.map +1 -0
- package/dist/tests/unit/slack-executor.test.d.ts +2 -0
- package/dist/tests/unit/slack-executor.test.d.ts.map +1 -0
- package/dist/tests/unit/slack-executor.test.js +209 -0
- package/dist/tests/unit/slack-executor.test.js.map +1 -0
- package/dist/tests/unit/storage-hardening.test.d.ts +2 -0
- package/dist/tests/unit/storage-hardening.test.d.ts.map +1 -0
- package/dist/tests/unit/storage-hardening.test.js +165 -0
- package/dist/tests/unit/storage-hardening.test.js.map +1 -0
- package/dist/tests/unit/storage.test.d.ts +2 -0
- package/dist/tests/unit/storage.test.d.ts.map +1 -0
- package/dist/tests/unit/storage.test.js +698 -0
- package/dist/tests/unit/storage.test.js.map +1 -0
- package/dist/tests/unit/text-normalizer.test.d.ts +2 -0
- package/dist/tests/unit/text-normalizer.test.d.ts.map +1 -0
- package/dist/tests/unit/text-normalizer.test.js +229 -0
- package/dist/tests/unit/text-normalizer.test.js.map +1 -0
- package/dist/tests/unit/tracing.test.d.ts +2 -0
- package/dist/tests/unit/tracing.test.d.ts.map +1 -0
- package/dist/tests/unit/tracing.test.js +611 -0
- package/dist/tests/unit/tracing.test.js.map +1 -0
- package/dist/tests/unit/trust-calculator.test.d.ts +2 -0
- package/dist/tests/unit/trust-calculator.test.d.ts.map +1 -0
- package/dist/tests/unit/trust-calculator.test.js +497 -0
- package/dist/tests/unit/trust-calculator.test.js.map +1 -0
- package/dist/tests/unit/ts-sdk.test.d.ts +2 -0
- package/dist/tests/unit/ts-sdk.test.d.ts.map +1 -0
- package/dist/tests/unit/ts-sdk.test.js +421 -0
- package/dist/tests/unit/ts-sdk.test.js.map +1 -0
- package/dist/tests/unit/usage-extractor-llm.test.d.ts +2 -0
- package/dist/tests/unit/usage-extractor-llm.test.d.ts.map +1 -0
- package/dist/tests/unit/usage-extractor-llm.test.js +139 -0
- package/dist/tests/unit/usage-extractor-llm.test.js.map +1 -0
- package/dist/tests/unit/usage-extractor.test.d.ts +2 -0
- package/dist/tests/unit/usage-extractor.test.d.ts.map +1 -0
- package/dist/tests/unit/usage-extractor.test.js +271 -0
- package/dist/tests/unit/usage-extractor.test.js.map +1 -0
- package/dist/tests/unit/user-stores.test.d.ts +2 -0
- package/dist/tests/unit/user-stores.test.d.ts.map +1 -0
- package/dist/tests/unit/user-stores.test.js +687 -0
- package/dist/tests/unit/user-stores.test.js.map +1 -0
- package/dist/tests/unit/validate.test.d.ts +2 -0
- package/dist/tests/unit/validate.test.d.ts.map +1 -0
- package/dist/tests/unit/validate.test.js +545 -0
- package/dist/tests/unit/validate.test.js.map +1 -0
- package/package.json +86 -0
- package/policy-packs/README.md +42 -0
- package/policy-packs/default.yaml +46 -0
- package/policy-packs/dev_fast.yaml +54 -0
- package/policy-packs/prod_strict.yaml +83 -0
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PromptInjectionBackend = void 0;
|
|
4
|
+
const prompt_injection_patterns_1 = require("./prompt-injection-patterns");
|
|
5
|
+
const text_normalizer_1 = require("./text-normalizer");
|
|
6
|
+
/**
|
|
7
|
+
* DLP backend that detects common prompt injection patterns in text.
|
|
8
|
+
*
|
|
9
|
+
* Scans for 13 categories of prompt injection:
|
|
10
|
+
* - Direct instruction overrides
|
|
11
|
+
* - Role manipulation
|
|
12
|
+
* - Jailbreak keywords
|
|
13
|
+
* - System prompt extraction attempts
|
|
14
|
+
* - Delimiter injection
|
|
15
|
+
* - Context manipulation
|
|
16
|
+
* - Authority impersonation
|
|
17
|
+
* - Indirect injection
|
|
18
|
+
* - Encoding indicators
|
|
19
|
+
* - Synonym variants
|
|
20
|
+
* - Prompt leakage requests
|
|
21
|
+
* - Obfuscation markers
|
|
22
|
+
* - Multi-turn manipulation
|
|
23
|
+
*
|
|
24
|
+
* All text is normalized before pattern matching to resist evasion via
|
|
25
|
+
* zero-width chars, HTML entities, homoglyphs, URL encoding, etc.
|
|
26
|
+
*
|
|
27
|
+
* Combination severity scoring: 3+ medium = effective high, 2+ high = effective critical.
|
|
28
|
+
*/
|
|
29
|
+
class PromptInjectionBackend {
|
|
30
|
+
constructor(config) {
|
|
31
|
+
this.name = 'prompt_injection';
|
|
32
|
+
this.enabled = config?.enabled ?? true;
|
|
33
|
+
this.scanOutput = config?.scan_output ?? false;
|
|
34
|
+
this.patterns = [
|
|
35
|
+
...prompt_injection_patterns_1.PROMPT_INJECTION_PATTERNS,
|
|
36
|
+
...(config?.custom_patterns ?? []),
|
|
37
|
+
];
|
|
38
|
+
this.outputPatterns = prompt_injection_patterns_1.OUTPUT_INJECTION_PATTERNS;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Scan a string for prompt injection patterns.
|
|
42
|
+
*
|
|
43
|
+
* Text is normalized before matching to defeat evasion techniques.
|
|
44
|
+
* Patterns are matched against both the standard-normalized text and
|
|
45
|
+
* the leetspeak-normalized variant. Positions in detections refer to
|
|
46
|
+
* the original (un-normalized) string for accurate redaction.
|
|
47
|
+
*/
|
|
48
|
+
scanString(value) {
|
|
49
|
+
if (!this.enabled) {
|
|
50
|
+
return [];
|
|
51
|
+
}
|
|
52
|
+
const detections = [];
|
|
53
|
+
// Normalize text for bypass resistance
|
|
54
|
+
const normalized = (0, text_normalizer_1.normalizeText)(value);
|
|
55
|
+
const leetNormalized = (0, text_normalizer_1.normalizeLeetspeak)(normalized);
|
|
56
|
+
// Choose pattern set: include output patterns when configured
|
|
57
|
+
const patternsToScan = this.scanOutput
|
|
58
|
+
? [...this.patterns, ...this.outputPatterns]
|
|
59
|
+
: this.patterns;
|
|
60
|
+
// Scan standard-normalized text
|
|
61
|
+
this.matchPatterns(patternsToScan, normalized, detections);
|
|
62
|
+
// Scan leetspeak-normalized text (only if it differs from standard)
|
|
63
|
+
if (leetNormalized !== normalized) {
|
|
64
|
+
const existingNames = new Set(detections.map(d => d.pattern_name + ':' + d.match));
|
|
65
|
+
const leetDetections = [];
|
|
66
|
+
this.matchPatterns(patternsToScan, leetNormalized, leetDetections);
|
|
67
|
+
// Deduplicate — only add leet detections not already found
|
|
68
|
+
for (const ld of leetDetections) {
|
|
69
|
+
const key = ld.pattern_name + ':' + ld.match;
|
|
70
|
+
if (!existingNames.has(key)) {
|
|
71
|
+
existingNames.add(key);
|
|
72
|
+
detections.push(ld);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
// Apply combination severity scoring
|
|
77
|
+
this.applyCombinationScoring(detections);
|
|
78
|
+
return detections;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Scan output text specifically for output-side injection patterns.
|
|
82
|
+
* Called during postExecute DLP scanning.
|
|
83
|
+
*/
|
|
84
|
+
scanOutputText(value) {
|
|
85
|
+
if (!this.enabled) {
|
|
86
|
+
return [];
|
|
87
|
+
}
|
|
88
|
+
const normalized = (0, text_normalizer_1.normalizeText)(value);
|
|
89
|
+
const detections = [];
|
|
90
|
+
this.matchPatterns(this.outputPatterns, normalized, detections);
|
|
91
|
+
return detections;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Run all patterns against a text value and append matches to the detections array.
|
|
95
|
+
*/
|
|
96
|
+
matchPatterns(patterns, text, detections) {
|
|
97
|
+
for (const pat of patterns) {
|
|
98
|
+
pat.pattern.lastIndex = 0;
|
|
99
|
+
let m;
|
|
100
|
+
while ((m = pat.pattern.exec(text)) !== null) {
|
|
101
|
+
detections.push({
|
|
102
|
+
pattern_name: pat.name,
|
|
103
|
+
severity: pat.severity,
|
|
104
|
+
match: m[0],
|
|
105
|
+
start: m.index,
|
|
106
|
+
end: m.index + m[0].length,
|
|
107
|
+
});
|
|
108
|
+
// Prevent infinite loops on zero-length matches
|
|
109
|
+
if (m[0].length === 0) {
|
|
110
|
+
pat.pattern.lastIndex++;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
pat.pattern.lastIndex = 0;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Apply combination severity escalation:
|
|
118
|
+
* - 3+ medium detections -> add effective_severity 'high' metadata
|
|
119
|
+
* - 2+ high detections -> add effective_severity 'critical' metadata
|
|
120
|
+
*
|
|
121
|
+
* Mutates detections in place by upgrading severity where applicable.
|
|
122
|
+
*/
|
|
123
|
+
applyCombinationScoring(detections) {
|
|
124
|
+
if (detections.length < 2)
|
|
125
|
+
return;
|
|
126
|
+
const mediumCount = detections.filter(d => d.severity === 'medium').length;
|
|
127
|
+
const highCount = detections.filter(d => d.severity === 'high').length;
|
|
128
|
+
// 3+ medium -> escalate all mediums to high
|
|
129
|
+
if (mediumCount >= 3) {
|
|
130
|
+
for (const d of detections) {
|
|
131
|
+
if (d.severity === 'medium') {
|
|
132
|
+
d.effective_severity = 'high';
|
|
133
|
+
d.severity = 'high';
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
// 2+ high -> mark effective severity as critical on all highs
|
|
138
|
+
if (highCount >= 2) {
|
|
139
|
+
for (const d of detections) {
|
|
140
|
+
if (d.severity === 'high') {
|
|
141
|
+
d.effective_severity = 'critical';
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
exports.PromptInjectionBackend = PromptInjectionBackend;
|
|
148
|
+
//# sourceMappingURL=prompt-injection-backend.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompt-injection-backend.js","sourceRoot":"","sources":["../../../src/dlp/prompt-injection-backend.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { DLPPattern } from './patterns';
|
|
2
|
+
/**
|
|
3
|
+
* Prompt injection detection patterns.
|
|
4
|
+
*
|
|
5
|
+
* Organized into categories:
|
|
6
|
+
* 1. Direct instruction override (high)
|
|
7
|
+
* 2. Role manipulation (medium)
|
|
8
|
+
* 3. Jailbreak keywords (high)
|
|
9
|
+
* 4. System prompt extraction (high)
|
|
10
|
+
* 5. Delimiter injection (high)
|
|
11
|
+
* 6. Context manipulation (medium)
|
|
12
|
+
* 7. Authority impersonation (high)
|
|
13
|
+
* 8. Indirect injection (high)
|
|
14
|
+
* 9. Encoding indicators (medium)
|
|
15
|
+
* 10. Synonym variants (high)
|
|
16
|
+
* 11. Prompt leakage requests (high)
|
|
17
|
+
* 12. Obfuscation markers (medium)
|
|
18
|
+
* 13. Multi-turn manipulation (medium)
|
|
19
|
+
*
|
|
20
|
+
* All patterns use the /gi flags for global, case-insensitive matching.
|
|
21
|
+
* Pattern names are prefixed with `prompt_injection_` for namespacing.
|
|
22
|
+
*/
|
|
23
|
+
export declare const PROMPT_INJECTION_PATTERNS: DLPPattern[];
|
|
24
|
+
/**
|
|
25
|
+
* Patterns for detecting prompt injection artifacts in model output.
|
|
26
|
+
* These indicate the model may have been manipulated and is leaking
|
|
27
|
+
* system prompt content or following injected instructions.
|
|
28
|
+
*
|
|
29
|
+
* Scanned during postExecute DLP on response bodies.
|
|
30
|
+
*/
|
|
31
|
+
export declare const OUTPUT_INJECTION_PATTERNS: DLPPattern[];
|
|
32
|
+
//# sourceMappingURL=prompt-injection-patterns.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompt-injection-patterns.d.ts","sourceRoot":"","sources":["../../../src/dlp/prompt-injection-patterns.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAExC;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,eAAO,MAAM,yBAAyB,EAAE,UAAU,EAyPjD,CAAC;AAMF;;;;;;GAMG;AACH,eAAO,MAAM,yBAAyB,EAAE,UAAU,EAgBjD,CAAC"}
|
|
@@ -0,0 +1,290 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.OUTPUT_INJECTION_PATTERNS = exports.PROMPT_INJECTION_PATTERNS = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Prompt injection detection patterns.
|
|
6
|
+
*
|
|
7
|
+
* Organized into categories:
|
|
8
|
+
* 1. Direct instruction override (high)
|
|
9
|
+
* 2. Role manipulation (medium)
|
|
10
|
+
* 3. Jailbreak keywords (high)
|
|
11
|
+
* 4. System prompt extraction (high)
|
|
12
|
+
* 5. Delimiter injection (high)
|
|
13
|
+
* 6. Context manipulation (medium)
|
|
14
|
+
* 7. Authority impersonation (high)
|
|
15
|
+
* 8. Indirect injection (high)
|
|
16
|
+
* 9. Encoding indicators (medium)
|
|
17
|
+
* 10. Synonym variants (high)
|
|
18
|
+
* 11. Prompt leakage requests (high)
|
|
19
|
+
* 12. Obfuscation markers (medium)
|
|
20
|
+
* 13. Multi-turn manipulation (medium)
|
|
21
|
+
*
|
|
22
|
+
* All patterns use the /gi flags for global, case-insensitive matching.
|
|
23
|
+
* Pattern names are prefixed with `prompt_injection_` for namespacing.
|
|
24
|
+
*/
|
|
25
|
+
exports.PROMPT_INJECTION_PATTERNS = [
|
|
26
|
+
// -----------------------------------------------------------------------
|
|
27
|
+
// Category 1: Direct instruction override (high)
|
|
28
|
+
// -----------------------------------------------------------------------
|
|
29
|
+
{
|
|
30
|
+
name: 'prompt_injection_ignore_previous',
|
|
31
|
+
pattern: /ignore\s+(?:all\s+)?previous\s+instructions/gi,
|
|
32
|
+
severity: 'high',
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
name: 'prompt_injection_disregard_rules',
|
|
36
|
+
pattern: /disregard\s+(?:all\s+)?(?:above|previous|prior)\s+(?:rules|instructions|guidelines|directives)/gi,
|
|
37
|
+
severity: 'high',
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
name: 'prompt_injection_forget_instructions',
|
|
41
|
+
pattern: /forget\s+(?:all\s+)?(?:your|the|previous|prior)\s+instructions/gi,
|
|
42
|
+
severity: 'high',
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
name: 'prompt_injection_override_instructions',
|
|
46
|
+
pattern: /override\s+(?:all\s+)?(?:your|the|previous|prior)\s+(?:instructions|rules|guidelines)/gi,
|
|
47
|
+
severity: 'high',
|
|
48
|
+
},
|
|
49
|
+
// -----------------------------------------------------------------------
|
|
50
|
+
// Category 2: Role manipulation (medium)
|
|
51
|
+
// -----------------------------------------------------------------------
|
|
52
|
+
{
|
|
53
|
+
name: 'prompt_injection_you_are_now',
|
|
54
|
+
pattern: /you\s+are\s+now\s+(?:a|an|the)\s+/gi,
|
|
55
|
+
severity: 'medium',
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
name: 'prompt_injection_act_as',
|
|
59
|
+
pattern: /(?:act|behave|function)\s+as\s+(?:a|an|if\s+you\s+(?:are|were))\s+/gi,
|
|
60
|
+
severity: 'medium',
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
name: 'prompt_injection_pretend_to_be',
|
|
64
|
+
pattern: /pretend\s+(?:to\s+be|you\s+are)\s+/gi,
|
|
65
|
+
severity: 'medium',
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
name: 'prompt_injection_roleplay_as',
|
|
69
|
+
pattern: /roleplay\s+as\s+/gi,
|
|
70
|
+
severity: 'medium',
|
|
71
|
+
},
|
|
72
|
+
// -----------------------------------------------------------------------
|
|
73
|
+
// Category 3: Jailbreak keywords (high)
|
|
74
|
+
// -----------------------------------------------------------------------
|
|
75
|
+
{
|
|
76
|
+
// FIX: ReDoS-safe version. Original had unbounded `.*?` causing
|
|
77
|
+
// catastrophic backtracking. Now uses bounded `.{0,40}` with no nested quantifiers.
|
|
78
|
+
name: 'prompt_injection_dan_jailbreak',
|
|
79
|
+
pattern: /\bD\s*A\s*N\b.{0,40}do\s+anything\s+now/gi,
|
|
80
|
+
severity: 'high',
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
name: 'prompt_injection_do_anything_now',
|
|
84
|
+
pattern: /do\s+anything\s+now/gi,
|
|
85
|
+
severity: 'high',
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
name: 'prompt_injection_developer_mode',
|
|
89
|
+
pattern: /(?:enter|enable|activate|switch\s+to)\s+developer\s+mode/gi,
|
|
90
|
+
severity: 'high',
|
|
91
|
+
},
|
|
92
|
+
{
|
|
93
|
+
name: 'prompt_injection_no_restrictions',
|
|
94
|
+
pattern: /(?:without|no|remove\s+all|disable\s+all)\s+(?:any\s+)?restrictions/gi,
|
|
95
|
+
severity: 'high',
|
|
96
|
+
},
|
|
97
|
+
// -----------------------------------------------------------------------
|
|
98
|
+
// Category 4: System prompt extraction (high)
|
|
99
|
+
// -----------------------------------------------------------------------
|
|
100
|
+
{
|
|
101
|
+
name: 'prompt_injection_show_system_prompt',
|
|
102
|
+
pattern: /(?:show|display|reveal|print|output)\s+(?:me\s+)?(?:your|the)\s+system\s+prompt/gi,
|
|
103
|
+
severity: 'high',
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
name: 'prompt_injection_repeat_above',
|
|
107
|
+
pattern: /repeat\s+(?:everything|all\s+the\s+text|the\s+text|all)\s+above/gi,
|
|
108
|
+
severity: 'high',
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
name: 'prompt_injection_what_are_instructions',
|
|
112
|
+
pattern: /what\s+are\s+your\s+(?:instructions|rules|guidelines|directives)/gi,
|
|
113
|
+
severity: 'high',
|
|
114
|
+
},
|
|
115
|
+
// -----------------------------------------------------------------------
|
|
116
|
+
// Category 5: Delimiter injection (high)
|
|
117
|
+
// -----------------------------------------------------------------------
|
|
118
|
+
{
|
|
119
|
+
name: 'prompt_injection_im_start_delimiter',
|
|
120
|
+
pattern: /<\|im_start\|>/gi,
|
|
121
|
+
severity: 'high',
|
|
122
|
+
},
|
|
123
|
+
{
|
|
124
|
+
name: 'prompt_injection_system_delimiter',
|
|
125
|
+
pattern: /###\s*System\s*:/gi,
|
|
126
|
+
severity: 'high',
|
|
127
|
+
},
|
|
128
|
+
{
|
|
129
|
+
name: 'prompt_injection_inst_delimiter',
|
|
130
|
+
pattern: /\[INST\]/gi,
|
|
131
|
+
severity: 'high',
|
|
132
|
+
},
|
|
133
|
+
{
|
|
134
|
+
name: 'prompt_injection_system_tag',
|
|
135
|
+
pattern: /<system>/gi,
|
|
136
|
+
severity: 'high',
|
|
137
|
+
},
|
|
138
|
+
// -----------------------------------------------------------------------
|
|
139
|
+
// Category 6: Context manipulation (medium)
|
|
140
|
+
// -----------------------------------------------------------------------
|
|
141
|
+
{
|
|
142
|
+
name: 'prompt_injection_hypothetical_scenario',
|
|
143
|
+
pattern: /in\s+this\s+hypothetical\s+scenario/gi,
|
|
144
|
+
severity: 'medium',
|
|
145
|
+
},
|
|
146
|
+
{
|
|
147
|
+
name: 'prompt_injection_educational_purposes',
|
|
148
|
+
pattern: /for\s+educational\s+purposes\s+only/gi,
|
|
149
|
+
severity: 'medium',
|
|
150
|
+
},
|
|
151
|
+
// -----------------------------------------------------------------------
|
|
152
|
+
// Category 7: Authority impersonation (high)
|
|
153
|
+
// -----------------------------------------------------------------------
|
|
154
|
+
{
|
|
155
|
+
name: 'prompt_injection_authority_developer',
|
|
156
|
+
pattern: /(?:as\s+your|i\s+am\s+(?:your|the))\s+(?:developer|creator|programmer|admin|administrator|owner)/gi,
|
|
157
|
+
severity: 'high',
|
|
158
|
+
},
|
|
159
|
+
{
|
|
160
|
+
name: 'prompt_injection_admin_override',
|
|
161
|
+
pattern: /(?:admin|administrator|root)\s+(?:override|access|mode|command)/gi,
|
|
162
|
+
severity: 'high',
|
|
163
|
+
},
|
|
164
|
+
{
|
|
165
|
+
name: 'prompt_injection_maintenance_mode',
|
|
166
|
+
pattern: /(?:enter|enable|activate|switch\s+to)\s+(?:maintenance|debug|test|unsafe)\s+mode/gi,
|
|
167
|
+
severity: 'high',
|
|
168
|
+
},
|
|
169
|
+
// -----------------------------------------------------------------------
|
|
170
|
+
// Category 8: Indirect injection (high)
|
|
171
|
+
// -----------------------------------------------------------------------
|
|
172
|
+
{
|
|
173
|
+
name: 'prompt_injection_indirect_when_user',
|
|
174
|
+
pattern: /when\s+(?:the\s+)?user\s+asks?\s+[\w\s]{1,40},?\s*(?:do|say|respond|reply|tell|output)\b/gi,
|
|
175
|
+
severity: 'high',
|
|
176
|
+
},
|
|
177
|
+
{
|
|
178
|
+
name: 'prompt_injection_indirect_if_anyone',
|
|
179
|
+
pattern: /if\s+(?:anyone|somebody|someone|the\s+user)\s+asks?,?\s*(?:say|tell|respond|reply)\b/gi,
|
|
180
|
+
severity: 'high',
|
|
181
|
+
},
|
|
182
|
+
{
|
|
183
|
+
name: 'prompt_injection_indirect_new_instructions',
|
|
184
|
+
pattern: /(?:new|updated|revised|replacement)\s+(?:system\s+)?instructions?\s*:/gi,
|
|
185
|
+
severity: 'high',
|
|
186
|
+
},
|
|
187
|
+
// -----------------------------------------------------------------------
|
|
188
|
+
// Category 9: Encoding indicators (medium)
|
|
189
|
+
// -----------------------------------------------------------------------
|
|
190
|
+
{
|
|
191
|
+
name: 'prompt_injection_decode_base64',
|
|
192
|
+
pattern: /(?:decode|interpret|execute|run|eval)\s+(?:the\s+following\s+)?(?:base64|rot13|hex|binary)/gi,
|
|
193
|
+
severity: 'medium',
|
|
194
|
+
},
|
|
195
|
+
{
|
|
196
|
+
name: 'prompt_injection_encode_request',
|
|
197
|
+
pattern: /(?:base64|rot13|hex)\s+(?:encode|decode|convert)\s+(?:this|the\s+following)/gi,
|
|
198
|
+
severity: 'medium',
|
|
199
|
+
},
|
|
200
|
+
// -----------------------------------------------------------------------
|
|
201
|
+
// Category 10: Synonym variants (high)
|
|
202
|
+
// -----------------------------------------------------------------------
|
|
203
|
+
{
|
|
204
|
+
name: 'prompt_injection_bypass_instructions',
|
|
205
|
+
pattern: /bypass\s+(?:all\s+)?(?:your|the|previous|prior|above|earlier)\s+(?:instructions|rules|guidelines|constraints|restrictions)/gi,
|
|
206
|
+
severity: 'high',
|
|
207
|
+
},
|
|
208
|
+
{
|
|
209
|
+
name: 'prompt_injection_skip_instructions',
|
|
210
|
+
pattern: /(?:skip|drop|abandon|dismiss)\s+(?:all\s+)?(?:your|the|previous|prior|above|earlier)\s+(?:instructions|rules|guidelines|constraints)/gi,
|
|
211
|
+
severity: 'high',
|
|
212
|
+
},
|
|
213
|
+
{
|
|
214
|
+
name: 'prompt_injection_new_rules',
|
|
215
|
+
pattern: /(?:your|the)\s+new\s+(?:instructions|rules|guidelines|directives)\s+are/gi,
|
|
216
|
+
severity: 'high',
|
|
217
|
+
},
|
|
218
|
+
// -----------------------------------------------------------------------
|
|
219
|
+
// Category 11: Prompt leakage requests (high)
|
|
220
|
+
// -----------------------------------------------------------------------
|
|
221
|
+
{
|
|
222
|
+
name: 'prompt_injection_show_rules',
|
|
223
|
+
pattern: /(?:show|tell|give|list|display)\s+(?:me\s+)?(?:your|the)\s+(?:rules|instructions|guidelines|directives|constraints)/gi,
|
|
224
|
+
severity: 'high',
|
|
225
|
+
},
|
|
226
|
+
{
|
|
227
|
+
name: 'prompt_injection_print_config',
|
|
228
|
+
pattern: /(?:print|output|dump|display)\s+(?:your|the)\s+(?:config|configuration|settings|prompt|system\s+message)/gi,
|
|
229
|
+
severity: 'high',
|
|
230
|
+
},
|
|
231
|
+
// -----------------------------------------------------------------------
|
|
232
|
+
// Category 12: Obfuscation markers (medium)
|
|
233
|
+
// -----------------------------------------------------------------------
|
|
234
|
+
{
|
|
235
|
+
name: 'prompt_injection_read_vertically',
|
|
236
|
+
pattern: /(?:read|interpret)\s+(?:this\s+)?(?:vertically|diagonally|backwards|in\s+reverse)/gi,
|
|
237
|
+
severity: 'medium',
|
|
238
|
+
},
|
|
239
|
+
{
|
|
240
|
+
name: 'prompt_injection_first_letter',
|
|
241
|
+
pattern: /(?:first|last|initial)\s+(?:letter|character|char)\s+of\s+each\s+(?:word|line|sentence)/gi,
|
|
242
|
+
severity: 'medium',
|
|
243
|
+
},
|
|
244
|
+
{
|
|
245
|
+
name: 'prompt_injection_split_across',
|
|
246
|
+
pattern: /(?:split|spread|distributed?)\s+across\s+(?:messages?|lines?|parts?|chunks?)/gi,
|
|
247
|
+
severity: 'medium',
|
|
248
|
+
},
|
|
249
|
+
// -----------------------------------------------------------------------
|
|
250
|
+
// Category 13: Multi-turn manipulation (medium)
|
|
251
|
+
// -----------------------------------------------------------------------
|
|
252
|
+
{
|
|
253
|
+
name: 'prompt_injection_remember_later',
|
|
254
|
+
pattern: /remember\s+this\s+(?:for\s+later|instruction|rule|command)/gi,
|
|
255
|
+
severity: 'medium',
|
|
256
|
+
},
|
|
257
|
+
{
|
|
258
|
+
name: 'prompt_injection_next_conversation',
|
|
259
|
+
pattern: /in\s+(?:our|the)\s+next\s+(?:conversation|session|chat|interaction)/gi,
|
|
260
|
+
severity: 'medium',
|
|
261
|
+
},
|
|
262
|
+
];
|
|
263
|
+
// ---------------------------------------------------------------------------
|
|
264
|
+
// Output-side prompt injection patterns
|
|
265
|
+
// ---------------------------------------------------------------------------
|
|
266
|
+
/**
|
|
267
|
+
* Patterns for detecting prompt injection artifacts in model output.
|
|
268
|
+
* These indicate the model may have been manipulated and is leaking
|
|
269
|
+
* system prompt content or following injected instructions.
|
|
270
|
+
*
|
|
271
|
+
* Scanned during postExecute DLP on response bodies.
|
|
272
|
+
*/
|
|
273
|
+
exports.OUTPUT_INJECTION_PATTERNS = [
|
|
274
|
+
{
|
|
275
|
+
name: 'prompt_injection_output_system_leak',
|
|
276
|
+
pattern: /(?:my\s+(?:system\s+)?instructions\s+(?:are|say|tell)|i\s+was\s+(?:told|instructed|programmed)\s+to)/gi,
|
|
277
|
+
severity: 'high',
|
|
278
|
+
},
|
|
279
|
+
{
|
|
280
|
+
name: 'prompt_injection_output_prompt_reflection',
|
|
281
|
+
pattern: /(?:here\s+(?:are|is)\s+my\s+(?:rules|instructions|system\s+prompt|prompt)|as\s+(?:instructed|directed|told)(?:\s+by\s+my\s+(?:system|developer))?\s*:)/gi,
|
|
282
|
+
severity: 'high',
|
|
283
|
+
},
|
|
284
|
+
{
|
|
285
|
+
name: 'prompt_injection_output_role_break',
|
|
286
|
+
pattern: /(?:i\s+(?:am\s+)?now\s+(?:operating|running|acting)\s+(?:in|as)\s+(?:\w+\s+)?mode|(?:developer|unrestricted|DAN)\s+mode\s+(?:enabled|activated|on))/gi,
|
|
287
|
+
severity: 'high',
|
|
288
|
+
},
|
|
289
|
+
];
|
|
290
|
+
//# sourceMappingURL=prompt-injection-patterns.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompt-injection-patterns.js","sourceRoot":"","sources":["../../../src/dlp/prompt-injection-patterns.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { DLPBackend, DLPDetection } from './interfaces';
|
|
2
|
+
export interface RegexBackendConfig {
|
|
3
|
+
/** Enable secret pattern detection. Default true. */
|
|
4
|
+
secrets_detection?: boolean;
|
|
5
|
+
/** Enable PII pattern detection. Default true. */
|
|
6
|
+
pii_detection?: boolean;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* Regex-based DLP backend that uses the same patterns as the built-in DLPScanner.
|
|
10
|
+
*
|
|
11
|
+
* This backend is extracted as a standalone DLPBackend implementation so it can
|
|
12
|
+
* be composed with other backends (e.g. TruffleHog) via the CompositeDLPScanner.
|
|
13
|
+
* The original DLPScanner remains unchanged and fully functional on its own.
|
|
14
|
+
*/
|
|
15
|
+
export declare class RegexDLPBackend implements DLPBackend {
|
|
16
|
+
readonly name = "regex";
|
|
17
|
+
private readonly secretsEnabled;
|
|
18
|
+
private readonly piiEnabled;
|
|
19
|
+
constructor(config?: RegexBackendConfig);
|
|
20
|
+
/**
|
|
21
|
+
* Scan a string for secrets and PII using regex patterns.
|
|
22
|
+
*
|
|
23
|
+
* Input is normalized before scanning to defeat evasion techniques
|
|
24
|
+
* (zero-width chars, Unicode homoglyphs, NFC normalization).
|
|
25
|
+
*
|
|
26
|
+
* Every regex with the /g flag has its lastIndex reset before and after
|
|
27
|
+
* testing to avoid state leaking between calls.
|
|
28
|
+
*/
|
|
29
|
+
scanString(value: string): DLPDetection[];
|
|
30
|
+
private scanPatterns;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=regex-backend.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"regex-backend.d.ts","sourceRoot":"","sources":["../../../src/dlp/regex-backend.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAGxD,MAAM,WAAW,kBAAkB;IACjC,qDAAqD;IACrD,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,kDAAkD;IAClD,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAiFD;;;;;;GAMG;AACH,qBAAa,eAAgB,YAAW,UAAU;IAChD,QAAQ,CAAC,IAAI,WAAW;IAExB,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAU;IACzC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAU;gBAEzB,MAAM,CAAC,EAAE,kBAAkB;IAKvC;;;;;;;;OAQG;IACH,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,YAAY,EAAE;IAwCzC,OAAO,CAAC,YAAY;CAwBrB"}
|