palaryn 0.1.0 → 0.3.2
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/README.md +243 -588
- package/dist/sdk/typescript/src/client.js +2 -2
- package/dist/sdk/typescript/src/client.js.map +1 -1
- package/dist/src/anomaly/detector.d.ts +7 -4
- package/dist/src/anomaly/detector.d.ts.map +1 -1
- package/dist/src/anomaly/detector.js +22 -12
- package/dist/src/anomaly/detector.js.map +1 -1
- package/dist/src/audit/logger.d.ts +10 -0
- package/dist/src/audit/logger.d.ts.map +1 -1
- package/dist/src/audit/logger.js +52 -38
- package/dist/src/audit/logger.js.map +1 -1
- package/dist/src/auth/routes.d.ts.map +1 -1
- package/dist/src/auth/routes.js +35 -0
- package/dist/src/auth/routes.js.map +1 -1
- package/dist/src/budget/manager.d.ts +5 -0
- package/dist/src/budget/manager.d.ts.map +1 -1
- package/dist/src/budget/manager.js +32 -0
- package/dist/src/budget/manager.js.map +1 -1
- package/dist/src/budget/model-pricing.d.ts +20 -0
- package/dist/src/budget/model-pricing.d.ts.map +1 -0
- package/dist/src/budget/model-pricing.js +107 -0
- package/dist/src/budget/model-pricing.js.map +1 -0
- package/dist/src/budget/usage-extractor.d.ts +3 -1
- package/dist/src/budget/usage-extractor.d.ts.map +1 -1
- package/dist/src/budget/usage-extractor.js +47 -3
- package/dist/src/budget/usage-extractor.js.map +1 -1
- package/dist/src/config/defaults.d.ts.map +1 -1
- package/dist/src/config/defaults.js +65 -13
- package/dist/src/config/defaults.js.map +1 -1
- package/dist/src/dlp/tool-patterns.d.ts +7 -0
- package/dist/src/dlp/tool-patterns.d.ts.map +1 -0
- package/dist/src/dlp/tool-patterns.js +34 -0
- package/dist/src/dlp/tool-patterns.js.map +1 -0
- package/dist/src/executor/filesystem-executor.d.ts +28 -0
- package/dist/src/executor/filesystem-executor.d.ts.map +1 -0
- package/dist/src/executor/filesystem-executor.js +192 -0
- package/dist/src/executor/filesystem-executor.js.map +1 -0
- package/dist/src/executor/http-executor.d.ts.map +1 -1
- package/dist/src/executor/http-executor.js +22 -2
- package/dist/src/executor/http-executor.js.map +1 -1
- package/dist/src/executor/index.d.ts +4 -0
- package/dist/src/executor/index.d.ts.map +1 -1
- package/dist/src/executor/index.js +9 -1
- package/dist/src/executor/index.js.map +1 -1
- package/dist/src/executor/shell-executor.d.ts +22 -0
- package/dist/src/executor/shell-executor.d.ts.map +1 -0
- package/dist/src/executor/shell-executor.js +119 -0
- package/dist/src/executor/shell-executor.js.map +1 -0
- package/dist/src/executor/sql-executor.d.ts +29 -0
- package/dist/src/executor/sql-executor.d.ts.map +1 -0
- package/dist/src/executor/sql-executor.js +114 -0
- package/dist/src/executor/sql-executor.js.map +1 -0
- package/dist/src/executor/websocket-executor.d.ts +26 -0
- package/dist/src/executor/websocket-executor.d.ts.map +1 -0
- package/dist/src/executor/websocket-executor.js +205 -0
- package/dist/src/executor/websocket-executor.js.map +1 -0
- package/dist/src/interceptor/index.d.ts +2 -0
- package/dist/src/interceptor/index.d.ts.map +1 -0
- package/dist/src/interceptor/index.js +6 -0
- package/dist/src/interceptor/index.js.map +1 -0
- package/dist/src/interceptor/provider-interceptor.d.ts +36 -0
- package/dist/src/interceptor/provider-interceptor.d.ts.map +1 -0
- package/dist/src/interceptor/provider-interceptor.js +302 -0
- package/dist/src/interceptor/provider-interceptor.js.map +1 -0
- package/dist/src/mcp/auth-verifier.d.ts.map +1 -1
- package/dist/src/mcp/auth-verifier.js +3 -2
- package/dist/src/mcp/auth-verifier.js.map +1 -1
- package/dist/src/mcp/bridge.d.ts +14 -10
- package/dist/src/mcp/bridge.d.ts.map +1 -1
- package/dist/src/mcp/bridge.js +51 -227
- package/dist/src/mcp/bridge.js.map +1 -1
- package/dist/src/mcp/http-transport.d.ts +2 -0
- package/dist/src/mcp/http-transport.d.ts.map +1 -1
- package/dist/src/mcp/http-transport.js +117 -66
- package/dist/src/mcp/http-transport.js.map +1 -1
- package/dist/src/mcp/internal-auth.d.ts +13 -0
- package/dist/src/mcp/internal-auth.d.ts.map +1 -0
- package/dist/src/mcp/internal-auth.js +12 -0
- package/dist/src/mcp/internal-auth.js.map +1 -0
- package/dist/src/mcp/tool-definitions.d.ts +41 -0
- package/dist/src/mcp/tool-definitions.d.ts.map +1 -0
- package/dist/src/mcp/tool-definitions.js +491 -0
- package/dist/src/mcp/tool-definitions.js.map +1 -0
- package/dist/src/middleware/auth.js.map +1 -1
- package/dist/src/middleware/session.js.map +1 -1
- package/dist/src/middleware/validate.d.ts +8 -0
- package/dist/src/middleware/validate.d.ts.map +1 -1
- package/dist/src/middleware/validate.js +45 -0
- package/dist/src/middleware/validate.js.map +1 -1
- package/dist/src/policy/engine.d.ts +4 -0
- package/dist/src/policy/engine.d.ts.map +1 -1
- package/dist/src/policy/engine.js +117 -0
- package/dist/src/policy/engine.js.map +1 -1
- package/dist/src/saas/routes.d.ts.map +1 -1
- package/dist/src/saas/routes.js +355 -22
- package/dist/src/saas/routes.js.map +1 -1
- package/dist/src/server/app.d.ts.map +1 -1
- package/dist/src/server/app.js +24 -3
- package/dist/src/server/app.js.map +1 -1
- package/dist/src/server/gateway.d.ts.map +1 -1
- package/dist/src/server/gateway.js +17 -0
- package/dist/src/server/gateway.js.map +1 -1
- package/dist/src/server/index.d.ts.map +1 -1
- package/dist/src/server/index.js +18 -0
- package/dist/src/server/index.js.map +1 -1
- package/dist/src/storage/interfaces.d.ts +14 -3
- package/dist/src/storage/interfaces.d.ts.map +1 -1
- package/dist/src/storage/memory.d.ts +2 -0
- package/dist/src/storage/memory.d.ts.map +1 -1
- package/dist/src/storage/memory.js +6 -0
- package/dist/src/storage/memory.js.map +1 -1
- package/dist/src/storage/postgres.d.ts +5 -0
- package/dist/src/storage/postgres.d.ts.map +1 -1
- package/dist/src/storage/postgres.js +16 -0
- package/dist/src/storage/postgres.js.map +1 -1
- package/dist/src/storage/redis.d.ts +10 -0
- package/dist/src/storage/redis.d.ts.map +1 -1
- package/dist/src/storage/redis.js +65 -0
- package/dist/src/storage/redis.js.map +1 -1
- package/dist/src/types/budget.d.ts +4 -0
- package/dist/src/types/budget.d.ts.map +1 -1
- package/dist/src/types/config.d.ts +58 -0
- package/dist/src/types/config.d.ts.map +1 -1
- package/dist/src/types/events.d.ts +1 -0
- package/dist/src/types/events.d.ts.map +1 -1
- package/dist/src/types/policy.d.ts +11 -1
- package/dist/src/types/policy.d.ts.map +1 -1
- package/dist/src/types/tool-result.d.ts +11 -0
- package/dist/src/types/tool-result.d.ts.map +1 -1
- package/dist/tests/unit/app-routes.test.d.ts +2 -0
- package/dist/tests/unit/app-routes.test.d.ts.map +1 -0
- package/dist/tests/unit/app-routes.test.js +715 -0
- package/dist/tests/unit/app-routes.test.js.map +1 -0
- package/dist/tests/unit/audit-logger.test.js +105 -0
- package/dist/tests/unit/audit-logger.test.js.map +1 -1
- package/dist/tests/unit/auth-providers.test.d.ts +2 -0
- package/dist/tests/unit/auth-providers.test.d.ts.map +1 -0
- package/dist/tests/unit/auth-providers.test.js +279 -0
- package/dist/tests/unit/auth-providers.test.js.map +1 -0
- package/dist/tests/unit/auth-routes-extended.test.d.ts +2 -0
- package/dist/tests/unit/auth-routes-extended.test.d.ts.map +1 -0
- package/dist/tests/unit/auth-routes-extended.test.js +993 -0
- package/dist/tests/unit/auth-routes-extended.test.js.map +1 -0
- package/dist/tests/unit/auth-verifier.test.d.ts +2 -0
- package/dist/tests/unit/auth-verifier.test.d.ts.map +1 -0
- package/dist/tests/unit/auth-verifier.test.js +505 -0
- package/dist/tests/unit/auth-verifier.test.js.map +1 -0
- package/dist/tests/unit/billing-routes.test.d.ts +2 -0
- package/dist/tests/unit/billing-routes.test.d.ts.map +1 -0
- package/dist/tests/unit/billing-routes.test.js +432 -0
- package/dist/tests/unit/billing-routes.test.js.map +1 -0
- package/dist/tests/unit/config-defaults.test.d.ts +2 -0
- package/dist/tests/unit/config-defaults.test.d.ts.map +1 -0
- package/dist/tests/unit/config-defaults.test.js +119 -0
- package/dist/tests/unit/config-defaults.test.js.map +1 -0
- package/dist/tests/unit/defaults.test.js +0 -10
- package/dist/tests/unit/defaults.test.js.map +1 -1
- package/dist/tests/unit/filesystem-executor.test.d.ts +2 -0
- package/dist/tests/unit/filesystem-executor.test.d.ts.map +1 -0
- package/dist/tests/unit/filesystem-executor.test.js +280 -0
- package/dist/tests/unit/filesystem-executor.test.js.map +1 -0
- package/dist/tests/unit/gateway-branches.test.d.ts +2 -0
- package/dist/tests/unit/gateway-branches.test.d.ts.map +1 -0
- package/dist/tests/unit/gateway-branches.test.js +1039 -0
- package/dist/tests/unit/gateway-branches.test.js.map +1 -0
- package/dist/tests/unit/http-executor-branches.test.d.ts +2 -0
- package/dist/tests/unit/http-executor-branches.test.d.ts.map +1 -0
- package/dist/tests/unit/http-executor-branches.test.js +495 -0
- package/dist/tests/unit/http-executor-branches.test.js.map +1 -0
- package/dist/tests/unit/logger.test.d.ts +2 -0
- package/dist/tests/unit/logger.test.d.ts.map +1 -0
- package/dist/tests/unit/logger.test.js +97 -0
- package/dist/tests/unit/logger.test.js.map +1 -0
- package/dist/tests/unit/mcp-internal-auth.test.d.ts +2 -0
- package/dist/tests/unit/mcp-internal-auth.test.d.ts.map +1 -0
- package/dist/tests/unit/mcp-internal-auth.test.js +445 -0
- package/dist/tests/unit/mcp-internal-auth.test.js.map +1 -0
- package/dist/tests/unit/metrics.test.js +102 -0
- package/dist/tests/unit/metrics.test.js.map +1 -1
- package/dist/tests/unit/model-pricing.test.d.ts +2 -0
- package/dist/tests/unit/model-pricing.test.d.ts.map +1 -0
- package/dist/tests/unit/model-pricing.test.js +87 -0
- package/dist/tests/unit/model-pricing.test.js.map +1 -0
- package/dist/tests/unit/oauth-stores.test.d.ts +2 -0
- package/dist/tests/unit/oauth-stores.test.d.ts.map +1 -0
- package/dist/tests/unit/oauth-stores.test.js +260 -0
- package/dist/tests/unit/oauth-stores.test.js.map +1 -0
- package/dist/tests/unit/policy-engine.test.js +466 -0
- package/dist/tests/unit/policy-engine.test.js.map +1 -1
- package/dist/tests/unit/provider-interceptor.test.d.ts +2 -0
- package/dist/tests/unit/provider-interceptor.test.d.ts.map +1 -0
- package/dist/tests/unit/provider-interceptor.test.js +472 -0
- package/dist/tests/unit/provider-interceptor.test.js.map +1 -0
- package/dist/tests/unit/saas-routes-branches.test.d.ts +2 -0
- package/dist/tests/unit/saas-routes-branches.test.d.ts.map +1 -0
- package/dist/tests/unit/saas-routes-branches.test.js +2165 -0
- package/dist/tests/unit/saas-routes-branches.test.js.map +1 -0
- package/dist/tests/unit/saas-routes-crud.test.d.ts +2 -0
- package/dist/tests/unit/saas-routes-crud.test.d.ts.map +1 -0
- package/dist/tests/unit/saas-routes-crud.test.js +332 -0
- package/dist/tests/unit/saas-routes-crud.test.js.map +1 -0
- package/dist/tests/unit/saas-routes-data.test.d.ts +2 -0
- package/dist/tests/unit/saas-routes-data.test.d.ts.map +1 -0
- package/dist/tests/unit/saas-routes-data.test.js +405 -0
- package/dist/tests/unit/saas-routes-data.test.js.map +1 -0
- package/dist/tests/unit/saas-routes.test.js +3 -3
- package/dist/tests/unit/saas-routes.test.js.map +1 -1
- package/dist/tests/unit/shell-executor.test.d.ts +2 -0
- package/dist/tests/unit/shell-executor.test.d.ts.map +1 -0
- package/dist/tests/unit/shell-executor.test.js +145 -0
- package/dist/tests/unit/shell-executor.test.js.map +1 -0
- package/dist/tests/unit/sql-executor.test.d.ts +2 -0
- package/dist/tests/unit/sql-executor.test.d.ts.map +1 -0
- package/dist/tests/unit/sql-executor.test.js +177 -0
- package/dist/tests/unit/sql-executor.test.js.map +1 -0
- package/dist/tests/unit/stream-proxy.test.d.ts +2 -0
- package/dist/tests/unit/stream-proxy.test.d.ts.map +1 -0
- package/dist/tests/unit/stream-proxy.test.js +147 -0
- package/dist/tests/unit/stream-proxy.test.js.map +1 -0
- package/dist/tests/unit/tool-definitions.test.d.ts +2 -0
- package/dist/tests/unit/tool-definitions.test.d.ts.map +1 -0
- package/dist/tests/unit/tool-definitions.test.js +184 -0
- package/dist/tests/unit/tool-definitions.test.js.map +1 -0
- package/dist/tests/unit/usage-extractor.test.js +140 -0
- package/dist/tests/unit/usage-extractor.test.js.map +1 -1
- package/dist/tests/unit/webhook-handler.test.d.ts +2 -0
- package/dist/tests/unit/webhook-handler.test.d.ts.map +1 -0
- package/dist/tests/unit/webhook-handler.test.js +453 -0
- package/dist/tests/unit/webhook-handler.test.js.map +1 -0
- package/dist/tests/unit/webhook-routes.test.d.ts +2 -0
- package/dist/tests/unit/webhook-routes.test.d.ts.map +1 -0
- package/dist/tests/unit/webhook-routes.test.js +69 -0
- package/dist/tests/unit/webhook-routes.test.js.map +1 -0
- package/dist/tests/unit/websocket-executor.test.d.ts +2 -0
- package/dist/tests/unit/websocket-executor.test.d.ts.map +1 -0
- package/dist/tests/unit/websocket-executor.test.js +121 -0
- package/dist/tests/unit/websocket-executor.test.js.map +1 -0
- package/package.json +8 -2
- package/policy-packs/demo_fail.yaml +41 -0
- package/policy-packs/full_tools.yaml +136 -0
- package/src/admin/index.ts +1 -0
- package/src/admin/routes.ts +509 -0
- package/src/admin/templates.ts +572 -0
- package/src/anomaly/detector.ts +730 -0
- package/src/anomaly/index.ts +1 -0
- package/src/approval/manager.ts +569 -0
- package/src/approval/webhook.ts +133 -0
- package/src/audit/logger.ts +490 -0
- package/src/auth/index.ts +5 -0
- package/src/auth/password.ts +21 -0
- package/src/auth/pkce.ts +22 -0
- package/src/auth/providers.ts +208 -0
- package/src/auth/routes.ts +561 -0
- package/src/auth/session.ts +84 -0
- package/src/billing/index.ts +6 -0
- package/src/billing/plan-enforcer.ts +135 -0
- package/src/billing/routes.ts +229 -0
- package/src/billing/stripe-client.ts +58 -0
- package/src/billing/webhook-handler.ts +182 -0
- package/src/billing/webhook-routes.ts +28 -0
- package/src/budget/manager.ts +679 -0
- package/src/budget/model-pricing.ts +119 -0
- package/src/budget/usage-extractor.ts +214 -0
- package/src/cli.ts +91 -0
- package/src/config/defaults.ts +261 -0
- package/src/config/validate.ts +88 -0
- package/src/dlp/composite-scanner.ts +213 -0
- package/src/dlp/index.ts +9 -0
- package/src/dlp/interfaces.ts +34 -0
- package/src/dlp/patterns.ts +30 -0
- package/src/dlp/prompt-injection-backend.ts +181 -0
- package/src/dlp/prompt-injection-patterns.ts +302 -0
- package/src/dlp/regex-backend.ts +181 -0
- package/src/dlp/scanner.ts +502 -0
- package/src/dlp/text-normalizer.ts +225 -0
- package/src/dlp/tool-patterns.ts +35 -0
- package/src/dlp/trufflehog-backend.ts +190 -0
- package/src/executor/filesystem-executor.ts +196 -0
- package/src/executor/http-executor.ts +349 -0
- package/src/executor/index.ts +9 -0
- package/src/executor/interfaces.ts +11 -0
- package/src/executor/noop-executor.ts +23 -0
- package/src/executor/registry.ts +64 -0
- package/src/executor/shell-executor.ts +148 -0
- package/src/executor/slack-executor.ts +176 -0
- package/src/executor/sql-executor.ts +146 -0
- package/src/executor/websocket-executor.ts +211 -0
- package/src/index.ts +24 -0
- package/src/interceptor/index.ts +1 -0
- package/src/interceptor/provider-interceptor.ts +315 -0
- package/src/mcp/auth-verifier.ts +152 -0
- package/src/mcp/bridge.ts +703 -0
- package/src/mcp/http-transport.ts +698 -0
- package/src/mcp/index.ts +9 -0
- package/src/mcp/internal-auth.ts +14 -0
- package/src/mcp/oauth-pages.ts +139 -0
- package/src/mcp/oauth-postgres-stores.ts +278 -0
- package/src/mcp/oauth-provider.ts +536 -0
- package/src/mcp/oauth-stores.ts +202 -0
- package/src/mcp/server.ts +55 -0
- package/src/mcp/tool-definitions.ts +562 -0
- package/src/metrics/collector.ts +357 -0
- package/src/metrics/index.ts +1 -0
- package/src/middleware/auth.ts +814 -0
- package/src/middleware/session.ts +85 -0
- package/src/middleware/validate.ts +130 -0
- package/src/policy/engine.ts +815 -0
- package/src/policy/index.ts +2 -0
- package/src/policy/opa-engine.ts +829 -0
- package/src/proxy/forward-proxy.ts +649 -0
- package/src/proxy/index.ts +1 -0
- package/src/ratelimit/limiter.ts +196 -0
- package/src/replay/engine.ts +142 -0
- package/src/replay/index.ts +1 -0
- package/src/saas/index.ts +1 -0
- package/src/saas/routes.ts +2178 -0
- package/src/server/app.ts +985 -0
- package/src/server/errors.ts +49 -0
- package/src/server/gateway.ts +1130 -0
- package/src/server/index.ts +307 -0
- package/src/server/logger.ts +255 -0
- package/src/server/stream-proxy.ts +202 -0
- package/src/storage/file-persistence.ts +315 -0
- package/src/storage/index.ts +4 -0
- package/src/storage/interfaces.ts +287 -0
- package/src/storage/memory.ts +686 -0
- package/src/storage/postgres.ts +1831 -0
- package/src/storage/redis.ts +835 -0
- package/src/tracing/index.ts +1 -0
- package/src/tracing/provider.ts +100 -0
- package/src/trust/calculator.ts +141 -0
- package/src/trust/index.ts +7 -0
- package/src/types/budget.ts +36 -0
- package/src/types/config.ts +278 -0
- package/src/types/events.ts +41 -0
- package/src/types/express.d.ts +14 -0
- package/src/types/index.ts +7 -0
- package/src/types/policy.ts +83 -0
- package/src/types/stripe-config.ts +11 -0
- package/src/types/subscription.ts +59 -0
- package/src/types/tool-call.ts +47 -0
- package/src/types/tool-result.ts +82 -0
- package/src/types/user.ts +125 -0
- package/tsconfig.json +24 -0
|
@@ -1341,5 +1341,471 @@ rules:
|
|
|
1341
1341
|
expect(result.rule_name).toBe('__ssrf_protection');
|
|
1342
1342
|
});
|
|
1343
1343
|
});
|
|
1344
|
+
// -----------------------------------------------------------------------
|
|
1345
|
+
// New tool type conditions
|
|
1346
|
+
// -----------------------------------------------------------------------
|
|
1347
|
+
describe('New tool type conditions', () => {
|
|
1348
|
+
/** Build a minimal valid ToolCall for testing new conditions. */
|
|
1349
|
+
function makeToolCall(overrides = {}) {
|
|
1350
|
+
return {
|
|
1351
|
+
tool_call_id: 'tc_test',
|
|
1352
|
+
task_id: 'task_test',
|
|
1353
|
+
workspace_id: 'ws_test',
|
|
1354
|
+
actor: { type: 'agent', id: 'agent_test' },
|
|
1355
|
+
source: { platform: 'test' },
|
|
1356
|
+
tool: { name: 'test.tool', capability: 'read' },
|
|
1357
|
+
args: {},
|
|
1358
|
+
...overrides,
|
|
1359
|
+
};
|
|
1360
|
+
}
|
|
1361
|
+
// --- file_paths ---
|
|
1362
|
+
describe('file_paths', () => {
|
|
1363
|
+
it('matches when file path matches glob pattern', () => {
|
|
1364
|
+
const pack = {
|
|
1365
|
+
name: 'file_paths_test',
|
|
1366
|
+
version: '1.0.0',
|
|
1367
|
+
rules: [
|
|
1368
|
+
{
|
|
1369
|
+
name: 'deny-env-files',
|
|
1370
|
+
effect: 'DENY',
|
|
1371
|
+
priority: 1,
|
|
1372
|
+
conditions: { file_paths: ['*.env'] },
|
|
1373
|
+
},
|
|
1374
|
+
],
|
|
1375
|
+
};
|
|
1376
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1377
|
+
const tc = makeToolCall({ args: { path: '.env' } });
|
|
1378
|
+
expect(engine.evaluate(tc).decision).toBe('deny');
|
|
1379
|
+
});
|
|
1380
|
+
it('does not match when file path does not match', () => {
|
|
1381
|
+
const pack = {
|
|
1382
|
+
name: 'file_paths_no_match',
|
|
1383
|
+
version: '1.0.0',
|
|
1384
|
+
rules: [
|
|
1385
|
+
{
|
|
1386
|
+
name: 'deny-env-files',
|
|
1387
|
+
effect: 'DENY',
|
|
1388
|
+
priority: 1,
|
|
1389
|
+
conditions: { file_paths: ['*.env'] },
|
|
1390
|
+
},
|
|
1391
|
+
],
|
|
1392
|
+
};
|
|
1393
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1394
|
+
const tc = makeToolCall({ args: { path: 'readme.md' } });
|
|
1395
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1396
|
+
});
|
|
1397
|
+
it('does not match when no path arg present', () => {
|
|
1398
|
+
const pack = {
|
|
1399
|
+
name: 'file_paths_no_path',
|
|
1400
|
+
version: '1.0.0',
|
|
1401
|
+
rules: [
|
|
1402
|
+
{
|
|
1403
|
+
name: 'deny-env-files',
|
|
1404
|
+
effect: 'DENY',
|
|
1405
|
+
priority: 1,
|
|
1406
|
+
conditions: { file_paths: ['*.env'] },
|
|
1407
|
+
},
|
|
1408
|
+
],
|
|
1409
|
+
};
|
|
1410
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1411
|
+
const tc = makeToolCall({ args: {} });
|
|
1412
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1413
|
+
});
|
|
1414
|
+
});
|
|
1415
|
+
// --- file_paths_blocklist ---
|
|
1416
|
+
describe('file_paths_blocklist', () => {
|
|
1417
|
+
it('blocks when path matches blocklist pattern', () => {
|
|
1418
|
+
const pack = {
|
|
1419
|
+
name: 'file_blocklist_test',
|
|
1420
|
+
version: '1.0.0',
|
|
1421
|
+
rules: [
|
|
1422
|
+
{
|
|
1423
|
+
name: 'allow-all-except-secrets',
|
|
1424
|
+
effect: 'ALLOW',
|
|
1425
|
+
priority: 1,
|
|
1426
|
+
conditions: { file_paths_blocklist: ['/etc/**'] },
|
|
1427
|
+
},
|
|
1428
|
+
{
|
|
1429
|
+
name: 'deny-all',
|
|
1430
|
+
effect: 'DENY',
|
|
1431
|
+
priority: 100,
|
|
1432
|
+
conditions: {},
|
|
1433
|
+
},
|
|
1434
|
+
],
|
|
1435
|
+
};
|
|
1436
|
+
const engine = engine_1.PolicyEngine.fromPack(pack);
|
|
1437
|
+
const tc = makeToolCall({ args: { path: '/etc/passwd' } });
|
|
1438
|
+
// The ALLOW rule won't match because file_paths_blocklist blocks it, so deny-all fires
|
|
1439
|
+
expect(engine.evaluate(tc).decision).toBe('deny');
|
|
1440
|
+
});
|
|
1441
|
+
it('allows when path does not match blocklist', () => {
|
|
1442
|
+
const pack = {
|
|
1443
|
+
name: 'file_blocklist_allow',
|
|
1444
|
+
version: '1.0.0',
|
|
1445
|
+
rules: [
|
|
1446
|
+
{
|
|
1447
|
+
name: 'allow-all-except-secrets',
|
|
1448
|
+
effect: 'ALLOW',
|
|
1449
|
+
priority: 1,
|
|
1450
|
+
conditions: { file_paths_blocklist: ['/etc/**'] },
|
|
1451
|
+
},
|
|
1452
|
+
{
|
|
1453
|
+
name: 'deny-all',
|
|
1454
|
+
effect: 'DENY',
|
|
1455
|
+
priority: 100,
|
|
1456
|
+
conditions: {},
|
|
1457
|
+
},
|
|
1458
|
+
],
|
|
1459
|
+
};
|
|
1460
|
+
const engine = engine_1.PolicyEngine.fromPack(pack);
|
|
1461
|
+
const tc = makeToolCall({ args: { path: '/home/user/file.txt' } });
|
|
1462
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1463
|
+
});
|
|
1464
|
+
});
|
|
1465
|
+
// --- file_extensions ---
|
|
1466
|
+
describe('file_extensions', () => {
|
|
1467
|
+
it('matches when file extension is in list', () => {
|
|
1468
|
+
const pack = {
|
|
1469
|
+
name: 'file_ext_test',
|
|
1470
|
+
version: '1.0.0',
|
|
1471
|
+
rules: [
|
|
1472
|
+
{
|
|
1473
|
+
name: 'deny-key-files',
|
|
1474
|
+
effect: 'DENY',
|
|
1475
|
+
priority: 1,
|
|
1476
|
+
conditions: { file_extensions: ['.key', '.pem'] },
|
|
1477
|
+
},
|
|
1478
|
+
],
|
|
1479
|
+
};
|
|
1480
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1481
|
+
const tc = makeToolCall({ args: { path: '/certs/server.key' } });
|
|
1482
|
+
expect(engine.evaluate(tc).decision).toBe('deny');
|
|
1483
|
+
});
|
|
1484
|
+
it('does not match when extension not in list', () => {
|
|
1485
|
+
const pack = {
|
|
1486
|
+
name: 'file_ext_no_match',
|
|
1487
|
+
version: '1.0.0',
|
|
1488
|
+
rules: [
|
|
1489
|
+
{
|
|
1490
|
+
name: 'deny-key-files',
|
|
1491
|
+
effect: 'DENY',
|
|
1492
|
+
priority: 1,
|
|
1493
|
+
conditions: { file_extensions: ['.key', '.pem'] },
|
|
1494
|
+
},
|
|
1495
|
+
],
|
|
1496
|
+
};
|
|
1497
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1498
|
+
const tc = makeToolCall({ args: { path: '/app/config.json' } });
|
|
1499
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1500
|
+
});
|
|
1501
|
+
});
|
|
1502
|
+
// --- sql_tables ---
|
|
1503
|
+
describe('sql_tables', () => {
|
|
1504
|
+
it('matches when query references matching table', () => {
|
|
1505
|
+
const pack = {
|
|
1506
|
+
name: 'sql_tables_test',
|
|
1507
|
+
version: '1.0.0',
|
|
1508
|
+
rules: [
|
|
1509
|
+
{
|
|
1510
|
+
name: 'deny-users-table',
|
|
1511
|
+
effect: 'DENY',
|
|
1512
|
+
priority: 1,
|
|
1513
|
+
conditions: { sql_tables: ['users'] },
|
|
1514
|
+
},
|
|
1515
|
+
],
|
|
1516
|
+
};
|
|
1517
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1518
|
+
const tc = makeToolCall({ args: { query: 'SELECT * FROM users WHERE id = 1' } });
|
|
1519
|
+
expect(engine.evaluate(tc).decision).toBe('deny');
|
|
1520
|
+
});
|
|
1521
|
+
it('does not match when table not found in query', () => {
|
|
1522
|
+
const pack = {
|
|
1523
|
+
name: 'sql_tables_no_match',
|
|
1524
|
+
version: '1.0.0',
|
|
1525
|
+
rules: [
|
|
1526
|
+
{
|
|
1527
|
+
name: 'deny-users-table',
|
|
1528
|
+
effect: 'DENY',
|
|
1529
|
+
priority: 1,
|
|
1530
|
+
conditions: { sql_tables: ['users'] },
|
|
1531
|
+
},
|
|
1532
|
+
],
|
|
1533
|
+
};
|
|
1534
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1535
|
+
const tc = makeToolCall({ args: { query: 'SELECT * FROM orders WHERE id = 1' } });
|
|
1536
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1537
|
+
});
|
|
1538
|
+
});
|
|
1539
|
+
// --- sql_tables_blocklist ---
|
|
1540
|
+
describe('sql_tables_blocklist', () => {
|
|
1541
|
+
it('blocks when query references blocked table (FROM, JOIN, INTO, UPDATE)', () => {
|
|
1542
|
+
const pack = {
|
|
1543
|
+
name: 'sql_blocklist_test',
|
|
1544
|
+
version: '1.0.0',
|
|
1545
|
+
rules: [
|
|
1546
|
+
{
|
|
1547
|
+
name: 'allow-except-secrets',
|
|
1548
|
+
effect: 'ALLOW',
|
|
1549
|
+
priority: 1,
|
|
1550
|
+
conditions: { sql_tables_blocklist: ['secrets'] },
|
|
1551
|
+
},
|
|
1552
|
+
{
|
|
1553
|
+
name: 'deny-all',
|
|
1554
|
+
effect: 'DENY',
|
|
1555
|
+
priority: 100,
|
|
1556
|
+
conditions: {},
|
|
1557
|
+
},
|
|
1558
|
+
],
|
|
1559
|
+
};
|
|
1560
|
+
const engine = engine_1.PolicyEngine.fromPack(pack);
|
|
1561
|
+
// FROM
|
|
1562
|
+
expect(engine.evaluate(makeToolCall({ args: { query: 'SELECT * FROM secrets' } })).decision).toBe('deny');
|
|
1563
|
+
// JOIN
|
|
1564
|
+
expect(engine.evaluate(makeToolCall({ args: { query: 'SELECT * FROM orders JOIN secrets ON 1=1' } })).decision).toBe('deny');
|
|
1565
|
+
// INTO
|
|
1566
|
+
expect(engine.evaluate(makeToolCall({ args: { query: 'INSERT INTO secrets VALUES (1)' } })).decision).toBe('deny');
|
|
1567
|
+
// UPDATE
|
|
1568
|
+
expect(engine.evaluate(makeToolCall({ args: { query: 'UPDATE secrets SET val = 1' } })).decision).toBe('deny');
|
|
1569
|
+
});
|
|
1570
|
+
it('allows when no blocked tables referenced', () => {
|
|
1571
|
+
const pack = {
|
|
1572
|
+
name: 'sql_blocklist_allow',
|
|
1573
|
+
version: '1.0.0',
|
|
1574
|
+
rules: [
|
|
1575
|
+
{
|
|
1576
|
+
name: 'allow-except-secrets',
|
|
1577
|
+
effect: 'ALLOW',
|
|
1578
|
+
priority: 1,
|
|
1579
|
+
conditions: { sql_tables_blocklist: ['secrets'] },
|
|
1580
|
+
},
|
|
1581
|
+
{
|
|
1582
|
+
name: 'deny-all',
|
|
1583
|
+
effect: 'DENY',
|
|
1584
|
+
priority: 100,
|
|
1585
|
+
conditions: {},
|
|
1586
|
+
},
|
|
1587
|
+
],
|
|
1588
|
+
};
|
|
1589
|
+
const engine = engine_1.PolicyEngine.fromPack(pack);
|
|
1590
|
+
const tc = makeToolCall({ args: { query: 'SELECT * FROM orders' } });
|
|
1591
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1592
|
+
});
|
|
1593
|
+
});
|
|
1594
|
+
// --- sql_statements ---
|
|
1595
|
+
describe('sql_statements', () => {
|
|
1596
|
+
it('matches SELECT statement', () => {
|
|
1597
|
+
const pack = {
|
|
1598
|
+
name: 'sql_stmt_select',
|
|
1599
|
+
version: '1.0.0',
|
|
1600
|
+
rules: [
|
|
1601
|
+
{
|
|
1602
|
+
name: 'deny-selects',
|
|
1603
|
+
effect: 'DENY',
|
|
1604
|
+
priority: 1,
|
|
1605
|
+
conditions: { sql_statements: ['SELECT'] },
|
|
1606
|
+
},
|
|
1607
|
+
],
|
|
1608
|
+
};
|
|
1609
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1610
|
+
const tc = makeToolCall({ args: { query: 'SELECT * FROM users' } });
|
|
1611
|
+
expect(engine.evaluate(tc).decision).toBe('deny');
|
|
1612
|
+
});
|
|
1613
|
+
it('matches INSERT statement', () => {
|
|
1614
|
+
const pack = {
|
|
1615
|
+
name: 'sql_stmt_insert',
|
|
1616
|
+
version: '1.0.0',
|
|
1617
|
+
rules: [
|
|
1618
|
+
{
|
|
1619
|
+
name: 'deny-inserts',
|
|
1620
|
+
effect: 'DENY',
|
|
1621
|
+
priority: 1,
|
|
1622
|
+
conditions: { sql_statements: ['INSERT'] },
|
|
1623
|
+
},
|
|
1624
|
+
],
|
|
1625
|
+
};
|
|
1626
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1627
|
+
const tc = makeToolCall({ args: { query: 'INSERT INTO users VALUES (1)' } });
|
|
1628
|
+
expect(engine.evaluate(tc).decision).toBe('deny');
|
|
1629
|
+
});
|
|
1630
|
+
it('does not match when statement type differs', () => {
|
|
1631
|
+
const pack = {
|
|
1632
|
+
name: 'sql_stmt_no_match',
|
|
1633
|
+
version: '1.0.0',
|
|
1634
|
+
rules: [
|
|
1635
|
+
{
|
|
1636
|
+
name: 'deny-deletes',
|
|
1637
|
+
effect: 'DENY',
|
|
1638
|
+
priority: 1,
|
|
1639
|
+
conditions: { sql_statements: ['DELETE'] },
|
|
1640
|
+
},
|
|
1641
|
+
],
|
|
1642
|
+
};
|
|
1643
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1644
|
+
const tc = makeToolCall({ args: { query: 'SELECT * FROM users' } });
|
|
1645
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1646
|
+
});
|
|
1647
|
+
});
|
|
1648
|
+
// --- shell_commands ---
|
|
1649
|
+
describe('shell_commands', () => {
|
|
1650
|
+
it('matches when command is in allowed list', () => {
|
|
1651
|
+
const pack = {
|
|
1652
|
+
name: 'shell_cmd_test',
|
|
1653
|
+
version: '1.0.0',
|
|
1654
|
+
rules: [
|
|
1655
|
+
{
|
|
1656
|
+
name: 'deny-rm',
|
|
1657
|
+
effect: 'DENY',
|
|
1658
|
+
priority: 1,
|
|
1659
|
+
conditions: { shell_commands: ['rm'] },
|
|
1660
|
+
},
|
|
1661
|
+
],
|
|
1662
|
+
};
|
|
1663
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1664
|
+
const tc = makeToolCall({ args: { command: 'rm' } });
|
|
1665
|
+
expect(engine.evaluate(tc).decision).toBe('deny');
|
|
1666
|
+
});
|
|
1667
|
+
it('does not match when command not in list', () => {
|
|
1668
|
+
const pack = {
|
|
1669
|
+
name: 'shell_cmd_no_match',
|
|
1670
|
+
version: '1.0.0',
|
|
1671
|
+
rules: [
|
|
1672
|
+
{
|
|
1673
|
+
name: 'deny-rm',
|
|
1674
|
+
effect: 'DENY',
|
|
1675
|
+
priority: 1,
|
|
1676
|
+
conditions: { shell_commands: ['rm'] },
|
|
1677
|
+
},
|
|
1678
|
+
],
|
|
1679
|
+
};
|
|
1680
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1681
|
+
const tc = makeToolCall({ args: { command: 'ls' } });
|
|
1682
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1683
|
+
});
|
|
1684
|
+
});
|
|
1685
|
+
// --- shell_commands_blocklist ---
|
|
1686
|
+
describe('shell_commands_blocklist', () => {
|
|
1687
|
+
it('blocks when command is in blocklist', () => {
|
|
1688
|
+
const pack = {
|
|
1689
|
+
name: 'shell_blocklist_test',
|
|
1690
|
+
version: '1.0.0',
|
|
1691
|
+
rules: [
|
|
1692
|
+
{
|
|
1693
|
+
name: 'allow-except-rm',
|
|
1694
|
+
effect: 'ALLOW',
|
|
1695
|
+
priority: 1,
|
|
1696
|
+
conditions: { shell_commands_blocklist: ['rm', 'shutdown'] },
|
|
1697
|
+
},
|
|
1698
|
+
{
|
|
1699
|
+
name: 'deny-all',
|
|
1700
|
+
effect: 'DENY',
|
|
1701
|
+
priority: 100,
|
|
1702
|
+
conditions: {},
|
|
1703
|
+
},
|
|
1704
|
+
],
|
|
1705
|
+
};
|
|
1706
|
+
const engine = engine_1.PolicyEngine.fromPack(pack);
|
|
1707
|
+
const tc = makeToolCall({ args: { command: 'rm' } });
|
|
1708
|
+
// ALLOW rule won't match because blocklist fires, so deny-all fires
|
|
1709
|
+
expect(engine.evaluate(tc).decision).toBe('deny');
|
|
1710
|
+
});
|
|
1711
|
+
it('allows when command not in blocklist', () => {
|
|
1712
|
+
const pack = {
|
|
1713
|
+
name: 'shell_blocklist_allow',
|
|
1714
|
+
version: '1.0.0',
|
|
1715
|
+
rules: [
|
|
1716
|
+
{
|
|
1717
|
+
name: 'allow-except-rm',
|
|
1718
|
+
effect: 'ALLOW',
|
|
1719
|
+
priority: 1,
|
|
1720
|
+
conditions: { shell_commands_blocklist: ['rm', 'shutdown'] },
|
|
1721
|
+
},
|
|
1722
|
+
{
|
|
1723
|
+
name: 'deny-all',
|
|
1724
|
+
effect: 'DENY',
|
|
1725
|
+
priority: 100,
|
|
1726
|
+
conditions: {},
|
|
1727
|
+
},
|
|
1728
|
+
],
|
|
1729
|
+
};
|
|
1730
|
+
const engine = engine_1.PolicyEngine.fromPack(pack);
|
|
1731
|
+
const tc = makeToolCall({ args: { command: 'ls' } });
|
|
1732
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1733
|
+
});
|
|
1734
|
+
});
|
|
1735
|
+
// --- providers ---
|
|
1736
|
+
describe('providers', () => {
|
|
1737
|
+
it('matches when provider arg matches', () => {
|
|
1738
|
+
const pack = {
|
|
1739
|
+
name: 'providers_test',
|
|
1740
|
+
version: '1.0.0',
|
|
1741
|
+
rules: [
|
|
1742
|
+
{
|
|
1743
|
+
name: 'deny-openai',
|
|
1744
|
+
effect: 'DENY',
|
|
1745
|
+
priority: 1,
|
|
1746
|
+
conditions: { providers: ['openai'] },
|
|
1747
|
+
},
|
|
1748
|
+
],
|
|
1749
|
+
};
|
|
1750
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1751
|
+
const tc = makeToolCall({ args: { provider: 'openai' } });
|
|
1752
|
+
expect(engine.evaluate(tc).decision).toBe('deny');
|
|
1753
|
+
});
|
|
1754
|
+
it('does not match when provider differs', () => {
|
|
1755
|
+
const pack = {
|
|
1756
|
+
name: 'providers_no_match',
|
|
1757
|
+
version: '1.0.0',
|
|
1758
|
+
rules: [
|
|
1759
|
+
{
|
|
1760
|
+
name: 'deny-openai',
|
|
1761
|
+
effect: 'DENY',
|
|
1762
|
+
priority: 1,
|
|
1763
|
+
conditions: { providers: ['openai'] },
|
|
1764
|
+
},
|
|
1765
|
+
],
|
|
1766
|
+
};
|
|
1767
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1768
|
+
const tc = makeToolCall({ args: { provider: 'claude' } });
|
|
1769
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1770
|
+
});
|
|
1771
|
+
});
|
|
1772
|
+
// --- provider_tool_types ---
|
|
1773
|
+
describe('provider_tool_types', () => {
|
|
1774
|
+
it('matches when provider_tool_type arg matches', () => {
|
|
1775
|
+
const pack = {
|
|
1776
|
+
name: 'provider_types_test',
|
|
1777
|
+
version: '1.0.0',
|
|
1778
|
+
rules: [
|
|
1779
|
+
{
|
|
1780
|
+
name: 'deny-computer-use',
|
|
1781
|
+
effect: 'DENY',
|
|
1782
|
+
priority: 1,
|
|
1783
|
+
conditions: { provider_tool_types: ['computer_use'] },
|
|
1784
|
+
},
|
|
1785
|
+
],
|
|
1786
|
+
};
|
|
1787
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1788
|
+
const tc = makeToolCall({ args: { provider_tool_type: 'computer_use' } });
|
|
1789
|
+
expect(engine.evaluate(tc).decision).toBe('deny');
|
|
1790
|
+
});
|
|
1791
|
+
it('does not match when type differs', () => {
|
|
1792
|
+
const pack = {
|
|
1793
|
+
name: 'provider_types_no_match',
|
|
1794
|
+
version: '1.0.0',
|
|
1795
|
+
rules: [
|
|
1796
|
+
{
|
|
1797
|
+
name: 'deny-computer-use',
|
|
1798
|
+
effect: 'DENY',
|
|
1799
|
+
priority: 1,
|
|
1800
|
+
conditions: { provider_tool_types: ['computer_use'] },
|
|
1801
|
+
},
|
|
1802
|
+
],
|
|
1803
|
+
};
|
|
1804
|
+
const engine = engine_1.PolicyEngine.fromPack(pack, 'ALLOW');
|
|
1805
|
+
const tc = makeToolCall({ args: { provider_tool_type: 'function' } });
|
|
1806
|
+
expect(engine.evaluate(tc).decision).toBe('allow');
|
|
1807
|
+
});
|
|
1808
|
+
});
|
|
1809
|
+
});
|
|
1344
1810
|
});
|
|
1345
1811
|
//# sourceMappingURL=policy-engine.test.js.map
|