sandstream-kit 1.0.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 +617 -0
- package/dist/adapters/api-key-adapter.d.ts +35 -0
- package/dist/adapters/api-key-adapter.js +46 -0
- package/dist/adapters/api-key-adapter.js.map +1 -0
- package/dist/adapters/clerk-auth.d.ts +6 -0
- package/dist/adapters/clerk-auth.js +20 -0
- package/dist/adapters/clerk-auth.js.map +1 -0
- package/dist/adapters/cloudflare-r2.d.ts +6 -0
- package/dist/adapters/cloudflare-r2.js +136 -0
- package/dist/adapters/cloudflare-r2.js.map +1 -0
- package/dist/adapters/expo-eas.d.ts +6 -0
- package/dist/adapters/expo-eas.js +129 -0
- package/dist/adapters/expo-eas.js.map +1 -0
- package/dist/adapters/flagsmith-flags.d.ts +5 -0
- package/dist/adapters/flagsmith-flags.js +20 -0
- package/dist/adapters/flagsmith-flags.js.map +1 -0
- package/dist/adapters/flyio-hosting.d.ts +2 -0
- package/dist/adapters/flyio-hosting.js +143 -0
- package/dist/adapters/flyio-hosting.js.map +1 -0
- package/dist/adapters/index.d.ts +6 -0
- package/dist/adapters/index.js +48 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/adapters/inngest-background.d.ts +5 -0
- package/dist/adapters/inngest-background.js +19 -0
- package/dist/adapters/inngest-background.js.map +1 -0
- package/dist/adapters/liveblocks-realtime.d.ts +11 -0
- package/dist/adapters/liveblocks-realtime.js +62 -0
- package/dist/adapters/liveblocks-realtime.js.map +1 -0
- package/dist/adapters/loops-email.d.ts +6 -0
- package/dist/adapters/loops-email.js +18 -0
- package/dist/adapters/loops-email.js.map +1 -0
- package/dist/adapters/neon-db.d.ts +10 -0
- package/dist/adapters/neon-db.js +94 -0
- package/dist/adapters/neon-db.js.map +1 -0
- package/dist/adapters/planetscale-db.d.ts +11 -0
- package/dist/adapters/planetscale-db.js +134 -0
- package/dist/adapters/planetscale-db.js.map +1 -0
- package/dist/adapters/posthog-analytics.d.ts +6 -0
- package/dist/adapters/posthog-analytics.js +22 -0
- package/dist/adapters/posthog-analytics.js.map +1 -0
- package/dist/adapters/railway-hosting.d.ts +2 -0
- package/dist/adapters/railway-hosting.js +136 -0
- package/dist/adapters/railway-hosting.js.map +1 -0
- package/dist/adapters/resend-email.d.ts +35 -0
- package/dist/adapters/resend-email.js +109 -0
- package/dist/adapters/resend-email.js.map +1 -0
- package/dist/adapters/searxng-instance.d.ts +6 -0
- package/dist/adapters/searxng-instance.js +240 -0
- package/dist/adapters/searxng-instance.js.map +1 -0
- package/dist/adapters/sentry-monitoring.d.ts +7 -0
- package/dist/adapters/sentry-monitoring.js +27 -0
- package/dist/adapters/sentry-monitoring.js.map +1 -0
- package/dist/adapters/stripe-payments.d.ts +6 -0
- package/dist/adapters/stripe-payments.js +134 -0
- package/dist/adapters/stripe-payments.js.map +1 -0
- package/dist/adapters/supabase-db.d.ts +6 -0
- package/dist/adapters/supabase-db.js +130 -0
- package/dist/adapters/supabase-db.js.map +1 -0
- package/dist/adapters/tinybird-analytics.d.ts +5 -0
- package/dist/adapters/tinybird-analytics.js +20 -0
- package/dist/adapters/tinybird-analytics.js.map +1 -0
- package/dist/adapters/trigger-background.d.ts +6 -0
- package/dist/adapters/trigger-background.js +20 -0
- package/dist/adapters/trigger-background.js.map +1 -0
- package/dist/adapters/types.d.ts +7 -0
- package/dist/adapters/types.js +2 -0
- package/dist/adapters/types.js.map +1 -0
- package/dist/adapters/upstash-redis.d.ts +6 -0
- package/dist/adapters/upstash-redis.js +88 -0
- package/dist/adapters/upstash-redis.js.map +1 -0
- package/dist/adapters/vercel-hosting.d.ts +6 -0
- package/dist/adapters/vercel-hosting.js +112 -0
- package/dist/adapters/vercel-hosting.js.map +1 -0
- package/dist/agent-adapter-model.d.ts +108 -0
- package/dist/agent-adapter-model.js +6 -0
- package/dist/agent-adapter-model.js.map +1 -0
- package/dist/agent-adapter-service.d.ts +67 -0
- package/dist/agent-adapter-service.js +299 -0
- package/dist/agent-adapter-service.js.map +1 -0
- package/dist/agent-config.d.ts +56 -0
- package/dist/agent-config.js +129 -0
- package/dist/agent-config.js.map +1 -0
- package/dist/agent-governance-model.d.ts +128 -0
- package/dist/agent-governance-model.js +6 -0
- package/dist/agent-governance-model.js.map +1 -0
- package/dist/agent-governance-service.d.ts +101 -0
- package/dist/agent-governance-service.js +319 -0
- package/dist/agent-governance-service.js.map +1 -0
- package/dist/alert-rules-engine.d.ts +102 -0
- package/dist/alert-rules-engine.js +210 -0
- package/dist/alert-rules-engine.js.map +1 -0
- package/dist/analytics-service.d.ts +126 -0
- package/dist/analytics-service.js +318 -0
- package/dist/analytics-service.js.map +1 -0
- package/dist/analyze.d.ts +19 -0
- package/dist/analyze.js +311 -0
- package/dist/analyze.js.map +1 -0
- package/dist/apm-instrumentor.d.ts +119 -0
- package/dist/apm-instrumentor.js +225 -0
- package/dist/apm-instrumentor.js.map +1 -0
- package/dist/approval-model.d.ts +82 -0
- package/dist/approval-model.js +6 -0
- package/dist/approval-model.js.map +1 -0
- package/dist/approval-service.d.ts +39 -0
- package/dist/approval-service.js +236 -0
- package/dist/approval-service.js.map +1 -0
- package/dist/approval.d.ts +22 -0
- package/dist/approval.js +148 -0
- package/dist/approval.js.map +1 -0
- package/dist/audit-logging-model.d.ts +157 -0
- package/dist/audit-logging-model.js +6 -0
- package/dist/audit-logging-model.js.map +1 -0
- package/dist/audit-logging-service.d.ts +89 -0
- package/dist/audit-logging-service.js +367 -0
- package/dist/audit-logging-service.js.map +1 -0
- package/dist/audit-secrets.d.ts +42 -0
- package/dist/audit-secrets.js +126 -0
- package/dist/audit-secrets.js.map +1 -0
- package/dist/audit.d.ts +43 -0
- package/dist/audit.js +286 -0
- package/dist/audit.js.map +1 -0
- package/dist/author-dashboard.d.ts +84 -0
- package/dist/author-dashboard.js +204 -0
- package/dist/author-dashboard.js.map +1 -0
- package/dist/author-notifications.d.ts +130 -0
- package/dist/author-notifications.js +261 -0
- package/dist/author-notifications.js.map +1 -0
- package/dist/author-verification.d.ts +79 -0
- package/dist/author-verification.js +257 -0
- package/dist/author-verification.js.map +1 -0
- package/dist/autonomous-setup-model.d.ts +117 -0
- package/dist/autonomous-setup-model.js +6 -0
- package/dist/autonomous-setup-model.js.map +1 -0
- package/dist/autonomous-setup-service.d.ts +74 -0
- package/dist/autonomous-setup-service.js +325 -0
- package/dist/autonomous-setup-service.js.map +1 -0
- package/dist/badge-system.d.ts +70 -0
- package/dist/badge-system.js +210 -0
- package/dist/badge-system.js.map +1 -0
- package/dist/baseline.d.ts +34 -0
- package/dist/baseline.js +78 -0
- package/dist/baseline.js.map +1 -0
- package/dist/beta-program-service.d.ts +112 -0
- package/dist/beta-program-service.js +240 -0
- package/dist/beta-program-service.js.map +1 -0
- package/dist/budget.d.ts +34 -0
- package/dist/budget.js +159 -0
- package/dist/budget.js.map +1 -0
- package/dist/bumblebee.d.ts +143 -0
- package/dist/bumblebee.js +384 -0
- package/dist/bumblebee.js.map +1 -0
- package/dist/cache-manager.d.ts +97 -0
- package/dist/cache-manager.js +244 -0
- package/dist/cache-manager.js.map +1 -0
- package/dist/cdn-adapter.d.ts +64 -0
- package/dist/cdn-adapter.js +263 -0
- package/dist/cdn-adapter.js.map +1 -0
- package/dist/certification-workflow-model.d.ts +95 -0
- package/dist/certification-workflow-model.js +6 -0
- package/dist/certification-workflow-model.js.map +1 -0
- package/dist/certification-workflow-service.d.ts +72 -0
- package/dist/certification-workflow-service.js +305 -0
- package/dist/certification-workflow-service.js.map +1 -0
- package/dist/check-design.d.ts +38 -0
- package/dist/check-design.js +256 -0
- package/dist/check-design.js.map +1 -0
- package/dist/check-gitignore.d.ts +39 -0
- package/dist/check-gitignore.js +156 -0
- package/dist/check-gitignore.js.map +1 -0
- package/dist/check-hooks.d.ts +15 -0
- package/dist/check-hooks.js +72 -0
- package/dist/check-hooks.js.map +1 -0
- package/dist/check-lock.d.ts +16 -0
- package/dist/check-lock.js +94 -0
- package/dist/check-lock.js.map +1 -0
- package/dist/check-secrets.d.ts +11 -0
- package/dist/check-secrets.js +320 -0
- package/dist/check-secrets.js.map +1 -0
- package/dist/check-security.d.ts +13 -0
- package/dist/check-security.js +887 -0
- package/dist/check-security.js.map +1 -0
- package/dist/check-services.d.ts +10 -0
- package/dist/check-services.js +44 -0
- package/dist/check-services.js.map +1 -0
- package/dist/check-skills.d.ts +8 -0
- package/dist/check-skills.js +26 -0
- package/dist/check-skills.js.map +1 -0
- package/dist/check-tests.d.ts +43 -0
- package/dist/check-tests.js +175 -0
- package/dist/check-tests.js.map +1 -0
- package/dist/check-tools.d.ts +8 -0
- package/dist/check-tools.js +42 -0
- package/dist/check-tools.js.map +1 -0
- package/dist/check-web-search.d.ts +12 -0
- package/dist/check-web-search.js +168 -0
- package/dist/check-web-search.js.map +1 -0
- package/dist/ci-cd-publisher.d.ts +162 -0
- package/dist/ci-cd-publisher.js +319 -0
- package/dist/ci-cd-publisher.js.map +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.js +4074 -0
- package/dist/cli.js.map +1 -0
- package/dist/clone.d.ts +25 -0
- package/dist/clone.js +73 -0
- package/dist/clone.js.map +1 -0
- package/dist/completions.d.ts +8 -0
- package/dist/completions.js +250 -0
- package/dist/completions.js.map +1 -0
- package/dist/compression-manager.d.ts +107 -0
- package/dist/compression-manager.js +250 -0
- package/dist/compression-manager.js.map +1 -0
- package/dist/config.d.ts +233 -0
- package/dist/config.js +255 -0
- package/dist/config.js.map +1 -0
- package/dist/context.d.ts +38 -0
- package/dist/context.js +86 -0
- package/dist/context.js.map +1 -0
- package/dist/cost-monitor.d.ts +72 -0
- package/dist/cost-monitor.js +218 -0
- package/dist/cost-monitor.js.map +1 -0
- package/dist/create-plugin.d.ts +22 -0
- package/dist/create-plugin.js +266 -0
- package/dist/create-plugin.js.map +1 -0
- package/dist/database.d.ts +123 -0
- package/dist/database.js +354 -0
- package/dist/database.js.map +1 -0
- package/dist/datadog-adapter.d.ts +60 -0
- package/dist/datadog-adapter.js +245 -0
- package/dist/datadog-adapter.js.map +1 -0
- package/dist/doctor.d.ts +15 -0
- package/dist/doctor.js +131 -0
- package/dist/doctor.js.map +1 -0
- package/dist/documentation-generator.d.ts +226 -0
- package/dist/documentation-generator.js +348 -0
- package/dist/documentation-generator.js.map +1 -0
- package/dist/elevation-scopes.d.ts +40 -0
- package/dist/elevation-scopes.js +110 -0
- package/dist/elevation-scopes.js.map +1 -0
- package/dist/elevation.d.ts +102 -0
- package/dist/elevation.js +449 -0
- package/dist/elevation.js.map +1 -0
- package/dist/env-diff.d.ts +27 -0
- package/dist/env-diff.js +104 -0
- package/dist/env-diff.js.map +1 -0
- package/dist/env-inspect.d.ts +28 -0
- package/dist/env-inspect.js +81 -0
- package/dist/env-inspect.js.map +1 -0
- package/dist/env-switch.d.ts +37 -0
- package/dist/env-switch.js +102 -0
- package/dist/env-switch.js.map +1 -0
- package/dist/environment.d.ts +27 -0
- package/dist/environment.js +148 -0
- package/dist/environment.js.map +1 -0
- package/dist/error-tracker.d.ts +92 -0
- package/dist/error-tracker.js +206 -0
- package/dist/error-tracker.js.map +1 -0
- package/dist/escalate.d.ts +11 -0
- package/dist/escalate.js +73 -0
- package/dist/escalate.js.map +1 -0
- package/dist/event-stream.d.ts +81 -0
- package/dist/event-stream.js +161 -0
- package/dist/event-stream.js.map +1 -0
- package/dist/fix.d.ts +42 -0
- package/dist/fix.js +419 -0
- package/dist/fix.js.map +1 -0
- package/dist/governance-middleware.d.ts +22 -0
- package/dist/governance-middleware.js +173 -0
- package/dist/governance-middleware.js.map +1 -0
- package/dist/governance.d.ts +44 -0
- package/dist/governance.js +236 -0
- package/dist/governance.js.map +1 -0
- package/dist/hooks.d.ts +25 -0
- package/dist/hooks.js +281 -0
- package/dist/hooks.js.map +1 -0
- package/dist/id-generator.d.ts +43 -0
- package/dist/id-generator.js +47 -0
- package/dist/id-generator.js.map +1 -0
- package/dist/image-optimizer.d.ts +92 -0
- package/dist/image-optimizer.js +202 -0
- package/dist/image-optimizer.js.map +1 -0
- package/dist/install.d.ts +15 -0
- package/dist/install.js +59 -0
- package/dist/install.js.map +1 -0
- package/dist/lock.d.ts +82 -0
- package/dist/lock.js +264 -0
- package/dist/lock.js.map +1 -0
- package/dist/login.d.ts +23 -0
- package/dist/login.js +132 -0
- package/dist/login.js.map +1 -0
- package/dist/mcp-kit-tools-model.d.ts +195 -0
- package/dist/mcp-kit-tools-model.js +6 -0
- package/dist/mcp-kit-tools-model.js.map +1 -0
- package/dist/mcp-kit-tools-service.d.ts +127 -0
- package/dist/mcp-kit-tools-service.js +943 -0
- package/dist/mcp-kit-tools-service.js.map +1 -0
- package/dist/mcp-orchestrator.d.ts +70 -0
- package/dist/mcp-orchestrator.js +175 -0
- package/dist/mcp-orchestrator.js.map +1 -0
- package/dist/mcp-server.d.ts +3 -0
- package/dist/mcp-server.js +722 -0
- package/dist/mcp-server.js.map +1 -0
- package/dist/middleware/rate-limiter.d.ts +74 -0
- package/dist/middleware/rate-limiter.js +342 -0
- package/dist/middleware/rate-limiter.js.map +1 -0
- package/dist/migration-runner.d.ts +66 -0
- package/dist/migration-runner.js +192 -0
- package/dist/migration-runner.js.map +1 -0
- package/dist/migrations.d.ts +25 -0
- package/dist/migrations.js +530 -0
- package/dist/migrations.js.map +1 -0
- package/dist/moderation-system.d.ts +153 -0
- package/dist/moderation-system.js +338 -0
- package/dist/moderation-system.js.map +1 -0
- package/dist/multi-agent-workflow-model.d.ts +125 -0
- package/dist/multi-agent-workflow-model.js +6 -0
- package/dist/multi-agent-workflow-model.js.map +1 -0
- package/dist/multi-agent-workflow-service.d.ts +102 -0
- package/dist/multi-agent-workflow-service.js +452 -0
- package/dist/multi-agent-workflow-service.js.map +1 -0
- package/dist/onepassword.d.ts +75 -0
- package/dist/onepassword.js +140 -0
- package/dist/onepassword.js.map +1 -0
- package/dist/open.d.ts +30 -0
- package/dist/open.js +166 -0
- package/dist/open.js.map +1 -0
- package/dist/output.d.ts +32 -0
- package/dist/output.js +295 -0
- package/dist/output.js.map +1 -0
- package/dist/partner-service.d.ts +101 -0
- package/dist/partner-service.js +191 -0
- package/dist/partner-service.js.map +1 -0
- package/dist/payout-service.d.ts +136 -0
- package/dist/payout-service.js +293 -0
- package/dist/payout-service.js.map +1 -0
- package/dist/pkg.d.ts +30 -0
- package/dist/pkg.js +162 -0
- package/dist/pkg.js.map +1 -0
- package/dist/plugin-loader.d.ts +16 -0
- package/dist/plugin-loader.js +124 -0
- package/dist/plugin-loader.js.map +1 -0
- package/dist/plugin-registry-model.d.ts +133 -0
- package/dist/plugin-registry-model.js +6 -0
- package/dist/plugin-registry-model.js.map +1 -0
- package/dist/plugin-registry-service.d.ts +109 -0
- package/dist/plugin-registry-service.js +361 -0
- package/dist/plugin-registry-service.js.map +1 -0
- package/dist/plugin-registry.d.ts +58 -0
- package/dist/plugin-registry.js +108 -0
- package/dist/plugin-registry.js.map +1 -0
- package/dist/plugin-updates.d.ts +135 -0
- package/dist/plugin-updates.js +326 -0
- package/dist/plugin-updates.js.map +1 -0
- package/dist/plugins-cli.d.ts +7 -0
- package/dist/plugins-cli.js +157 -0
- package/dist/plugins-cli.js.map +1 -0
- package/dist/plugins.d.ts +88 -0
- package/dist/plugins.js +251 -0
- package/dist/plugins.js.map +1 -0
- package/dist/policy.d.ts +66 -0
- package/dist/policy.js +160 -0
- package/dist/policy.js.map +1 -0
- package/dist/post-pull-audit.d.ts +39 -0
- package/dist/post-pull-audit.js +151 -0
- package/dist/post-pull-audit.js.map +1 -0
- package/dist/provision.d.ts +17 -0
- package/dist/provision.js +147 -0
- package/dist/provision.js.map +1 -0
- package/dist/query-optimizer.d.ts +102 -0
- package/dist/query-optimizer.js +199 -0
- package/dist/query-optimizer.js.map +1 -0
- package/dist/read-only-mode.d.ts +46 -0
- package/dist/read-only-mode.js +71 -0
- package/dist/read-only-mode.js.map +1 -0
- package/dist/redis-adapter.d.ts +71 -0
- package/dist/redis-adapter.js +278 -0
- package/dist/redis-adapter.js.map +1 -0
- package/dist/resilience-tests.d.ts +120 -0
- package/dist/resilience-tests.js +293 -0
- package/dist/resilience-tests.js.map +1 -0
- package/dist/revocation.d.ts +22 -0
- package/dist/revocation.js +100 -0
- package/dist/revocation.js.map +1 -0
- package/dist/run.d.ts +21 -0
- package/dist/run.js +80 -0
- package/dist/run.js.map +1 -0
- package/dist/scan-build.d.ts +18 -0
- package/dist/scan-build.js +100 -0
- package/dist/scan-build.js.map +1 -0
- package/dist/scan-plaintext.d.ts +24 -0
- package/dist/scan-plaintext.js +147 -0
- package/dist/scan-plaintext.js.map +1 -0
- package/dist/scan-staged.d.ts +15 -0
- package/dist/scan-staged.js +70 -0
- package/dist/scan-staged.js.map +1 -0
- package/dist/scan-transcripts.d.ts +23 -0
- package/dist/scan-transcripts.js +93 -0
- package/dist/scan-transcripts.js.map +1 -0
- package/dist/secret-backends.d.ts +50 -0
- package/dist/secret-backends.js +510 -0
- package/dist/secret-backends.js.map +1 -0
- package/dist/secret-expiration.d.ts +46 -0
- package/dist/secret-expiration.js +172 -0
- package/dist/secret-expiration.js.map +1 -0
- package/dist/secrets-migrate.d.ts +75 -0
- package/dist/secrets-migrate.js +185 -0
- package/dist/secrets-migrate.js.map +1 -0
- package/dist/secrets-model.d.ts +77 -0
- package/dist/secrets-model.js +6 -0
- package/dist/secrets-model.js.map +1 -0
- package/dist/secrets-onecli.d.ts +65 -0
- package/dist/secrets-onecli.js +113 -0
- package/dist/secrets-onecli.js.map +1 -0
- package/dist/secrets-propagate.d.ts +48 -0
- package/dist/secrets-propagate.js +201 -0
- package/dist/secrets-propagate.js.map +1 -0
- package/dist/secrets-pull.d.ts +34 -0
- package/dist/secrets-pull.js +118 -0
- package/dist/secrets-pull.js.map +1 -0
- package/dist/secrets-purge-history.d.ts +53 -0
- package/dist/secrets-purge-history.js +144 -0
- package/dist/secrets-purge-history.js.map +1 -0
- package/dist/secrets-rotate-cli.d.ts +54 -0
- package/dist/secrets-rotate-cli.js +438 -0
- package/dist/secrets-rotate-cli.js.map +1 -0
- package/dist/secrets-rotate.d.ts +38 -0
- package/dist/secrets-rotate.js +65 -0
- package/dist/secrets-rotate.js.map +1 -0
- package/dist/secrets-service.d.ts +73 -0
- package/dist/secrets-service.js +283 -0
- package/dist/secrets-service.js.map +1 -0
- package/dist/secrets-set.d.ts +25 -0
- package/dist/secrets-set.js +33 -0
- package/dist/secrets-set.js.map +1 -0
- package/dist/secrets-sync.d.ts +21 -0
- package/dist/secrets-sync.js +215 -0
- package/dist/secrets-sync.js.map +1 -0
- package/dist/secrets-validate.d.ts +41 -0
- package/dist/secrets-validate.js +126 -0
- package/dist/secrets-validate.js.map +1 -0
- package/dist/secrets-vault-migrate.d.ts +71 -0
- package/dist/secrets-vault-migrate.js +258 -0
- package/dist/secrets-vault-migrate.js.map +1 -0
- package/dist/secrets.d.ts +16 -0
- package/dist/secrets.js +72 -0
- package/dist/secrets.js.map +1 -0
- package/dist/security-hardening.d.ts +150 -0
- package/dist/security-hardening.js +275 -0
- package/dist/security-hardening.js.map +1 -0
- package/dist/security-policy.d.ts +89 -0
- package/dist/security-policy.js +174 -0
- package/dist/security-policy.js.map +1 -0
- package/dist/security-prescan.d.ts +117 -0
- package/dist/security-prescan.js +566 -0
- package/dist/security-prescan.js.map +1 -0
- package/dist/sentry-adapter.d.ts +49 -0
- package/dist/sentry-adapter.js +227 -0
- package/dist/sentry-adapter.js.map +1 -0
- package/dist/service-adapter.d.ts +94 -0
- package/dist/service-adapter.js +162 -0
- package/dist/service-adapter.js.map +1 -0
- package/dist/skills.d.ts +13 -0
- package/dist/skills.js +17 -0
- package/dist/skills.js.map +1 -0
- package/dist/sla-monitor.d.ts +107 -0
- package/dist/sla-monitor.js +233 -0
- package/dist/sla-monitor.js.map +1 -0
- package/dist/stack-detector.d.ts +12 -0
- package/dist/stack-detector.js +251 -0
- package/dist/stack-detector.js.map +1 -0
- package/dist/team-model.d.ts +58 -0
- package/dist/team-model.js +83 -0
- package/dist/team-model.js.map +1 -0
- package/dist/team-service.d.ts +54 -0
- package/dist/team-service.js +206 -0
- package/dist/team-service.js.map +1 -0
- package/dist/toml-generator.d.ts +8 -0
- package/dist/toml-generator.js +223 -0
- package/dist/toml-generator.js.map +1 -0
- package/dist/triage-sandbox.d.ts +34 -0
- package/dist/triage-sandbox.js +167 -0
- package/dist/triage-sandbox.js.map +1 -0
- package/dist/triage.d.ts +30 -0
- package/dist/triage.js +79 -0
- package/dist/triage.js.map +1 -0
- package/dist/update-check.d.ts +13 -0
- package/dist/update-check.js +91 -0
- package/dist/update-check.js.map +1 -0
- package/dist/utils/colors.d.ts +14 -0
- package/dist/utils/colors.js +15 -0
- package/dist/utils/colors.js.map +1 -0
- package/dist/utils/didYouMean.d.ts +15 -0
- package/dist/utils/didYouMean.js +47 -0
- package/dist/utils/didYouMean.js.map +1 -0
- package/dist/utils/exec.d.ts +21 -0
- package/dist/utils/exec.js +23 -0
- package/dist/utils/exec.js.map +1 -0
- package/dist/utils/execFileNoThrow.d.ts +14 -0
- package/dist/utils/execFileNoThrow.js +29 -0
- package/dist/utils/execFileNoThrow.js.map +1 -0
- package/dist/utils/flags.d.ts +19 -0
- package/dist/utils/flags.js +36 -0
- package/dist/utils/flags.js.map +1 -0
- package/dist/utils/parseCommand.d.ts +16 -0
- package/dist/utils/parseCommand.js +13 -0
- package/dist/utils/parseCommand.js.map +1 -0
- package/dist/utils/prompt.d.ts +13 -0
- package/dist/utils/prompt.js +35 -0
- package/dist/utils/prompt.js.map +1 -0
- package/dist/utils/promptSelect.d.ts +19 -0
- package/dist/utils/promptSelect.js +89 -0
- package/dist/utils/promptSelect.js.map +1 -0
- package/dist/utils/redactSecrets.d.ts +24 -0
- package/dist/utils/redactSecrets.js +134 -0
- package/dist/utils/redactSecrets.js.map +1 -0
- package/dist/validation/dynamic-schema.d.ts +29 -0
- package/dist/validation/dynamic-schema.js +76 -0
- package/dist/validation/dynamic-schema.js.map +1 -0
- package/package.json +52 -0
|
@@ -0,0 +1,367 @@
|
|
|
1
|
+
import { randomUUID } from "node:crypto";
|
|
2
|
+
const auditEntries = new Map();
|
|
3
|
+
const userActivity = new Map();
|
|
4
|
+
const changeHistory = new Map();
|
|
5
|
+
const complianceReports = new Map();
|
|
6
|
+
const auditLogs = new Map();
|
|
7
|
+
const dataExports = new Map();
|
|
8
|
+
const sessionAudits = new Map();
|
|
9
|
+
/**
|
|
10
|
+
* Record audit entry
|
|
11
|
+
*/
|
|
12
|
+
export function recordAuditEntry(action, resource, resource_id, actor_id, actor_name, status = "success", details = {}, severity = "low", team_id, actor_ip) {
|
|
13
|
+
const entry = {
|
|
14
|
+
id: `audit_${randomUUID()}`,
|
|
15
|
+
action,
|
|
16
|
+
resource,
|
|
17
|
+
resource_id,
|
|
18
|
+
actor_id,
|
|
19
|
+
actor_name,
|
|
20
|
+
actor_ip,
|
|
21
|
+
team_id,
|
|
22
|
+
status,
|
|
23
|
+
details,
|
|
24
|
+
severity,
|
|
25
|
+
timestamp: new Date().toISOString(),
|
|
26
|
+
created_at: new Date().toISOString(),
|
|
27
|
+
};
|
|
28
|
+
auditEntries.set(entry.id, entry);
|
|
29
|
+
// Update user activity
|
|
30
|
+
updateUserActivity(actor_id, actor_name, team_id);
|
|
31
|
+
// Create audit log entry
|
|
32
|
+
const log = {
|
|
33
|
+
id: `log_${randomUUID()}`,
|
|
34
|
+
team_id,
|
|
35
|
+
action,
|
|
36
|
+
resource,
|
|
37
|
+
resource_id,
|
|
38
|
+
actor_id,
|
|
39
|
+
actor_name,
|
|
40
|
+
status,
|
|
41
|
+
severity,
|
|
42
|
+
details,
|
|
43
|
+
timestamp: entry.timestamp,
|
|
44
|
+
created_at: entry.created_at,
|
|
45
|
+
};
|
|
46
|
+
auditLogs.set(log.id, log);
|
|
47
|
+
return { entry };
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Record change history
|
|
51
|
+
*/
|
|
52
|
+
export function recordChangeHistory(resource_id, resource_type, change_type, current_state, changed_by, changed_by_name, previous_state, reason, team_id) {
|
|
53
|
+
const history = {
|
|
54
|
+
id: `hist_${randomUUID()}`,
|
|
55
|
+
resource_id,
|
|
56
|
+
resource_type,
|
|
57
|
+
team_id,
|
|
58
|
+
change_type,
|
|
59
|
+
current_state,
|
|
60
|
+
previous_state,
|
|
61
|
+
changed_by,
|
|
62
|
+
changed_by_name,
|
|
63
|
+
reason,
|
|
64
|
+
timestamp: new Date().toISOString(),
|
|
65
|
+
created_at: new Date().toISOString(),
|
|
66
|
+
};
|
|
67
|
+
changeHistory.set(history.id, history);
|
|
68
|
+
return { history };
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Query audit entries
|
|
72
|
+
*/
|
|
73
|
+
export function queryAuditEntries(query) {
|
|
74
|
+
let results = Array.from(auditEntries.values());
|
|
75
|
+
if (query.team_id) {
|
|
76
|
+
results = results.filter((e) => e.team_id === query.team_id);
|
|
77
|
+
}
|
|
78
|
+
if (query.actor_id) {
|
|
79
|
+
results = results.filter((e) => e.actor_id === query.actor_id);
|
|
80
|
+
}
|
|
81
|
+
if (query.resource) {
|
|
82
|
+
results = results.filter((e) => e.resource === query.resource);
|
|
83
|
+
}
|
|
84
|
+
if (query.action) {
|
|
85
|
+
results = results.filter((e) => e.action === query.action);
|
|
86
|
+
}
|
|
87
|
+
if (query.status) {
|
|
88
|
+
results = results.filter((e) => e.status === query.status);
|
|
89
|
+
}
|
|
90
|
+
if (query.severity) {
|
|
91
|
+
results = results.filter((e) => e.severity === query.severity);
|
|
92
|
+
}
|
|
93
|
+
if (query.start_date) {
|
|
94
|
+
const startDate = new Date(query.start_date);
|
|
95
|
+
results = results.filter((e) => new Date(e.timestamp) >= startDate);
|
|
96
|
+
}
|
|
97
|
+
if (query.end_date) {
|
|
98
|
+
const endDate = new Date(query.end_date);
|
|
99
|
+
results = results.filter((e) => new Date(e.timestamp) <= endDate);
|
|
100
|
+
}
|
|
101
|
+
// Sort by timestamp descending
|
|
102
|
+
results.sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime());
|
|
103
|
+
const limit = query.limit || 100;
|
|
104
|
+
const offset = query.offset || 0;
|
|
105
|
+
const total = results.length;
|
|
106
|
+
return { entries: results.slice(offset, offset + limit), total };
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Get user activity
|
|
110
|
+
*/
|
|
111
|
+
export function getUserActivity(user_id) {
|
|
112
|
+
const activity = userActivity.get(user_id);
|
|
113
|
+
return {
|
|
114
|
+
activity: activity || null,
|
|
115
|
+
error: activity ? undefined : "User activity not found",
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* List user activities
|
|
120
|
+
*/
|
|
121
|
+
export function listUserActivities(team_id, limit = 50, offset = 0) {
|
|
122
|
+
let all = Array.from(userActivity.values());
|
|
123
|
+
if (team_id) {
|
|
124
|
+
all = all.filter((a) => a.team_id === team_id);
|
|
125
|
+
}
|
|
126
|
+
all.sort((a, b) => new Date(b.updated_at).getTime() - new Date(a.updated_at).getTime());
|
|
127
|
+
const total = all.length;
|
|
128
|
+
return { activities: all.slice(offset, offset + limit), total };
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Get change history for resource
|
|
132
|
+
*/
|
|
133
|
+
export function getChangeHistory(resource_id, limit = 50, offset = 0) {
|
|
134
|
+
let all = Array.from(changeHistory.values()).filter((h) => h.resource_id === resource_id);
|
|
135
|
+
all.sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime());
|
|
136
|
+
const total = all.length;
|
|
137
|
+
return { history: all.slice(offset, offset + limit), total };
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Generate compliance report
|
|
141
|
+
*/
|
|
142
|
+
export function generateComplianceReport(standard, period_start, period_end, generated_by, team_id) {
|
|
143
|
+
const startDate = new Date(period_start);
|
|
144
|
+
const endDate = new Date(period_end);
|
|
145
|
+
const entries = Array.from(auditEntries.values()).filter((e) => {
|
|
146
|
+
const timestamp = new Date(e.timestamp);
|
|
147
|
+
const teamMatch = !team_id || e.team_id === team_id;
|
|
148
|
+
const dateMatch = timestamp >= startDate && timestamp <= endDate;
|
|
149
|
+
return teamMatch && dateMatch;
|
|
150
|
+
});
|
|
151
|
+
const issues = [];
|
|
152
|
+
// Identify compliance issues
|
|
153
|
+
const failedOps = entries.filter((e) => e.status === "failure");
|
|
154
|
+
failedOps.forEach((e) => {
|
|
155
|
+
if (failedOps.length > 10) {
|
|
156
|
+
// Threshold for concern
|
|
157
|
+
issues.push({
|
|
158
|
+
id: `issue_${randomUUID()}`,
|
|
159
|
+
severity: "medium",
|
|
160
|
+
type: "high_failure_rate",
|
|
161
|
+
description: `High rate of failed operations detected (${failedOps.length} in period)`,
|
|
162
|
+
timestamp: new Date().toISOString(),
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
});
|
|
166
|
+
const criticalEvents = entries.filter((e) => e.severity === "critical");
|
|
167
|
+
if (criticalEvents.length > 0) {
|
|
168
|
+
criticalEvents.forEach((e) => {
|
|
169
|
+
issues.push({
|
|
170
|
+
id: `issue_${randomUUID()}`,
|
|
171
|
+
severity: "critical",
|
|
172
|
+
type: "critical_event",
|
|
173
|
+
description: `Critical event: ${e.action} on ${e.resource}`,
|
|
174
|
+
resource_id: e.resource_id,
|
|
175
|
+
resource_type: e.resource,
|
|
176
|
+
actor_id: e.actor_id,
|
|
177
|
+
timestamp: e.timestamp,
|
|
178
|
+
});
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
// Calculate compliance score
|
|
182
|
+
let score = 100;
|
|
183
|
+
score -= failedOps.length * 2;
|
|
184
|
+
score -= criticalEvents.length * 10;
|
|
185
|
+
score = Math.max(0, Math.min(100, score));
|
|
186
|
+
const report = {
|
|
187
|
+
id: `report_${randomUUID()}`,
|
|
188
|
+
standard,
|
|
189
|
+
period_start,
|
|
190
|
+
period_end,
|
|
191
|
+
team_id,
|
|
192
|
+
total_audit_entries: entries.length,
|
|
193
|
+
security_events: entries.filter((e) => e.severity === "critical" || e.severity === "high")
|
|
194
|
+
.length,
|
|
195
|
+
failed_operations: failedOps.length,
|
|
196
|
+
data_access_events: entries.filter((e) => e.action === "read" ||
|
|
197
|
+
e.action === "export" ||
|
|
198
|
+
e.action === "import").length,
|
|
199
|
+
deletion_events: entries.filter((e) => e.action === "delete").length,
|
|
200
|
+
role_changes: entries.filter((e) => e.resource === "role" && e.action === "update").length,
|
|
201
|
+
permission_changes: entries.filter((e) => e.resource === "permission").length,
|
|
202
|
+
compliance_score: score,
|
|
203
|
+
issues,
|
|
204
|
+
generated_at: new Date().toISOString(),
|
|
205
|
+
generated_by,
|
|
206
|
+
created_at: new Date().toISOString(),
|
|
207
|
+
};
|
|
208
|
+
complianceReports.set(report.id, report);
|
|
209
|
+
return { report };
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* List compliance reports
|
|
213
|
+
*/
|
|
214
|
+
export function listComplianceReports(team_id, limit = 50, offset = 0) {
|
|
215
|
+
let all = Array.from(complianceReports.values());
|
|
216
|
+
if (team_id) {
|
|
217
|
+
all = all.filter((r) => r.team_id === team_id);
|
|
218
|
+
}
|
|
219
|
+
all.sort((a, b) => new Date(b.created_at).getTime() - new Date(a.created_at).getTime());
|
|
220
|
+
const total = all.length;
|
|
221
|
+
return { reports: all.slice(offset, offset + limit), total };
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* Request data export for compliance
|
|
225
|
+
*/
|
|
226
|
+
export function requestDataExport(user_id, format, data_types, team_id, start_date, end_date) {
|
|
227
|
+
const request = {
|
|
228
|
+
id: `export_${randomUUID()}`,
|
|
229
|
+
user_id,
|
|
230
|
+
team_id,
|
|
231
|
+
export_type: "filtered",
|
|
232
|
+
data_types,
|
|
233
|
+
start_date,
|
|
234
|
+
end_date,
|
|
235
|
+
format,
|
|
236
|
+
status: "pending",
|
|
237
|
+
requested_at: new Date().toISOString(),
|
|
238
|
+
created_at: new Date().toISOString(),
|
|
239
|
+
};
|
|
240
|
+
dataExports.set(request.id, request);
|
|
241
|
+
// Simulate processing (in real system would be async)
|
|
242
|
+
setTimeout(() => {
|
|
243
|
+
const exp = dataExports.get(request.id);
|
|
244
|
+
if (exp) {
|
|
245
|
+
exp.status = "completed";
|
|
246
|
+
exp.download_url = `https://api.example.com/exports/${request.id}`;
|
|
247
|
+
const expiresAt = new Date();
|
|
248
|
+
expiresAt.setDate(expiresAt.getDate() + 7);
|
|
249
|
+
exp.expires_at = expiresAt.toISOString();
|
|
250
|
+
exp.completed_at = new Date().toISOString();
|
|
251
|
+
}
|
|
252
|
+
}, 1000);
|
|
253
|
+
return { request };
|
|
254
|
+
}
|
|
255
|
+
/**
|
|
256
|
+
* Get data export status
|
|
257
|
+
*/
|
|
258
|
+
export function getDataExportStatus(export_id) {
|
|
259
|
+
const request = dataExports.get(export_id);
|
|
260
|
+
return {
|
|
261
|
+
request: request || null,
|
|
262
|
+
error: request ? undefined : "Export request not found",
|
|
263
|
+
};
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Record session audit
|
|
267
|
+
*/
|
|
268
|
+
export function recordSessionAudit(user_id, session_id, ip_address, user_agent) {
|
|
269
|
+
const session = {
|
|
270
|
+
id: `session_${randomUUID()}`,
|
|
271
|
+
user_id,
|
|
272
|
+
session_id,
|
|
273
|
+
ip_address,
|
|
274
|
+
user_agent,
|
|
275
|
+
login_time: new Date().toISOString(),
|
|
276
|
+
actions_count: 0,
|
|
277
|
+
last_activity_at: new Date().toISOString(),
|
|
278
|
+
is_active: true,
|
|
279
|
+
created_at: new Date().toISOString(),
|
|
280
|
+
};
|
|
281
|
+
sessionAudits.set(session.id, session);
|
|
282
|
+
return { session };
|
|
283
|
+
}
|
|
284
|
+
/**
|
|
285
|
+
* End session audit
|
|
286
|
+
*/
|
|
287
|
+
export function endSessionAudit(session_id) {
|
|
288
|
+
const session = Array.from(sessionAudits.values()).find((s) => s.session_id === session_id);
|
|
289
|
+
if (!session) {
|
|
290
|
+
return { success: false, error: "Session not found" };
|
|
291
|
+
}
|
|
292
|
+
session.is_active = false;
|
|
293
|
+
session.logout_time = new Date().toISOString();
|
|
294
|
+
session.duration_minutes = Math.round((new Date(session.logout_time).getTime() - new Date(session.login_time).getTime()) /
|
|
295
|
+
60000);
|
|
296
|
+
return { success: true };
|
|
297
|
+
}
|
|
298
|
+
/**
|
|
299
|
+
* Get audit metrics
|
|
300
|
+
*/
|
|
301
|
+
export function getAuditMetrics(team_id) {
|
|
302
|
+
const now = new Date();
|
|
303
|
+
const last24h = new Date(now.getTime() - 24 * 60 * 60 * 1000);
|
|
304
|
+
const last7d = new Date(now.getTime() - 7 * 24 * 60 * 60 * 1000);
|
|
305
|
+
const last30d = new Date(now.getTime() - 30 * 24 * 60 * 60 * 1000);
|
|
306
|
+
let entries = Array.from(auditEntries.values());
|
|
307
|
+
if (team_id) {
|
|
308
|
+
entries = entries.filter((e) => e.team_id === team_id);
|
|
309
|
+
}
|
|
310
|
+
const entries24h = entries.filter((e) => new Date(e.timestamp) >= last24h).length;
|
|
311
|
+
const entries7d = entries.filter((e) => new Date(e.timestamp) >= last7d).length;
|
|
312
|
+
const entries30d = entries.filter((e) => new Date(e.timestamp) >= last30d).length;
|
|
313
|
+
const uniqueUsers = new Set(entries.map((e) => e.actor_id)).size;
|
|
314
|
+
const uniqueResources = new Set(entries.map((e) => e.resource_id)).size;
|
|
315
|
+
const failedOps = entries.filter((e) => e.status === "failure").length;
|
|
316
|
+
const criticalEvents = entries.filter((e) => e.severity === "critical").length;
|
|
317
|
+
const actionCounts = {};
|
|
318
|
+
const resourceCounts = {};
|
|
319
|
+
entries.forEach((e) => {
|
|
320
|
+
actionCounts[e.action] = (actionCounts[e.action] || 0) + 1;
|
|
321
|
+
resourceCounts[e.resource] = (resourceCounts[e.resource] || 0) + 1;
|
|
322
|
+
});
|
|
323
|
+
const mostCommonAction = Object.entries(actionCounts).sort((a, b) => b[1] - a[1])[0]?.[0] || "none";
|
|
324
|
+
const mostAccessedResource = Object.entries(resourceCounts).sort((a, b) => b[1] - a[1])[0]?.[0] || "none";
|
|
325
|
+
return {
|
|
326
|
+
total_entries: entries.length,
|
|
327
|
+
entries_last_24h: entries24h,
|
|
328
|
+
entries_last_7d: entries7d,
|
|
329
|
+
entries_last_30d: entries30d,
|
|
330
|
+
unique_users: uniqueUsers,
|
|
331
|
+
unique_resources: uniqueResources,
|
|
332
|
+
failed_operations_count: failedOps,
|
|
333
|
+
critical_events_count: criticalEvents,
|
|
334
|
+
average_actions_per_user: uniqueUsers > 0 ? Math.round(entries.length / uniqueUsers) : 0,
|
|
335
|
+
most_common_action: mostCommonAction,
|
|
336
|
+
most_accessed_resource: mostAccessedResource,
|
|
337
|
+
};
|
|
338
|
+
}
|
|
339
|
+
/**
|
|
340
|
+
* Update user activity (internal)
|
|
341
|
+
*/
|
|
342
|
+
function updateUserActivity(user_id, user_name, team_id) {
|
|
343
|
+
const existing = userActivity.get(user_id);
|
|
344
|
+
if (existing) {
|
|
345
|
+
existing.action_count += 1;
|
|
346
|
+
existing.last_action_at = new Date().toISOString();
|
|
347
|
+
existing.updated_at = new Date().toISOString();
|
|
348
|
+
}
|
|
349
|
+
else {
|
|
350
|
+
const activity = {
|
|
351
|
+
id: `activity_${randomUUID()}`,
|
|
352
|
+
user_id,
|
|
353
|
+
user_name,
|
|
354
|
+
team_id,
|
|
355
|
+
action_count: 1,
|
|
356
|
+
first_action_at: new Date().toISOString(),
|
|
357
|
+
last_action_at: new Date().toISOString(),
|
|
358
|
+
login_count: 0,
|
|
359
|
+
unique_resources_accessed: 1,
|
|
360
|
+
is_active: true,
|
|
361
|
+
created_at: new Date().toISOString(),
|
|
362
|
+
updated_at: new Date().toISOString(),
|
|
363
|
+
};
|
|
364
|
+
userActivity.set(user_id, activity);
|
|
365
|
+
}
|
|
366
|
+
}
|
|
367
|
+
//# sourceMappingURL=audit-logging-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit-logging-service.js","sourceRoot":"","sources":["../src/audit-logging-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Forensics view on the audit log filtered to secret-touching operations.
|
|
3
|
+
*
|
|
4
|
+
* After a leak it's invaluable to know:
|
|
5
|
+
* - Which agent / user resolved each key, and when
|
|
6
|
+
* - Which migrate / rotate / register-fake / propagate events touched it
|
|
7
|
+
* - Whether the key appeared in any service-output that flowed to disk
|
|
8
|
+
*
|
|
9
|
+
* Reads `.kit-audit.jsonl` (the JSONL append-only log written by the
|
|
10
|
+
* existing `logAuditEvent` helper). Filters + groups events per key.
|
|
11
|
+
*/
|
|
12
|
+
import type { AuditEvent } from "./audit.js";
|
|
13
|
+
export interface SecretAccessEntry {
|
|
14
|
+
timestamp: string;
|
|
15
|
+
operation: string;
|
|
16
|
+
agent?: string;
|
|
17
|
+
detail: string;
|
|
18
|
+
success: boolean;
|
|
19
|
+
}
|
|
20
|
+
export interface SecretAuditReport {
|
|
21
|
+
key: string;
|
|
22
|
+
events: SecretAccessEntry[];
|
|
23
|
+
}
|
|
24
|
+
export declare function readSecretAuditEvents(cwd?: string, sinceDays?: number): Promise<AuditEvent[]>;
|
|
25
|
+
/**
|
|
26
|
+
* Extracts secret-related event details, attempting to attribute each event
|
|
27
|
+
* to one or more specific keys via the metadata payload.
|
|
28
|
+
*/
|
|
29
|
+
export declare function groupBySecret(events: AuditEvent[]): {
|
|
30
|
+
reports: SecretAuditReport[];
|
|
31
|
+
unattributed: SecretAccessEntry[];
|
|
32
|
+
};
|
|
33
|
+
export interface AuditSummary {
|
|
34
|
+
totalEvents: number;
|
|
35
|
+
keyCount: number;
|
|
36
|
+
topKey?: {
|
|
37
|
+
key: string;
|
|
38
|
+
count: number;
|
|
39
|
+
};
|
|
40
|
+
windowDays: number;
|
|
41
|
+
}
|
|
42
|
+
export declare function summarize(reports: SecretAuditReport[], windowDays: number): AuditSummary;
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Forensics view on the audit log filtered to secret-touching operations.
|
|
3
|
+
*
|
|
4
|
+
* After a leak it's invaluable to know:
|
|
5
|
+
* - Which agent / user resolved each key, and when
|
|
6
|
+
* - Which migrate / rotate / register-fake / propagate events touched it
|
|
7
|
+
* - Whether the key appeared in any service-output that flowed to disk
|
|
8
|
+
*
|
|
9
|
+
* Reads `.kit-audit.jsonl` (the JSONL append-only log written by the
|
|
10
|
+
* existing `logAuditEvent` helper). Filters + groups events per key.
|
|
11
|
+
*/
|
|
12
|
+
import { readFile, access } from "node:fs/promises";
|
|
13
|
+
import { resolve } from "node:path";
|
|
14
|
+
const AUDIT_FILE = ".kit-audit.jsonl";
|
|
15
|
+
const SECRET_OPERATIONS = new Set([
|
|
16
|
+
"secrets.generate",
|
|
17
|
+
"secrets.sync",
|
|
18
|
+
"secrets.migrate",
|
|
19
|
+
"secrets.rotate",
|
|
20
|
+
"secrets.onecli.register",
|
|
21
|
+
"secrets.propagate",
|
|
22
|
+
"services.login",
|
|
23
|
+
"fix",
|
|
24
|
+
]);
|
|
25
|
+
export async function readSecretAuditEvents(cwd = process.cwd(), sinceDays = 30) {
|
|
26
|
+
const path = resolve(cwd, AUDIT_FILE);
|
|
27
|
+
try {
|
|
28
|
+
await access(path);
|
|
29
|
+
}
|
|
30
|
+
catch {
|
|
31
|
+
return [];
|
|
32
|
+
}
|
|
33
|
+
const text = await readFile(path, "utf-8");
|
|
34
|
+
const lines = text.split("\n").filter((l) => l.trim().length > 0);
|
|
35
|
+
const cutoff = Date.now() - sinceDays * 24 * 3600 * 1000;
|
|
36
|
+
const events = [];
|
|
37
|
+
for (const line of lines) {
|
|
38
|
+
try {
|
|
39
|
+
const e = JSON.parse(line);
|
|
40
|
+
if (!SECRET_OPERATIONS.has(e.operation))
|
|
41
|
+
continue;
|
|
42
|
+
const ts = Date.parse(e.timestamp);
|
|
43
|
+
if (!Number.isFinite(ts) || ts < cutoff)
|
|
44
|
+
continue;
|
|
45
|
+
events.push(e);
|
|
46
|
+
}
|
|
47
|
+
catch {
|
|
48
|
+
// skip malformed line
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return events;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Extracts secret-related event details, attempting to attribute each event
|
|
55
|
+
* to one or more specific keys via the metadata payload.
|
|
56
|
+
*/
|
|
57
|
+
export function groupBySecret(events) {
|
|
58
|
+
const byKey = new Map();
|
|
59
|
+
const unattributed = [];
|
|
60
|
+
for (const e of events) {
|
|
61
|
+
const meta = (e.metadata ?? {});
|
|
62
|
+
const keys = collectKeyNames(meta);
|
|
63
|
+
const entry = {
|
|
64
|
+
timestamp: e.timestamp,
|
|
65
|
+
operation: e.operation,
|
|
66
|
+
agent: e.agent_name ?? e.agent_id,
|
|
67
|
+
detail: summarizeEvent(e),
|
|
68
|
+
success: e.success,
|
|
69
|
+
};
|
|
70
|
+
if (keys.length === 0) {
|
|
71
|
+
unattributed.push(entry);
|
|
72
|
+
continue;
|
|
73
|
+
}
|
|
74
|
+
for (const k of keys) {
|
|
75
|
+
const arr = byKey.get(k) ?? [];
|
|
76
|
+
arr.push(entry);
|
|
77
|
+
byKey.set(k, arr);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
const reports = [...byKey.entries()]
|
|
81
|
+
.map(([key, events]) => ({
|
|
82
|
+
key,
|
|
83
|
+
events: events.sort((a, b) => a.timestamp.localeCompare(b.timestamp)),
|
|
84
|
+
}))
|
|
85
|
+
.sort((a, b) => b.events.length - a.events.length);
|
|
86
|
+
return { reports, unattributed };
|
|
87
|
+
}
|
|
88
|
+
function collectKeyNames(meta) {
|
|
89
|
+
const names = [];
|
|
90
|
+
if (typeof meta.key === "string")
|
|
91
|
+
names.push(meta.key);
|
|
92
|
+
if (Array.isArray(meta.keys)) {
|
|
93
|
+
for (const k of meta.keys)
|
|
94
|
+
if (typeof k === "string")
|
|
95
|
+
names.push(k);
|
|
96
|
+
}
|
|
97
|
+
if (typeof meta.name === "string")
|
|
98
|
+
names.push(meta.name);
|
|
99
|
+
return [...new Set(names)];
|
|
100
|
+
}
|
|
101
|
+
function summarizeEvent(e) {
|
|
102
|
+
const meta = (e.metadata ?? {});
|
|
103
|
+
const parts = [];
|
|
104
|
+
if (typeof meta.store === "string")
|
|
105
|
+
parts.push(`store=${meta.store}`);
|
|
106
|
+
if (typeof meta.target === "string")
|
|
107
|
+
parts.push(`target=${meta.target}`);
|
|
108
|
+
if (typeof meta.source === "string")
|
|
109
|
+
parts.push(`source=${meta.source}`);
|
|
110
|
+
if (e.error)
|
|
111
|
+
parts.push(`error=${e.error.split("\n")[0]}`);
|
|
112
|
+
if (e.environment)
|
|
113
|
+
parts.push(`env=${e.environment}`);
|
|
114
|
+
return parts.join(" ");
|
|
115
|
+
}
|
|
116
|
+
export function summarize(reports, windowDays) {
|
|
117
|
+
const totalEvents = reports.reduce((sum, r) => sum + r.events.length, 0);
|
|
118
|
+
const top = reports[0];
|
|
119
|
+
return {
|
|
120
|
+
totalEvents,
|
|
121
|
+
keyCount: reports.length,
|
|
122
|
+
topKey: top ? { key: top.key, count: top.events.length } : undefined,
|
|
123
|
+
windowDays,
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
//# sourceMappingURL=audit-secrets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit-secrets.js","sourceRoot":"","sources":["../src/audit-secrets.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAgBpC,MAAM,UAAU,GAAG,kBAAkB,CAAC;AAEtC,MAAM,iBAAiB,GAAG,IAAI,GAAG,CAAC;IAChC,kBAAkB;IAClB,cAAc;IACd,iBAAiB;IACjB,gBAAgB;IAChB,yBAAyB;IACzB,mBAAmB;IACnB,gBAAgB;IAChB,KAAK;CACN,CAAC,CAAC;AAEH,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,MAAc,OAAO,CAAC,GAAG,EAAE,EAC3B,SAAS,GAAG,EAAE;IAEd,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;IACtC,IAAI,CAAC;QACH,MAAM,MAAM,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IAC3C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAElE,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,GAAG,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC;IACzD,MAAM,MAAM,GAAiB,EAAE,CAAC;IAChC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC;YACH,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAe,CAAC;YACzC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC;gBAAE,SAAS;YAClD,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;YACnC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,MAAM;gBAAE,SAAS;YAClD,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjB,CAAC;QAAC,MAAM,CAAC;YACP,sBAAsB;QACxB,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,aAAa,CAC3B,MAAoB;IAEpB,MAAM,KAAK,GAAG,IAAI,GAAG,EAA+B,CAAC;IACrD,MAAM,YAAY,GAAwB,EAAE,CAAC;IAE7C,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;QACvB,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,IAAI,EAAE,CAA4B,CAAC;QAC3D,MAAM,IAAI,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC;QACnC,MAAM,KAAK,GAAsB;YAC/B,SAAS,EAAE,CAAC,CAAC,SAAS;YACtB,SAAS,EAAE,CAAC,CAAC,SAAS;YACtB,KAAK,EAAE,CAAC,CAAC,UAAU,IAAI,CAAC,CAAC,QAAQ;YACjC,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC;YACzB,OAAO,EAAE,CAAC,CAAC,OAAO;SACnB,CAAC;QACF,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACtB,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACzB,SAAS;QACX,CAAC;QACD,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;YACrB,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YAC/B,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAChB,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QACpB,CAAC;IACH,CAAC;IAED,MAAM,OAAO,GAAwB,CAAC,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC;SACtD,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC;QACvB,GAAG;QACH,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;KACtE,CAAC,CAAC;SACF,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAErD,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC;AACnC,CAAC;AAED,SAAS,eAAe,CAAC,IAA6B;IACpD,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,IAAI,OAAO,IAAI,CAAC,GAAG,KAAK,QAAQ;QAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACvD,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAC7B,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI;YAAE,IAAI,OAAO,CAAC,KAAK,QAAQ;gBAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtE,CAAC;IACD,IAAI,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ;QAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzD,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;AAC7B,CAAC;AAED,SAAS,cAAc,CAAC,CAAa;IACnC,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,IAAI,EAAE,CAA4B,CAAC;IAC3D,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ;QAAE,KAAK,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACtE,IAAI,OAAO,IAAI,CAAC,MAAM,KAAK,QAAQ;QAAE,KAAK,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACzE,IAAI,OAAO,IAAI,CAAC,MAAM,KAAK,QAAQ;QAAE,KAAK,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACzE,IAAI,CAAC,CAAC,KAAK;QAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IAC3D,IAAI,CAAC,CAAC,WAAW;QAAE,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IACtD,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AASD,MAAM,UAAU,SAAS,CACvB,OAA4B,EAC5B,UAAkB;IAElB,MAAM,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IACzE,MAAM,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;IACvB,OAAO;QACL,WAAW;QACX,QAAQ,EAAE,OAAO,CAAC,MAAM;QACxB,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,SAAS;QACpE,UAAU;KACX,CAAC;AACJ,CAAC"}
|
package/dist/audit.d.ts
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import type { GovernanceConfig } from "./config.js";
|
|
2
|
+
export interface AuditEvent {
|
|
3
|
+
timestamp: string;
|
|
4
|
+
agent_id?: string;
|
|
5
|
+
agent_name?: string;
|
|
6
|
+
operation: string;
|
|
7
|
+
environment: string;
|
|
8
|
+
success: boolean;
|
|
9
|
+
duration_ms?: number;
|
|
10
|
+
error?: string;
|
|
11
|
+
metadata?: Record<string, unknown>;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Append an audit event directly to .kit-audit.jsonl without requiring a
|
|
15
|
+
* governance config to be loaded. Used by code paths that *must* log without
|
|
16
|
+
* the possibility of being short-circuited by missing config — primarily the
|
|
17
|
+
* elevation gate, the prod-key bypass, and the rate-limiter fail-open hatch.
|
|
18
|
+
*
|
|
19
|
+
* Returns true on success, false if the append failed. Callers that gate
|
|
20
|
+
* destructive ops on auditability should treat `false` as "do not proceed".
|
|
21
|
+
*
|
|
22
|
+
* `cwd` lets tests/hooks point at a sandbox; production callers pass nothing.
|
|
23
|
+
*/
|
|
24
|
+
export declare function appendAuditEventDirect(event: Omit<AuditEvent, "timestamp">, opts?: {
|
|
25
|
+
cwd?: string;
|
|
26
|
+
logFile?: string;
|
|
27
|
+
}): Promise<boolean>;
|
|
28
|
+
/**
|
|
29
|
+
* Log an audit event to the configured audit log file and Remote API
|
|
30
|
+
*/
|
|
31
|
+
export declare function logAuditEvent(config: Required<GovernanceConfig>, event: Omit<AuditEvent, "timestamp" | "agent_id" | "agent_name">, companyId?: string): Promise<void>;
|
|
32
|
+
/**
|
|
33
|
+
* Test-only: reset the module-scoped warning flag.
|
|
34
|
+
*/
|
|
35
|
+
export declare function _resetRemotePushWarningForTests(): void;
|
|
36
|
+
/**
|
|
37
|
+
* Read recent audit log entries
|
|
38
|
+
*/
|
|
39
|
+
export declare function readAuditLog(logFile: string, limit?: number): Promise<AuditEvent[]>;
|
|
40
|
+
/**
|
|
41
|
+
* Format audit log for display
|
|
42
|
+
*/
|
|
43
|
+
export declare function formatAuditLog(events: AuditEvent[]): string;
|