4runr-os 2.10.85 → 2.10.86
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/SETUP.md +2 -2
- package/USER-PRIVACY.md +2 -2
- package/apps/os-server/DEPLOYMENT.md +426 -0
- package/apps/os-server/JWT-RATE-LIMIT-VALIDATION.md +462 -0
- package/apps/os-server/PERSISTENCE-AND-AUTH.md +227 -0
- package/apps/os-server/PHASE5-TESTING.md +222 -0
- package/apps/os-server/README.md +368 -0
- package/apps/os-server/TROUBLESHOOTING.md +541 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/gateway-cancel-adapter.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/gateway-cancel-adapter.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/gateway-cancel-adapter.js +28 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/gateway-cancel-adapter.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/redis-sentinel-publisher.d.ts +23 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/redis-sentinel-publisher.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/redis-sentinel-publisher.js +95 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/redis-sentinel-publisher.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/sentinel-event-stream.d.ts +14 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/sentinel-event-stream.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/sentinel-event-stream.js +69 -0
- package/apps/os-server/dist/apps/os-server/src/adapters/sentinel-event-stream.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/agents/definitions-simple.d.ts +10 -0
- package/apps/os-server/dist/apps/os-server/src/agents/definitions-simple.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/agents/definitions-simple.js +377 -0
- package/apps/os-server/dist/apps/os-server/src/agents/definitions-simple.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/agents/definitions.d.ts +14 -0
- package/apps/os-server/dist/apps/os-server/src/agents/definitions.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/agents/definitions.js +210 -0
- package/apps/os-server/dist/apps/os-server/src/agents/definitions.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/agents/local-model-provider.d.ts +25 -0
- package/apps/os-server/dist/apps/os-server/src/agents/local-model-provider.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/agents/local-model-provider.js +144 -0
- package/apps/os-server/dist/apps/os-server/src/agents/local-model-provider.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/agents/tools.d.ts +24 -0
- package/apps/os-server/dist/apps/os-server/src/agents/tools.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/agents/tools.js +110 -0
- package/apps/os-server/dist/apps/os-server/src/agents/tools.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/anthropic-provider.d.ts +14 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/anthropic-provider.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/anthropic-provider.js +139 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/anthropic-provider.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/index.d.ts +6 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/index.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/index.js +6 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/index.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/openai-provider.d.ts +14 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/openai-provider.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/openai-provider.js +136 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/openai-provider.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/provider-manager.d.ts +18 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/provider-manager.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/provider-manager.js +91 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/provider-manager.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/redis-credentials-store.d.ts +15 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/redis-credentials-store.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/redis-credentials-store.js +181 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/redis-credentials-store.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/types.d.ts +54 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/types.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/types.js +2 -0
- package/apps/os-server/dist/apps/os-server/src/ai-providers/types.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/config/persistence.d.ts +5 -0
- package/apps/os-server/dist/apps/os-server/src/config/persistence.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/config/persistence.js +14 -0
- package/apps/os-server/dist/apps/os-server/src/config/persistence.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/crypto/envelope.d.ts +28 -0
- package/apps/os-server/dist/apps/os-server/src/crypto/envelope.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/crypto/envelope.js +111 -0
- package/apps/os-server/dist/apps/os-server/src/crypto/envelope.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/crypto/mfa-storage.d.ts +6 -0
- package/apps/os-server/dist/apps/os-server/src/crypto/mfa-storage.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/crypto/mfa-storage.js +61 -0
- package/apps/os-server/dist/apps/os-server/src/crypto/mfa-storage.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/db/docker-manager.d.ts +21 -0
- package/apps/os-server/dist/apps/os-server/src/db/docker-manager.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/db/docker-manager.js +166 -0
- package/apps/os-server/dist/apps/os-server/src/db/docker-manager.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/db/init.d.ts +11 -0
- package/apps/os-server/dist/apps/os-server/src/db/init.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/db/init.js +202 -0
- package/apps/os-server/dist/apps/os-server/src/db/init.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/db/memory-db.d.ts +149 -0
- package/apps/os-server/dist/apps/os-server/src/db/memory-db.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/db/memory-db.js +295 -0
- package/apps/os-server/dist/apps/os-server/src/db/memory-db.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/db/prisma.d.ts +4 -0
- package/apps/os-server/dist/apps/os-server/src/db/prisma.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/db/prisma.js +31 -0
- package/apps/os-server/dist/apps/os-server/src/db/prisma.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/db/redis.d.ts +5 -0
- package/apps/os-server/dist/apps/os-server/src/db/redis.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/db/redis.js +69 -0
- package/apps/os-server/dist/apps/os-server/src/db/redis.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/agents-api.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/agents-api.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/agents-api.js +369 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/agents-api.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/metrics-parser.d.ts +46 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/metrics-parser.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/metrics-parser.js +114 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/metrics-parser.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/middleware.d.ts +9 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/middleware.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/middleware.js +23 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/middleware.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/routes.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/routes.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/routes.js +270 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/routes.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/tools-api.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/tools-api.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/tools-api.js +183 -0
- package/apps/os-server/dist/apps/os-server/src/devkit/tools-api.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/health/index.d.ts +36 -0
- package/apps/os-server/dist/apps/os-server/src/health/index.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/health/index.js +275 -0
- package/apps/os-server/dist/apps/os-server/src/health/index.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/index.d.ts +2 -0
- package/apps/os-server/dist/apps/os-server/src/index.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/index.js +1131 -0
- package/apps/os-server/dist/apps/os-server/src/index.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/metrics/index.d.ts +48 -0
- package/apps/os-server/dist/apps/os-server/src/metrics/index.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/metrics/index.js +296 -0
- package/apps/os-server/dist/apps/os-server/src/metrics/index.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/metrics/monitoring-detail.d.ts +18 -0
- package/apps/os-server/dist/apps/os-server/src/metrics/monitoring-detail.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/metrics/monitoring-detail.js +117 -0
- package/apps/os-server/dist/apps/os-server/src/metrics/monitoring-detail.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/auth.d.ts +5 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/auth.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/auth.js +64 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/auth.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/authApiKey.d.ts +4 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/authApiKey.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/authApiKey.js +105 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/authApiKey.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/authJwt.d.ts +12 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/authJwt.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/authJwt.js +75 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/authJwt.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/correlationId.d.ts +6 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/correlationId.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/correlationId.js +21 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/correlationId.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/ddos-protection.d.ts +13 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/ddos-protection.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/ddos-protection.js +202 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/ddos-protection.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/errorHandler.d.ts +14 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/errorHandler.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/errorHandler.js +98 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/errorHandler.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/log-capture.d.ts +2 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/log-capture.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/log-capture.js +63 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/log-capture.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/mfa.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/mfa.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/mfa.js +96 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/mfa.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/rateLimit.d.ts +6 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/rateLimit.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/rateLimit.js +54 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/rateLimit.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/rbac.d.ts +19 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/rbac.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/rbac.js +229 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/rbac.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/security.d.ts +10 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/security.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/security.js +146 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/security.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/validate.d.ts +7 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/validate.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/validate.js +156 -0
- package/apps/os-server/dist/apps/os-server/src/middleware/validate.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/queue/config.d.ts +26 -0
- package/apps/os-server/dist/apps/os-server/src/queue/config.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/queue/config.js +21 -0
- package/apps/os-server/dist/apps/os-server/src/queue/config.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/queue/index.d.ts +13 -0
- package/apps/os-server/dist/apps/os-server/src/queue/index.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/queue/index.js +152 -0
- package/apps/os-server/dist/apps/os-server/src/queue/index.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/queue/processor.d.ts +16 -0
- package/apps/os-server/dist/apps/os-server/src/queue/processor.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/queue/processor.js +378 -0
- package/apps/os-server/dist/apps/os-server/src/queue/processor.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/queue/sentinel-execute-watch.d.ts +7 -0
- package/apps/os-server/dist/apps/os-server/src/queue/sentinel-execute-watch.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/queue/sentinel-execute-watch.js +22 -0
- package/apps/os-server/dist/apps/os-server/src/queue/sentinel-execute-watch.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/ai-providers-simple.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/routes/ai-providers-simple.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/ai-providers-simple.js +175 -0
- package/apps/os-server/dist/apps/os-server/src/routes/ai-providers-simple.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/chats.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/routes/chats.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/chats.js +150 -0
- package/apps/os-server/dist/apps/os-server/src/routes/chats.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/gdpr.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/routes/gdpr.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/gdpr.js +252 -0
- package/apps/os-server/dist/apps/os-server/src/routes/gdpr.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/mfa.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/routes/mfa.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/mfa.js +240 -0
- package/apps/os-server/dist/apps/os-server/src/routes/mfa.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/monitoring.d.ts +16 -0
- package/apps/os-server/dist/apps/os-server/src/routes/monitoring.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/monitoring.js +168 -0
- package/apps/os-server/dist/apps/os-server/src/routes/monitoring.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/sentinel-policies.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/routes/sentinel-policies.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/sentinel-policies.js +209 -0
- package/apps/os-server/dist/apps/os-server/src/routes/sentinel-policies.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/sentinel-predictive.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/routes/sentinel-predictive.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/sentinel-predictive.js +88 -0
- package/apps/os-server/dist/apps/os-server/src/routes/sentinel-predictive.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/shield.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/routes/shield.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/shield.js +85 -0
- package/apps/os-server/dist/apps/os-server/src/routes/shield.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/tool-credentials.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/routes/tool-credentials.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/tool-credentials.js +209 -0
- package/apps/os-server/dist/apps/os-server/src/routes/tool-credentials.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/tool-proxy.d.ts +3 -0
- package/apps/os-server/dist/apps/os-server/src/routes/tool-proxy.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/routes/tool-proxy.js +206 -0
- package/apps/os-server/dist/apps/os-server/src/routes/tool-proxy.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/index.d.ts +5 -0
- package/apps/os-server/dist/apps/os-server/src/runs/index.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/index.js +19 -0
- package/apps/os-server/dist/apps/os-server/src/runs/index.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/memoryRunStore.d.ts +12 -0
- package/apps/os-server/dist/apps/os-server/src/runs/memoryRunStore.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/memoryRunStore.js +78 -0
- package/apps/os-server/dist/apps/os-server/src/runs/memoryRunStore.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/postgresRunStore.d.ts +15 -0
- package/apps/os-server/dist/apps/os-server/src/runs/postgresRunStore.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/postgresRunStore.js +148 -0
- package/apps/os-server/dist/apps/os-server/src/runs/postgresRunStore.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/run-kill.d.ts +20 -0
- package/apps/os-server/dist/apps/os-server/src/runs/run-kill.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/run-kill.js +69 -0
- package/apps/os-server/dist/apps/os-server/src/runs/run-kill.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/run-retention.d.ts +17 -0
- package/apps/os-server/dist/apps/os-server/src/runs/run-retention.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/run-retention.js +124 -0
- package/apps/os-server/dist/apps/os-server/src/runs/run-retention.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/runStore.d.ts +10 -0
- package/apps/os-server/dist/apps/os-server/src/runs/runStore.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/runStore.js +2 -0
- package/apps/os-server/dist/apps/os-server/src/runs/runStore.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/types.d.ts +44 -0
- package/apps/os-server/dist/apps/os-server/src/runs/types.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/runs/types.js +2 -0
- package/apps/os-server/dist/apps/os-server/src/runs/types.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/schemas/runs.d.ts +126 -0
- package/apps/os-server/dist/apps/os-server/src/schemas/runs.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/schemas/runs.js +63 -0
- package/apps/os-server/dist/apps/os-server/src/schemas/runs.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/security/agent-token.d.ts +51 -0
- package/apps/os-server/dist/apps/os-server/src/security/agent-token.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/security/agent-token.js +161 -0
- package/apps/os-server/dist/apps/os-server/src/security/agent-token.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/security/outbound-url.d.ts +2 -0
- package/apps/os-server/dist/apps/os-server/src/security/outbound-url.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/security/outbound-url.js +65 -0
- package/apps/os-server/dist/apps/os-server/src/security/outbound-url.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/security/sentinel-config-store.d.ts +14 -0
- package/apps/os-server/dist/apps/os-server/src/security/sentinel-config-store.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/security/sentinel-config-store.js +168 -0
- package/apps/os-server/dist/apps/os-server/src/security/sentinel-config-store.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/security/sentinel-run-failure.d.ts +25 -0
- package/apps/os-server/dist/apps/os-server/src/security/sentinel-run-failure.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/security/sentinel-run-failure.js +46 -0
- package/apps/os-server/dist/apps/os-server/src/security/sentinel-run-failure.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/security/shield-config.d.ts +14 -0
- package/apps/os-server/dist/apps/os-server/src/security/shield-config.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/security/shield-config.js +70 -0
- package/apps/os-server/dist/apps/os-server/src/security/shield-config.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/utils/circuit-breaker.d.ts +13 -0
- package/apps/os-server/dist/apps/os-server/src/utils/circuit-breaker.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/utils/circuit-breaker.js +72 -0
- package/apps/os-server/dist/apps/os-server/src/utils/circuit-breaker.js.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/utils/log-encryption.d.ts +10 -0
- package/apps/os-server/dist/apps/os-server/src/utils/log-encryption.d.ts.map +1 -0
- package/apps/os-server/dist/apps/os-server/src/utils/log-encryption.js +140 -0
- package/apps/os-server/dist/apps/os-server/src/utils/log-encryption.js.map +1 -0
- package/apps/os-server/docker-compose.local.yml +46 -0
- package/apps/os-server/find-gateway.sh +37 -0
- package/apps/os-server/jest.config.cjs +52 -0
- package/apps/os-server/package-lock.json +8809 -0
- package/apps/os-server/package.json +66 -0
- package/apps/os-server/scripts/setup-test-env.sh +67 -0
- package/apps/os-server/src/__tests__/integration/README.md +92 -0
- package/apps/os-server/src/__tests__/integration/helpers/test-server.ts +178 -0
- package/apps/os-server/src/__tests__/integration/sentinel.test.ts +364 -0
- package/apps/os-server/src/adapters/redis-sentinel-publisher.ts +176 -0
- package/apps/os-server/src/agents/definitions-simple.ts +536 -0
- package/apps/os-server/src/ai-providers/anthropic-provider.ts +194 -0
- package/apps/os-server/src/ai-providers/openai-provider.ts +193 -0
- package/apps/os-server/src/ai-providers/redis-credentials-store.ts +224 -0
- package/apps/os-server/src/db/docker-manager.ts +262 -0
- package/apps/os-server/src/db/init.ts +292 -0
- package/apps/os-server/src/devkit/routes.ts +349 -0
- package/apps/os-server/src/health/index.ts +375 -0
- package/apps/os-server/src/index.ts +1506 -0
- package/apps/os-server/src/middleware/correlationId.ts +56 -0
- package/apps/os-server/src/middleware/ddos-protection.ts +318 -0
- package/apps/os-server/src/middleware/log-capture.ts +92 -0
- package/apps/os-server/src/middleware/security.ts +222 -0
- package/apps/os-server/src/routes/ai-providers-simple.ts +220 -0
- package/apps/os-server/src/routes/gdpr.ts +337 -0
- package/apps/os-server/src/routes/monitoring.ts +315 -0
- package/apps/os-server/src/routes/sentinel-policies.ts +293 -0
- package/apps/os-server/src/routes/sentinel-predictive.ts +129 -0
- package/apps/os-server/src/routes/tool-proxy.ts +285 -0
- package/apps/os-server/src/security/outbound-url.ts +83 -0
- package/apps/os-server/update-and-test.sh +36 -0
- package/dist/boot-sequence.js +1 -1
- package/dist/boot-sequence.js.map +1 -1
- package/dist/gateway-api-key-bootstrap.js +1 -1
- package/dist/gateway-api-key-bootstrap.js.map +1 -1
- package/dist/gateway-prisma-bootstrap.d.ts +1 -1
- package/dist/gateway-prisma-bootstrap.js +1 -1
- package/dist/index.js +8 -8
- package/dist/index.js.map +1 -1
- package/dist/local-gateway-pid.d.ts +1 -1
- package/dist/local-gateway-pid.js +1 -1
- package/dist/os-tui-binary-bootstrap.d.ts +18 -0
- package/dist/os-tui-binary-bootstrap.d.ts.map +1 -0
- package/dist/os-tui-binary-bootstrap.js +175 -0
- package/dist/os-tui-binary-bootstrap.js.map +1 -0
- package/dist/rust-check.js +2 -2
- package/dist/rust-check.js.map +1 -1
- package/dist/system-verify.js +8 -8
- package/dist/system-verify.js.map +1 -1
- package/dist/tui-handlers.js +12 -12
- package/dist/tui-handlers.js.map +1 -1
- package/dist/watchdog.js +73 -73
- package/os-tui/Cargo.lock +1118 -0
- package/os-tui/Cargo.toml +17 -0
- package/os-tui/bin/os-tui.js +63 -0
- package/os-tui/binaries/win32-x64/os-tui.exe +0 -0
- package/os-tui/src/app/render_scheduler.rs +111 -0
- package/os-tui/src/app.rs +3814 -0
- package/os-tui/src/debug_log.rs +131 -0
- package/os-tui/src/io/mod.rs +63 -0
- package/os-tui/src/io/protocol.rs +14 -0
- package/os-tui/src/io/stdio.rs +31 -0
- package/os-tui/src/io/ws.rs +25 -0
- package/os-tui/src/main.rs +2090 -0
- package/os-tui/src/monitoring/mod.rs +439 -0
- package/os-tui/src/screens/mod.rs +254 -0
- package/os-tui/src/storage/cache.rs +221 -0
- package/os-tui/src/storage/mod.rs +5 -0
- package/os-tui/src/ui/agent_builder.rs +1148 -0
- package/os-tui/src/ui/agent_list.rs +344 -0
- package/os-tui/src/ui/boot.rs +145 -0
- package/os-tui/src/ui/connection_portal.rs +839 -0
- package/os-tui/src/ui/help.rs +340 -0
- package/os-tui/src/ui/layout.rs +978 -0
- package/os-tui/src/ui/mod.rs +13 -0
- package/os-tui/src/ui/portal_monitoring.rs +1128 -0
- package/os-tui/src/ui/run_manager.rs +922 -0
- package/os-tui/src/ui/safe_viewport.rs +236 -0
- package/os-tui/src/ui/sentinel_config.rs +828 -0
- package/os-tui/src/ui/settings.rs +414 -0
- package/os-tui/src/ui/setup_portal.rs +547 -0
- package/os-tui/src/ui/shield_dashboard.rs +1081 -0
- package/os-tui/src/websocket.rs +315 -0
- package/package.json +121 -121
- package/prisma/schema.prisma +470 -470
- package/scripts/cleanup-build-artifacts.js +2 -2
- package/scripts/os-tools-smoke.cjs +549 -549
- package/scripts/postinstall-os-server.js +63 -0
- package/scripts/postinstall-os-tui.js +64 -0
- package/scripts/seed-os-server-api-key.cjs +77 -0
- package/scripts/setup.js +11 -11
- package/src/security/package-integrity.ts +188 -188
- package/src/security/ssrf-protection.ts +147 -147
- package/apps/gateway/DEPLOYMENT.md +0 -426
- package/apps/gateway/JWT-RATE-LIMIT-VALIDATION.md +0 -462
- package/apps/gateway/PERSISTENCE-AND-AUTH.md +0 -227
- package/apps/gateway/PHASE5-TESTING.md +0 -222
- package/apps/gateway/README.md +0 -368
- package/apps/gateway/TROUBLESHOOTING.md +0 -541
- package/apps/gateway/docker-compose.local.yml +0 -46
- package/apps/gateway/find-gateway.sh +0 -37
- package/apps/gateway/jest.config.cjs +0 -52
- package/apps/gateway/package-lock.json +0 -8810
- package/apps/gateway/package.json +0 -66
- package/apps/gateway/scripts/setup-test-env.sh +0 -67
- package/apps/gateway/src/__tests__/integration/README.md +0 -92
- package/apps/gateway/src/__tests__/integration/helpers/test-server.ts +0 -178
- package/apps/gateway/src/__tests__/integration/sentinel.test.ts +0 -364
- package/apps/gateway/src/adapters/redis-sentinel-publisher.ts +0 -176
- package/apps/gateway/src/agents/definitions-simple.ts +0 -536
- package/apps/gateway/src/ai-providers/anthropic-provider.ts +0 -194
- package/apps/gateway/src/ai-providers/openai-provider.ts +0 -193
- package/apps/gateway/src/ai-providers/redis-credentials-store.ts +0 -224
- package/apps/gateway/src/db/docker-manager.ts +0 -262
- package/apps/gateway/src/db/init.ts +0 -292
- package/apps/gateway/src/devkit/routes.ts +0 -349
- package/apps/gateway/src/health/index.ts +0 -375
- package/apps/gateway/src/index.ts +0 -1506
- package/apps/gateway/src/middleware/correlationId.ts +0 -56
- package/apps/gateway/src/middleware/ddos-protection.ts +0 -318
- package/apps/gateway/src/middleware/log-capture.ts +0 -92
- package/apps/gateway/src/middleware/security.ts +0 -222
- package/apps/gateway/src/routes/ai-providers-simple.ts +0 -220
- package/apps/gateway/src/routes/gdpr.ts +0 -337
- package/apps/gateway/src/routes/monitoring.ts +0 -315
- package/apps/gateway/src/routes/sentinel-policies.ts +0 -293
- package/apps/gateway/src/routes/sentinel-predictive.ts +0 -129
- package/apps/gateway/src/routes/tool-proxy.ts +0 -285
- package/apps/gateway/src/security/outbound-url.ts +0 -83
- package/apps/gateway/update-and-test.sh +0 -36
- package/mk3-tui/Cargo.lock +0 -1118
- package/mk3-tui/Cargo.toml +0 -17
- package/mk3-tui/bin/mk3-tui.js +0 -63
- package/mk3-tui/binaries/win32-x64/mk3-tui.exe +0 -0
- package/mk3-tui/src/app/render_scheduler.rs +0 -111
- package/mk3-tui/src/app.rs +0 -3813
- package/mk3-tui/src/debug_log.rs +0 -131
- package/mk3-tui/src/io/mod.rs +0 -63
- package/mk3-tui/src/io/protocol.rs +0 -14
- package/mk3-tui/src/io/stdio.rs +0 -31
- package/mk3-tui/src/io/ws.rs +0 -25
- package/mk3-tui/src/main.rs +0 -2090
- package/mk3-tui/src/monitoring/mod.rs +0 -439
- package/mk3-tui/src/screens/mod.rs +0 -254
- package/mk3-tui/src/storage/cache.rs +0 -221
- package/mk3-tui/src/storage/mod.rs +0 -5
- package/mk3-tui/src/ui/agent_builder.rs +0 -1148
- package/mk3-tui/src/ui/agent_list.rs +0 -344
- package/mk3-tui/src/ui/boot.rs +0 -145
- package/mk3-tui/src/ui/connection_portal.rs +0 -839
- package/mk3-tui/src/ui/help.rs +0 -340
- package/mk3-tui/src/ui/layout.rs +0 -978
- package/mk3-tui/src/ui/mod.rs +0 -13
- package/mk3-tui/src/ui/portal_monitoring.rs +0 -1128
- package/mk3-tui/src/ui/run_manager.rs +0 -913
- package/mk3-tui/src/ui/safe_viewport.rs +0 -236
- package/mk3-tui/src/ui/sentinel_config.rs +0 -828
- package/mk3-tui/src/ui/settings.rs +0 -414
- package/mk3-tui/src/ui/setup_portal.rs +0 -547
- package/mk3-tui/src/ui/shield_dashboard.rs +0 -1081
- package/mk3-tui/src/websocket.rs +0 -315
- package/scripts/postinstall-gateway.js +0 -63
- package/scripts/postinstall-mk3.js +0 -64
- package/scripts/seed-gateway-api-key.cjs +0 -77
- /package/apps/{gateway → os-server}/.dockerignore +0 -0
- /package/apps/{gateway → os-server}/.eslintrc.json +0 -0
- /package/apps/{gateway → os-server}/Dockerfile +0 -0
- /package/apps/{gateway → os-server}/Dockerfile.bak +0 -0
- /package/apps/{gateway → os-server}/ENV_VARIABLES.md +0 -0
- /package/apps/{gateway → os-server}/create-test-script.sh +0 -0
- /package/apps/{gateway → os-server}/debug-api-responses.sh +0 -0
- /package/apps/{gateway → os-server}/debug-failing-tests-v2.sh +0 -0
- /package/apps/{gateway → os-server}/debug-failing-tests.sh +0 -0
- /package/apps/{gateway → os-server}/debug-responses.sh +0 -0
- /package/apps/{gateway → os-server}/debug-test-responses.sh +0 -0
- /package/apps/{gateway → os-server}/debug-tests.sh +0 -0
- /package/apps/{gateway → os-server}/diagnose-test-failure.sh +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/gateway-cancel-adapter.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/gateway-cancel-adapter.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/gateway-cancel-adapter.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/gateway-cancel-adapter.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/redis-sentinel-publisher.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/redis-sentinel-publisher.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/redis-sentinel-publisher.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/redis-sentinel-publisher.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/sentinel-event-stream.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/sentinel-event-stream.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/sentinel-event-stream.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/adapters/sentinel-event-stream.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/definitions-simple.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/definitions-simple.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/definitions-simple.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/definitions-simple.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/definitions.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/definitions.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/definitions.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/definitions.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/local-model-provider.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/local-model-provider.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/local-model-provider.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/local-model-provider.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/tools.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/tools.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/tools.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/agents/tools.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/anthropic-provider.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/anthropic-provider.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/anthropic-provider.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/anthropic-provider.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/index.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/index.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/index.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/index.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/openai-provider.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/openai-provider.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/openai-provider.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/openai-provider.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/provider-manager.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/provider-manager.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/provider-manager.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/provider-manager.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/redis-credentials-store.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/redis-credentials-store.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/redis-credentials-store.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/redis-credentials-store.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/types.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/types.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/types.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/ai-providers/types.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/config/persistence.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/config/persistence.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/config/persistence.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/config/persistence.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/crypto/envelope.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/crypto/envelope.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/crypto/envelope.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/crypto/envelope.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/crypto/mfa-storage.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/crypto/mfa-storage.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/crypto/mfa-storage.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/crypto/mfa-storage.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/docker-manager.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/docker-manager.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/docker-manager.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/docker-manager.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/init.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/init.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/init.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/init.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/memory-db.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/memory-db.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/memory-db.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/memory-db.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/prisma.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/prisma.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/prisma.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/prisma.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/redis.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/redis.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/redis.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/db/redis.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/agents-api.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/agents-api.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/agents-api.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/agents-api.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/metrics-parser.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/metrics-parser.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/metrics-parser.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/metrics-parser.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/middleware.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/middleware.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/middleware.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/middleware.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/routes.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/routes.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/routes.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/routes.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/tools-api.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/tools-api.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/tools-api.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/devkit/tools-api.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/health/index.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/health/index.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/health/index.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/health/index.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/index.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/index.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/index.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/index.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/metrics/index.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/metrics/index.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/metrics/index.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/metrics/index.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/metrics/monitoring-detail.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/metrics/monitoring-detail.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/metrics/monitoring-detail.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/metrics/monitoring-detail.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/auth.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/auth.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/auth.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/auth.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/authApiKey.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/authApiKey.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/authApiKey.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/authApiKey.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/authJwt.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/authJwt.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/authJwt.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/authJwt.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/correlationId.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/correlationId.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/correlationId.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/correlationId.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/ddos-protection.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/ddos-protection.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/ddos-protection.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/ddos-protection.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/errorHandler.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/errorHandler.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/errorHandler.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/errorHandler.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/log-capture.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/log-capture.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/log-capture.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/log-capture.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/mfa.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/mfa.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/mfa.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/mfa.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/rateLimit.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/rateLimit.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/rateLimit.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/rateLimit.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/rbac.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/rbac.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/rbac.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/rbac.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/security.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/security.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/security.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/security.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/validate.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/validate.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/validate.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/middleware/validate.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/config.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/config.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/config.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/config.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/index.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/index.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/index.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/index.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/processor.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/processor.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/processor.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/processor.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/sentinel-execute-watch.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/sentinel-execute-watch.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/sentinel-execute-watch.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/queue/sentinel-execute-watch.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/ai-providers-simple.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/ai-providers-simple.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/ai-providers-simple.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/ai-providers-simple.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/chats.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/chats.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/chats.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/chats.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/gdpr.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/gdpr.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/gdpr.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/gdpr.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/mfa.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/mfa.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/mfa.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/mfa.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/monitoring.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/monitoring.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/monitoring.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/monitoring.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/sentinel-policies.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/sentinel-policies.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/sentinel-policies.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/sentinel-policies.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/sentinel-predictive.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/sentinel-predictive.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/sentinel-predictive.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/sentinel-predictive.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/shield.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/shield.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/shield.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/shield.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/tool-credentials.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/tool-credentials.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/tool-credentials.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/tool-credentials.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/tool-proxy.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/tool-proxy.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/tool-proxy.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/routes/tool-proxy.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/index.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/index.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/index.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/index.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/memoryRunStore.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/memoryRunStore.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/memoryRunStore.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/memoryRunStore.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/postgresRunStore.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/postgresRunStore.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/postgresRunStore.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/postgresRunStore.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/run-kill.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/run-kill.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/run-kill.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/run-kill.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/run-retention.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/run-retention.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/run-retention.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/run-retention.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/runStore.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/runStore.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/runStore.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/runStore.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/types.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/types.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/types.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/runs/types.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/schemas/runs.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/schemas/runs.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/schemas/runs.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/schemas/runs.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/agent-token.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/agent-token.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/agent-token.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/agent-token.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/outbound-url.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/outbound-url.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/outbound-url.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/outbound-url.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/sentinel-config-store.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/sentinel-config-store.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/sentinel-config-store.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/sentinel-config-store.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/sentinel-run-failure.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/sentinel-run-failure.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/sentinel-run-failure.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/sentinel-run-failure.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/shield-config.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/shield-config.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/shield-config.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/security/shield-config.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/utils/circuit-breaker.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/utils/circuit-breaker.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/utils/circuit-breaker.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/utils/circuit-breaker.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/utils/log-encryption.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/utils/log-encryption.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/utils/log-encryption.js +0 -0
- /package/apps/{gateway → os-server}/dist/apps/gateway/src/utils/log-encryption.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/index.js +0 -0
- /package/apps/{gateway → os-server}/dist/packages/adapters/redis/IdempotencyStore.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/packages/adapters/redis/IdempotencyStore.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/packages/adapters/redis/IdempotencyStore.js +0 -0
- /package/apps/{gateway → os-server}/dist/packages/adapters/redis/IdempotencyStore.js.map +0 -0
- /package/apps/{gateway → os-server}/dist/packages/middleware/idempotency/idempotency.d.ts +0 -0
- /package/apps/{gateway → os-server}/dist/packages/middleware/idempotency/idempotency.d.ts.map +0 -0
- /package/apps/{gateway → os-server}/dist/packages/middleware/idempotency/idempotency.js +0 -0
- /package/apps/{gateway → os-server}/dist/packages/middleware/idempotency/idempotency.js.map +0 -0
- /package/apps/{gateway → os-server}/load-tests/README.md +0 -0
- /package/apps/{gateway → os-server}/load-tests/k6-basic.js +0 -0
- /package/apps/{gateway → os-server}/load-tests/k6-rate-limit.js +0 -0
- /package/apps/{gateway → os-server}/minimal-test.sh +0 -0
- /package/apps/{gateway → os-server}/public/sentinel-dashboard.html +0 -0
- /package/apps/{gateway → os-server}/quick-debug.sh +0 -0
- /package/apps/{gateway → os-server}/scripts/seed-api-key.ts +0 -0
- /package/apps/{gateway → os-server}/scripts/verify-sentinel-persist.mjs +0 -0
- /package/apps/{gateway → os-server}/simple-test.sh +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/agent-token.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/auth.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/correlationId.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/devkit-api.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/integration/authentication.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/integration/e2e-comprehensive-fixed.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/integration/e2e-workflow.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/integration/idempotency.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/integration/postgres-persistence.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/integration/rate-limiting.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/integration/shield.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/log-capture.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/no-persistence-mode.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/outbound-url.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/rateLimit.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/run-kill.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/run-retention.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/sentinel-config-persist-http.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/sentinel-config-store.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/sentinel-events.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/sentinel-execute-watch.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/sentinel-policies.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/sentinel-publish-kill.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/sentinel-run-failure.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/shield-config.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/shield-health.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/shield-metrics.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/tool-proxy.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/validateSecrets.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/__tests__/validation.test.ts +0 -0
- /package/apps/{gateway → os-server}/src/adapters/gateway-cancel-adapter.ts +0 -0
- /package/apps/{gateway → os-server}/src/adapters/sentinel-event-stream.ts +0 -0
- /package/apps/{gateway → os-server}/src/agents/definitions.ts +0 -0
- /package/apps/{gateway → os-server}/src/agents/local-model-provider.ts +0 -0
- /package/apps/{gateway → os-server}/src/agents/tools.ts +0 -0
- /package/apps/{gateway → os-server}/src/ai-providers/index.ts +0 -0
- /package/apps/{gateway → os-server}/src/ai-providers/provider-manager.ts +0 -0
- /package/apps/{gateway → os-server}/src/ai-providers/types.ts +0 -0
- /package/apps/{gateway → os-server}/src/config/persistence.ts +0 -0
- /package/apps/{gateway → os-server}/src/crypto/envelope.ts +0 -0
- /package/apps/{gateway → os-server}/src/crypto/mfa-storage.ts +0 -0
- /package/apps/{gateway → os-server}/src/db/memory-db.ts +0 -0
- /package/apps/{gateway → os-server}/src/db/prisma.ts +0 -0
- /package/apps/{gateway → os-server}/src/db/redis.ts +0 -0
- /package/apps/{gateway → os-server}/src/devkit/agents-api.ts +0 -0
- /package/apps/{gateway → os-server}/src/devkit/metrics-parser.ts +0 -0
- /package/apps/{gateway → os-server}/src/devkit/middleware.ts +0 -0
- /package/apps/{gateway → os-server}/src/devkit/tools-api.ts +0 -0
- /package/apps/{gateway → os-server}/src/metrics/index.ts +0 -0
- /package/apps/{gateway → os-server}/src/metrics/monitoring-detail.ts +0 -0
- /package/apps/{gateway → os-server}/src/middleware/auth.ts +0 -0
- /package/apps/{gateway → os-server}/src/middleware/authApiKey.ts +0 -0
- /package/apps/{gateway → os-server}/src/middleware/authJwt.ts +0 -0
- /package/apps/{gateway → os-server}/src/middleware/errorHandler.ts +0 -0
- /package/apps/{gateway → os-server}/src/middleware/mfa.ts +0 -0
- /package/apps/{gateway → os-server}/src/middleware/rateLimit.ts +0 -0
- /package/apps/{gateway → os-server}/src/middleware/rbac.ts +0 -0
- /package/apps/{gateway → os-server}/src/middleware/validate.ts +0 -0
- /package/apps/{gateway → os-server}/src/middleware/validate.ts.backup +0 -0
- /package/apps/{gateway → os-server}/src/queue/config.ts +0 -0
- /package/apps/{gateway → os-server}/src/queue/index.ts +0 -0
- /package/apps/{gateway → os-server}/src/queue/processor.ts +0 -0
- /package/apps/{gateway → os-server}/src/queue/sentinel-execute-watch.ts +0 -0
- /package/apps/{gateway → os-server}/src/routes/chats.ts +0 -0
- /package/apps/{gateway → os-server}/src/routes/mfa.ts +0 -0
- /package/apps/{gateway → os-server}/src/routes/shield.ts +0 -0
- /package/apps/{gateway → os-server}/src/routes/tool-credentials.ts +0 -0
- /package/apps/{gateway → os-server}/src/runs/index.ts +0 -0
- /package/apps/{gateway → os-server}/src/runs/memoryRunStore.ts +0 -0
- /package/apps/{gateway → os-server}/src/runs/postgresRunStore.ts +0 -0
- /package/apps/{gateway → os-server}/src/runs/run-kill.ts +0 -0
- /package/apps/{gateway → os-server}/src/runs/run-retention.ts +0 -0
- /package/apps/{gateway → os-server}/src/runs/runStore.ts +0 -0
- /package/apps/{gateway → os-server}/src/runs/types.ts +0 -0
- /package/apps/{gateway → os-server}/src/schemas/runs.ts +0 -0
- /package/apps/{gateway → os-server}/src/security/agent-token.ts +0 -0
- /package/apps/{gateway → os-server}/src/security/sentinel-config-store.ts +0 -0
- /package/apps/{gateway → os-server}/src/security/sentinel-run-failure.ts +0 -0
- /package/apps/{gateway → os-server}/src/security/shield-config.ts +0 -0
- /package/apps/{gateway → os-server}/src/types/fastify-rate-limit.d.ts +0 -0
- /package/apps/{gateway → os-server}/src/utils/circuit-breaker.ts +0 -0
- /package/apps/{gateway → os-server}/src/utils/log-encryption.ts +0 -0
- /package/apps/{gateway → os-server}/test-all-individual.sh +0 -0
- /package/apps/{gateway → os-server}/test-all-phases-final.sh +0 -0
- /package/apps/{gateway → os-server}/test-all-phases-fixed-v2.sh +0 -0
- /package/apps/{gateway → os-server}/test-all-phases-fixed.sh +0 -0
- /package/apps/{gateway → os-server}/test-all-phases.sh +0 -0
- /package/apps/{gateway → os-server}/test-concurrency.sh +0 -0
- /package/apps/{gateway → os-server}/test-debug.sh +0 -0
- /package/apps/{gateway → os-server}/test-e2e.sh +0 -0
- /package/apps/{gateway → os-server}/test-extraction.sh +0 -0
- /package/apps/{gateway → os-server}/test-full-operations-final.sh +0 -0
- /package/apps/{gateway → os-server}/test-full-operations.sh +0 -0
- /package/apps/{gateway → os-server}/test-idempotency-only.sh +0 -0
- /package/apps/{gateway → os-server}/test-idempotency.sh +0 -0
- /package/apps/{gateway → os-server}/test-individual.sh +0 -0
- /package/apps/{gateway → os-server}/test-queue.sh +0 -0
- /package/apps/{gateway → os-server}/tsconfig.json +0 -0
- /package/{mk3-tui → os-tui}/src/ui/connection_portal.rs.backup +0 -0
|
@@ -1,315 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Advanced monitoring routes for Portal Monitoring (Phase 0)
|
|
3
|
-
* Provides structured logs, dependency details, and extended metrics
|
|
4
|
-
*
|
|
5
|
-
* SECURITY: All monitoring endpoints require authentication in production.
|
|
6
|
-
* For local development, consider network binding (127.0.0.1 only).
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
import { FastifyInstance, FastifyRequest, FastifyReply } from 'fastify';
|
|
10
|
-
import { getQueue } from '../queue/index.js';
|
|
11
|
-
import { getRedisClient } from '../db/redis.js';
|
|
12
|
-
import { getPrismaClient } from '../db/prisma.js';
|
|
13
|
-
import { performHealthChecks } from '../health/index.js';
|
|
14
|
-
import { createLogger } from '@4runr/shared';
|
|
15
|
-
import { wrapLoggerForMonitoring } from '../middleware/log-capture.js';
|
|
16
|
-
import {
|
|
17
|
-
getDependencyPoolsPayload,
|
|
18
|
-
getMonitoringHttpPayload,
|
|
19
|
-
getMonitoringRunsPayload,
|
|
20
|
-
getMonitoringSsePayload,
|
|
21
|
-
} from '../metrics/monitoring-detail.js';
|
|
22
|
-
|
|
23
|
-
interface LogEntry {
|
|
24
|
-
timestamp: string;
|
|
25
|
-
level: 'error' | 'warn' | 'info' | 'debug';
|
|
26
|
-
message: string;
|
|
27
|
-
context?: string;
|
|
28
|
-
correlationId?: string;
|
|
29
|
-
data?: Record<string, unknown>;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
// In-memory ring buffer for logs (last 1000 entries)
|
|
33
|
-
const LOG_BUFFER_SIZE = 1000;
|
|
34
|
-
const logBuffer: LogEntry[] = [];
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* Add log entry to buffer (called by logger middleware or manually)
|
|
38
|
-
*/
|
|
39
|
-
export function addMonitoringLog(entry: LogEntry): void {
|
|
40
|
-
logBuffer.push(entry);
|
|
41
|
-
if (logBuffer.length > LOG_BUFFER_SIZE) {
|
|
42
|
-
logBuffer.shift();
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* Register monitoring routes
|
|
48
|
-
* @param fastify Fastify instance
|
|
49
|
-
* @param options Optional configuration for route security
|
|
50
|
-
*/
|
|
51
|
-
export function registerMonitoringRoutes(
|
|
52
|
-
fastify: FastifyInstance,
|
|
53
|
-
options?: {
|
|
54
|
-
requireAuth?: boolean | any; // boolean false or auth handler function
|
|
55
|
-
readRateLimit?: any;
|
|
56
|
-
}
|
|
57
|
-
): void {
|
|
58
|
-
const { requireAuth, readRateLimit } = options || {};
|
|
59
|
-
const logger = wrapLoggerForMonitoring(createLogger('Gateway:Monitoring'));
|
|
60
|
-
|
|
61
|
-
// Determine if auth is required (requireAuth can be false, function, or undefined)
|
|
62
|
-
const authHandler = requireAuth === false ? null : requireAuth;
|
|
63
|
-
const preHandler = authHandler && readRateLimit
|
|
64
|
-
? [authHandler, readRateLimit]
|
|
65
|
-
: authHandler
|
|
66
|
-
? [authHandler]
|
|
67
|
-
: [];
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* GET /api/monitoring/logs
|
|
71
|
-
* Returns last N Gateway logs for TUI display
|
|
72
|
-
* SECURITY: Requires authentication (contains operational data)
|
|
73
|
-
*/
|
|
74
|
-
fastify.get('/api/monitoring/logs', {
|
|
75
|
-
...(preHandler.length > 0 && { preHandler }),
|
|
76
|
-
}, async (request: FastifyRequest, reply: FastifyReply) => {
|
|
77
|
-
const query = request.query as { limit?: string; level?: string };
|
|
78
|
-
const limit = Math.min(parseInt(query.limit || '100', 10), LOG_BUFFER_SIZE);
|
|
79
|
-
const levelFilter = query.level as LogEntry['level'] | undefined;
|
|
80
|
-
|
|
81
|
-
let logs = logBuffer.slice(-limit);
|
|
82
|
-
|
|
83
|
-
if (levelFilter) {
|
|
84
|
-
logs = logs.filter(log => log.level === levelFilter);
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
return {
|
|
88
|
-
logs,
|
|
89
|
-
count: logs.length,
|
|
90
|
-
bufferSize: logBuffer.length,
|
|
91
|
-
timestamp: new Date().toISOString(),
|
|
92
|
-
};
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* GET /api/monitoring/dependencies/detail
|
|
97
|
-
* Extended dependency info (connection pools, queue stats, etc.)
|
|
98
|
-
* SECURITY: Requires authentication (exposes infrastructure details)
|
|
99
|
-
*/
|
|
100
|
-
fastify.get('/api/monitoring/dependencies/detail', {
|
|
101
|
-
...(preHandler.length > 0 && { preHandler }),
|
|
102
|
-
}, async (request: FastifyRequest, reply: FastifyReply) => {
|
|
103
|
-
const health = await performHealthChecks();
|
|
104
|
-
const details: {
|
|
105
|
-
database?: {
|
|
106
|
-
status: string;
|
|
107
|
-
latency?: number;
|
|
108
|
-
poolAvailable?: boolean;
|
|
109
|
-
pool?: { active: number; idle: number };
|
|
110
|
-
telemetry?: { source: string; bestEffort: boolean; note: string };
|
|
111
|
-
};
|
|
112
|
-
redis?: {
|
|
113
|
-
status: string;
|
|
114
|
-
latency?: number;
|
|
115
|
-
connectionCountAvailable?: boolean;
|
|
116
|
-
connections?: { active: number };
|
|
117
|
-
telemetry?: { source: string; bestEffort: boolean; note: string };
|
|
118
|
-
};
|
|
119
|
-
queue?: {
|
|
120
|
-
status: string;
|
|
121
|
-
jobs?: {
|
|
122
|
-
waiting: number;
|
|
123
|
-
active: number;
|
|
124
|
-
completed: number;
|
|
125
|
-
failed: number;
|
|
126
|
-
delayed: number;
|
|
127
|
-
};
|
|
128
|
-
};
|
|
129
|
-
shield?: {
|
|
130
|
-
enabled: boolean;
|
|
131
|
-
mode: string;
|
|
132
|
-
detectors: {
|
|
133
|
-
pii: boolean;
|
|
134
|
-
injection: boolean;
|
|
135
|
-
hallucination: boolean;
|
|
136
|
-
};
|
|
137
|
-
status: 'operational' | 'misconfigured';
|
|
138
|
-
warnings?: string[];
|
|
139
|
-
};
|
|
140
|
-
} = {};
|
|
141
|
-
|
|
142
|
-
const pools = await getDependencyPoolsPayload();
|
|
143
|
-
|
|
144
|
-
// Database details
|
|
145
|
-
if (health.checks.database) {
|
|
146
|
-
const dbLatency = health.checks.database.responseTime;
|
|
147
|
-
details.database = {
|
|
148
|
-
status: health.checks.database.status,
|
|
149
|
-
...(dbLatency !== undefined && { latency: dbLatency }),
|
|
150
|
-
poolAvailable: true,
|
|
151
|
-
pool: {
|
|
152
|
-
active: pools.database.active,
|
|
153
|
-
idle: pools.database.idle,
|
|
154
|
-
},
|
|
155
|
-
telemetry: pools.telemetry,
|
|
156
|
-
};
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
// Redis details
|
|
160
|
-
if (health.checks.redis) {
|
|
161
|
-
const redisLatency = health.checks.redis.responseTime;
|
|
162
|
-
details.redis = {
|
|
163
|
-
status: health.checks.redis.status,
|
|
164
|
-
...(redisLatency !== undefined && { latency: redisLatency }),
|
|
165
|
-
connectionCountAvailable: true,
|
|
166
|
-
connections: {
|
|
167
|
-
active: pools.redis.active,
|
|
168
|
-
},
|
|
169
|
-
telemetry: pools.telemetry,
|
|
170
|
-
};
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
// Queue details (real data from BullMQ)
|
|
174
|
-
if (health.checks.queue) {
|
|
175
|
-
details.queue = {
|
|
176
|
-
status: health.checks.queue.status,
|
|
177
|
-
};
|
|
178
|
-
|
|
179
|
-
try {
|
|
180
|
-
const queue = getQueue();
|
|
181
|
-
if (queue) {
|
|
182
|
-
// BullMQ v4+ getJobCounts: pass state names as separate args
|
|
183
|
-
// Returns object with keys matching exact state names passed
|
|
184
|
-
const counts = await queue.getJobCounts(
|
|
185
|
-
'waiting',
|
|
186
|
-
'active',
|
|
187
|
-
'completed',
|
|
188
|
-
'failed',
|
|
189
|
-
'delayed'
|
|
190
|
-
) as Record<string, number>;
|
|
191
|
-
|
|
192
|
-
details.queue.jobs = {
|
|
193
|
-
waiting: counts['waiting'] ?? 0,
|
|
194
|
-
active: counts['active'] ?? 0,
|
|
195
|
-
completed: counts['completed'] ?? 0,
|
|
196
|
-
failed: counts['failed'] ?? 0,
|
|
197
|
-
delayed: counts['delayed'] ?? 0,
|
|
198
|
-
};
|
|
199
|
-
}
|
|
200
|
-
} catch (err) {
|
|
201
|
-
logger.error('Failed to fetch queue job counts', {
|
|
202
|
-
error: err instanceof Error ? err.message : String(err),
|
|
203
|
-
});
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
// S5 fix: include Shield health (was wasted work to fetch but not return)
|
|
208
|
-
if (health.checks.shield) {
|
|
209
|
-
details.shield = health.checks.shield;
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
return {
|
|
213
|
-
details,
|
|
214
|
-
telemetry: pools.telemetry,
|
|
215
|
-
timestamp: new Date().toISOString(),
|
|
216
|
-
};
|
|
217
|
-
});
|
|
218
|
-
|
|
219
|
-
/**
|
|
220
|
-
* GET /api/monitoring/metrics/http
|
|
221
|
-
* Detailed HTTP metrics with route breakdown
|
|
222
|
-
* SECURITY: Requires authentication
|
|
223
|
-
*/
|
|
224
|
-
fastify.get('/api/monitoring/metrics/http', {
|
|
225
|
-
...(preHandler.length > 0 && { preHandler }),
|
|
226
|
-
}, async (_request: FastifyRequest, _reply: FastifyReply) => {
|
|
227
|
-
return await getMonitoringHttpPayload();
|
|
228
|
-
});
|
|
229
|
-
|
|
230
|
-
/**
|
|
231
|
-
* GET /api/monitoring/metrics/runs
|
|
232
|
-
* Detailed run metrics
|
|
233
|
-
* SECURITY: Requires authentication
|
|
234
|
-
*/
|
|
235
|
-
fastify.get('/api/monitoring/metrics/runs', {
|
|
236
|
-
...(preHandler.length > 0 && { preHandler }),
|
|
237
|
-
}, async (_request: FastifyRequest, _reply: FastifyReply) => {
|
|
238
|
-
return await getMonitoringRunsPayload();
|
|
239
|
-
});
|
|
240
|
-
|
|
241
|
-
/**
|
|
242
|
-
* GET /api/monitoring/metrics/sse
|
|
243
|
-
* SSE connection / message counters (Phase 3)
|
|
244
|
-
*/
|
|
245
|
-
fastify.get('/api/monitoring/metrics/sse', {
|
|
246
|
-
...(preHandler.length > 0 && { preHandler }),
|
|
247
|
-
}, async (_request: FastifyRequest, _reply: FastifyReply) => {
|
|
248
|
-
return await getMonitoringSsePayload();
|
|
249
|
-
});
|
|
250
|
-
|
|
251
|
-
/**
|
|
252
|
-
* GET /api/monitoring/metrics/queue
|
|
253
|
-
* Detailed queue metrics with job states
|
|
254
|
-
* SECURITY: Requires authentication
|
|
255
|
-
*/
|
|
256
|
-
fastify.get('/api/monitoring/metrics/queue', {
|
|
257
|
-
...(preHandler.length > 0 && { preHandler }),
|
|
258
|
-
}, async (request: FastifyRequest, reply: FastifyReply) => {
|
|
259
|
-
try {
|
|
260
|
-
const queue = getQueue();
|
|
261
|
-
if (!queue) {
|
|
262
|
-
return {
|
|
263
|
-
available: false,
|
|
264
|
-
message: 'Queue not initialized (Redis required)',
|
|
265
|
-
timestamp: new Date().toISOString(),
|
|
266
|
-
};
|
|
267
|
-
}
|
|
268
|
-
|
|
269
|
-
// BullMQ v4+ getJobCounts: returns exact keys matching state names passed
|
|
270
|
-
const counts = await queue.getJobCounts(
|
|
271
|
-
'waiting',
|
|
272
|
-
'active',
|
|
273
|
-
'completed',
|
|
274
|
-
'failed',
|
|
275
|
-
'delayed',
|
|
276
|
-
'paused'
|
|
277
|
-
) as Record<string, number>;
|
|
278
|
-
|
|
279
|
-
return {
|
|
280
|
-
available: true,
|
|
281
|
-
jobs: {
|
|
282
|
-
waiting: counts['waiting'] ?? 0,
|
|
283
|
-
active: counts['active'] ?? 0,
|
|
284
|
-
completed: counts['completed'] ?? 0,
|
|
285
|
-
failed: counts['failed'] ?? 0,
|
|
286
|
-
delayed: counts['delayed'] ?? 0,
|
|
287
|
-
paused: counts['paused'] ?? 0,
|
|
288
|
-
},
|
|
289
|
-
queueName: (queue as any).name || 'run-execution',
|
|
290
|
-
timestamp: new Date().toISOString(),
|
|
291
|
-
};
|
|
292
|
-
} catch (error) {
|
|
293
|
-
logger.error('Failed to get queue metrics', {
|
|
294
|
-
error: error instanceof Error ? error.message : String(error),
|
|
295
|
-
});
|
|
296
|
-
return {
|
|
297
|
-
available: false,
|
|
298
|
-
error: error instanceof Error ? error.message : String(error),
|
|
299
|
-
timestamp: new Date().toISOString(),
|
|
300
|
-
};
|
|
301
|
-
}
|
|
302
|
-
});
|
|
303
|
-
|
|
304
|
-
logger.info('Monitoring routes registered (Phase 0)', {
|
|
305
|
-
authRequired: preHandler.length > 0,
|
|
306
|
-
endpoints: [
|
|
307
|
-
'/api/monitoring/logs',
|
|
308
|
-
'/api/monitoring/dependencies/detail',
|
|
309
|
-
'/api/monitoring/metrics/http',
|
|
310
|
-
'/api/monitoring/metrics/runs',
|
|
311
|
-
'/api/monitoring/metrics/sse',
|
|
312
|
-
'/api/monitoring/metrics/queue',
|
|
313
|
-
],
|
|
314
|
-
});
|
|
315
|
-
}
|
|
@@ -1,293 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Sentinel Policy Management Routes
|
|
3
|
-
* Handles policy templates and configuration
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import { FastifyInstance, FastifyRequest, FastifyReply } from 'fastify';
|
|
7
|
-
import {
|
|
8
|
-
getPolicyTemplate,
|
|
9
|
-
listPolicyTemplatesWithKeys,
|
|
10
|
-
applyPolicyTemplate,
|
|
11
|
-
recommendTemplate,
|
|
12
|
-
} from '@4runr/sentinel';
|
|
13
|
-
import { requireAuth } from '../middleware/auth.js';
|
|
14
|
-
import { readRateLimit, writeRateLimit } from '../middleware/rateLimit.js';
|
|
15
|
-
import {
|
|
16
|
-
persistSentinelConfigAfterApply,
|
|
17
|
-
hydrateSentinelConfigFromDisk,
|
|
18
|
-
getSentinelLimitsFilePath,
|
|
19
|
-
} from '../security/sentinel-config-store.js';
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* Register Sentinel policy management routes
|
|
23
|
-
*/
|
|
24
|
-
export async function sentinelPolicyRoutes(fastify: FastifyInstance) {
|
|
25
|
-
/**
|
|
26
|
-
* GET /api/sentinel/policies/templates
|
|
27
|
-
* List all available policy templates
|
|
28
|
-
*/
|
|
29
|
-
fastify.get(
|
|
30
|
-
'/api/sentinel/policies/templates',
|
|
31
|
-
{
|
|
32
|
-
preHandler: [requireAuth, readRateLimit],
|
|
33
|
-
},
|
|
34
|
-
async (
|
|
35
|
-
request: FastifyRequest,
|
|
36
|
-
reply: FastifyReply
|
|
37
|
-
) => {
|
|
38
|
-
try {
|
|
39
|
-
const templates = listPolicyTemplatesWithKeys();
|
|
40
|
-
return {
|
|
41
|
-
success: true,
|
|
42
|
-
templates: templates.map(t => ({
|
|
43
|
-
key: t.key,
|
|
44
|
-
name: t.name,
|
|
45
|
-
description: t.description,
|
|
46
|
-
useCase: t.useCase,
|
|
47
|
-
config: t.config
|
|
48
|
-
}))
|
|
49
|
-
};
|
|
50
|
-
} catch (error: any) {
|
|
51
|
-
return reply.status(500).send({
|
|
52
|
-
error: 'Failed to list templates',
|
|
53
|
-
details: error.message
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
);
|
|
58
|
-
|
|
59
|
-
/**
|
|
60
|
-
* GET /api/sentinel/policies/templates/:name
|
|
61
|
-
* Get a specific policy template
|
|
62
|
-
*/
|
|
63
|
-
fastify.get(
|
|
64
|
-
'/api/sentinel/policies/templates/:name',
|
|
65
|
-
{
|
|
66
|
-
preHandler: [requireAuth, readRateLimit],
|
|
67
|
-
},
|
|
68
|
-
async (request: FastifyRequest, reply: FastifyReply) => {
|
|
69
|
-
try {
|
|
70
|
-
const { name } = request.params as { name: string };
|
|
71
|
-
const template = getPolicyTemplate(name);
|
|
72
|
-
|
|
73
|
-
if (!template) {
|
|
74
|
-
return reply.status(404).send({
|
|
75
|
-
error: 'Template not found',
|
|
76
|
-
available: listPolicyTemplatesWithKeys().map(t => t.key)
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
return {
|
|
81
|
-
success: true,
|
|
82
|
-
template: {
|
|
83
|
-
name: template.name,
|
|
84
|
-
description: template.description,
|
|
85
|
-
useCase: template.useCase,
|
|
86
|
-
config: template.config
|
|
87
|
-
}
|
|
88
|
-
};
|
|
89
|
-
} catch (error: any) {
|
|
90
|
-
return reply.status(500).send({
|
|
91
|
-
error: 'Failed to get template',
|
|
92
|
-
details: error.message
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
);
|
|
97
|
-
|
|
98
|
-
/**
|
|
99
|
-
* POST /api/sentinel/policies/recommend
|
|
100
|
-
* Get template recommendation based on use case
|
|
101
|
-
*/
|
|
102
|
-
fastify.post(
|
|
103
|
-
'/api/sentinel/policies/recommend',
|
|
104
|
-
{
|
|
105
|
-
preHandler: [requireAuth, writeRateLimit],
|
|
106
|
-
},
|
|
107
|
-
async (request: FastifyRequest, reply: FastifyReply) => {
|
|
108
|
-
try {
|
|
109
|
-
const { useCase } = (request.body || {}) as { useCase?: string };
|
|
110
|
-
|
|
111
|
-
if (!useCase) {
|
|
112
|
-
return reply.status(400).send({
|
|
113
|
-
error: 'useCase is required'
|
|
114
|
-
});
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
const recommendation = recommendTemplate(useCase);
|
|
118
|
-
|
|
119
|
-
if (!recommendation) {
|
|
120
|
-
return reply.status(404).send({
|
|
121
|
-
error: 'No recommendation found'
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
return {
|
|
126
|
-
success: true,
|
|
127
|
-
recommended: {
|
|
128
|
-
name: recommendation.name,
|
|
129
|
-
description: recommendation.description,
|
|
130
|
-
useCase: recommendation.useCase,
|
|
131
|
-
config: recommendation.config,
|
|
132
|
-
reason: `Recommended for use case: ${useCase}`
|
|
133
|
-
}
|
|
134
|
-
};
|
|
135
|
-
} catch (error: any) {
|
|
136
|
-
return reply.status(500).send({
|
|
137
|
-
error: 'Failed to get recommendation',
|
|
138
|
-
details: error.message
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
);
|
|
143
|
-
|
|
144
|
-
/**
|
|
145
|
-
* POST /api/sentinel/policies/apply
|
|
146
|
-
* Apply a policy template to current configuration
|
|
147
|
-
*/
|
|
148
|
-
fastify.post(
|
|
149
|
-
'/api/sentinel/policies/apply',
|
|
150
|
-
{
|
|
151
|
-
preHandler: [requireAuth, writeRateLimit],
|
|
152
|
-
},
|
|
153
|
-
async (request: FastifyRequest, reply: FastifyReply) => {
|
|
154
|
-
try {
|
|
155
|
-
const { template: templateName } = (request.body || {}) as { template?: string };
|
|
156
|
-
|
|
157
|
-
if (!templateName) {
|
|
158
|
-
return reply.status(400).send({
|
|
159
|
-
error: 'template is required'
|
|
160
|
-
});
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
const config = applyPolicyTemplate(templateName);
|
|
164
|
-
|
|
165
|
-
if (!config) {
|
|
166
|
-
return reply.status(404).send({
|
|
167
|
-
error: 'Template not found',
|
|
168
|
-
available: listPolicyTemplatesWithKeys().map(t => t.key)
|
|
169
|
-
});
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
// Apply the template to Sentinel's configuration
|
|
173
|
-
const { Sentinel } = await import('@4runr/sentinel');
|
|
174
|
-
const sentinel = Sentinel.getInstance();
|
|
175
|
-
|
|
176
|
-
try {
|
|
177
|
-
sentinel.updateConfig(config);
|
|
178
|
-
const savedTo = persistSentinelConfigAfterApply(sentinel, config, fastify.log);
|
|
179
|
-
return {
|
|
180
|
-
success: true,
|
|
181
|
-
template: templateName,
|
|
182
|
-
config: config,
|
|
183
|
-
message: `Template '${templateName}' applied. Limits active and saved to ${savedTo}.`,
|
|
184
|
-
};
|
|
185
|
-
} catch (error: any) {
|
|
186
|
-
return reply.status(400).send({
|
|
187
|
-
error: 'Failed to apply template',
|
|
188
|
-
details: error.message
|
|
189
|
-
});
|
|
190
|
-
}
|
|
191
|
-
} catch (error: any) {
|
|
192
|
-
return reply.status(500).send({
|
|
193
|
-
error: 'Failed to apply template',
|
|
194
|
-
details: error.message
|
|
195
|
-
});
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
);
|
|
199
|
-
|
|
200
|
-
/**
|
|
201
|
-
* POST /api/sentinel/policies/custom
|
|
202
|
-
* Apply operator-defined limits (merge with current config for omitted fields).
|
|
203
|
-
*/
|
|
204
|
-
fastify.post(
|
|
205
|
-
'/api/sentinel/policies/custom',
|
|
206
|
-
{
|
|
207
|
-
preHandler: [requireAuth, writeRateLimit],
|
|
208
|
-
},
|
|
209
|
-
async (request: FastifyRequest, reply: FastifyReply) => {
|
|
210
|
-
try {
|
|
211
|
-
const body = (request.body || {}) as Record<string, unknown>;
|
|
212
|
-
const { Sentinel } = await import('@4runr/sentinel');
|
|
213
|
-
const sentinel = Sentinel.getInstance();
|
|
214
|
-
const current = sentinel.getConfig();
|
|
215
|
-
|
|
216
|
-
const num = (key: string, fallback: number): number => {
|
|
217
|
-
const v = body[key];
|
|
218
|
-
if (typeof v === 'number' && Number.isFinite(v)) return v;
|
|
219
|
-
if (typeof v === 'string' && v.trim() !== '') {
|
|
220
|
-
const n = Number(v);
|
|
221
|
-
if (Number.isFinite(n)) return n;
|
|
222
|
-
}
|
|
223
|
-
return fallback;
|
|
224
|
-
};
|
|
225
|
-
|
|
226
|
-
const config = {
|
|
227
|
-
enabled: typeof body['enabled'] === 'boolean' ? body['enabled'] : current.enabled,
|
|
228
|
-
runMaxDurationMs: num('runMaxDurationMs', current.runMaxDurationMs),
|
|
229
|
-
runMaxTokens: num('runMaxTokens', current.runMaxTokens),
|
|
230
|
-
runIdleMs: num('runIdleMs', current.runIdleMs),
|
|
231
|
-
loopWindow: num('loopWindow', current.loopWindow),
|
|
232
|
-
loopMax: num('loopMax', current.loopMax),
|
|
233
|
-
runMaxCost: num('runMaxCost', current.runMaxCost ?? 1.0),
|
|
234
|
-
};
|
|
235
|
-
|
|
236
|
-
try {
|
|
237
|
-
sentinel.updateConfig(config);
|
|
238
|
-
const savedTo = persistSentinelConfigAfterApply(sentinel, config, fastify.log);
|
|
239
|
-
return {
|
|
240
|
-
success: true,
|
|
241
|
-
config,
|
|
242
|
-
message: `Custom limits saved (${savedTo}). Reopen Sentinel or restart Gateway to reload; env vars override fields when set.`,
|
|
243
|
-
};
|
|
244
|
-
} catch (error: unknown) {
|
|
245
|
-
const msg = error instanceof Error ? error.message : String(error);
|
|
246
|
-
return reply.status(400).send({
|
|
247
|
-
error: 'Invalid custom config',
|
|
248
|
-
details: msg,
|
|
249
|
-
});
|
|
250
|
-
}
|
|
251
|
-
} catch (error: unknown) {
|
|
252
|
-
const msg = error instanceof Error ? error.message : String(error);
|
|
253
|
-
return reply.status(500).send({
|
|
254
|
-
error: 'Failed to apply custom config',
|
|
255
|
-
details: msg,
|
|
256
|
-
});
|
|
257
|
-
}
|
|
258
|
-
}
|
|
259
|
-
);
|
|
260
|
-
|
|
261
|
-
/**
|
|
262
|
-
* GET /api/sentinel/policies/current
|
|
263
|
-
* Get current policy configuration
|
|
264
|
-
*/
|
|
265
|
-
fastify.get(
|
|
266
|
-
'/api/sentinel/policies/current',
|
|
267
|
-
{
|
|
268
|
-
preHandler: [requireAuth, readRateLimit],
|
|
269
|
-
},
|
|
270
|
-
async (
|
|
271
|
-
request: FastifyRequest,
|
|
272
|
-
reply: FastifyReply
|
|
273
|
-
) => {
|
|
274
|
-
try {
|
|
275
|
-
const { Sentinel } = await import('@4runr/sentinel');
|
|
276
|
-
const sentinel = Sentinel.getInstance();
|
|
277
|
-
hydrateSentinelConfigFromDisk(sentinel);
|
|
278
|
-
|
|
279
|
-
return {
|
|
280
|
-
success: true,
|
|
281
|
-
config: sentinel.getConfig(),
|
|
282
|
-
persistedPath: getSentinelLimitsFilePath(),
|
|
283
|
-
};
|
|
284
|
-
} catch (error: any) {
|
|
285
|
-
return reply.status(500).send({
|
|
286
|
-
error: 'Failed to get current config',
|
|
287
|
-
details: error.message
|
|
288
|
-
});
|
|
289
|
-
}
|
|
290
|
-
}
|
|
291
|
-
);
|
|
292
|
-
}
|
|
293
|
-
|