@agentlensai/server 0.10.0 → 0.13.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/dist/cloud/auth/api-key-middleware.d.ts +66 -0
- package/dist/cloud/auth/api-key-middleware.d.ts.map +1 -0
- package/dist/cloud/auth/api-key-middleware.js +147 -0
- package/dist/cloud/auth/api-key-middleware.js.map +1 -0
- package/dist/cloud/auth/api-keys.d.ts +90 -0
- package/dist/cloud/auth/api-keys.d.ts.map +1 -0
- package/dist/cloud/auth/api-keys.js +162 -0
- package/dist/cloud/auth/api-keys.js.map +1 -0
- package/dist/cloud/auth/audit-log.d.ts +66 -0
- package/dist/cloud/auth/audit-log.d.ts.map +1 -0
- package/dist/cloud/auth/audit-log.js +92 -0
- package/dist/cloud/auth/audit-log.js.map +1 -0
- package/dist/cloud/auth/auth-service.d.ts +77 -0
- package/dist/cloud/auth/auth-service.d.ts.map +1 -0
- package/dist/cloud/auth/auth-service.js +229 -0
- package/dist/cloud/auth/auth-service.js.map +1 -0
- package/dist/cloud/auth/brute-force.d.ts +36 -0
- package/dist/cloud/auth/brute-force.d.ts.map +1 -0
- package/dist/cloud/auth/brute-force.js +67 -0
- package/dist/cloud/auth/brute-force.js.map +1 -0
- package/dist/cloud/auth/index.d.ts +11 -0
- package/dist/cloud/auth/index.d.ts.map +1 -0
- package/dist/cloud/auth/index.js +11 -0
- package/dist/cloud/auth/index.js.map +1 -0
- package/dist/cloud/auth/jwt.d.ts +34 -0
- package/dist/cloud/auth/jwt.d.ts.map +1 -0
- package/dist/cloud/auth/jwt.js +68 -0
- package/dist/cloud/auth/jwt.js.map +1 -0
- package/dist/cloud/auth/oauth.d.ts +37 -0
- package/dist/cloud/auth/oauth.d.ts.map +1 -0
- package/dist/cloud/auth/oauth.js +120 -0
- package/dist/cloud/auth/oauth.js.map +1 -0
- package/dist/cloud/auth/passwords.d.ts +25 -0
- package/dist/cloud/auth/passwords.d.ts.map +1 -0
- package/dist/cloud/auth/passwords.js +50 -0
- package/dist/cloud/auth/passwords.js.map +1 -0
- package/dist/cloud/auth/rbac.d.ts +51 -0
- package/dist/cloud/auth/rbac.d.ts.map +1 -0
- package/dist/cloud/auth/rbac.js +89 -0
- package/dist/cloud/auth/rbac.js.map +1 -0
- package/dist/cloud/auth/tokens.d.ts +18 -0
- package/dist/cloud/auth/tokens.d.ts.map +1 -0
- package/dist/cloud/auth/tokens.js +29 -0
- package/dist/cloud/auth/tokens.js.map +1 -0
- package/dist/cloud/billing/billing-service.d.ts +44 -0
- package/dist/cloud/billing/billing-service.d.ts.map +1 -0
- package/dist/cloud/billing/billing-service.js +153 -0
- package/dist/cloud/billing/billing-service.js.map +1 -0
- package/dist/cloud/billing/index.d.ts +11 -0
- package/dist/cloud/billing/index.d.ts.map +1 -0
- package/dist/cloud/billing/index.js +11 -0
- package/dist/cloud/billing/index.js.map +1 -0
- package/dist/cloud/billing/invoice-service.d.ts +57 -0
- package/dist/cloud/billing/invoice-service.d.ts.map +1 -0
- package/dist/cloud/billing/invoice-service.js +123 -0
- package/dist/cloud/billing/invoice-service.js.map +1 -0
- package/dist/cloud/billing/plan-management.d.ts +46 -0
- package/dist/cloud/billing/plan-management.d.ts.map +1 -0
- package/dist/cloud/billing/plan-management.js +157 -0
- package/dist/cloud/billing/plan-management.js.map +1 -0
- package/dist/cloud/billing/quota-enforcement.d.ts +53 -0
- package/dist/cloud/billing/quota-enforcement.d.ts.map +1 -0
- package/dist/cloud/billing/quota-enforcement.js +143 -0
- package/dist/cloud/billing/quota-enforcement.js.map +1 -0
- package/dist/cloud/billing/stripe-client.d.ts +142 -0
- package/dist/cloud/billing/stripe-client.d.ts.map +1 -0
- package/dist/cloud/billing/stripe-client.js +174 -0
- package/dist/cloud/billing/stripe-client.js.map +1 -0
- package/dist/cloud/billing/trial-service.d.ts +47 -0
- package/dist/cloud/billing/trial-service.d.ts.map +1 -0
- package/dist/cloud/billing/trial-service.js +104 -0
- package/dist/cloud/billing/trial-service.js.map +1 -0
- package/dist/cloud/billing/usage-metering.d.ts +83 -0
- package/dist/cloud/billing/usage-metering.d.ts.map +1 -0
- package/dist/cloud/billing/usage-metering.js +174 -0
- package/dist/cloud/billing/usage-metering.js.map +1 -0
- package/dist/cloud/ingestion/backpressure.d.ts +107 -0
- package/dist/cloud/ingestion/backpressure.d.ts.map +1 -0
- package/dist/cloud/ingestion/backpressure.js +134 -0
- package/dist/cloud/ingestion/backpressure.js.map +1 -0
- package/dist/cloud/ingestion/batch-writer.d.ts +115 -0
- package/dist/cloud/ingestion/batch-writer.d.ts.map +1 -0
- package/dist/cloud/ingestion/batch-writer.js +319 -0
- package/dist/cloud/ingestion/batch-writer.js.map +1 -0
- package/dist/cloud/ingestion/dlq-manager.d.ts +116 -0
- package/dist/cloud/ingestion/dlq-manager.d.ts.map +1 -0
- package/dist/cloud/ingestion/dlq-manager.js +244 -0
- package/dist/cloud/ingestion/dlq-manager.js.map +1 -0
- package/dist/cloud/ingestion/event-queue.d.ts +105 -0
- package/dist/cloud/ingestion/event-queue.d.ts.map +1 -0
- package/dist/cloud/ingestion/event-queue.js +185 -0
- package/dist/cloud/ingestion/event-queue.js.map +1 -0
- package/dist/cloud/ingestion/gateway.d.ts +68 -0
- package/dist/cloud/ingestion/gateway.d.ts.map +1 -0
- package/dist/cloud/ingestion/gateway.js +197 -0
- package/dist/cloud/ingestion/gateway.js.map +1 -0
- package/dist/cloud/ingestion/index.d.ts +7 -0
- package/dist/cloud/ingestion/index.d.ts.map +1 -0
- package/dist/cloud/ingestion/index.js +7 -0
- package/dist/cloud/ingestion/index.js.map +1 -0
- package/dist/cloud/ingestion/rate-limiter.d.ts +73 -0
- package/dist/cloud/ingestion/rate-limiter.d.ts.map +1 -0
- package/dist/cloud/ingestion/rate-limiter.js +153 -0
- package/dist/cloud/ingestion/rate-limiter.js.map +1 -0
- package/dist/cloud/middleware/validate-org-access.d.ts +14 -0
- package/dist/cloud/middleware/validate-org-access.d.ts.map +1 -0
- package/dist/cloud/middleware/validate-org-access.js +38 -0
- package/dist/cloud/middleware/validate-org-access.js.map +1 -0
- package/dist/cloud/migrate.d.ts +45 -0
- package/dist/cloud/migrate.d.ts.map +1 -0
- package/dist/cloud/migrate.js +147 -0
- package/dist/cloud/migrate.js.map +1 -0
- package/dist/cloud/migration/export-import.d.ts +56 -0
- package/dist/cloud/migration/export-import.d.ts.map +1 -0
- package/dist/cloud/migration/export-import.js +289 -0
- package/dist/cloud/migration/export-import.js.map +1 -0
- package/dist/cloud/migration/index.d.ts +5 -0
- package/dist/cloud/migration/index.d.ts.map +1 -0
- package/dist/cloud/migration/index.js +5 -0
- package/dist/cloud/migration/index.js.map +1 -0
- package/dist/cloud/org-service.d.ts +68 -0
- package/dist/cloud/org-service.d.ts.map +1 -0
- package/dist/cloud/org-service.js +169 -0
- package/dist/cloud/org-service.js.map +1 -0
- package/dist/cloud/partition-maintenance.d.ts +29 -0
- package/dist/cloud/partition-maintenance.d.ts.map +1 -0
- package/dist/cloud/partition-maintenance.js +96 -0
- package/dist/cloud/partition-maintenance.js.map +1 -0
- package/dist/cloud/retention/index.d.ts +7 -0
- package/dist/cloud/retention/index.d.ts.map +1 -0
- package/dist/cloud/retention/index.js +7 -0
- package/dist/cloud/retention/index.js.map +1 -0
- package/dist/cloud/retention/partition-management.d.ts +61 -0
- package/dist/cloud/retention/partition-management.d.ts.map +1 -0
- package/dist/cloud/retention/partition-management.js +167 -0
- package/dist/cloud/retention/partition-management.js.map +1 -0
- package/dist/cloud/retention/retention-job.d.ts +70 -0
- package/dist/cloud/retention/retention-job.d.ts.map +1 -0
- package/dist/cloud/retention/retention-job.js +160 -0
- package/dist/cloud/retention/retention-job.js.map +1 -0
- package/dist/cloud/retention/retention-policy.d.ts +27 -0
- package/dist/cloud/retention/retention-policy.d.ts.map +1 -0
- package/dist/cloud/retention/retention-policy.js +36 -0
- package/dist/cloud/retention/retention-policy.js.map +1 -0
- package/dist/cloud/routes/api-key-routes.d.ts +38 -0
- package/dist/cloud/routes/api-key-routes.d.ts.map +1 -0
- package/dist/cloud/routes/api-key-routes.js +84 -0
- package/dist/cloud/routes/api-key-routes.js.map +1 -0
- package/dist/cloud/routes/audit-routes.d.ts +36 -0
- package/dist/cloud/routes/audit-routes.d.ts.map +1 -0
- package/dist/cloud/routes/audit-routes.js +47 -0
- package/dist/cloud/routes/audit-routes.js.map +1 -0
- package/dist/cloud/routes/billing-routes.d.ts +51 -0
- package/dist/cloud/routes/billing-routes.d.ts.map +1 -0
- package/dist/cloud/routes/billing-routes.js +114 -0
- package/dist/cloud/routes/billing-routes.js.map +1 -0
- package/dist/cloud/routes/index.d.ts +13 -0
- package/dist/cloud/routes/index.d.ts.map +1 -0
- package/dist/cloud/routes/index.js +98 -0
- package/dist/cloud/routes/index.js.map +1 -0
- package/dist/cloud/routes/onboarding-routes.d.ts +34 -0
- package/dist/cloud/routes/onboarding-routes.d.ts.map +1 -0
- package/dist/cloud/routes/onboarding-routes.js +58 -0
- package/dist/cloud/routes/onboarding-routes.js.map +1 -0
- package/dist/cloud/routes/org-routes.d.ts +80 -0
- package/dist/cloud/routes/org-routes.d.ts.map +1 -0
- package/dist/cloud/routes/org-routes.js +153 -0
- package/dist/cloud/routes/org-routes.js.map +1 -0
- package/dist/cloud/routes/usage-routes.d.ts +18 -0
- package/dist/cloud/routes/usage-routes.d.ts.map +1 -0
- package/dist/cloud/routes/usage-routes.js +66 -0
- package/dist/cloud/routes/usage-routes.js.map +1 -0
- package/dist/cloud/storage/adapter.d.ts +102 -0
- package/dist/cloud/storage/adapter.d.ts.map +1 -0
- package/dist/cloud/storage/adapter.js +21 -0
- package/dist/cloud/storage/adapter.js.map +1 -0
- package/dist/cloud/storage/index.d.ts +8 -0
- package/dist/cloud/storage/index.d.ts.map +1 -0
- package/dist/cloud/storage/index.js +7 -0
- package/dist/cloud/storage/index.js.map +1 -0
- package/dist/cloud/storage/postgres-adapter.d.ts +34 -0
- package/dist/cloud/storage/postgres-adapter.d.ts.map +1 -0
- package/dist/cloud/storage/postgres-adapter.js +544 -0
- package/dist/cloud/storage/postgres-adapter.js.map +1 -0
- package/dist/cloud/storage/sqlite-adapter.d.ts +29 -0
- package/dist/cloud/storage/sqlite-adapter.d.ts.map +1 -0
- package/dist/cloud/storage/sqlite-adapter.js +176 -0
- package/dist/cloud/storage/sqlite-adapter.js.map +1 -0
- package/dist/cloud/tenant-pool.d.ts +49 -0
- package/dist/cloud/tenant-pool.d.ts.map +1 -0
- package/dist/cloud/tenant-pool.js +61 -0
- package/dist/cloud/tenant-pool.js.map +1 -0
- package/dist/config.d.ts +33 -1
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +71 -1
- package/dist/config.js.map +1 -1
- package/dist/db/api-key-lookup.d.ts +25 -0
- package/dist/db/api-key-lookup.d.ts.map +1 -0
- package/dist/db/api-key-lookup.js +38 -0
- package/dist/db/api-key-lookup.js.map +1 -0
- package/dist/db/connection.postgres.d.ts +44 -0
- package/dist/db/connection.postgres.d.ts.map +1 -0
- package/dist/db/connection.postgres.js +79 -0
- package/dist/db/connection.postgres.js.map +1 -0
- package/dist/db/cost-budget-store.d.ts +30 -0
- package/dist/db/cost-budget-store.d.ts.map +1 -0
- package/dist/db/cost-budget-store.js +201 -0
- package/dist/db/cost-budget-store.js.map +1 -0
- package/dist/db/drizzle/0000_initial.sql +336 -0
- package/dist/db/drizzle/0001_indexes.sql +20 -0
- package/dist/db/drizzle/0002_pgvector.sql +19 -0
- package/dist/db/drizzle/drizzle/0000_initial.sql +336 -0
- package/dist/db/drizzle/drizzle/0001_indexes.sql +20 -0
- package/dist/db/drizzle/drizzle/0002_pgvector.sql +19 -0
- package/dist/db/drizzle/drizzle/meta/0000_snapshot.json +2593 -0
- package/dist/db/drizzle/drizzle/meta/_journal.json +27 -0
- package/dist/db/drizzle/meta/0000_snapshot.json +2593 -0
- package/dist/db/drizzle/meta/_journal.json +27 -0
- package/dist/db/embedding-store.d.ts +2 -1
- package/dist/db/embedding-store.d.ts.map +1 -1
- package/dist/db/embedding-store.interface.d.ts +19 -0
- package/dist/db/embedding-store.interface.d.ts.map +1 -0
- package/dist/db/embedding-store.interface.js +7 -0
- package/dist/db/embedding-store.interface.js.map +1 -0
- package/dist/db/embedding-store.js +3 -1
- package/dist/db/embedding-store.js.map +1 -1
- package/dist/db/eval-store.d.ts +88 -0
- package/dist/db/eval-store.d.ts.map +1 -0
- package/dist/db/eval-store.js +408 -0
- package/dist/db/eval-store.js.map +1 -0
- package/dist/db/guardrail-store.d.ts +9 -0
- package/dist/db/guardrail-store.d.ts.map +1 -1
- package/dist/db/guardrail-store.js +57 -3
- package/dist/db/guardrail-store.js.map +1 -1
- package/dist/db/index.d.ts +7 -0
- package/dist/db/index.d.ts.map +1 -1
- package/dist/db/index.js +4 -12
- package/dist/db/index.js.map +1 -1
- package/dist/db/migrate.d.ts +5 -22
- package/dist/db/migrate.d.ts.map +1 -1
- package/dist/db/migrate.js +7 -637
- package/dist/db/migrate.js.map +1 -1
- package/dist/db/migrate.postgres.d.ts +16 -0
- package/dist/db/migrate.postgres.d.ts.map +1 -0
- package/dist/db/migrate.postgres.js +23 -0
- package/dist/db/migrate.postgres.js.map +1 -0
- package/dist/db/migrate.sqlite.d.ts +26 -0
- package/dist/db/migrate.sqlite.d.ts.map +1 -0
- package/dist/db/migrate.sqlite.js +920 -0
- package/dist/db/migrate.sqlite.js.map +1 -0
- package/dist/db/postgres-embedding-store.d.ts +23 -0
- package/dist/db/postgres-embedding-store.d.ts.map +1 -0
- package/dist/db/postgres-embedding-store.js +218 -0
- package/dist/db/postgres-embedding-store.js.map +1 -0
- package/dist/db/postgres-store.d.ts +80 -0
- package/dist/db/postgres-store.d.ts.map +1 -0
- package/dist/db/postgres-store.js +910 -0
- package/dist/db/postgres-store.js.map +1 -0
- package/dist/db/prompt-store.d.ts +57 -0
- package/dist/db/prompt-store.d.ts.map +1 -0
- package/dist/db/prompt-store.js +300 -0
- package/dist/db/prompt-store.js.map +1 -0
- package/dist/db/repositories/agent-repository.d.ts +21 -0
- package/dist/db/repositories/agent-repository.d.ts.map +1 -0
- package/dist/db/repositories/agent-repository.js +142 -0
- package/dist/db/repositories/agent-repository.js.map +1 -0
- package/dist/db/repositories/alert-repository.d.ts +27 -0
- package/dist/db/repositories/alert-repository.d.ts.map +1 -0
- package/dist/db/repositories/alert-repository.js +164 -0
- package/dist/db/repositories/alert-repository.js.map +1 -0
- package/dist/db/repositories/analytics-repository.d.ts +24 -0
- package/dist/db/repositories/analytics-repository.d.ts.map +1 -0
- package/dist/db/repositories/analytics-repository.js +147 -0
- package/dist/db/repositories/analytics-repository.js.map +1 -0
- package/dist/db/repositories/event-repository.d.ts +81 -0
- package/dist/db/repositories/event-repository.d.ts.map +1 -0
- package/dist/db/repositories/event-repository.js +331 -0
- package/dist/db/repositories/event-repository.js.map +1 -0
- package/dist/db/repositories/notification-channel-repository.d.ts +28 -0
- package/dist/db/repositories/notification-channel-repository.d.ts.map +1 -0
- package/dist/db/repositories/notification-channel-repository.js +151 -0
- package/dist/db/repositories/notification-channel-repository.js.map +1 -0
- package/dist/db/repositories/session-repository.d.ts +26 -0
- package/dist/db/repositories/session-repository.d.ts.map +1 -0
- package/dist/db/repositories/session-repository.js +240 -0
- package/dist/db/repositories/session-repository.js.map +1 -0
- package/dist/db/schema.postgres.d.ts +4681 -0
- package/dist/db/schema.postgres.d.ts.map +1 -0
- package/dist/db/schema.postgres.js +458 -0
- package/dist/db/schema.postgres.js.map +1 -0
- package/dist/db/schema.sqlite.d.ts +2221 -671
- package/dist/db/schema.sqlite.d.ts.map +1 -1
- package/dist/db/schema.sqlite.js +137 -2
- package/dist/db/schema.sqlite.js.map +1 -1
- package/dist/db/services/retention-service.d.ts +13 -0
- package/dist/db/services/retention-service.d.ts.map +1 -0
- package/dist/db/services/retention-service.js +48 -0
- package/dist/db/services/retention-service.js.map +1 -0
- package/dist/db/shared/query-helpers.d.ts +32 -0
- package/dist/db/shared/query-helpers.d.ts.map +1 -0
- package/dist/db/shared/query-helpers.js +180 -0
- package/dist/db/shared/query-helpers.js.map +1 -0
- package/dist/db/sqlite-store.d.ts +48 -55
- package/dist/db/sqlite-store.d.ts.map +1 -1
- package/dist/db/sqlite-store.js +78 -945
- package/dist/db/sqlite-store.js.map +1 -1
- package/dist/db/tenant-scoped-store.d.ts +18 -1
- package/dist/db/tenant-scoped-store.d.ts.map +1 -1
- package/dist/db/tenant-scoped-store.js +6 -0
- package/dist/db/tenant-scoped-store.js.map +1 -1
- package/dist/index.d.ts +28 -14
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +432 -97
- package/dist/index.js.map +1 -1
- package/dist/lib/alert-engine.d.ts +10 -0
- package/dist/lib/alert-engine.d.ts.map +1 -1
- package/dist/lib/alert-engine.js +73 -20
- package/dist/lib/alert-engine.js.map +1 -1
- package/dist/lib/audit-verify.d.ts +40 -0
- package/dist/lib/audit-verify.d.ts.map +1 -0
- package/dist/lib/audit-verify.js +128 -0
- package/dist/lib/audit-verify.js.map +1 -0
- package/dist/lib/audit.d.ts +37 -0
- package/dist/lib/audit.d.ts.map +1 -0
- package/dist/lib/audit.js +59 -0
- package/dist/lib/audit.js.map +1 -0
- package/dist/lib/budget-engine.d.ts +26 -0
- package/dist/lib/budget-engine.d.ts.map +1 -0
- package/dist/lib/budget-engine.js +201 -0
- package/dist/lib/budget-engine.js.map +1 -0
- package/dist/lib/compliance-export.d.ts +41 -0
- package/dist/lib/compliance-export.d.ts.map +1 -0
- package/dist/lib/compliance-export.js +124 -0
- package/dist/lib/compliance-export.js.map +1 -0
- package/dist/lib/compliance-report.d.ts +87 -0
- package/dist/lib/compliance-report.d.ts.map +1 -0
- package/dist/lib/compliance-report.js +148 -0
- package/dist/lib/compliance-report.js.map +1 -0
- package/dist/lib/context/retrieval.d.ts +5 -3
- package/dist/lib/context/retrieval.d.ts.map +1 -1
- package/dist/lib/context/retrieval.js +5 -2
- package/dist/lib/context/retrieval.js.map +1 -1
- package/dist/lib/cost-anomaly-detector.d.ts +23 -0
- package/dist/lib/cost-anomaly-detector.d.ts.map +1 -0
- package/dist/lib/cost-anomaly-detector.js +108 -0
- package/dist/lib/cost-anomaly-detector.js.map +1 -0
- package/dist/lib/db-resilience.d.ts +15 -0
- package/dist/lib/db-resilience.d.ts.map +1 -0
- package/dist/lib/db-resilience.js +49 -0
- package/dist/lib/db-resilience.js.map +1 -0
- package/dist/lib/diagnostics/cache.d.ts +29 -0
- package/dist/lib/diagnostics/cache.d.ts.map +1 -0
- package/dist/lib/diagnostics/cache.js +88 -0
- package/dist/lib/diagnostics/cache.js.map +1 -0
- package/dist/lib/diagnostics/context-builder.d.ts +41 -0
- package/dist/lib/diagnostics/context-builder.d.ts.map +1 -0
- package/dist/lib/diagnostics/context-builder.js +135 -0
- package/dist/lib/diagnostics/context-builder.js.map +1 -0
- package/dist/lib/diagnostics/index.d.ts +34 -0
- package/dist/lib/diagnostics/index.d.ts.map +1 -0
- package/dist/lib/diagnostics/index.js +223 -0
- package/dist/lib/diagnostics/index.js.map +1 -0
- package/dist/lib/diagnostics/llm-client.d.ts +24 -0
- package/dist/lib/diagnostics/llm-client.d.ts.map +1 -0
- package/dist/lib/diagnostics/llm-client.js +42 -0
- package/dist/lib/diagnostics/llm-client.js.map +1 -0
- package/dist/lib/diagnostics/prompt-templates.d.ts +18 -0
- package/dist/lib/diagnostics/prompt-templates.d.ts.map +1 -0
- package/dist/lib/diagnostics/prompt-templates.js +144 -0
- package/dist/lib/diagnostics/prompt-templates.js.map +1 -0
- package/dist/lib/diagnostics/providers/anthropic.d.ts +8 -0
- package/dist/lib/diagnostics/providers/anthropic.d.ts.map +1 -0
- package/dist/lib/diagnostics/providers/anthropic.js +79 -0
- package/dist/lib/diagnostics/providers/anthropic.js.map +1 -0
- package/dist/lib/diagnostics/providers/openai.d.ts +8 -0
- package/dist/lib/diagnostics/providers/openai.d.ts.map +1 -0
- package/dist/lib/diagnostics/providers/openai.js +70 -0
- package/dist/lib/diagnostics/providers/openai.js.map +1 -0
- package/dist/lib/diagnostics/providers/types.d.ts +23 -0
- package/dist/lib/diagnostics/providers/types.d.ts.map +1 -0
- package/dist/lib/diagnostics/providers/types.js +5 -0
- package/dist/lib/diagnostics/providers/types.js.map +1 -0
- package/dist/lib/diagnostics/response-parser.d.ts +60 -0
- package/dist/lib/diagnostics/response-parser.d.ts.map +1 -0
- package/dist/lib/diagnostics/response-parser.js +55 -0
- package/dist/lib/diagnostics/response-parser.js.map +1 -0
- package/dist/lib/diagnostics/types.d.ts +60 -0
- package/dist/lib/diagnostics/types.d.ts.map +1 -0
- package/dist/lib/diagnostics/types.js +7 -0
- package/dist/lib/diagnostics/types.js.map +1 -0
- package/dist/lib/embeddings/index.d.ts +6 -3
- package/dist/lib/embeddings/index.d.ts.map +1 -1
- package/dist/lib/embeddings/index.js +7 -15
- package/dist/lib/embeddings/index.js.map +1 -1
- package/dist/lib/embeddings/worker.d.ts +2 -2
- package/dist/lib/embeddings/worker.d.ts.map +1 -1
- package/dist/lib/embeddings/worker.js +3 -1
- package/dist/lib/embeddings/worker.js.map +1 -1
- package/dist/lib/error-sanitizer.d.ts +28 -0
- package/dist/lib/error-sanitizer.d.ts.map +1 -0
- package/dist/lib/error-sanitizer.js +106 -0
- package/dist/lib/error-sanitizer.js.map +1 -0
- package/dist/lib/eval/index.d.ts +15 -0
- package/dist/lib/eval/index.d.ts.map +1 -0
- package/dist/lib/eval/index.js +24 -0
- package/dist/lib/eval/index.js.map +1 -0
- package/dist/lib/eval/runner.d.ts +28 -0
- package/dist/lib/eval/runner.d.ts.map +1 -0
- package/dist/lib/eval/runner.js +260 -0
- package/dist/lib/eval/runner.js.map +1 -0
- package/dist/lib/eval/scorers/contains.d.ts +10 -0
- package/dist/lib/eval/scorers/contains.d.ts.map +1 -0
- package/dist/lib/eval/scorers/contains.js +33 -0
- package/dist/lib/eval/scorers/contains.js.map +1 -0
- package/dist/lib/eval/scorers/exact-match.d.ts +10 -0
- package/dist/lib/eval/scorers/exact-match.d.ts.map +1 -0
- package/dist/lib/eval/scorers/exact-match.js +33 -0
- package/dist/lib/eval/scorers/exact-match.js.map +1 -0
- package/dist/lib/eval/scorers/index.d.ts +20 -0
- package/dist/lib/eval/scorers/index.d.ts.map +1 -0
- package/dist/lib/eval/scorers/index.js +19 -0
- package/dist/lib/eval/scorers/index.js.map +1 -0
- package/dist/lib/eval/scorers/llm-judge.d.ts +22 -0
- package/dist/lib/eval/scorers/llm-judge.d.ts.map +1 -0
- package/dist/lib/eval/scorers/llm-judge.js +79 -0
- package/dist/lib/eval/scorers/llm-judge.js.map +1 -0
- package/dist/lib/eval/scorers/regex.d.ts +10 -0
- package/dist/lib/eval/scorers/regex.d.ts.map +1 -0
- package/dist/lib/eval/scorers/regex.js +36 -0
- package/dist/lib/eval/scorers/regex.js.map +1 -0
- package/dist/lib/guardrails/actions.d.ts +6 -0
- package/dist/lib/guardrails/actions.d.ts.map +1 -1
- package/dist/lib/guardrails/actions.js +82 -0
- package/dist/lib/guardrails/actions.js.map +1 -1
- package/dist/lib/guardrails/conditions.d.ts +47 -0
- package/dist/lib/guardrails/conditions.d.ts.map +1 -1
- package/dist/lib/guardrails/conditions.js +55 -10
- package/dist/lib/guardrails/conditions.js.map +1 -1
- package/dist/lib/guardrails/content-engine.d.ts +19 -0
- package/dist/lib/guardrails/content-engine.d.ts.map +1 -0
- package/dist/lib/guardrails/content-engine.js +154 -0
- package/dist/lib/guardrails/content-engine.js.map +1 -0
- package/dist/lib/guardrails/engine.d.ts +33 -0
- package/dist/lib/guardrails/engine.d.ts.map +1 -1
- package/dist/lib/guardrails/engine.js +37 -2
- package/dist/lib/guardrails/engine.js.map +1 -1
- package/dist/lib/guardrails/scanners/base-scanner.d.ts +23 -0
- package/dist/lib/guardrails/scanners/base-scanner.d.ts.map +1 -0
- package/dist/lib/guardrails/scanners/base-scanner.js +7 -0
- package/dist/lib/guardrails/scanners/base-scanner.js.map +1 -0
- package/dist/lib/guardrails/scanners/patterns/pii-patterns.d.ts +13 -0
- package/dist/lib/guardrails/scanners/patterns/pii-patterns.d.ts.map +1 -0
- package/dist/lib/guardrails/scanners/patterns/pii-patterns.js +49 -0
- package/dist/lib/guardrails/scanners/patterns/pii-patterns.js.map +1 -0
- package/dist/lib/guardrails/scanners/patterns/secret-patterns.d.ts +6 -0
- package/dist/lib/guardrails/scanners/patterns/secret-patterns.d.ts.map +1 -0
- package/dist/lib/guardrails/scanners/patterns/secret-patterns.js +69 -0
- package/dist/lib/guardrails/scanners/patterns/secret-patterns.js.map +1 -0
- package/dist/lib/guardrails/scanners/pii-scanner.d.ts +10 -0
- package/dist/lib/guardrails/scanners/pii-scanner.d.ts.map +1 -0
- package/dist/lib/guardrails/scanners/pii-scanner.js +57 -0
- package/dist/lib/guardrails/scanners/pii-scanner.js.map +1 -0
- package/dist/lib/guardrails/scanners/scanner-registry.d.ts +14 -0
- package/dist/lib/guardrails/scanners/scanner-registry.d.ts.map +1 -0
- package/dist/lib/guardrails/scanners/scanner-registry.js +51 -0
- package/dist/lib/guardrails/scanners/scanner-registry.js.map +1 -0
- package/dist/lib/guardrails/scanners/secrets-scanner.d.ts +9 -0
- package/dist/lib/guardrails/scanners/secrets-scanner.d.ts.map +1 -0
- package/dist/lib/guardrails/scanners/secrets-scanner.js +47 -0
- package/dist/lib/guardrails/scanners/secrets-scanner.js.map +1 -0
- package/dist/lib/logger.d.ts +8 -0
- package/dist/lib/logger.d.ts.map +1 -0
- package/dist/lib/logger.js +31 -0
- package/dist/lib/logger.js.map +1 -0
- package/dist/lib/lore-client.d.ts +128 -0
- package/dist/lib/lore-client.d.ts.map +1 -0
- package/dist/lib/lore-client.js +188 -0
- package/dist/lib/lore-client.js.map +1 -0
- package/dist/lib/mesh-client.d.ts +31 -0
- package/dist/lib/mesh-client.d.ts.map +1 -0
- package/dist/lib/mesh-client.js +72 -0
- package/dist/lib/mesh-client.js.map +1 -0
- package/dist/lib/notifications/grouping-buffer.d.ts +25 -0
- package/dist/lib/notifications/grouping-buffer.d.ts.map +1 -0
- package/dist/lib/notifications/grouping-buffer.js +73 -0
- package/dist/lib/notifications/grouping-buffer.js.map +1 -0
- package/dist/lib/notifications/provider.d.ts +10 -0
- package/dist/lib/notifications/provider.d.ts.map +1 -0
- package/dist/lib/notifications/provider.js +5 -0
- package/dist/lib/notifications/provider.js.map +1 -0
- package/dist/lib/notifications/providers/email.d.ts +14 -0
- package/dist/lib/notifications/providers/email.d.ts.map +1 -0
- package/dist/lib/notifications/providers/email.js +88 -0
- package/dist/lib/notifications/providers/email.js.map +1 -0
- package/dist/lib/notifications/providers/pagerduty.d.ts +16 -0
- package/dist/lib/notifications/providers/pagerduty.d.ts.map +1 -0
- package/dist/lib/notifications/providers/pagerduty.js +94 -0
- package/dist/lib/notifications/providers/pagerduty.js.map +1 -0
- package/dist/lib/notifications/providers/slack.d.ts +14 -0
- package/dist/lib/notifications/providers/slack.d.ts.map +1 -0
- package/dist/lib/notifications/providers/slack.js +106 -0
- package/dist/lib/notifications/providers/slack.js.map +1 -0
- package/dist/lib/notifications/providers/webhook.d.ts +16 -0
- package/dist/lib/notifications/providers/webhook.d.ts.map +1 -0
- package/dist/lib/notifications/providers/webhook.js +78 -0
- package/dist/lib/notifications/providers/webhook.js.map +1 -0
- package/dist/lib/notifications/router.d.ts +30 -0
- package/dist/lib/notifications/router.d.ts.map +1 -0
- package/dist/lib/notifications/router.js +137 -0
- package/dist/lib/notifications/router.js.map +1 -0
- package/dist/lib/notifications/ssrf.d.ts +13 -0
- package/dist/lib/notifications/ssrf.d.ts.map +1 -0
- package/dist/lib/notifications/ssrf.js +37 -0
- package/dist/lib/notifications/ssrf.js.map +1 -0
- package/dist/lib/optimization/analyzers/model-downgrade.d.ts +15 -0
- package/dist/lib/optimization/analyzers/model-downgrade.d.ts.map +1 -0
- package/dist/lib/optimization/analyzers/model-downgrade.js +58 -0
- package/dist/lib/optimization/analyzers/model-downgrade.js.map +1 -0
- package/dist/lib/optimization/analyzers/prompt-optimization.d.ts +17 -0
- package/dist/lib/optimization/analyzers/prompt-optimization.d.ts.map +1 -0
- package/dist/lib/optimization/analyzers/prompt-optimization.js +160 -0
- package/dist/lib/optimization/analyzers/prompt-optimization.js.map +1 -0
- package/dist/lib/optimization/analyzers/types.d.ts +23 -0
- package/dist/lib/optimization/analyzers/types.d.ts.map +1 -0
- package/dist/lib/optimization/analyzers/types.js +5 -0
- package/dist/lib/optimization/analyzers/types.js.map +1 -0
- package/dist/lib/optimization/classifier.d.ts +4 -3
- package/dist/lib/optimization/classifier.d.ts.map +1 -1
- package/dist/lib/optimization/classifier.js +15 -9
- package/dist/lib/optimization/classifier.js.map +1 -1
- package/dist/lib/optimization/cost-optimizer.d.ts +21 -0
- package/dist/lib/optimization/cost-optimizer.d.ts.map +1 -0
- package/dist/lib/optimization/cost-optimizer.js +114 -0
- package/dist/lib/optimization/cost-optimizer.js.map +1 -0
- package/dist/lib/optimization/engine.d.ts.map +1 -1
- package/dist/lib/optimization/engine.js +45 -6
- package/dist/lib/optimization/engine.js.map +1 -1
- package/dist/lib/optimization/forecast.d.ts +39 -0
- package/dist/lib/optimization/forecast.d.ts.map +1 -0
- package/dist/lib/optimization/forecast.js +128 -0
- package/dist/lib/optimization/forecast.js.map +1 -0
- package/dist/lib/secrets.d.ts +30 -0
- package/dist/lib/secrets.d.ts.map +1 -0
- package/dist/lib/secrets.js +103 -0
- package/dist/lib/secrets.js.map +1 -0
- package/dist/lib/threshold-monitor.d.ts +53 -0
- package/dist/lib/threshold-monitor.d.ts.map +1 -0
- package/dist/lib/threshold-monitor.js +112 -0
- package/dist/lib/threshold-monitor.js.map +1 -0
- package/dist/middleware/audit.d.ts +16 -0
- package/dist/middleware/audit.d.ts.map +1 -0
- package/dist/middleware/audit.js +16 -0
- package/dist/middleware/audit.js.map +1 -0
- package/dist/middleware/auth-errors.d.ts +67 -0
- package/dist/middleware/auth-errors.d.ts.map +1 -0
- package/dist/middleware/auth-errors.js +84 -0
- package/dist/middleware/auth-errors.js.map +1 -0
- package/dist/middleware/auth.d.ts +5 -2
- package/dist/middleware/auth.d.ts.map +1 -1
- package/dist/middleware/auth.js +44 -17
- package/dist/middleware/auth.js.map +1 -1
- package/dist/middleware/body-limit.d.ts +9 -0
- package/dist/middleware/body-limit.d.ts.map +1 -0
- package/dist/middleware/body-limit.js +15 -0
- package/dist/middleware/body-limit.js.map +1 -0
- package/dist/middleware/cors-config.d.ts +30 -0
- package/dist/middleware/cors-config.d.ts.map +1 -0
- package/dist/middleware/cors-config.js +55 -0
- package/dist/middleware/cors-config.js.map +1 -0
- package/dist/middleware/rate-limit.d.ts +9 -0
- package/dist/middleware/rate-limit.d.ts.map +1 -0
- package/dist/middleware/rate-limit.js +56 -0
- package/dist/middleware/rate-limit.js.map +1 -0
- package/dist/middleware/rbac.d.ts +30 -0
- package/dist/middleware/rbac.d.ts.map +1 -0
- package/dist/middleware/rbac.js +87 -0
- package/dist/middleware/rbac.js.map +1 -0
- package/dist/middleware/security-headers.d.ts +12 -0
- package/dist/middleware/security-headers.d.ts.map +1 -0
- package/dist/middleware/security-headers.js +57 -0
- package/dist/middleware/security-headers.js.map +1 -0
- package/dist/middleware/unified-auth.d.ts +49 -0
- package/dist/middleware/unified-auth.d.ts.map +1 -0
- package/dist/middleware/unified-auth.js +246 -0
- package/dist/middleware/unified-auth.js.map +1 -0
- package/dist/middleware/validation.d.ts +31 -0
- package/dist/middleware/validation.d.ts.map +1 -0
- package/dist/middleware/validation.js +45 -0
- package/dist/middleware/validation.js.map +1 -0
- package/dist/routes/alerts.d.ts.map +1 -1
- package/dist/routes/alerts.js +4 -3
- package/dist/routes/alerts.js.map +1 -1
- package/dist/routes/analytics.d.ts +2 -1
- package/dist/routes/analytics.d.ts.map +1 -1
- package/dist/routes/analytics.js +175 -95
- package/dist/routes/analytics.js.map +1 -1
- package/dist/routes/api-keys.d.ts +5 -0
- package/dist/routes/api-keys.d.ts.map +1 -1
- package/dist/routes/api-keys.js +89 -8
- package/dist/routes/api-keys.js.map +1 -1
- package/dist/routes/audit-verify.d.ts +12 -0
- package/dist/routes/audit-verify.d.ts.map +1 -0
- package/dist/routes/audit-verify.js +73 -0
- package/dist/routes/audit-verify.js.map +1 -0
- package/dist/routes/audit.d.ts +4 -6
- package/dist/routes/audit.d.ts.map +1 -1
- package/dist/routes/audit.js +54 -157
- package/dist/routes/audit.js.map +1 -1
- package/dist/routes/auth.d.ts +21 -0
- package/dist/routes/auth.d.ts.map +1 -0
- package/dist/routes/auth.js +235 -0
- package/dist/routes/auth.js.map +1 -0
- package/dist/routes/benchmarks.d.ts.map +1 -1
- package/dist/routes/benchmarks.js +63 -11
- package/dist/routes/benchmarks.js.map +1 -1
- package/dist/routes/capabilities-top.d.ts.map +1 -1
- package/dist/routes/capabilities-top.js +1 -4
- package/dist/routes/capabilities-top.js.map +1 -1
- package/dist/routes/capabilities.d.ts.map +1 -1
- package/dist/routes/capabilities.js +1 -7
- package/dist/routes/capabilities.js.map +1 -1
- package/dist/routes/compliance.d.ts +17 -0
- package/dist/routes/compliance.d.ts.map +1 -0
- package/dist/routes/compliance.js +151 -0
- package/dist/routes/compliance.js.map +1 -0
- package/dist/routes/config.d.ts +1 -13
- package/dist/routes/config.d.ts.map +1 -1
- package/dist/routes/context.d.ts.map +1 -1
- package/dist/routes/context.js +6 -5
- package/dist/routes/context.js.map +1 -1
- package/dist/routes/cost-budgets.d.ts +20 -0
- package/dist/routes/cost-budgets.d.ts.map +1 -0
- package/dist/routes/cost-budgets.js +194 -0
- package/dist/routes/cost-budgets.js.map +1 -0
- package/dist/routes/delegation.d.ts.map +1 -1
- package/dist/routes/delegation.js +67 -41
- package/dist/routes/delegation.js.map +1 -1
- package/dist/routes/delegations-top.d.ts.map +1 -1
- package/dist/routes/delegations-top.js +1 -3
- package/dist/routes/delegations-top.js.map +1 -1
- package/dist/routes/diagnose.d.ts +16 -0
- package/dist/routes/diagnose.d.ts.map +1 -0
- package/dist/routes/diagnose.js +82 -0
- package/dist/routes/diagnose.js.map +1 -0
- package/dist/routes/discovery.d.ts.map +1 -1
- package/dist/routes/discovery.js +50 -38
- package/dist/routes/discovery.js.map +1 -1
- package/dist/routes/eval.d.ts +24 -0
- package/dist/routes/eval.d.ts.map +1 -0
- package/dist/routes/eval.js +281 -0
- package/dist/routes/eval.js.map +1 -0
- package/dist/routes/events.d.ts.map +1 -1
- package/dist/routes/events.js +11 -6
- package/dist/routes/events.js.map +1 -1
- package/dist/routes/guardrails.d.ts +2 -1
- package/dist/routes/guardrails.d.ts.map +1 -1
- package/dist/routes/guardrails.js +85 -14
- package/dist/routes/guardrails.js.map +1 -1
- package/dist/routes/health.d.ts +14 -11
- package/dist/routes/health.d.ts.map +1 -1
- package/dist/routes/health.js +181 -61
- package/dist/routes/health.js.map +1 -1
- package/dist/routes/lore-proxy.d.ts +13 -0
- package/dist/routes/lore-proxy.d.ts.map +1 -0
- package/dist/routes/lore-proxy.js +229 -0
- package/dist/routes/lore-proxy.js.map +1 -0
- package/dist/routes/mesh-proxy.d.ts +7 -0
- package/dist/routes/mesh-proxy.d.ts.map +1 -0
- package/dist/routes/mesh-proxy.js +94 -0
- package/dist/routes/mesh-proxy.js.map +1 -0
- package/dist/routes/notifications.d.ts +19 -0
- package/dist/routes/notifications.d.ts.map +1 -0
- package/dist/routes/notifications.js +129 -0
- package/dist/routes/notifications.js.map +1 -0
- package/dist/routes/optimize.d.ts.map +1 -1
- package/dist/routes/optimize.js +44 -0
- package/dist/routes/optimize.js.map +1 -1
- package/dist/routes/otlp.d.ts +17 -0
- package/dist/routes/otlp.d.ts.map +1 -0
- package/dist/routes/otlp.js +544 -0
- package/dist/routes/otlp.js.map +1 -0
- package/dist/routes/prompts.d.ts +21 -0
- package/dist/routes/prompts.d.ts.map +1 -0
- package/dist/routes/prompts.js +173 -0
- package/dist/routes/prompts.js.map +1 -0
- package/dist/routes/recall.d.ts.map +1 -1
- package/dist/routes/recall.js +6 -4
- package/dist/routes/recall.js.map +1 -1
- package/dist/routes/replay.d.ts.map +1 -1
- package/dist/routes/replay.js +2 -1
- package/dist/routes/replay.js.map +1 -1
- package/dist/routes/server-info.d.ts +9 -0
- package/dist/routes/server-info.d.ts.map +1 -0
- package/dist/routes/server-info.js +18 -0
- package/dist/routes/server-info.js.map +1 -0
- package/dist/routes/sessions.d.ts +7 -7
- package/dist/routes/sessions.d.ts.map +1 -1
- package/dist/routes/sessions.js +112 -35
- package/dist/routes/sessions.js.map +1 -1
- package/dist/routes/stats.d.ts.map +1 -1
- package/dist/routes/stats.js +40 -0
- package/dist/routes/stats.js.map +1 -1
- package/dist/routes/stream.d.ts +2 -2
- package/dist/routes/stream.d.ts.map +1 -1
- package/dist/routes/stream.js +7 -11
- package/dist/routes/stream.js.map +1 -1
- package/dist/routes/tenant-helper.d.ts +15 -10
- package/dist/routes/tenant-helper.d.ts.map +1 -1
- package/dist/routes/tenant-helper.js +36 -22
- package/dist/routes/tenant-helper.js.map +1 -1
- package/dist/routes/trust.d.ts.map +1 -1
- package/dist/routes/trust.js +1 -3
- package/dist/routes/trust.js.map +1 -1
- package/dist/schemas/api-keys.d.ts +11 -0
- package/dist/schemas/api-keys.d.ts.map +1 -0
- package/dist/schemas/api-keys.js +10 -0
- package/dist/schemas/api-keys.js.map +1 -0
- package/dist/schemas/common.d.ts +34 -0
- package/dist/schemas/common.d.ts.map +1 -0
- package/dist/schemas/common.js +43 -0
- package/dist/schemas/common.js.map +1 -0
- package/dist/schemas/delegation.d.ts +23 -0
- package/dist/schemas/delegation.d.ts.map +1 -0
- package/dist/schemas/delegation.js +22 -0
- package/dist/schemas/delegation.js.map +1 -0
- package/dist/schemas/discovery.d.ts +17 -0
- package/dist/schemas/discovery.d.ts.map +1 -0
- package/dist/schemas/discovery.js +15 -0
- package/dist/schemas/discovery.js.map +1 -0
- package/dist/schemas/health.d.ts +75 -0
- package/dist/schemas/health.d.ts.map +1 -0
- package/dist/schemas/health.js +55 -0
- package/dist/schemas/health.js.map +1 -0
- package/dist/schemas/index.d.ts +6 -0
- package/dist/schemas/index.d.ts.map +1 -0
- package/dist/schemas/index.js +6 -0
- package/dist/schemas/index.js.map +1 -0
- package/dist/schemas/sessions.d.ts +67 -0
- package/dist/schemas/sessions.d.ts.map +1 -0
- package/dist/schemas/sessions.js +58 -0
- package/dist/schemas/sessions.js.map +1 -0
- package/dist/services/delegation-service.d.ts +1 -4
- package/dist/services/delegation-service.d.ts.map +1 -1
- package/dist/services/delegation-service.js +5 -31
- package/dist/services/delegation-service.js.map +1 -1
- package/package.json +29 -19
- package/dist/db/lesson-store.d.ts +0 -57
- package/dist/db/lesson-store.d.ts.map +0 -1
- package/dist/db/lesson-store.js +0 -217
- package/dist/db/lesson-store.js.map +0 -1
- package/dist/lib/embeddings/local.d.ts +0 -15
- package/dist/lib/embeddings/local.d.ts.map +0 -1
- package/dist/lib/embeddings/local.js +0 -65
- package/dist/lib/embeddings/local.js.map +0 -1
- package/dist/lib/redaction/human-review-layer.d.ts +0 -37
- package/dist/lib/redaction/human-review-layer.d.ts.map +0 -1
- package/dist/lib/redaction/human-review-layer.js +0 -62
- package/dist/lib/redaction/human-review-layer.js.map +0 -1
- package/dist/lib/redaction/index.d.ts +0 -12
- package/dist/lib/redaction/index.d.ts.map +0 -1
- package/dist/lib/redaction/index.js +0 -12
- package/dist/lib/redaction/index.js.map +0 -1
- package/dist/lib/redaction/pii-detection-layer.d.ts +0 -30
- package/dist/lib/redaction/pii-detection-layer.d.ts.map +0 -1
- package/dist/lib/redaction/pii-detection-layer.js +0 -183
- package/dist/lib/redaction/pii-detection-layer.js.map +0 -1
- package/dist/lib/redaction/pipeline.d.ts +0 -26
- package/dist/lib/redaction/pipeline.d.ts.map +0 -1
- package/dist/lib/redaction/pipeline.js +0 -91
- package/dist/lib/redaction/pipeline.js.map +0 -1
- package/dist/lib/redaction/secret-detection-layer.d.ts +0 -10
- package/dist/lib/redaction/secret-detection-layer.d.ts.map +0 -1
- package/dist/lib/redaction/secret-detection-layer.js +0 -79
- package/dist/lib/redaction/secret-detection-layer.js.map +0 -1
- package/dist/lib/redaction/secret-patterns.d.ts +0 -29
- package/dist/lib/redaction/secret-patterns.d.ts.map +0 -1
- package/dist/lib/redaction/secret-patterns.js +0 -133
- package/dist/lib/redaction/secret-patterns.js.map +0 -1
- package/dist/lib/redaction/semantic-denylist-layer.d.ts +0 -10
- package/dist/lib/redaction/semantic-denylist-layer.d.ts.map +0 -1
- package/dist/lib/redaction/semantic-denylist-layer.js +0 -64
- package/dist/lib/redaction/semantic-denylist-layer.js.map +0 -1
- package/dist/lib/redaction/tenant-deidentification-layer.d.ts +0 -10
- package/dist/lib/redaction/tenant-deidentification-layer.d.ts.map +0 -1
- package/dist/lib/redaction/tenant-deidentification-layer.js +0 -64
- package/dist/lib/redaction/tenant-deidentification-layer.js.map +0 -1
- package/dist/lib/redaction/url-path-scrubbing-layer.d.ts +0 -14
- package/dist/lib/redaction/url-path-scrubbing-layer.d.ts.map +0 -1
- package/dist/lib/redaction/url-path-scrubbing-layer.js +0 -156
- package/dist/lib/redaction/url-path-scrubbing-layer.js.map +0 -1
- package/dist/routes/community.d.ts +0 -24
- package/dist/routes/community.d.ts.map +0 -1
- package/dist/routes/community.js +0 -272
- package/dist/routes/community.js.map +0 -1
- package/dist/routes/lessons.d.ts +0 -19
- package/dist/routes/lessons.d.ts.map +0 -1
- package/dist/routes/lessons.js +0 -164
- package/dist/routes/lessons.js.map +0 -1
- package/dist/routes/redaction-test.d.ts +0 -14
- package/dist/routes/redaction-test.d.ts.map +0 -1
- package/dist/routes/redaction-test.js +0 -33
- package/dist/routes/redaction-test.js.map +0 -1
- package/dist/services/community-service.d.ts +0 -283
- package/dist/services/community-service.d.ts.map +0 -1
- package/dist/services/community-service.js +0 -816
- package/dist/services/community-service.js.map +0 -1
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Free Trial Service (S-6.6)
|
|
3
|
+
*
|
|
4
|
+
* - New signups get 14-day Pro trial, no credit card required
|
|
5
|
+
* - After trial → auto-downgrade to Free
|
|
6
|
+
* - Trial status visible in dashboard
|
|
7
|
+
* - Upgrade during trial converts to paid immediately
|
|
8
|
+
*/
|
|
9
|
+
import { TIER_CONFIG } from './stripe-client.js';
|
|
10
|
+
export const TRIAL_DURATION_DAYS = 14;
|
|
11
|
+
export class TrialService {
|
|
12
|
+
deps;
|
|
13
|
+
constructor(deps) {
|
|
14
|
+
this.deps = deps;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Start a free trial for a new org. Sets plan to 'pro' with trial metadata.
|
|
18
|
+
* No credit card required.
|
|
19
|
+
*/
|
|
20
|
+
async startTrial(orgId) {
|
|
21
|
+
const now = new Date();
|
|
22
|
+
const trialEnd = new Date(now.getTime() + TRIAL_DURATION_DAYS * 86400 * 1000);
|
|
23
|
+
await this.deps.db.query(`UPDATE orgs SET plan = 'pro', event_quota = $1,
|
|
24
|
+
settings = jsonb_set(
|
|
25
|
+
jsonb_set(COALESCE(settings, '{}'), '{trial_started_at}', $2::jsonb),
|
|
26
|
+
'{trial_ends_at}', $3::jsonb
|
|
27
|
+
),
|
|
28
|
+
updated_at = now()
|
|
29
|
+
WHERE id = $4`, [
|
|
30
|
+
TIER_CONFIG.pro.event_quota,
|
|
31
|
+
JSON.stringify(now.toISOString()),
|
|
32
|
+
JSON.stringify(trialEnd.toISOString()),
|
|
33
|
+
orgId,
|
|
34
|
+
]);
|
|
35
|
+
return {
|
|
36
|
+
is_trial: true,
|
|
37
|
+
trial_started_at: now.toISOString(),
|
|
38
|
+
trial_ends_at: trialEnd.toISOString(),
|
|
39
|
+
days_remaining: TRIAL_DURATION_DAYS,
|
|
40
|
+
expired: false,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Get trial status for an org.
|
|
45
|
+
*/
|
|
46
|
+
async getTrialStatus(orgId) {
|
|
47
|
+
const result = await this.deps.db.query(`SELECT settings FROM orgs WHERE id = $1`, [orgId]);
|
|
48
|
+
const org = result.rows[0];
|
|
49
|
+
if (!org)
|
|
50
|
+
throw new Error(`Org ${orgId} not found`);
|
|
51
|
+
const settings = org.settings ?? {};
|
|
52
|
+
const trialStarted = settings.trial_started_at;
|
|
53
|
+
const trialEnds = settings.trial_ends_at;
|
|
54
|
+
if (!trialStarted || !trialEnds) {
|
|
55
|
+
return { is_trial: false, trial_started_at: null, trial_ends_at: null, days_remaining: 0, expired: false };
|
|
56
|
+
}
|
|
57
|
+
const now = new Date();
|
|
58
|
+
const endDate = new Date(trialEnds);
|
|
59
|
+
const daysRemaining = Math.max(0, Math.ceil((endDate.getTime() - now.getTime()) / (86400 * 1000)));
|
|
60
|
+
const expired = now >= endDate;
|
|
61
|
+
return {
|
|
62
|
+
is_trial: !expired,
|
|
63
|
+
trial_started_at: trialStarted,
|
|
64
|
+
trial_ends_at: trialEnds,
|
|
65
|
+
days_remaining: daysRemaining,
|
|
66
|
+
expired,
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Check and expire trials. Called by a daily cron job.
|
|
71
|
+
* Downgrades expired trial orgs to Free.
|
|
72
|
+
* Returns number of orgs downgraded.
|
|
73
|
+
*/
|
|
74
|
+
async expireTrials() {
|
|
75
|
+
const now = new Date().toISOString();
|
|
76
|
+
// Find orgs on trial that have expired
|
|
77
|
+
const result = await this.deps.db.query(`SELECT id FROM orgs
|
|
78
|
+
WHERE plan = 'pro'
|
|
79
|
+
AND settings->>'trial_ends_at' IS NOT NULL
|
|
80
|
+
AND settings->>'trial_ends_at' < $1
|
|
81
|
+
AND stripe_subscription_id IS NULL`, [now]);
|
|
82
|
+
const expiredOrgs = result.rows;
|
|
83
|
+
let downgraded = 0;
|
|
84
|
+
for (const org of expiredOrgs) {
|
|
85
|
+
await this.deps.db.query(`UPDATE orgs SET plan = 'free', event_quota = $1,
|
|
86
|
+
settings = settings - 'trial_started_at' - 'trial_ends_at',
|
|
87
|
+
updated_at = now()
|
|
88
|
+
WHERE id = $2`, [TIER_CONFIG.free.event_quota, org.id]);
|
|
89
|
+
downgraded++;
|
|
90
|
+
}
|
|
91
|
+
return downgraded;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Cancel trial when org upgrades to a paid plan.
|
|
95
|
+
* Clears trial metadata so the org is no longer in trial state.
|
|
96
|
+
*/
|
|
97
|
+
async cancelTrial(orgId) {
|
|
98
|
+
await this.deps.db.query(`UPDATE orgs SET
|
|
99
|
+
settings = settings - 'trial_started_at' - 'trial_ends_at',
|
|
100
|
+
updated_at = now()
|
|
101
|
+
WHERE id = $1`, [orgId]);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=trial-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trial-service.js","sourceRoot":"","sources":["../../../src/cloud/billing/trial-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Usage Metering Pipeline (S-6.2)
|
|
3
|
+
*
|
|
4
|
+
* Tracks event counts per org per month. Provides:
|
|
5
|
+
* - In-memory batch accumulator (flushes every 10s or 100 events)
|
|
6
|
+
* - Monthly usage query for billing
|
|
7
|
+
* - Stripe usage reporting for metered billing
|
|
8
|
+
* - Redis counter sync for fast quota checks
|
|
9
|
+
*/
|
|
10
|
+
import type { MigrationClient } from '../migrate.js';
|
|
11
|
+
import type { IStripeClient } from './stripe-client.js';
|
|
12
|
+
import { type TierName } from './stripe-client.js';
|
|
13
|
+
export interface UsageMeteringDeps {
|
|
14
|
+
db: MigrationClient;
|
|
15
|
+
stripe: IStripeClient;
|
|
16
|
+
}
|
|
17
|
+
export interface UsageSummary {
|
|
18
|
+
org_id: string;
|
|
19
|
+
month: string;
|
|
20
|
+
total_events: number;
|
|
21
|
+
quota: number;
|
|
22
|
+
plan: TierName;
|
|
23
|
+
overage_events: number;
|
|
24
|
+
usage_pct: number;
|
|
25
|
+
}
|
|
26
|
+
export interface RedisUsageStore {
|
|
27
|
+
get(key: string): Promise<string | null>;
|
|
28
|
+
set(key: string, value: string): Promise<void>;
|
|
29
|
+
incrby(key: string, amount: number): Promise<number>;
|
|
30
|
+
expire(key: string, seconds: number): Promise<void>;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* In-memory accumulator that batches usage increments
|
|
34
|
+
* before flushing to the database.
|
|
35
|
+
*/
|
|
36
|
+
export declare class UsageAccumulator {
|
|
37
|
+
private deps;
|
|
38
|
+
private redisStore?;
|
|
39
|
+
private buffer;
|
|
40
|
+
private lastFlush;
|
|
41
|
+
private totalBuffered;
|
|
42
|
+
private flushIntervalMs;
|
|
43
|
+
private flushThreshold;
|
|
44
|
+
constructor(deps: UsageMeteringDeps, redisStore?: RedisUsageStore | undefined, config?: {
|
|
45
|
+
flushIntervalMs?: number;
|
|
46
|
+
flushThreshold?: number;
|
|
47
|
+
});
|
|
48
|
+
/**
|
|
49
|
+
* Record events for an org. Accumulates in memory,
|
|
50
|
+
* flushes when threshold or interval is reached.
|
|
51
|
+
*/
|
|
52
|
+
recordEvents(orgId: string, count: number, timestamp?: Date): Promise<void>;
|
|
53
|
+
/**
|
|
54
|
+
* Flush accumulated counts to the database.
|
|
55
|
+
*/
|
|
56
|
+
flush(): Promise<number>;
|
|
57
|
+
/** Get current buffer size (for testing) */
|
|
58
|
+
getBufferSize(): number;
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Query usage data for an org.
|
|
62
|
+
*/
|
|
63
|
+
export declare class UsageQuery {
|
|
64
|
+
private db;
|
|
65
|
+
constructor(db: MigrationClient);
|
|
66
|
+
/**
|
|
67
|
+
* Get current month usage summary for an org.
|
|
68
|
+
*/
|
|
69
|
+
getCurrentMonthUsage(orgId: string): Promise<UsageSummary>;
|
|
70
|
+
/**
|
|
71
|
+
* Get usage history (monthly summaries).
|
|
72
|
+
*/
|
|
73
|
+
getUsageHistory(orgId: string, months?: number): Promise<Array<{
|
|
74
|
+
month: string;
|
|
75
|
+
total_events: number;
|
|
76
|
+
}>>;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Report overage usage to Stripe for metered billing.
|
|
80
|
+
* Called by an hourly cron job.
|
|
81
|
+
*/
|
|
82
|
+
export declare function reportOverageToStripe(db: MigrationClient, stripe: IStripeClient): Promise<number>;
|
|
83
|
+
//# sourceMappingURL=usage-metering.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"usage-metering.d.ts","sourceRoot":"","sources":["../../../src/cloud/billing/usage-metering.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAe,KAAK,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAEhE,MAAM,WAAW,iBAAiB;IAChC,EAAE,EAAE,eAAe,CAAC;IACpB,MAAM,EAAE,aAAa,CAAC;CACvB;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,MAAM,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,QAAQ,CAAC;IACf,cAAc,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,eAAe;IAC9B,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IACzC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/C,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACrD,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACrD;AAED;;;GAGG;AACH,qBAAa,gBAAgB;IAQzB,OAAO,CAAC,IAAI;IACZ,OAAO,CAAC,UAAU,CAAC;IARrB,OAAO,CAAC,MAAM,CAA6B;IAC3C,OAAO,CAAC,SAAS,CAAc;IAC/B,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,eAAe,CAAS;IAChC,OAAO,CAAC,cAAc,CAAS;gBAGrB,IAAI,EAAE,iBAAiB,EACvB,UAAU,CAAC,EAAE,eAAe,YAAA,EACpC,MAAM,CAAC,EAAE;QAAE,eAAe,CAAC,EAAE,MAAM,CAAC;QAAC,cAAc,CAAC,EAAE,MAAM,CAAA;KAAE;IAMhE;;;OAGG;IACG,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IA0BjF;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,MAAM,CAAC;IAyB9B,4CAA4C;IAC5C,aAAa,IAAI,MAAM;CAGxB;AAED;;GAEG;AACH,qBAAa,UAAU;IACT,OAAO,CAAC,EAAE;gBAAF,EAAE,EAAE,eAAe;IAEvC;;OAEG;IACG,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAuChE;;OAEG;IACG,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,GAAE,MAAU,GAAG,OAAO,CAAC,KAAK,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAalH;AAED;;;GAGG;AACH,wBAAsB,qBAAqB,CACzC,EAAE,EAAE,eAAe,EACnB,MAAM,EAAE,aAAa,GACpB,OAAO,CAAC,MAAM,CAAC,CA2CjB"}
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Usage Metering Pipeline (S-6.2)
|
|
3
|
+
*
|
|
4
|
+
* Tracks event counts per org per month. Provides:
|
|
5
|
+
* - In-memory batch accumulator (flushes every 10s or 100 events)
|
|
6
|
+
* - Monthly usage query for billing
|
|
7
|
+
* - Stripe usage reporting for metered billing
|
|
8
|
+
* - Redis counter sync for fast quota checks
|
|
9
|
+
*/
|
|
10
|
+
import { TIER_CONFIG } from './stripe-client.js';
|
|
11
|
+
/**
|
|
12
|
+
* In-memory accumulator that batches usage increments
|
|
13
|
+
* before flushing to the database.
|
|
14
|
+
*/
|
|
15
|
+
export class UsageAccumulator {
|
|
16
|
+
deps;
|
|
17
|
+
redisStore;
|
|
18
|
+
buffer = new Map(); // key: orgId:YYYY-MM, value: count
|
|
19
|
+
lastFlush = Date.now();
|
|
20
|
+
totalBuffered = 0;
|
|
21
|
+
flushIntervalMs;
|
|
22
|
+
flushThreshold;
|
|
23
|
+
constructor(deps, redisStore, config) {
|
|
24
|
+
this.deps = deps;
|
|
25
|
+
this.redisStore = redisStore;
|
|
26
|
+
this.flushIntervalMs = config?.flushIntervalMs ?? 10_000;
|
|
27
|
+
this.flushThreshold = config?.flushThreshold ?? 100;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Record events for an org. Accumulates in memory,
|
|
31
|
+
* flushes when threshold or interval is reached.
|
|
32
|
+
*/
|
|
33
|
+
async recordEvents(orgId, count, timestamp) {
|
|
34
|
+
const date = timestamp ?? new Date();
|
|
35
|
+
// Truncate to hour to match batch-writer granularity and avoid double-counting
|
|
36
|
+
const hourDate = new Date(date);
|
|
37
|
+
hourDate.setUTCMinutes(0, 0, 0);
|
|
38
|
+
const hourKey = hourDate.toISOString();
|
|
39
|
+
const month = `${date.getUTCFullYear()}-${String(date.getUTCMonth() + 1).padStart(2, '0')}`;
|
|
40
|
+
const key = `${orgId}:${hourKey}`;
|
|
41
|
+
this.buffer.set(key, (this.buffer.get(key) ?? 0) + count);
|
|
42
|
+
this.totalBuffered += count;
|
|
43
|
+
// Update Redis counter immediately for fast quota checks
|
|
44
|
+
if (this.redisStore) {
|
|
45
|
+
const redisKey = `usage:${orgId}:${month}`;
|
|
46
|
+
await this.redisStore.incrby(redisKey, count);
|
|
47
|
+
// Expire at end of month + 7 days
|
|
48
|
+
await this.redisStore.expire(redisKey, 40 * 86400);
|
|
49
|
+
}
|
|
50
|
+
// Check if we should flush
|
|
51
|
+
if (this.totalBuffered >= this.flushThreshold || Date.now() - this.lastFlush >= this.flushIntervalMs) {
|
|
52
|
+
await this.flush();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Flush accumulated counts to the database.
|
|
57
|
+
*/
|
|
58
|
+
async flush() {
|
|
59
|
+
if (this.buffer.size === 0)
|
|
60
|
+
return 0;
|
|
61
|
+
const entries = Array.from(this.buffer.entries());
|
|
62
|
+
this.buffer.clear();
|
|
63
|
+
const flushed = this.totalBuffered;
|
|
64
|
+
this.totalBuffered = 0;
|
|
65
|
+
this.lastFlush = Date.now();
|
|
66
|
+
for (const [key, count] of entries) {
|
|
67
|
+
const [orgId, ...rest] = key.split(':');
|
|
68
|
+
const hour = rest.join(':'); // hour ISO string stored as key
|
|
69
|
+
await this.deps.db.query(`INSERT INTO usage_records (org_id, hour, event_count, api_key_id)
|
|
70
|
+
VALUES ($1, $2, $3, '00000000-0000-0000-0000-000000000000')
|
|
71
|
+
ON CONFLICT (org_id, hour, api_key_id)
|
|
72
|
+
DO UPDATE SET event_count = usage_records.event_count + $3`, [orgId, hour, count]);
|
|
73
|
+
}
|
|
74
|
+
return flushed;
|
|
75
|
+
}
|
|
76
|
+
/** Get current buffer size (for testing) */
|
|
77
|
+
getBufferSize() {
|
|
78
|
+
return this.totalBuffered;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Query usage data for an org.
|
|
83
|
+
*/
|
|
84
|
+
export class UsageQuery {
|
|
85
|
+
db;
|
|
86
|
+
constructor(db) {
|
|
87
|
+
this.db = db;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Get current month usage summary for an org.
|
|
91
|
+
*/
|
|
92
|
+
async getCurrentMonthUsage(orgId) {
|
|
93
|
+
const now = new Date();
|
|
94
|
+
const month = `${now.getUTCFullYear()}-${String(now.getUTCMonth() + 1).padStart(2, '0')}`;
|
|
95
|
+
const monthStart = `${month}-01T00:00:00Z`;
|
|
96
|
+
const nextMonth = new Date(now.getUTCFullYear(), now.getUTCMonth() + 1, 1);
|
|
97
|
+
const monthEnd = nextMonth.toISOString();
|
|
98
|
+
// Get total events this month
|
|
99
|
+
const usageResult = await this.db.query(`SELECT COALESCE(SUM(event_count), 0)::int as total
|
|
100
|
+
FROM usage_records
|
|
101
|
+
WHERE org_id = $1 AND hour >= $2 AND hour < $3`, [orgId, monthStart, monthEnd]);
|
|
102
|
+
const totalEvents = usageResult.rows[0]?.total ?? 0;
|
|
103
|
+
// Get org plan and quota
|
|
104
|
+
const orgResult = await this.db.query(`SELECT plan, event_quota FROM orgs WHERE id = $1`, [orgId]);
|
|
105
|
+
const org = orgResult.rows[0];
|
|
106
|
+
const plan = (org?.plan ?? 'free');
|
|
107
|
+
const quota = org?.event_quota ?? TIER_CONFIG.free.event_quota;
|
|
108
|
+
const overageEvents = Math.max(0, totalEvents - quota);
|
|
109
|
+
const usagePct = quota > 0 ? (totalEvents / quota) * 100 : 0;
|
|
110
|
+
return {
|
|
111
|
+
org_id: orgId,
|
|
112
|
+
month,
|
|
113
|
+
total_events: totalEvents,
|
|
114
|
+
quota,
|
|
115
|
+
plan,
|
|
116
|
+
overage_events: overageEvents,
|
|
117
|
+
usage_pct: Math.round(usagePct * 100) / 100,
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Get usage history (monthly summaries).
|
|
122
|
+
*/
|
|
123
|
+
async getUsageHistory(orgId, months = 6) {
|
|
124
|
+
const result = await this.db.query(`SELECT
|
|
125
|
+
to_char(date_trunc('month', hour), 'YYYY-MM') as month,
|
|
126
|
+
COALESCE(SUM(event_count), 0)::int as total_events
|
|
127
|
+
FROM usage_records
|
|
128
|
+
WHERE org_id = $1 AND hour >= (now() - make_interval(months => $2))
|
|
129
|
+
GROUP BY date_trunc('month', hour)
|
|
130
|
+
ORDER BY month DESC`, [orgId, months]);
|
|
131
|
+
return result.rows;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Report overage usage to Stripe for metered billing.
|
|
136
|
+
* Called by an hourly cron job.
|
|
137
|
+
*/
|
|
138
|
+
export async function reportOverageToStripe(db, stripe) {
|
|
139
|
+
// Find orgs on paid plans with overage this month
|
|
140
|
+
const now = new Date();
|
|
141
|
+
const month = `${now.getUTCFullYear()}-${String(now.getUTCMonth() + 1).padStart(2, '0')}`;
|
|
142
|
+
const monthStart = `${month}-01T00:00:00Z`;
|
|
143
|
+
const orgsResult = await db.query(`SELECT o.id, o.plan, o.event_quota, o.stripe_subscription_id,
|
|
144
|
+
COALESCE(SUM(u.event_count), 0)::int as total_events
|
|
145
|
+
FROM orgs o
|
|
146
|
+
LEFT JOIN usage_records u ON u.org_id = o.id AND u.hour >= $1
|
|
147
|
+
WHERE o.plan IN ('pro', 'team') AND o.stripe_subscription_id IS NOT NULL
|
|
148
|
+
GROUP BY o.id
|
|
149
|
+
HAVING COALESCE(SUM(u.event_count), 0) > o.event_quota`, [monthStart]);
|
|
150
|
+
let reported = 0;
|
|
151
|
+
for (const org of orgsResult.rows) {
|
|
152
|
+
const overageEvents = org.total_events - org.event_quota;
|
|
153
|
+
if (overageEvents <= 0)
|
|
154
|
+
continue;
|
|
155
|
+
// Find the metered subscription item
|
|
156
|
+
const sub = await stripe.getSubscription(org.stripe_subscription_id);
|
|
157
|
+
if (!sub)
|
|
158
|
+
continue;
|
|
159
|
+
const meteredItem = sub.items.data.find((item) => item.price.recurring?.usage_type === 'metered');
|
|
160
|
+
if (!meteredItem)
|
|
161
|
+
continue;
|
|
162
|
+
// Report overage in units of 1K events
|
|
163
|
+
const overageUnits = Math.ceil(overageEvents / 1000);
|
|
164
|
+
await stripe.reportUsage({
|
|
165
|
+
subscription_item: meteredItem.id,
|
|
166
|
+
quantity: overageUnits,
|
|
167
|
+
timestamp: Math.floor(Date.now() / 1000),
|
|
168
|
+
action: 'set',
|
|
169
|
+
});
|
|
170
|
+
reported++;
|
|
171
|
+
}
|
|
172
|
+
return reported;
|
|
173
|
+
}
|
|
174
|
+
//# sourceMappingURL=usage-metering.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"usage-metering.js","sourceRoot":"","sources":["../../../src/cloud/billing/usage-metering.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Backpressure Mechanism (S-3.5)
|
|
3
|
+
*
|
|
4
|
+
* Monitors Redis Stream length. When pending messages exceed a configurable
|
|
5
|
+
* threshold (default 100K, env: BACKPRESSURE_THRESHOLD), the API gateway
|
|
6
|
+
* returns 503 with Retry-After header.
|
|
7
|
+
*
|
|
8
|
+
* Includes CloudWatch alarm configuration and auto-scaling policy definitions.
|
|
9
|
+
*/
|
|
10
|
+
import type { EventQueue } from './event-queue.js';
|
|
11
|
+
export interface BackpressureStatus {
|
|
12
|
+
/** Whether the system is under backpressure */
|
|
13
|
+
underPressure: boolean;
|
|
14
|
+
/** Current stream depth */
|
|
15
|
+
streamLength: number;
|
|
16
|
+
/** Configured threshold */
|
|
17
|
+
threshold: number;
|
|
18
|
+
/** Suggested Retry-After in seconds (0 if not under pressure) */
|
|
19
|
+
retryAfterSeconds: number;
|
|
20
|
+
}
|
|
21
|
+
export interface BackpressureConfig {
|
|
22
|
+
/** Pending message threshold (default: from env or 100K) */
|
|
23
|
+
threshold?: number;
|
|
24
|
+
/** Retry-After header value in seconds when under pressure (default: 5) */
|
|
25
|
+
retryAfterSeconds?: number;
|
|
26
|
+
/** Check interval for cached status in ms (default: 1000) */
|
|
27
|
+
cacheMs?: number;
|
|
28
|
+
}
|
|
29
|
+
export interface CloudWatchAlarmConfig {
|
|
30
|
+
alarmName: string;
|
|
31
|
+
metricName: string;
|
|
32
|
+
namespace: string;
|
|
33
|
+
threshold: number;
|
|
34
|
+
evaluationPeriods: number;
|
|
35
|
+
period: number;
|
|
36
|
+
statistic: string;
|
|
37
|
+
comparisonOperator: string;
|
|
38
|
+
alarmActions: string[];
|
|
39
|
+
dimensions: Array<{
|
|
40
|
+
Name: string;
|
|
41
|
+
Value: string;
|
|
42
|
+
}>;
|
|
43
|
+
}
|
|
44
|
+
export interface AutoScalingPolicy {
|
|
45
|
+
policyName: string;
|
|
46
|
+
serviceNamespace: string;
|
|
47
|
+
resourceId: string;
|
|
48
|
+
scalableDimension: string;
|
|
49
|
+
stepAdjustments: Array<{
|
|
50
|
+
metricIntervalLowerBound: number;
|
|
51
|
+
metricIntervalUpperBound?: number;
|
|
52
|
+
scalingAdjustment: number;
|
|
53
|
+
}>;
|
|
54
|
+
cooldownSeconds: number;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Monitors queue depth and reports backpressure status.
|
|
58
|
+
* Caches the stream length check to avoid hitting Redis on every request.
|
|
59
|
+
*/
|
|
60
|
+
export declare class BackpressureMonitor {
|
|
61
|
+
private queue;
|
|
62
|
+
private threshold;
|
|
63
|
+
private retryAfterSeconds;
|
|
64
|
+
private cacheMs;
|
|
65
|
+
private cachedStatus;
|
|
66
|
+
private lastCheckTime;
|
|
67
|
+
constructor(queue: EventQueue, config?: BackpressureConfig);
|
|
68
|
+
/** Get the configured threshold */
|
|
69
|
+
getThreshold(): number;
|
|
70
|
+
/**
|
|
71
|
+
* Check whether the system is under backpressure.
|
|
72
|
+
* Uses a cached value if checked within the cache interval.
|
|
73
|
+
*/
|
|
74
|
+
check(): Promise<BackpressureStatus>;
|
|
75
|
+
/** Force-clear the cache (useful after scaling or for tests) */
|
|
76
|
+
clearCache(): void;
|
|
77
|
+
/**
|
|
78
|
+
* Generate a 503 response body for backpressure.
|
|
79
|
+
*/
|
|
80
|
+
static make503Response(status: BackpressureStatus): {
|
|
81
|
+
status: 503;
|
|
82
|
+
headers: Record<string, string>;
|
|
83
|
+
body: {
|
|
84
|
+
error: string;
|
|
85
|
+
retry_after: number;
|
|
86
|
+
stream_depth: number;
|
|
87
|
+
};
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Generate CloudWatch alarm configuration for stream depth monitoring.
|
|
92
|
+
*/
|
|
93
|
+
export declare function generateCloudWatchAlarmConfig(opts?: {
|
|
94
|
+
threshold?: number;
|
|
95
|
+
snsTopicArn?: string;
|
|
96
|
+
streamName?: string;
|
|
97
|
+
}): CloudWatchAlarmConfig;
|
|
98
|
+
/**
|
|
99
|
+
* Generate auto-scaling step policy for worker tasks.
|
|
100
|
+
* When stream depth exceeds threshold, add workers in steps.
|
|
101
|
+
*/
|
|
102
|
+
export declare function generateAutoScalingPolicy(opts?: {
|
|
103
|
+
ecsCluster?: string;
|
|
104
|
+
ecsService?: string;
|
|
105
|
+
cooldownSeconds?: number;
|
|
106
|
+
}): AutoScalingPolicy;
|
|
107
|
+
//# sourceMappingURL=backpressure.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backpressure.d.ts","sourceRoot":"","sources":["../../../src/cloud/ingestion/backpressure.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Backpressure Mechanism (S-3.5)
|
|
3
|
+
*
|
|
4
|
+
* Monitors Redis Stream length. When pending messages exceed a configurable
|
|
5
|
+
* threshold (default 100K, env: BACKPRESSURE_THRESHOLD), the API gateway
|
|
6
|
+
* returns 503 with Retry-After header.
|
|
7
|
+
*
|
|
8
|
+
* Includes CloudWatch alarm configuration and auto-scaling policy definitions.
|
|
9
|
+
*/
|
|
10
|
+
import { BACKPRESSURE_THRESHOLD } from './event-queue.js';
|
|
11
|
+
// ═══════════════════════════════════════════
|
|
12
|
+
// BackpressureMonitor
|
|
13
|
+
// ═══════════════════════════════════════════
|
|
14
|
+
/**
|
|
15
|
+
* Monitors queue depth and reports backpressure status.
|
|
16
|
+
* Caches the stream length check to avoid hitting Redis on every request.
|
|
17
|
+
*/
|
|
18
|
+
export class BackpressureMonitor {
|
|
19
|
+
queue;
|
|
20
|
+
threshold;
|
|
21
|
+
retryAfterSeconds;
|
|
22
|
+
cacheMs;
|
|
23
|
+
cachedStatus = null;
|
|
24
|
+
lastCheckTime = 0;
|
|
25
|
+
constructor(queue, config) {
|
|
26
|
+
this.queue = queue;
|
|
27
|
+
// Allow env override
|
|
28
|
+
const envThreshold = typeof process !== 'undefined'
|
|
29
|
+
? parseInt(process.env.BACKPRESSURE_THRESHOLD ?? '', 10)
|
|
30
|
+
: NaN;
|
|
31
|
+
this.threshold = config?.threshold ?? (isNaN(envThreshold) ? BACKPRESSURE_THRESHOLD : envThreshold);
|
|
32
|
+
this.retryAfterSeconds = config?.retryAfterSeconds ?? 5;
|
|
33
|
+
this.cacheMs = config?.cacheMs ?? 1000;
|
|
34
|
+
}
|
|
35
|
+
/** Get the configured threshold */
|
|
36
|
+
getThreshold() {
|
|
37
|
+
return this.threshold;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Check whether the system is under backpressure.
|
|
41
|
+
* Uses a cached value if checked within the cache interval.
|
|
42
|
+
*/
|
|
43
|
+
async check() {
|
|
44
|
+
const now = Date.now();
|
|
45
|
+
if (this.cachedStatus && (now - this.lastCheckTime) < this.cacheMs) {
|
|
46
|
+
return this.cachedStatus;
|
|
47
|
+
}
|
|
48
|
+
const streamLength = await this.queue.getStreamLength();
|
|
49
|
+
const underPressure = streamLength >= this.threshold;
|
|
50
|
+
this.cachedStatus = {
|
|
51
|
+
underPressure,
|
|
52
|
+
streamLength,
|
|
53
|
+
threshold: this.threshold,
|
|
54
|
+
retryAfterSeconds: underPressure ? this.retryAfterSeconds : 0,
|
|
55
|
+
};
|
|
56
|
+
this.lastCheckTime = now;
|
|
57
|
+
return this.cachedStatus;
|
|
58
|
+
}
|
|
59
|
+
/** Force-clear the cache (useful after scaling or for tests) */
|
|
60
|
+
clearCache() {
|
|
61
|
+
this.cachedStatus = null;
|
|
62
|
+
this.lastCheckTime = 0;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Generate a 503 response body for backpressure.
|
|
66
|
+
*/
|
|
67
|
+
static make503Response(status) {
|
|
68
|
+
return {
|
|
69
|
+
status: 503,
|
|
70
|
+
headers: {
|
|
71
|
+
'Retry-After': String(status.retryAfterSeconds),
|
|
72
|
+
},
|
|
73
|
+
body: {
|
|
74
|
+
error: 'Service temporarily unavailable due to high load. Please retry.',
|
|
75
|
+
retry_after: status.retryAfterSeconds,
|
|
76
|
+
stream_depth: status.streamLength,
|
|
77
|
+
},
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
// ═══════════════════════════════════════════
|
|
82
|
+
// CloudWatch Alarm Configuration
|
|
83
|
+
// ═══════════════════════════════════════════
|
|
84
|
+
/**
|
|
85
|
+
* Generate CloudWatch alarm configuration for stream depth monitoring.
|
|
86
|
+
*/
|
|
87
|
+
export function generateCloudWatchAlarmConfig(opts) {
|
|
88
|
+
const threshold = opts?.threshold ?? BACKPRESSURE_THRESHOLD;
|
|
89
|
+
const snsArn = opts?.snsTopicArn ?? 'arn:aws:sns:us-east-1:ACCOUNT_ID:agentlens-alerts';
|
|
90
|
+
return {
|
|
91
|
+
alarmName: 'AgentLens-IngestionStreamDepth-High',
|
|
92
|
+
metricName: 'StreamPendingMessages',
|
|
93
|
+
namespace: 'AgentLens/Ingestion',
|
|
94
|
+
threshold,
|
|
95
|
+
evaluationPeriods: 2,
|
|
96
|
+
period: 60,
|
|
97
|
+
statistic: 'Average',
|
|
98
|
+
comparisonOperator: 'GreaterThanOrEqualToThreshold',
|
|
99
|
+
alarmActions: [snsArn],
|
|
100
|
+
dimensions: [
|
|
101
|
+
{ Name: 'StreamName', Value: opts?.streamName ?? 'event_ingestion' },
|
|
102
|
+
],
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
// ═══════════════════════════════════════════
|
|
106
|
+
// Auto-Scaling Policy Configuration
|
|
107
|
+
// ═══════════════════════════════════════════
|
|
108
|
+
/**
|
|
109
|
+
* Generate auto-scaling step policy for worker tasks.
|
|
110
|
+
* When stream depth exceeds threshold, add workers in steps.
|
|
111
|
+
*/
|
|
112
|
+
export function generateAutoScalingPolicy(opts) {
|
|
113
|
+
const cluster = opts?.ecsCluster ?? 'agentlens-cloud';
|
|
114
|
+
const service = opts?.ecsService ?? 'ingestion-workers';
|
|
115
|
+
return {
|
|
116
|
+
policyName: 'AgentLens-IngestionWorker-ScaleUp',
|
|
117
|
+
serviceNamespace: 'ecs',
|
|
118
|
+
resourceId: `service/${cluster}/${service}`,
|
|
119
|
+
scalableDimension: 'ecs:service:DesiredCount',
|
|
120
|
+
stepAdjustments: [
|
|
121
|
+
{
|
|
122
|
+
metricIntervalLowerBound: 0,
|
|
123
|
+
metricIntervalUpperBound: 50_000,
|
|
124
|
+
scalingAdjustment: 2,
|
|
125
|
+
},
|
|
126
|
+
{
|
|
127
|
+
metricIntervalLowerBound: 50_000,
|
|
128
|
+
scalingAdjustment: 5,
|
|
129
|
+
},
|
|
130
|
+
],
|
|
131
|
+
cooldownSeconds: opts?.cooldownSeconds ?? 120,
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
//# sourceMappingURL=backpressure.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backpressure.js","sourceRoot":"","sources":["../../../src/cloud/ingestion/backpressure.ts"],"names":[],"mappings":"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"}
|