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,58 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Team Management System — data models and types
|
|
3
|
+
* Supports RBAC, member management, invitations, audit logging
|
|
4
|
+
*/
|
|
5
|
+
export type Role = "owner" | "admin" | "developer" | "guest";
|
|
6
|
+
export interface Team {
|
|
7
|
+
id: string;
|
|
8
|
+
name: string;
|
|
9
|
+
owner_id: string;
|
|
10
|
+
created_at: string;
|
|
11
|
+
updated_at: string;
|
|
12
|
+
}
|
|
13
|
+
export interface TeamMember {
|
|
14
|
+
id: string;
|
|
15
|
+
team_id: string;
|
|
16
|
+
user_id: string;
|
|
17
|
+
email: string;
|
|
18
|
+
role: Role;
|
|
19
|
+
invited_at: string;
|
|
20
|
+
joined_at: string | null;
|
|
21
|
+
status: "pending" | "accepted" | "revoked";
|
|
22
|
+
}
|
|
23
|
+
export interface TeamInvitation {
|
|
24
|
+
id: string;
|
|
25
|
+
team_id: string;
|
|
26
|
+
email: string;
|
|
27
|
+
role: Role;
|
|
28
|
+
token: string;
|
|
29
|
+
created_at: string;
|
|
30
|
+
expires_at: string;
|
|
31
|
+
accepted_at: string | null;
|
|
32
|
+
}
|
|
33
|
+
export interface AuditLog {
|
|
34
|
+
id: string;
|
|
35
|
+
team_id: string;
|
|
36
|
+
user_id: string;
|
|
37
|
+
action: AuditAction;
|
|
38
|
+
resource_type: string;
|
|
39
|
+
resource_id: string;
|
|
40
|
+
resource_name: string;
|
|
41
|
+
status: "success" | "failure";
|
|
42
|
+
details: Record<string, unknown>;
|
|
43
|
+
timestamp: string;
|
|
44
|
+
}
|
|
45
|
+
export type AuditAction = "team_created" | "team_updated" | "team_deleted" | "member_invited" | "member_joined" | "member_removed" | "member_role_changed" | "member_revoked" | "secret_accessed" | "secret_rotated" | "config_changed";
|
|
46
|
+
/**
|
|
47
|
+
* RBAC Permission Matrix
|
|
48
|
+
* Maps role → actions allowed on resources
|
|
49
|
+
*/
|
|
50
|
+
export declare const PERMISSION_MATRIX: Record<Role, Record<string, boolean>>;
|
|
51
|
+
/**
|
|
52
|
+
* Check if role has permission for action
|
|
53
|
+
*/
|
|
54
|
+
export declare function hasPermission(role: Role, action: string): boolean;
|
|
55
|
+
/**
|
|
56
|
+
* Validate role
|
|
57
|
+
*/
|
|
58
|
+
export declare function isValidRole(role: string): role is Role;
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Team Management System — data models and types
|
|
3
|
+
* Supports RBAC, member management, invitations, audit logging
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* RBAC Permission Matrix
|
|
7
|
+
* Maps role → actions allowed on resources
|
|
8
|
+
*/
|
|
9
|
+
export const PERMISSION_MATRIX = {
|
|
10
|
+
owner: {
|
|
11
|
+
// Full access
|
|
12
|
+
"team:read": true,
|
|
13
|
+
"team:write": true,
|
|
14
|
+
"team:delete": true,
|
|
15
|
+
"member:read": true,
|
|
16
|
+
"member:invite": true,
|
|
17
|
+
"member:remove": true,
|
|
18
|
+
"member:role_change": true,
|
|
19
|
+
"secret:read": true,
|
|
20
|
+
"secret:write": true,
|
|
21
|
+
"secret:manage": true,
|
|
22
|
+
"audit:read": true,
|
|
23
|
+
"billing:manage": true,
|
|
24
|
+
},
|
|
25
|
+
admin: {
|
|
26
|
+
// Full access except billing
|
|
27
|
+
"team:read": true,
|
|
28
|
+
"team:write": true,
|
|
29
|
+
"team:delete": false,
|
|
30
|
+
"member:read": true,
|
|
31
|
+
"member:invite": true,
|
|
32
|
+
"member:remove": true,
|
|
33
|
+
"member:role_change": true,
|
|
34
|
+
"secret:read": true,
|
|
35
|
+
"secret:write": true,
|
|
36
|
+
"secret:manage": true,
|
|
37
|
+
"audit:read": true,
|
|
38
|
+
"billing:manage": false,
|
|
39
|
+
},
|
|
40
|
+
developer: {
|
|
41
|
+
// Can use team resources
|
|
42
|
+
"team:read": true,
|
|
43
|
+
"team:write": false,
|
|
44
|
+
"team:delete": false,
|
|
45
|
+
"member:read": true,
|
|
46
|
+
"member:invite": false,
|
|
47
|
+
"member:remove": false,
|
|
48
|
+
"member:role_change": false,
|
|
49
|
+
"secret:read": true,
|
|
50
|
+
"secret:write": false,
|
|
51
|
+
"secret:manage": false,
|
|
52
|
+
"audit:read": false,
|
|
53
|
+
"billing:manage": false,
|
|
54
|
+
},
|
|
55
|
+
guest: {
|
|
56
|
+
// Read-only access
|
|
57
|
+
"team:read": true,
|
|
58
|
+
"team:write": false,
|
|
59
|
+
"team:delete": false,
|
|
60
|
+
"member:read": true,
|
|
61
|
+
"member:invite": false,
|
|
62
|
+
"member:remove": false,
|
|
63
|
+
"member:role_change": false,
|
|
64
|
+
"secret:read": false,
|
|
65
|
+
"secret:write": false,
|
|
66
|
+
"secret:manage": false,
|
|
67
|
+
"audit:read": false,
|
|
68
|
+
"billing:manage": false,
|
|
69
|
+
},
|
|
70
|
+
};
|
|
71
|
+
/**
|
|
72
|
+
* Check if role has permission for action
|
|
73
|
+
*/
|
|
74
|
+
export function hasPermission(role, action) {
|
|
75
|
+
return PERMISSION_MATRIX[role]?.[action] ?? false;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Validate role
|
|
79
|
+
*/
|
|
80
|
+
export function isValidRole(role) {
|
|
81
|
+
return ["owner", "admin", "developer", "guest"].includes(role);
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=team-model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"team-model.js","sourceRoot":"","sources":["../src/team-model.ts"],"names":[],"mappings":"AAAA;;;GAGG;AA4DH;;;GAGG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAA0C;IACtE,KAAK,EAAE;QACL,cAAc;QACd,WAAW,EAAE,IAAI;QACjB,YAAY,EAAE,IAAI;QAClB,aAAa,EAAE,IAAI;QACnB,aAAa,EAAE,IAAI;QACnB,eAAe,EAAE,IAAI;QACrB,eAAe,EAAE,IAAI;QACrB,oBAAoB,EAAE,IAAI;QAC1B,aAAa,EAAE,IAAI;QACnB,cAAc,EAAE,IAAI;QACpB,eAAe,EAAE,IAAI;QACrB,YAAY,EAAE,IAAI;QAClB,gBAAgB,EAAE,IAAI;KACvB;IACD,KAAK,EAAE;QACL,6BAA6B;QAC7B,WAAW,EAAE,IAAI;QACjB,YAAY,EAAE,IAAI;QAClB,aAAa,EAAE,KAAK;QACpB,aAAa,EAAE,IAAI;QACnB,eAAe,EAAE,IAAI;QACrB,eAAe,EAAE,IAAI;QACrB,oBAAoB,EAAE,IAAI;QAC1B,aAAa,EAAE,IAAI;QACnB,cAAc,EAAE,IAAI;QACpB,eAAe,EAAE,IAAI;QACrB,YAAY,EAAE,IAAI;QAClB,gBAAgB,EAAE,KAAK;KACxB;IACD,SAAS,EAAE;QACT,yBAAyB;QACzB,WAAW,EAAE,IAAI;QACjB,YAAY,EAAE,KAAK;QACnB,aAAa,EAAE,KAAK;QACpB,aAAa,EAAE,IAAI;QACnB,eAAe,EAAE,KAAK;QACtB,eAAe,EAAE,KAAK;QACtB,oBAAoB,EAAE,KAAK;QAC3B,aAAa,EAAE,IAAI;QACnB,cAAc,EAAE,KAAK;QACrB,eAAe,EAAE,KAAK;QACtB,YAAY,EAAE,KAAK;QACnB,gBAAgB,EAAE,KAAK;KACxB;IACD,KAAK,EAAE;QACL,mBAAmB;QACnB,WAAW,EAAE,IAAI;QACjB,YAAY,EAAE,KAAK;QACnB,aAAa,EAAE,KAAK;QACpB,aAAa,EAAE,IAAI;QACnB,eAAe,EAAE,KAAK;QACtB,eAAe,EAAE,KAAK;QACtB,oBAAoB,EAAE,KAAK;QAC3B,aAAa,EAAE,KAAK;QACpB,cAAc,EAAE,KAAK;QACrB,eAAe,EAAE,KAAK;QACtB,YAAY,EAAE,KAAK;QACnB,gBAAgB,EAAE,KAAK;KACxB;CACF,CAAC;AAEF;;GAEG;AACH,MAAM,UAAU,aAAa,CAAC,IAAU,EAAE,MAAc;IACtD,OAAO,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC;AACpD,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,OAAO,CAAC,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AACjE,CAAC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import type { Team, TeamMember, TeamInvitation, AuditLog } from "./team-model.js";
|
|
2
|
+
/**
|
|
3
|
+
* Create team
|
|
4
|
+
*/
|
|
5
|
+
export declare function createTeam(name: string, owner_id: string): {
|
|
6
|
+
team: Team;
|
|
7
|
+
error?: string;
|
|
8
|
+
};
|
|
9
|
+
/**
|
|
10
|
+
* Get team by ID
|
|
11
|
+
*/
|
|
12
|
+
export declare function getTeam(team_id: string): Team | null;
|
|
13
|
+
/**
|
|
14
|
+
* Invite user to team
|
|
15
|
+
*/
|
|
16
|
+
export declare function inviteToTeam(team_id: string, email: string, role: string, inviter_id: string): {
|
|
17
|
+
invitation: TeamInvitation;
|
|
18
|
+
error?: string;
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* Accept invitation and join team
|
|
22
|
+
*/
|
|
23
|
+
export declare function acceptInvitation(invitation_id: string, user_id: string, email: string): {
|
|
24
|
+
member: TeamMember;
|
|
25
|
+
error?: string;
|
|
26
|
+
};
|
|
27
|
+
/**
|
|
28
|
+
* List team members
|
|
29
|
+
*/
|
|
30
|
+
export declare function listTeamMembers(team_id: string): {
|
|
31
|
+
members: TeamMember[];
|
|
32
|
+
error?: string;
|
|
33
|
+
};
|
|
34
|
+
/**
|
|
35
|
+
* Remove member from team
|
|
36
|
+
*/
|
|
37
|
+
export declare function removeTeamMember(team_id: string, member_id: string, requester_id: string): {
|
|
38
|
+
success: boolean;
|
|
39
|
+
error?: string;
|
|
40
|
+
};
|
|
41
|
+
/**
|
|
42
|
+
* Change member role
|
|
43
|
+
*/
|
|
44
|
+
export declare function changeTeamMemberRole(team_id: string, member_id: string, new_role: string, requester_id: string): {
|
|
45
|
+
success: boolean;
|
|
46
|
+
error?: string;
|
|
47
|
+
};
|
|
48
|
+
/**
|
|
49
|
+
* Get audit logs
|
|
50
|
+
*/
|
|
51
|
+
export declare function getAuditLogs(team_id: string, limit?: number): {
|
|
52
|
+
logs: AuditLog[];
|
|
53
|
+
total: number;
|
|
54
|
+
};
|
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
import { randomUUID } from "node:crypto";
|
|
2
|
+
import { hasPermission, isValidRole } from "./team-model.js";
|
|
3
|
+
/**
|
|
4
|
+
* In-memory team storage (production would use database)
|
|
5
|
+
*/
|
|
6
|
+
const teams = new Map();
|
|
7
|
+
const members = new Map();
|
|
8
|
+
const invitations = new Map();
|
|
9
|
+
const auditLogs = [];
|
|
10
|
+
/**
|
|
11
|
+
* Create team
|
|
12
|
+
*/
|
|
13
|
+
export function createTeam(name, owner_id) {
|
|
14
|
+
if (!name || name.trim().length === 0) {
|
|
15
|
+
return { team: {}, error: "Team name required" };
|
|
16
|
+
}
|
|
17
|
+
const team = {
|
|
18
|
+
id: `team_${randomUUID()}`,
|
|
19
|
+
name: name.trim(),
|
|
20
|
+
owner_id,
|
|
21
|
+
created_at: new Date().toISOString(),
|
|
22
|
+
updated_at: new Date().toISOString(),
|
|
23
|
+
};
|
|
24
|
+
teams.set(team.id, team);
|
|
25
|
+
// Add owner as member automatically
|
|
26
|
+
const ownerMember = {
|
|
27
|
+
id: `mem_${randomUUID()}`,
|
|
28
|
+
team_id: team.id,
|
|
29
|
+
user_id: owner_id,
|
|
30
|
+
email: `owner-${owner_id}@kit.local`, // Placeholder
|
|
31
|
+
role: "owner",
|
|
32
|
+
invited_at: team.created_at,
|
|
33
|
+
joined_at: team.created_at,
|
|
34
|
+
status: "accepted",
|
|
35
|
+
};
|
|
36
|
+
members.set(ownerMember.id, ownerMember);
|
|
37
|
+
logAudit(team.id, owner_id, "team_created", "team", team.id, name, {
|
|
38
|
+
owner_id,
|
|
39
|
+
});
|
|
40
|
+
return { team };
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Get team by ID
|
|
44
|
+
*/
|
|
45
|
+
export function getTeam(team_id) {
|
|
46
|
+
return teams.get(team_id) ?? null;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Invite user to team
|
|
50
|
+
*/
|
|
51
|
+
export function inviteToTeam(team_id, email, role, inviter_id) {
|
|
52
|
+
// Validate team exists
|
|
53
|
+
const team = teams.get(team_id);
|
|
54
|
+
if (!team) {
|
|
55
|
+
return { invitation: {}, error: "Team not found" };
|
|
56
|
+
}
|
|
57
|
+
// Check inviter has permission
|
|
58
|
+
const inviter = Array.from(members.values()).find((m) => m.team_id === team_id && m.user_id === inviter_id);
|
|
59
|
+
if (!inviter || !hasPermission(inviter.role, "member:invite")) {
|
|
60
|
+
return { invitation: {}, error: "Not authorized to invite" };
|
|
61
|
+
}
|
|
62
|
+
// Validate role
|
|
63
|
+
if (!isValidRole(role)) {
|
|
64
|
+
return { invitation: {}, error: "Invalid role" };
|
|
65
|
+
}
|
|
66
|
+
// Check email not already member
|
|
67
|
+
const existing = Array.from(members.values()).find((m) => m.team_id === team_id && m.email === email);
|
|
68
|
+
if (existing && existing.status === "accepted") {
|
|
69
|
+
return { invitation: {}, error: "User already member" };
|
|
70
|
+
}
|
|
71
|
+
const invitation = {
|
|
72
|
+
id: `inv_${randomUUID()}`,
|
|
73
|
+
team_id,
|
|
74
|
+
email,
|
|
75
|
+
role: role,
|
|
76
|
+
token: randomUUID(),
|
|
77
|
+
created_at: new Date().toISOString(),
|
|
78
|
+
expires_at: new Date(Date.now() + 7 * 24 * 60 * 60 * 1000).toISOString(), // 7 days
|
|
79
|
+
accepted_at: null,
|
|
80
|
+
};
|
|
81
|
+
invitations.set(invitation.id, invitation);
|
|
82
|
+
logAudit(team_id, inviter_id, "member_invited", "user", email, email, {
|
|
83
|
+
role,
|
|
84
|
+
});
|
|
85
|
+
return { invitation };
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Accept invitation and join team
|
|
89
|
+
*/
|
|
90
|
+
export function acceptInvitation(invitation_id, user_id, email) {
|
|
91
|
+
const invitation = invitations.get(invitation_id);
|
|
92
|
+
if (!invitation) {
|
|
93
|
+
return { member: {}, error: "Invitation not found" };
|
|
94
|
+
}
|
|
95
|
+
if (invitation.email !== email) {
|
|
96
|
+
return { member: {}, error: "Email mismatch" };
|
|
97
|
+
}
|
|
98
|
+
if (new Date(invitation.expires_at) < new Date()) {
|
|
99
|
+
return { member: {}, error: "Invitation expired" };
|
|
100
|
+
}
|
|
101
|
+
const member = {
|
|
102
|
+
id: `mem_${randomUUID()}`,
|
|
103
|
+
team_id: invitation.team_id,
|
|
104
|
+
user_id,
|
|
105
|
+
email,
|
|
106
|
+
role: invitation.role,
|
|
107
|
+
invited_at: invitation.created_at,
|
|
108
|
+
joined_at: new Date().toISOString(),
|
|
109
|
+
status: "accepted",
|
|
110
|
+
};
|
|
111
|
+
members.set(member.id, member);
|
|
112
|
+
invitation.accepted_at = new Date().toISOString();
|
|
113
|
+
logAudit(invitation.team_id, user_id, "member_joined", "user", user_id, email, {
|
|
114
|
+
role: invitation.role,
|
|
115
|
+
});
|
|
116
|
+
return { member };
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* List team members
|
|
120
|
+
*/
|
|
121
|
+
export function listTeamMembers(team_id) {
|
|
122
|
+
const team = teams.get(team_id);
|
|
123
|
+
if (!team) {
|
|
124
|
+
return { members: [], error: "Team not found" };
|
|
125
|
+
}
|
|
126
|
+
const teamMembers = Array.from(members.values()).filter((m) => m.team_id === team_id && m.status === "accepted");
|
|
127
|
+
return { members: teamMembers };
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Remove member from team
|
|
131
|
+
*/
|
|
132
|
+
export function removeTeamMember(team_id, member_id, requester_id) {
|
|
133
|
+
const team = teams.get(team_id);
|
|
134
|
+
if (!team) {
|
|
135
|
+
return { success: false, error: "Team not found" };
|
|
136
|
+
}
|
|
137
|
+
// Check requester has permission
|
|
138
|
+
const requester = Array.from(members.values()).find((m) => m.team_id === team_id && m.user_id === requester_id);
|
|
139
|
+
if (!requester || !hasPermission(requester.role, "member:remove")) {
|
|
140
|
+
return { success: false, error: "Not authorized to remove members" };
|
|
141
|
+
}
|
|
142
|
+
const member = members.get(member_id);
|
|
143
|
+
if (!member || member.team_id !== team_id) {
|
|
144
|
+
return { success: false, error: "Member not found" };
|
|
145
|
+
}
|
|
146
|
+
// Prevent removing owner
|
|
147
|
+
if (member.role === "owner") {
|
|
148
|
+
return { success: false, error: "Cannot remove team owner" };
|
|
149
|
+
}
|
|
150
|
+
member.status = "revoked";
|
|
151
|
+
logAudit(team_id, requester_id, "member_removed", "user", member.user_id, member.email, {});
|
|
152
|
+
return { success: true };
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Change member role
|
|
156
|
+
*/
|
|
157
|
+
export function changeTeamMemberRole(team_id, member_id, new_role, requester_id) {
|
|
158
|
+
if (!isValidRole(new_role)) {
|
|
159
|
+
return { success: false, error: "Invalid role" };
|
|
160
|
+
}
|
|
161
|
+
// Check requester has permission
|
|
162
|
+
const requester = Array.from(members.values()).find((m) => m.team_id === team_id && m.user_id === requester_id);
|
|
163
|
+
if (!requester || !hasPermission(requester.role, "member:role_change")) {
|
|
164
|
+
return { success: false, error: "Not authorized to change roles" };
|
|
165
|
+
}
|
|
166
|
+
const member = members.get(member_id);
|
|
167
|
+
if (!member || member.team_id !== team_id) {
|
|
168
|
+
return { success: false, error: "Member not found" };
|
|
169
|
+
}
|
|
170
|
+
const old_role = member.role;
|
|
171
|
+
member.role = new_role;
|
|
172
|
+
logAudit(team_id, requester_id, "member_role_changed", "user", member.user_id, member.email, {
|
|
173
|
+
old_role,
|
|
174
|
+
new_role,
|
|
175
|
+
});
|
|
176
|
+
return { success: true };
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* Get audit logs
|
|
180
|
+
*/
|
|
181
|
+
export function getAuditLogs(team_id, limit = 100) {
|
|
182
|
+
const filtered = auditLogs
|
|
183
|
+
.filter((log) => log.team_id === team_id)
|
|
184
|
+
.sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime())
|
|
185
|
+
.slice(0, limit);
|
|
186
|
+
return { logs: filtered, total: auditLogs.filter((l) => l.team_id === team_id).length };
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* Log audit event
|
|
190
|
+
*/
|
|
191
|
+
function logAudit(team_id, user_id, action, resource_type, resource_id, resource_name, details) {
|
|
192
|
+
const log = {
|
|
193
|
+
id: `audit_${randomUUID()}`,
|
|
194
|
+
team_id,
|
|
195
|
+
user_id,
|
|
196
|
+
action: action,
|
|
197
|
+
resource_type,
|
|
198
|
+
resource_id,
|
|
199
|
+
resource_name,
|
|
200
|
+
status: "success",
|
|
201
|
+
details,
|
|
202
|
+
timestamp: new Date().toISOString(),
|
|
203
|
+
};
|
|
204
|
+
auditLogs.push(log);
|
|
205
|
+
}
|
|
206
|
+
//# sourceMappingURL=team-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"team-service.js","sourceRoot":"","sources":["../src/team-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { DetectedStack } from "./stack-detector.js";
|
|
2
|
+
export type SecretsStore = "1password" | "infisical" | "bitwarden" | "doppler" | "vault" | "aws-sm" | "gcp-sm" | "azure-kv" | "env";
|
|
3
|
+
/**
|
|
4
|
+
* Generate a .kit.toml string from a detected stack profile.
|
|
5
|
+
*/
|
|
6
|
+
export declare function generateToml(stack: DetectedStack, options?: {
|
|
7
|
+
secretsStore?: SecretsStore;
|
|
8
|
+
}): string;
|
|
@@ -0,0 +1,223 @@
|
|
|
1
|
+
const SERVICE_TEMPLATES = {
|
|
2
|
+
stripe: {
|
|
3
|
+
login: "stripe login",
|
|
4
|
+
check: "stripe config --list",
|
|
5
|
+
secrets: ["STRIPE_SECRET_KEY", "STRIPE_PUBLISHABLE_KEY", "STRIPE_WEBHOOK_SECRET"],
|
|
6
|
+
tool: "stripe",
|
|
7
|
+
},
|
|
8
|
+
supabase: {
|
|
9
|
+
login: "supabase login",
|
|
10
|
+
check: "supabase projects list",
|
|
11
|
+
secrets: ["NEXT_PUBLIC_SUPABASE_URL", "NEXT_PUBLIC_SUPABASE_ANON_KEY", "SUPABASE_SERVICE_ROLE_KEY"],
|
|
12
|
+
tool: "supabase",
|
|
13
|
+
},
|
|
14
|
+
vercel: {
|
|
15
|
+
login: "vercel login",
|
|
16
|
+
check: "vercel whoami",
|
|
17
|
+
secrets: [],
|
|
18
|
+
tool: "vercel",
|
|
19
|
+
},
|
|
20
|
+
expo: {
|
|
21
|
+
login: "eas login",
|
|
22
|
+
check: "eas whoami",
|
|
23
|
+
secrets: ["EXPO_TOKEN"],
|
|
24
|
+
tool: "eas-cli",
|
|
25
|
+
},
|
|
26
|
+
resend: {
|
|
27
|
+
login: "# resend — no CLI login; set RESEND_API_KEY in env",
|
|
28
|
+
check: "# resend — check RESEND_API_KEY is set",
|
|
29
|
+
secrets: ["RESEND_API_KEY", "RESEND_FROM_EMAIL"],
|
|
30
|
+
},
|
|
31
|
+
clerk: {
|
|
32
|
+
login: "# clerk — no CLI login; get keys from https://dashboard.clerk.com",
|
|
33
|
+
check: "# clerk — check CLERK_SECRET_KEY is set",
|
|
34
|
+
secrets: ["CLERK_SECRET_KEY", "NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY"],
|
|
35
|
+
},
|
|
36
|
+
liveblocks: {
|
|
37
|
+
login: "# liveblocks — no CLI login; get keys from https://liveblocks.io/dashboard",
|
|
38
|
+
check: "# liveblocks — check LIVEBLOCKS_SECRET_KEY is set",
|
|
39
|
+
secrets: ["LIVEBLOCKS_SECRET_KEY", "NEXT_PUBLIC_LIVEBLOCKS_PUBLIC_KEY"],
|
|
40
|
+
},
|
|
41
|
+
trigger: {
|
|
42
|
+
login: "# trigger — no CLI login; get key from https://cloud.trigger.dev",
|
|
43
|
+
check: "# trigger — check TRIGGER_SECRET_KEY is set",
|
|
44
|
+
secrets: ["TRIGGER_SECRET_KEY"],
|
|
45
|
+
},
|
|
46
|
+
inngest: {
|
|
47
|
+
login: "# inngest — no CLI login; get keys from https://app.inngest.com",
|
|
48
|
+
check: "# inngest — check INNGEST_EVENT_KEY is set",
|
|
49
|
+
secrets: ["INNGEST_EVENT_KEY", "INNGEST_SIGNING_KEY"],
|
|
50
|
+
},
|
|
51
|
+
sentry: {
|
|
52
|
+
login: "# sentry — no CLI login; get DSN from https://sentry.io",
|
|
53
|
+
check: "# sentry — check SENTRY_DSN is set",
|
|
54
|
+
secrets: ["SENTRY_DSN", "SENTRY_ORG", "SENTRY_PROJECT", "SENTRY_AUTH_TOKEN"],
|
|
55
|
+
},
|
|
56
|
+
netlify: {
|
|
57
|
+
login: "netlify login",
|
|
58
|
+
check: "netlify status",
|
|
59
|
+
secrets: ["NETLIFY_AUTH_TOKEN", "NETLIFY_SITE_ID"],
|
|
60
|
+
tool: "netlify",
|
|
61
|
+
},
|
|
62
|
+
"cloudflare-pages": {
|
|
63
|
+
login: "wrangler login",
|
|
64
|
+
check: "wrangler whoami",
|
|
65
|
+
secrets: ["CLOUDFLARE_API_TOKEN", "CLOUDFLARE_ACCOUNT_ID"],
|
|
66
|
+
tool: "wrangler",
|
|
67
|
+
},
|
|
68
|
+
typeorm: {
|
|
69
|
+
login: "# typeorm — no CLI login; configure DATABASE_URL",
|
|
70
|
+
check: "# typeorm — check DATABASE_URL is set",
|
|
71
|
+
secrets: ["DATABASE_URL"],
|
|
72
|
+
},
|
|
73
|
+
mongoose: {
|
|
74
|
+
login: "# mongoose — no CLI login; configure MONGODB_URI",
|
|
75
|
+
check: "# mongoose — check MONGODB_URI is set",
|
|
76
|
+
secrets: ["MONGODB_URI"],
|
|
77
|
+
},
|
|
78
|
+
};
|
|
79
|
+
const FRAMEWORK_SETUP = {
|
|
80
|
+
nextjs: { install: "pnpm install", dev: "pnpm dev", verify: "pnpm build" },
|
|
81
|
+
remix: { install: "pnpm install", dev: "pnpm dev", verify: "pnpm build" },
|
|
82
|
+
astro: { install: "pnpm install", dev: "pnpm dev", verify: "pnpm build" },
|
|
83
|
+
sveltekit: { install: "pnpm install", dev: "pnpm dev", verify: "pnpm build" },
|
|
84
|
+
nestjs: { install: "pnpm install", dev: "pnpm start:dev", verify: "pnpm build" },
|
|
85
|
+
express: { install: "pnpm install", dev: "pnpm dev", verify: "pnpm build" },
|
|
86
|
+
react: { install: "pnpm install", dev: "pnpm dev", verify: "pnpm build" },
|
|
87
|
+
fastapi: { install: "uv sync", dev: "uv run uvicorn main:app --reload", verify: "uv run pytest" },
|
|
88
|
+
django: { install: "uv sync", migrate: "uv run python manage.py migrate", verify: "uv run python manage.py check" },
|
|
89
|
+
flask: { install: "uv sync", dev: "uv run flask run", verify: "uv run pytest" },
|
|
90
|
+
gin: { install: "go mod download", dev: "go run .", verify: "go build ./..." },
|
|
91
|
+
echo: { install: "go mod download", dev: "go run .", verify: "go build ./..." },
|
|
92
|
+
fiber: { install: "go mod download", dev: "go run .", verify: "go build ./..." },
|
|
93
|
+
laravel: { install: "composer install", migrate: "php artisan migrate", verify: "php artisan test" },
|
|
94
|
+
symfony: { install: "composer install", verify: "php bin/console lint:all" },
|
|
95
|
+
};
|
|
96
|
+
function lines(...parts) {
|
|
97
|
+
return parts.filter(Boolean).join("\n");
|
|
98
|
+
}
|
|
99
|
+
function toolsSection(tools) {
|
|
100
|
+
if (Object.keys(tools).length === 0)
|
|
101
|
+
return "";
|
|
102
|
+
const entries = Object.entries(tools)
|
|
103
|
+
.map(([k, v]) => `${k} = "${v}"`)
|
|
104
|
+
.join("\n");
|
|
105
|
+
return `[tools]\n${entries}\n`;
|
|
106
|
+
}
|
|
107
|
+
function servicesSection(services, allTools) {
|
|
108
|
+
const sections = [];
|
|
109
|
+
for (const svc of services) {
|
|
110
|
+
const tmpl = SERVICE_TEMPLATES[svc];
|
|
111
|
+
if (!tmpl)
|
|
112
|
+
continue;
|
|
113
|
+
// Add tool to tools if needed (handled outside)
|
|
114
|
+
sections.push(`[services.${svc}]\nlogin = "${tmpl.login}"\ncheck = "${tmpl.check}"`);
|
|
115
|
+
}
|
|
116
|
+
return sections.join("\n\n");
|
|
117
|
+
}
|
|
118
|
+
function secretsSection(services, store = "1password") {
|
|
119
|
+
const allKeys = [];
|
|
120
|
+
for (const svc of services) {
|
|
121
|
+
const tmpl = SERVICE_TEMPLATES[svc];
|
|
122
|
+
if (tmpl?.secrets.length)
|
|
123
|
+
allKeys.push(...tmpl.secrets);
|
|
124
|
+
}
|
|
125
|
+
if (allKeys.length === 0)
|
|
126
|
+
return "";
|
|
127
|
+
const keyLines = allKeys.map((k) => {
|
|
128
|
+
let src;
|
|
129
|
+
switch (store) {
|
|
130
|
+
case "1password":
|
|
131
|
+
src = `source = "1password", ref = "op://Dev/Project/${k}"`;
|
|
132
|
+
break;
|
|
133
|
+
case "infisical":
|
|
134
|
+
src = `source = "infisical", name = "${k}"`;
|
|
135
|
+
break;
|
|
136
|
+
case "bitwarden":
|
|
137
|
+
src = `source = "bitwarden", name = "${k}"`;
|
|
138
|
+
break;
|
|
139
|
+
case "doppler":
|
|
140
|
+
src = `source = "doppler", name = "${k}"`;
|
|
141
|
+
break;
|
|
142
|
+
case "vault":
|
|
143
|
+
src = `source = "vault", vault_path = "secret/data/myapp", vault_field = "${k}"`;
|
|
144
|
+
break;
|
|
145
|
+
case "aws-sm":
|
|
146
|
+
src = `source = "aws-sm", name = "${k}"`;
|
|
147
|
+
break;
|
|
148
|
+
case "gcp-sm":
|
|
149
|
+
src = `source = "gcp-sm", name = "${k}"`;
|
|
150
|
+
break;
|
|
151
|
+
case "azure-kv":
|
|
152
|
+
src = `source = "azure-kv", name = "${k}"`;
|
|
153
|
+
break;
|
|
154
|
+
default:
|
|
155
|
+
src = `source = "env"`;
|
|
156
|
+
}
|
|
157
|
+
return `${k} = { ${src} }`;
|
|
158
|
+
});
|
|
159
|
+
return lines(`[secrets]`, `store = "${store}"`, `template = ".env.template"`, ``, `[secrets.keys]`, keyLines.join("\n"));
|
|
160
|
+
}
|
|
161
|
+
function setupSection(stack) {
|
|
162
|
+
const frameworkSetup = stack.framework ? FRAMEWORK_SETUP[stack.framework] : null;
|
|
163
|
+
// Detect package manager from tools
|
|
164
|
+
let installCmd;
|
|
165
|
+
if (stack.tools.pnpm)
|
|
166
|
+
installCmd = "pnpm install";
|
|
167
|
+
else if (stack.tools.yarn)
|
|
168
|
+
installCmd = "yarn install";
|
|
169
|
+
else if (stack.tools.bun)
|
|
170
|
+
installCmd = "bun install";
|
|
171
|
+
else if (stack.tools.uv)
|
|
172
|
+
installCmd = "uv sync";
|
|
173
|
+
else if (stack.language === "go")
|
|
174
|
+
installCmd = "go mod download";
|
|
175
|
+
else if (stack.language === "rust")
|
|
176
|
+
installCmd = "cargo fetch";
|
|
177
|
+
else if (stack.language === "php")
|
|
178
|
+
installCmd = "composer install";
|
|
179
|
+
else
|
|
180
|
+
installCmd = frameworkSetup?.install ?? "npm install";
|
|
181
|
+
const hasSupabase = stack.services.includes("supabase");
|
|
182
|
+
const hasPrisma = stack.services.includes("prisma");
|
|
183
|
+
const hasDrizzle = stack.services.includes("drizzle");
|
|
184
|
+
let migrateCmd = null;
|
|
185
|
+
if (hasSupabase)
|
|
186
|
+
migrateCmd = "supabase db push";
|
|
187
|
+
else if (hasPrisma)
|
|
188
|
+
migrateCmd = "npx prisma migrate deploy";
|
|
189
|
+
else if (hasDrizzle)
|
|
190
|
+
migrateCmd = "npx drizzle-kit migrate";
|
|
191
|
+
else if (frameworkSetup?.migrate)
|
|
192
|
+
migrateCmd = frameworkSetup.migrate;
|
|
193
|
+
const verifyCmd = frameworkSetup?.verify ?? null;
|
|
194
|
+
const parts = [`[setup]`, `install = "${installCmd}"`];
|
|
195
|
+
if (migrateCmd)
|
|
196
|
+
parts.push(`migrate = "${migrateCmd}"`);
|
|
197
|
+
if (verifyCmd)
|
|
198
|
+
parts.push(`verify = "${verifyCmd}"`);
|
|
199
|
+
return parts.join("\n");
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Generate a .kit.toml string from a detected stack profile.
|
|
203
|
+
*/
|
|
204
|
+
export function generateToml(stack, options = {}) {
|
|
205
|
+
// Merge service tools into tools map
|
|
206
|
+
const tools = { ...stack.tools };
|
|
207
|
+
for (const svc of stack.services) {
|
|
208
|
+
const tmpl = SERVICE_TEMPLATES[svc];
|
|
209
|
+
if (tmpl?.tool && !tools[tmpl.tool]) {
|
|
210
|
+
tools[tmpl.tool] = "latest";
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
const header = lines(`# .kit.toml — generated by kit init`, stack.framework
|
|
214
|
+
? `# Detected: ${stack.language} / ${stack.framework}${stack.services.length ? ` + ${stack.services.join(", ")}` : ""}`
|
|
215
|
+
: `# Detected: ${stack.language}${stack.services.length ? ` + ${stack.services.join(", ")}` : ""}`, ``);
|
|
216
|
+
const toolsSec = toolsSection(tools);
|
|
217
|
+
const servicesSec = servicesSection(stack.services, tools);
|
|
218
|
+
const secretsSec = secretsSection(stack.services, options.secretsStore ?? "1password");
|
|
219
|
+
const setupSec = setupSection(stack);
|
|
220
|
+
const parts = [header, toolsSec, servicesSec, secretsSec, setupSec].filter((s) => s.trim().length > 0);
|
|
221
|
+
return parts.join("\n") + "\n";
|
|
222
|
+
}
|
|
223
|
+
//# sourceMappingURL=toml-generator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toml-generator.js","sourceRoot":"","sources":["../src/toml-generator.ts"],"names":[],"mappings":"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"}
|