manifest 5.3.4 → 5.6.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/README.md +19 -24
- package/dist/backend/analytics/analytics.module.d.ts +2 -0
- package/dist/backend/analytics/analytics.module.js +45 -0
- package/dist/backend/analytics/analytics.module.js.map +1 -0
- package/dist/backend/analytics/controllers/agent-analytics.controller.d.ts +14 -0
- package/dist/backend/analytics/controllers/agent-analytics.controller.js +60 -0
- package/dist/backend/analytics/controllers/agent-analytics.controller.js.map +1 -0
- package/dist/backend/analytics/controllers/agents.controller.d.ts +40 -0
- package/dist/backend/analytics/controllers/agents.controller.js +115 -0
- package/dist/backend/analytics/controllers/agents.controller.js.map +1 -0
- package/dist/backend/analytics/controllers/costs.controller.d.ts +28 -0
- package/dist/backend/analytics/controllers/costs.controller.js +64 -0
- package/dist/backend/analytics/controllers/costs.controller.js.map +1 -0
- package/dist/backend/analytics/controllers/messages.controller.d.ts +13 -0
- package/dist/backend/analytics/controllers/messages.controller.js +53 -0
- package/dist/backend/analytics/controllers/messages.controller.js.map +1 -0
- package/dist/backend/analytics/controllers/overview.controller.d.ts +59 -0
- package/dist/backend/analytics/controllers/overview.controller.js +84 -0
- package/dist/backend/analytics/controllers/overview.controller.js.map +1 -0
- package/dist/backend/analytics/controllers/tokens.controller.d.ts +26 -0
- package/dist/backend/analytics/controllers/tokens.controller.js +66 -0
- package/dist/backend/analytics/controllers/tokens.controller.js.map +1 -0
- package/dist/backend/analytics/dto/messages-query.dto.d.ts +11 -0
- package/dist/backend/analytics/dto/messages-query.dto.js +79 -0
- package/dist/backend/analytics/dto/messages-query.dto.js.map +1 -0
- package/dist/backend/analytics/services/agent-analytics.service.d.ts +33 -0
- package/dist/backend/analytics/services/agent-analytics.service.js +125 -0
- package/dist/backend/analytics/services/agent-analytics.service.js.map +1 -0
- package/dist/backend/analytics/services/aggregation.service.d.ts +38 -0
- package/dist/backend/analytics/services/aggregation.service.js +229 -0
- package/dist/backend/analytics/services/aggregation.service.js.map +1 -0
- package/dist/backend/analytics/services/query-helpers.d.ts +10 -0
- package/dist/backend/analytics/services/query-helpers.js +41 -0
- package/dist/backend/analytics/services/query-helpers.js.map +1 -0
- package/dist/backend/analytics/services/timeseries-queries.service.d.ts +58 -0
- package/dist/backend/analytics/services/timeseries-queries.service.js +265 -0
- package/dist/backend/analytics/services/timeseries-queries.service.js.map +1 -0
- package/dist/backend/app.module.d.ts +2 -0
- package/dist/backend/app.module.js +79 -0
- package/dist/backend/app.module.js.map +1 -0
- package/dist/backend/auth/auth.instance.d.ts +6 -0
- package/dist/backend/auth/auth.instance.js +116 -0
- package/dist/backend/auth/auth.instance.js.map +1 -0
- package/dist/backend/auth/auth.module.d.ts +2 -0
- package/dist/backend/auth/auth.module.js +17 -0
- package/dist/backend/auth/auth.module.js.map +1 -0
- package/dist/backend/auth/current-user.decorator.d.ts +1 -0
- package/dist/backend/auth/current-user.decorator.js +9 -0
- package/dist/backend/auth/current-user.decorator.js.map +1 -0
- package/dist/backend/auth/local-auth.guard.d.ts +7 -0
- package/dist/backend/auth/local-auth.guard.js +51 -0
- package/dist/backend/auth/local-auth.guard.js.map +1 -0
- package/dist/backend/auth/session.guard.d.ts +7 -0
- package/dist/backend/auth/session.guard.js +50 -0
- package/dist/backend/auth/session.guard.js.map +1 -0
- package/dist/backend/common/common.module.d.ts +2 -0
- package/dist/backend/common/common.module.js +24 -0
- package/dist/backend/common/common.module.js.map +1 -0
- package/dist/backend/common/constants/api-key.constants.d.ts +1 -0
- package/dist/backend/common/constants/api-key.constants.js +5 -0
- package/dist/backend/common/constants/api-key.constants.js.map +1 -0
- package/dist/backend/common/constants/cache.constants.d.ts +2 -0
- package/dist/backend/common/constants/cache.constants.js +6 -0
- package/dist/backend/common/constants/cache.constants.js.map +1 -0
- package/dist/backend/common/constants/local-mode.constants.d.ts +11 -0
- package/dist/backend/common/constants/local-mode.constants.js +94 -0
- package/dist/backend/common/constants/local-mode.constants.js.map +1 -0
- package/dist/backend/common/decorators/public.decorator.d.ts +2 -0
- package/dist/backend/common/decorators/public.decorator.js +8 -0
- package/dist/backend/common/decorators/public.decorator.js.map +1 -0
- package/dist/backend/common/dto/create-agent.dto.d.ts +3 -0
- package/dist/backend/common/dto/create-agent.dto.js +26 -0
- package/dist/backend/common/dto/create-agent.dto.js.map +1 -0
- package/dist/backend/common/dto/range-query.dto.d.ts +4 -0
- package/dist/backend/common/dto/range-query.dto.js +29 -0
- package/dist/backend/common/dto/range-query.dto.js.map +1 -0
- package/dist/backend/common/guards/api-key.guard.d.ts +14 -0
- package/dist/backend/common/guards/api-key.guard.js +83 -0
- package/dist/backend/common/guards/api-key.guard.js.map +1 -0
- package/dist/backend/common/interceptors/user-cache.interceptor.d.ts +9 -0
- package/dist/backend/common/interceptors/user-cache.interceptor.js +43 -0
- package/dist/backend/common/interceptors/user-cache.interceptor.js.map +1 -0
- package/dist/backend/common/services/cache-invalidation.service.d.ts +16 -0
- package/dist/backend/common/services/cache-invalidation.service.js +67 -0
- package/dist/backend/common/services/cache-invalidation.service.js.map +1 -0
- package/dist/backend/common/services/ingest-event-bus.service.d.ts +11 -0
- package/dist/backend/common/services/ingest-event-bus.service.js +44 -0
- package/dist/backend/common/services/ingest-event-bus.service.js.map +1 -0
- package/dist/backend/common/utils/hash.util.d.ts +2 -0
- package/dist/backend/common/utils/hash.util.js +14 -0
- package/dist/backend/common/utils/hash.util.js.map +1 -0
- package/dist/backend/common/utils/product-telemetry.d.ts +3 -0
- package/dist/backend/common/utils/product-telemetry.js +67 -0
- package/dist/backend/common/utils/product-telemetry.js.map +1 -0
- package/dist/backend/common/utils/range.util.d.ts +3 -0
- package/dist/backend/common/utils/range.util.js +29 -0
- package/dist/backend/common/utils/range.util.js.map +1 -0
- package/dist/backend/common/utils/sql-dialect.d.ts +11 -0
- package/dist/backend/common/utils/sql-dialect.js +64 -0
- package/dist/backend/common/utils/sql-dialect.js.map +1 -0
- package/dist/backend/config/app.config.d.ts +31 -0
- package/dist/backend/config/app.config.js +27 -0
- package/dist/backend/config/app.config.js.map +1 -0
- package/dist/backend/database/database-seeder.service.d.ts +30 -0
- package/dist/backend/database/database-seeder.service.js +252 -0
- package/dist/backend/database/database-seeder.service.js.map +1 -0
- package/dist/backend/database/database.module.d.ts +2 -0
- package/dist/backend/database/database.module.js +94 -0
- package/dist/backend/database/database.module.js.map +1 -0
- package/dist/backend/database/datasource.d.ts +4 -0
- package/dist/backend/database/datasource.js +27 -0
- package/dist/backend/database/datasource.js.map +1 -0
- package/dist/backend/database/local-bootstrap.service.d.ts +23 -0
- package/dist/backend/database/local-bootstrap.service.js +166 -0
- package/dist/backend/database/local-bootstrap.service.js.map +1 -0
- package/dist/backend/database/migrations/1771464895790-InitialSchema.d.ts +6 -0
- package/dist/backend/database/migrations/1771464895790-InitialSchema.js +91 -0
- package/dist/backend/database/migrations/1771464895790-InitialSchema.js.map +1 -0
- package/dist/backend/database/migrations/1771500000000-HashApiKeys.d.ts +6 -0
- package/dist/backend/database/migrations/1771500000000-HashApiKeys.js +67 -0
- package/dist/backend/database/migrations/1771500000000-HashApiKeys.js.map +1 -0
- package/dist/backend/database/migrations/1771600000000-ModelPricingImprovements.d.ts +9 -0
- package/dist/backend/database/migrations/1771600000000-ModelPricingImprovements.js +60 -0
- package/dist/backend/database/migrations/1771600000000-ModelPricingImprovements.js.map +1 -0
- package/dist/backend/database/pricing-history.service.d.ts +19 -0
- package/dist/backend/database/pricing-history.service.js +75 -0
- package/dist/backend/database/pricing-history.service.js.map +1 -0
- package/dist/backend/database/pricing-sync.service.d.ts +24 -0
- package/dist/backend/database/pricing-sync.service.js +165 -0
- package/dist/backend/database/pricing-sync.service.js.map +1 -0
- package/dist/backend/entities/agent-api-key.entity.d.ts +17 -0
- package/dist/backend/entities/agent-api-key.entity.js +91 -0
- package/dist/backend/entities/agent-api-key.entity.js.map +1 -0
- package/dist/backend/entities/agent-log.entity.d.ts +12 -0
- package/dist/backend/entities/agent-log.entity.js +74 -0
- package/dist/backend/entities/agent-log.entity.js.map +1 -0
- package/dist/backend/entities/agent-message.entity.d.ts +23 -0
- package/dist/backend/entities/agent-message.entity.js +130 -0
- package/dist/backend/entities/agent-message.entity.js.map +1 -0
- package/dist/backend/entities/agent.entity.d.ts +13 -0
- package/dist/backend/entities/agent.entity.js +70 -0
- package/dist/backend/entities/agent.entity.js.map +1 -0
- package/dist/backend/entities/api-key.entity.d.ts +10 -0
- package/dist/backend/entities/api-key.entity.js +62 -0
- package/dist/backend/entities/api-key.entity.js.map +1 -0
- package/dist/backend/entities/cost-snapshot.entity.d.ts +9 -0
- package/dist/backend/entities/cost-snapshot.entity.js +58 -0
- package/dist/backend/entities/cost-snapshot.entity.js.map +1 -0
- package/dist/backend/entities/llm-call.entity.d.ts +19 -0
- package/dist/backend/entities/llm-call.entity.js +108 -0
- package/dist/backend/entities/llm-call.entity.js.map +1 -0
- package/dist/backend/entities/model-pricing-history.entity.d.ts +10 -0
- package/dist/backend/entities/model-pricing-history.entity.js +62 -0
- package/dist/backend/entities/model-pricing-history.entity.js.map +1 -0
- package/dist/backend/entities/model-pricing.entity.d.ts +7 -0
- package/dist/backend/entities/model-pricing.entity.js +46 -0
- package/dist/backend/entities/model-pricing.entity.js.map +1 -0
- package/dist/backend/entities/notification-log.entity.d.ts +11 -0
- package/dist/backend/entities/notification-log.entity.js +67 -0
- package/dist/backend/entities/notification-log.entity.js.map +1 -0
- package/dist/backend/entities/notification-rule.entity.d.ts +13 -0
- package/dist/backend/entities/notification-rule.entity.js +77 -0
- package/dist/backend/entities/notification-rule.entity.js.map +1 -0
- package/dist/backend/entities/security-event.entity.d.ts +9 -0
- package/dist/backend/entities/security-event.entity.js +56 -0
- package/dist/backend/entities/security-event.entity.js.map +1 -0
- package/dist/backend/entities/tenant.entity.d.ts +11 -0
- package/dist/backend/entities/tenant.entity.js +62 -0
- package/dist/backend/entities/tenant.entity.js.map +1 -0
- package/dist/backend/entities/token-usage-snapshot.entity.d.ts +12 -0
- package/dist/backend/entities/token-usage-snapshot.entity.js +74 -0
- package/dist/backend/entities/token-usage-snapshot.entity.js.map +1 -0
- package/dist/backend/entities/tool-execution.entity.d.ts +10 -0
- package/dist/backend/entities/tool-execution.entity.js +63 -0
- package/dist/backend/entities/tool-execution.entity.js.map +1 -0
- package/dist/backend/entities/unresolved-model.entity.d.ts +9 -0
- package/dist/backend/entities/unresolved-model.entity.js +57 -0
- package/dist/backend/entities/unresolved-model.entity.js.map +1 -0
- package/dist/backend/github/github.controller.d.ts +5 -0
- package/dist/backend/github/github.controller.js +53 -0
- package/dist/backend/github/github.controller.js.map +1 -0
- package/dist/backend/github/github.module.d.ts +2 -0
- package/dist/backend/github/github.module.js +20 -0
- package/dist/backend/github/github.module.js.map +1 -0
- package/dist/backend/health/health.controller.d.ts +9 -0
- package/dist/backend/health/health.controller.js +40 -0
- package/dist/backend/health/health.controller.js.map +1 -0
- package/dist/backend/health/health.module.d.ts +2 -0
- package/dist/backend/health/health.module.js +20 -0
- package/dist/backend/health/health.module.js.map +1 -0
- package/dist/backend/main.d.ts +1 -0
- package/dist/backend/main.js +147 -0
- package/dist/backend/main.js.map +1 -0
- package/dist/backend/model-prices/model-name-normalizer.d.ts +4 -0
- package/dist/backend/model-prices/model-name-normalizer.js +69 -0
- package/dist/backend/model-prices/model-name-normalizer.js.map +1 -0
- package/dist/backend/model-prices/model-prices.controller.d.ts +30 -0
- package/dist/backend/model-prices/model-prices.controller.js +70 -0
- package/dist/backend/model-prices/model-prices.controller.js.map +1 -0
- package/dist/backend/model-prices/model-prices.module.d.ts +2 -0
- package/dist/backend/model-prices/model-prices.module.js +45 -0
- package/dist/backend/model-prices/model-prices.module.js.map +1 -0
- package/dist/backend/model-prices/model-prices.service.d.ts +36 -0
- package/dist/backend/model-prices/model-prices.service.js +69 -0
- package/dist/backend/model-prices/model-prices.service.js.map +1 -0
- package/dist/backend/model-prices/model-pricing-cache.service.d.ts +15 -0
- package/dist/backend/model-prices/model-pricing-cache.service.js +63 -0
- package/dist/backend/model-prices/model-pricing-cache.service.js.map +1 -0
- package/dist/backend/model-prices/unresolved-model-tracker.service.d.ts +16 -0
- package/dist/backend/model-prices/unresolved-model-tracker.service.js +97 -0
- package/dist/backend/model-prices/unresolved-model-tracker.service.js.map +1 -0
- package/dist/backend/notifications/dto/email-config.dto.d.ts +13 -0
- package/dist/backend/notifications/dto/email-config.dto.js +69 -0
- package/dist/backend/notifications/dto/email-config.dto.js.map +1 -0
- package/dist/backend/notifications/dto/notification-email.dto.d.ts +3 -0
- package/dist/backend/notifications/dto/notification-email.dto.js +22 -0
- package/dist/backend/notifications/dto/notification-email.dto.js.map +1 -0
- package/dist/backend/notifications/dto/notification-rule.dto.d.ts +12 -0
- package/dist/backend/notifications/dto/notification-rule.dto.js +70 -0
- package/dist/backend/notifications/dto/notification-rule.dto.js.map +1 -0
- package/dist/backend/notifications/email-config.controller.d.ts +32 -0
- package/dist/backend/notifications/email-config.controller.js +95 -0
- package/dist/backend/notifications/email-config.controller.js.map +1 -0
- package/dist/backend/notifications/emails/reset-password.d.ts +5 -0
- package/dist/backend/notifications/emails/reset-password.js +108 -0
- package/dist/backend/notifications/emails/reset-password.js.map +1 -0
- package/dist/backend/notifications/emails/test-email.d.ts +1 -0
- package/dist/backend/notifications/emails/test-email.js +90 -0
- package/dist/backend/notifications/emails/test-email.js.map +1 -0
- package/dist/backend/notifications/emails/threshold-alert.d.ts +9 -0
- package/dist/backend/notifications/emails/threshold-alert.js +143 -0
- package/dist/backend/notifications/emails/threshold-alert.js.map +1 -0
- package/dist/backend/notifications/emails/verify-email.d.ts +5 -0
- package/dist/backend/notifications/emails/verify-email.js +108 -0
- package/dist/backend/notifications/emails/verify-email.js.map +1 -0
- package/dist/backend/notifications/notifications.controller.d.ts +13 -0
- package/dist/backend/notifications/notifications.controller.js +77 -0
- package/dist/backend/notifications/notifications.controller.js.map +1 -0
- package/dist/backend/notifications/notifications.module.d.ts +2 -0
- package/dist/backend/notifications/notifications.module.js +33 -0
- package/dist/backend/notifications/notifications.module.js.map +1 -0
- package/dist/backend/notifications/services/email-config.service.d.ts +25 -0
- package/dist/backend/notifications/services/email-config.service.js +92 -0
- package/dist/backend/notifications/services/email-config.service.js.map +1 -0
- package/dist/backend/notifications/services/email-providers/email-provider.interface.d.ts +18 -0
- package/dist/backend/notifications/services/email-providers/email-provider.interface.js +3 -0
- package/dist/backend/notifications/services/email-providers/email-provider.interface.js.map +1 -0
- package/dist/backend/notifications/services/email-providers/mailgun.provider.d.ts +9 -0
- package/dist/backend/notifications/services/email-providers/mailgun.provider.js +62 -0
- package/dist/backend/notifications/services/email-providers/mailgun.provider.js.map +1 -0
- package/dist/backend/notifications/services/email-providers/resend.provider.d.ts +8 -0
- package/dist/backend/notifications/services/email-providers/resend.provider.js +51 -0
- package/dist/backend/notifications/services/email-providers/resend.provider.js.map +1 -0
- package/dist/backend/notifications/services/email-providers/resolve-provider.d.ts +2 -0
- package/dist/backend/notifications/services/email-providers/resolve-provider.js +19 -0
- package/dist/backend/notifications/services/email-providers/resolve-provider.js.map +1 -0
- package/dist/backend/notifications/services/email-providers/send-email.d.ts +2 -0
- package/dist/backend/notifications/services/email-providers/send-email.js +34 -0
- package/dist/backend/notifications/services/email-providers/send-email.js.map +1 -0
- package/dist/backend/notifications/services/email-providers/sendgrid.provider.d.ts +9 -0
- package/dist/backend/notifications/services/email-providers/sendgrid.provider.js +59 -0
- package/dist/backend/notifications/services/email-providers/sendgrid.provider.js.map +1 -0
- package/dist/backend/notifications/services/notification-cron.service.d.ts +18 -0
- package/dist/backend/notifications/services/notification-cron.service.js +156 -0
- package/dist/backend/notifications/services/notification-cron.service.js.map +1 -0
- package/dist/backend/notifications/services/notification-email-address.service.d.ts +8 -0
- package/dist/backend/notifications/services/notification-email-address.service.js +32 -0
- package/dist/backend/notifications/services/notification-email-address.service.js.map +1 -0
- package/dist/backend/notifications/services/notification-email.service.d.ts +5 -0
- package/dist/backend/notifications/services/notification-email.service.js +33 -0
- package/dist/backend/notifications/services/notification-email.service.js.map +1 -0
- package/dist/backend/notifications/services/notification-rules.service.d.ts +17 -0
- package/dist/backend/notifications/services/notification-rules.service.js +120 -0
- package/dist/backend/notifications/services/notification-rules.service.js.map +1 -0
- package/dist/backend/otlp/guards/otlp-auth.guard.d.ts +15 -0
- package/dist/backend/otlp/guards/otlp-auth.guard.js +116 -0
- package/dist/backend/otlp/guards/otlp-auth.guard.js.map +1 -0
- package/dist/backend/otlp/interfaces/index.d.ts +4 -0
- package/dist/backend/otlp/interfaces/index.js +21 -0
- package/dist/backend/otlp/interfaces/index.js.map +1 -0
- package/dist/backend/otlp/interfaces/ingestion-context.interface.d.ts +6 -0
- package/dist/backend/otlp/interfaces/ingestion-context.interface.js +3 -0
- package/dist/backend/otlp/interfaces/ingestion-context.interface.js.map +1 -0
- package/dist/backend/otlp/interfaces/otlp-common.d.ts +26 -0
- package/dist/backend/otlp/interfaces/otlp-common.js +3 -0
- package/dist/backend/otlp/interfaces/otlp-common.js.map +1 -0
- package/dist/backend/otlp/interfaces/otlp-log.d.ts +22 -0
- package/dist/backend/otlp/interfaces/otlp-log.js +3 -0
- package/dist/backend/otlp/interfaces/otlp-log.js.map +1 -0
- package/dist/backend/otlp/interfaces/otlp-metric.d.ts +34 -0
- package/dist/backend/otlp/interfaces/otlp-metric.js +3 -0
- package/dist/backend/otlp/interfaces/otlp-metric.js.map +1 -0
- package/dist/backend/otlp/interfaces/otlp-trace.d.ts +33 -0
- package/dist/backend/otlp/interfaces/otlp-trace.js +3 -0
- package/dist/backend/otlp/interfaces/otlp-trace.js.map +1 -0
- package/dist/backend/otlp/otlp.controller.d.ts +38 -0
- package/dist/backend/otlp/otlp.controller.js +118 -0
- package/dist/backend/otlp/otlp.controller.js.map +1 -0
- package/dist/backend/otlp/otlp.module.d.ts +2 -0
- package/dist/backend/otlp/otlp.module.js +53 -0
- package/dist/backend/otlp/otlp.module.js.map +1 -0
- package/dist/backend/otlp/proto/otlp-proto-defs.d.ts +1 -0
- package/dist/backend/otlp/proto/otlp-proto-defs.js +187 -0
- package/dist/backend/otlp/proto/otlp-proto-defs.js.map +1 -0
- package/dist/backend/otlp/services/api-key.service.d.ts +28 -0
- package/dist/backend/otlp/services/api-key.service.js +129 -0
- package/dist/backend/otlp/services/api-key.service.js.map +1 -0
- package/dist/backend/otlp/services/log-ingest.service.d.ts +11 -0
- package/dist/backend/otlp/services/log-ingest.service.js +62 -0
- package/dist/backend/otlp/services/log-ingest.service.js.map +1 -0
- package/dist/backend/otlp/services/metric-ingest.service.d.ts +16 -0
- package/dist/backend/otlp/services/metric-ingest.service.js +122 -0
- package/dist/backend/otlp/services/metric-ingest.service.js.map +1 -0
- package/dist/backend/otlp/services/otlp-decoder.service.d.ts +14 -0
- package/dist/backend/otlp/services/otlp-decoder.service.js +86 -0
- package/dist/backend/otlp/services/otlp-decoder.service.js.map +1 -0
- package/dist/backend/otlp/services/otlp-helpers.d.ts +14 -0
- package/dist/backend/otlp/services/otlp-helpers.js +84 -0
- package/dist/backend/otlp/services/otlp-helpers.js.map +1 -0
- package/dist/backend/otlp/services/trace-ingest.service.d.ts +27 -0
- package/dist/backend/otlp/services/trace-ingest.service.js +221 -0
- package/dist/backend/otlp/services/trace-ingest.service.js.map +1 -0
- package/dist/backend/security/security.controller.d.ts +16 -0
- package/dist/backend/security/security.controller.js +48 -0
- package/dist/backend/security/security.controller.js.map +1 -0
- package/dist/backend/security/security.module.d.ts +2 -0
- package/dist/backend/security/security.module.js +25 -0
- package/dist/backend/security/security.module.js.map +1 -0
- package/dist/backend/security/security.service.d.ts +22 -0
- package/dist/backend/security/security.service.js +90 -0
- package/dist/backend/security/security.service.js.map +1 -0
- package/dist/backend/sse/sse.controller.d.ts +13 -0
- package/dist/backend/sse/sse.controller.js +45 -0
- package/dist/backend/sse/sse.controller.js.map +1 -0
- package/dist/backend/sse/sse.module.d.ts +2 -0
- package/dist/backend/sse/sse.module.js +20 -0
- package/dist/backend/sse/sse.module.js.map +1 -0
- package/dist/backend/telemetry/dto/create-telemetry.dto.d.ts +20 -0
- package/dist/backend/telemetry/dto/create-telemetry.dto.js +110 -0
- package/dist/backend/telemetry/dto/create-telemetry.dto.js.map +1 -0
- package/dist/backend/telemetry/telemetry.controller.d.ts +13 -0
- package/dist/backend/telemetry/telemetry.controller.js +51 -0
- package/dist/backend/telemetry/telemetry.controller.js.map +1 -0
- package/dist/backend/telemetry/telemetry.module.d.ts +2 -0
- package/dist/backend/telemetry/telemetry.module.js +27 -0
- package/dist/backend/telemetry/telemetry.module.js.map +1 -0
- package/dist/backend/telemetry/telemetry.service.d.ts +26 -0
- package/dist/backend/telemetry/telemetry.service.js +116 -0
- package/dist/backend/telemetry/telemetry.service.js.map +1 -0
- package/dist/index.js +20 -33
- package/dist/openclaw.plugin.json +88 -0
- package/dist/package.json +91 -0
- package/dist/server.d.ts +9 -0
- package/dist/server.js +68 -0
- package/openclaw.plugin.json +5 -5
- package/package.json +36 -5
- package/public/assets/EmailProviderConfig-myeg-mr1.js +1 -0
- package/public/assets/NotificationEmailSection-D4q7OFkR.js +1 -0
- package/public/assets/index-CyTg3_v5.js +5 -0
- package/public/assets/index-LhnDr_YD.css +1 -0
- package/public/example-messages-dark.svg +136 -0
- package/public/example-messages.svg +136 -0
- package/public/example-overview-dark.svg +77 -0
- package/public/example-overview.svg +77 -0
- package/public/favicon.ico +0 -0
- package/public/fonts/boxicons/boxicons-duotone.min.css +1 -0
- package/public/fonts/boxicons/boxicons-duotone.ttf +0 -0
- package/public/fonts/boxicons/boxicons-duotone.woff +0 -0
- package/public/fonts/bricolage-grotesque-latin-ext.woff2 +0 -0
- package/public/fonts/bricolage-grotesque-latin.woff2 +0 -0
- package/public/fonts/dm-sans-latin-ext.woff2 +0 -0
- package/public/fonts/dm-sans-latin.woff2 +0 -0
- package/public/fonts/jetbrains-mono-latin.woff2 +0 -0
- package/public/index.html +23 -0
- package/public/logo-white.svg +85 -0
- package/public/logo.png +0 -0
- package/public/logo.svg +240 -0
- package/public/og-image.png +0 -0
- package/public/theme-init.js +6 -0
package/README.md
CHANGED
|
@@ -1,48 +1,44 @@
|
|
|
1
1
|
# Manifest
|
|
2
2
|
|
|
3
|
-
Observability plugin for [OpenClaw](https://github.com/open-claw/open-claw). Collects traces, metrics, and cost data from your AI agent and
|
|
3
|
+
Observability plugin for [OpenClaw](https://github.com/open-claw/open-claw). Collects traces, metrics, and cost data from your AI agent and displays them in a local dashboard — zero configuration required.
|
|
4
4
|
|
|
5
5
|
## Install
|
|
6
6
|
|
|
7
7
|
```bash
|
|
8
8
|
openclaw plugins install manifest
|
|
9
|
-
openclaw config set plugins.entries.manifest.config.apiKey "mnfst_YOUR_KEY"
|
|
10
9
|
openclaw gateway restart
|
|
11
10
|
```
|
|
12
11
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
```bash
|
|
16
|
-
export MANIFEST_API_KEY=mnfst_YOUR_KEY
|
|
17
|
-
```
|
|
12
|
+
That's it. The plugin starts an embedded server with SQLite at `http://127.0.0.1:2099`. Open that URL to see your dashboard.
|
|
18
13
|
|
|
19
|
-
|
|
14
|
+
### Cloud mode
|
|
20
15
|
|
|
21
|
-
|
|
16
|
+
To send telemetry to the hosted platform at [app.manifest.build](https://app.manifest.build) instead:
|
|
22
17
|
|
|
23
18
|
```bash
|
|
24
|
-
openclaw
|
|
25
|
-
openclaw config set plugins.entries.manifest.config.
|
|
19
|
+
openclaw config set plugins.entries.manifest.config.mode cloud
|
|
20
|
+
openclaw config set plugins.entries.manifest.config.apiKey "mnfst_YOUR_KEY"
|
|
26
21
|
openclaw gateway restart
|
|
27
22
|
```
|
|
28
23
|
|
|
29
|
-
|
|
24
|
+
Or with environment variables:
|
|
30
25
|
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
| `port` | number | `2099` | Local server port |
|
|
35
|
-
| `host` | string | `127.0.0.1` | Local server bind address |
|
|
26
|
+
```bash
|
|
27
|
+
export MANIFEST_API_KEY=mnfst_YOUR_KEY
|
|
28
|
+
```
|
|
36
29
|
|
|
37
30
|
## Configuration
|
|
38
31
|
|
|
39
32
|
| Option | Type | Default | Description |
|
|
40
33
|
|--------|------|---------|-------------|
|
|
41
|
-
| `
|
|
42
|
-
| `
|
|
34
|
+
| `mode` | string | `local` | `local` for embedded server + SQLite, `cloud` for app.manifest.build |
|
|
35
|
+
| `apiKey` | string | env `MANIFEST_API_KEY` | Agent API key (`mnfst_*`). Required for cloud mode only. |
|
|
36
|
+
| `endpoint` | string | `https://app.manifest.build/otlp` | OTLP endpoint URL (cloud mode) |
|
|
43
37
|
| `serviceName` | string | `openclaw-gateway` | OpenTelemetry service name |
|
|
44
|
-
| `captureContent` | boolean | `false` | Include message content in spans |
|
|
45
|
-
| `metricsIntervalMs` | number | `30000` | Metrics export interval (min 5000ms) |
|
|
38
|
+
| `captureContent` | boolean | `false` | Include message content in spans. Always enabled in local mode. |
|
|
39
|
+
| `metricsIntervalMs` | number | `30000` | Metrics export interval (min 5000ms). 10s in local mode. |
|
|
40
|
+
| `port` | number | `2099` | Local server port (local mode only) |
|
|
41
|
+
| `host` | string | `127.0.0.1` | Local server bind address (local mode only) |
|
|
46
42
|
|
|
47
43
|
Point to a self-hosted instance:
|
|
48
44
|
|
|
@@ -110,15 +106,14 @@ Local testing:
|
|
|
110
106
|
|
|
111
107
|
```bash
|
|
112
108
|
openclaw plugins install -l ./packages/openclaw-plugin
|
|
113
|
-
openclaw config set plugins.entries.manifest.config.apiKey "mnfst_YOUR_KEY"
|
|
114
|
-
openclaw config set plugins.entries.manifest.config.endpoint "http://localhost:3001/otlp/v1"
|
|
115
109
|
openclaw gateway restart
|
|
110
|
+
# Dashboard at http://127.0.0.1:2099
|
|
116
111
|
```
|
|
117
112
|
|
|
118
113
|
## Troubleshooting
|
|
119
114
|
|
|
120
115
|
**No spans appearing?**
|
|
121
|
-
-
|
|
116
|
+
- In cloud mode, check your API key starts with `mnfst_`
|
|
122
117
|
- Verify the endpoint is reachable: `curl -I http://your-endpoint/v1/traces`
|
|
123
118
|
- Disable `diagnostics-otel` if enabled: `openclaw plugins disable diagnostics-otel`
|
|
124
119
|
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AnalyticsModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
12
|
+
const agent_message_entity_1 = require("../entities/agent-message.entity");
|
|
13
|
+
const agent_entity_1 = require("../entities/agent.entity");
|
|
14
|
+
const tenant_entity_1 = require("../entities/tenant.entity");
|
|
15
|
+
const otlp_module_1 = require("../otlp/otlp.module");
|
|
16
|
+
const aggregation_service_1 = require("./services/aggregation.service");
|
|
17
|
+
const timeseries_queries_service_1 = require("./services/timeseries-queries.service");
|
|
18
|
+
const agent_analytics_service_1 = require("./services/agent-analytics.service");
|
|
19
|
+
const overview_controller_1 = require("./controllers/overview.controller");
|
|
20
|
+
const tokens_controller_1 = require("./controllers/tokens.controller");
|
|
21
|
+
const costs_controller_1 = require("./controllers/costs.controller");
|
|
22
|
+
const messages_controller_1 = require("./controllers/messages.controller");
|
|
23
|
+
const agents_controller_1 = require("./controllers/agents.controller");
|
|
24
|
+
const agent_analytics_controller_1 = require("./controllers/agent-analytics.controller");
|
|
25
|
+
let AnalyticsModule = class AnalyticsModule {
|
|
26
|
+
};
|
|
27
|
+
exports.AnalyticsModule = AnalyticsModule;
|
|
28
|
+
exports.AnalyticsModule = AnalyticsModule = __decorate([
|
|
29
|
+
(0, common_1.Module)({
|
|
30
|
+
imports: [
|
|
31
|
+
typeorm_1.TypeOrmModule.forFeature([agent_message_entity_1.AgentMessage, agent_entity_1.Agent, tenant_entity_1.Tenant]),
|
|
32
|
+
otlp_module_1.OtlpModule,
|
|
33
|
+
],
|
|
34
|
+
controllers: [
|
|
35
|
+
overview_controller_1.OverviewController,
|
|
36
|
+
tokens_controller_1.TokensController,
|
|
37
|
+
costs_controller_1.CostsController,
|
|
38
|
+
messages_controller_1.MessagesController,
|
|
39
|
+
agents_controller_1.AgentsController,
|
|
40
|
+
agent_analytics_controller_1.AgentAnalyticsController,
|
|
41
|
+
],
|
|
42
|
+
providers: [aggregation_service_1.AggregationService, timeseries_queries_service_1.TimeseriesQueriesService, agent_analytics_service_1.AgentAnalyticsService],
|
|
43
|
+
})
|
|
44
|
+
], AnalyticsModule);
|
|
45
|
+
//# sourceMappingURL=analytics.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"analytics.module.js","sourceRoot":"","sources":["../../src/analytics/analytics.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,6CAAgD;AAChD,2EAAgE;AAChE,2DAAiD;AACjD,6DAAmD;AACnD,qDAAiD;AACjD,wEAAoE;AACpE,sFAAiF;AACjF,gFAA2E;AAC3E,2EAAuE;AACvE,uEAAmE;AACnE,qEAAiE;AACjE,2EAAuE;AACvE,uEAAmE;AACnE,yFAAoF;AAiB7E,IAAM,eAAe,GAArB,MAAM,eAAe;CAAG,CAAA;AAAlB,0CAAe;0BAAf,eAAe;IAf3B,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,mCAAY,EAAE,oBAAK,EAAE,sBAAM,CAAC,CAAC;YACvD,wBAAU;SACX;QACD,WAAW,EAAE;YACX,wCAAkB;YAClB,oCAAgB;YAChB,kCAAe;YACf,wCAAkB;YAClB,oCAAgB;YAChB,qDAAwB;SACzB;QACD,SAAS,EAAE,CAAC,wCAAkB,EAAE,qDAAwB,EAAE,+CAAqB,CAAC;KACjF,CAAC;GACW,eAAe,CAAG"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Request } from 'express';
|
|
2
|
+
import { IngestionContext } from '../../otlp/interfaces/ingestion-context.interface';
|
|
3
|
+
import { AgentAnalyticsService } from '../services/agent-analytics.service';
|
|
4
|
+
import { RangeQueryDto } from '../../common/dto/range-query.dto';
|
|
5
|
+
interface AuthenticatedRequest extends Request {
|
|
6
|
+
ingestionContext: IngestionContext;
|
|
7
|
+
}
|
|
8
|
+
export declare class AgentAnalyticsController {
|
|
9
|
+
private readonly analytics;
|
|
10
|
+
constructor(analytics: AgentAnalyticsService);
|
|
11
|
+
getUsage(query: RangeQueryDto, req: AuthenticatedRequest): Promise<import("../services/agent-analytics.service").AgentUsageResult>;
|
|
12
|
+
getCosts(query: RangeQueryDto, req: AuthenticatedRequest): Promise<import("../services/agent-analytics.service").AgentCostsResult>;
|
|
13
|
+
}
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.AgentAnalyticsController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const public_decorator_1 = require("../../common/decorators/public.decorator");
|
|
18
|
+
const otlp_auth_guard_1 = require("../../otlp/guards/otlp-auth.guard");
|
|
19
|
+
const agent_analytics_service_1 = require("../services/agent-analytics.service");
|
|
20
|
+
const range_query_dto_1 = require("../../common/dto/range-query.dto");
|
|
21
|
+
let AgentAnalyticsController = class AgentAnalyticsController {
|
|
22
|
+
analytics;
|
|
23
|
+
constructor(analytics) {
|
|
24
|
+
this.analytics = analytics;
|
|
25
|
+
}
|
|
26
|
+
async getUsage(query, req) {
|
|
27
|
+
const range = query.range ?? '24h';
|
|
28
|
+
const ctx = req.ingestionContext;
|
|
29
|
+
return this.analytics.getUsage(range, ctx);
|
|
30
|
+
}
|
|
31
|
+
async getCosts(query, req) {
|
|
32
|
+
const range = query.range ?? '7d';
|
|
33
|
+
const ctx = req.ingestionContext;
|
|
34
|
+
return this.analytics.getCosts(range, ctx);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
exports.AgentAnalyticsController = AgentAnalyticsController;
|
|
38
|
+
__decorate([
|
|
39
|
+
(0, common_1.Get)('usage'),
|
|
40
|
+
__param(0, (0, common_1.Query)()),
|
|
41
|
+
__param(1, (0, common_1.Req)()),
|
|
42
|
+
__metadata("design:type", Function),
|
|
43
|
+
__metadata("design:paramtypes", [range_query_dto_1.RangeQueryDto, Object]),
|
|
44
|
+
__metadata("design:returntype", Promise)
|
|
45
|
+
], AgentAnalyticsController.prototype, "getUsage", null);
|
|
46
|
+
__decorate([
|
|
47
|
+
(0, common_1.Get)('costs'),
|
|
48
|
+
__param(0, (0, common_1.Query)()),
|
|
49
|
+
__param(1, (0, common_1.Req)()),
|
|
50
|
+
__metadata("design:type", Function),
|
|
51
|
+
__metadata("design:paramtypes", [range_query_dto_1.RangeQueryDto, Object]),
|
|
52
|
+
__metadata("design:returntype", Promise)
|
|
53
|
+
], AgentAnalyticsController.prototype, "getCosts", null);
|
|
54
|
+
exports.AgentAnalyticsController = AgentAnalyticsController = __decorate([
|
|
55
|
+
(0, common_1.Controller)('api/v1/agent'),
|
|
56
|
+
(0, public_decorator_1.Public)(),
|
|
57
|
+
(0, common_1.UseGuards)(otlp_auth_guard_1.OtlpAuthGuard),
|
|
58
|
+
__metadata("design:paramtypes", [agent_analytics_service_1.AgentAnalyticsService])
|
|
59
|
+
], AgentAnalyticsController);
|
|
60
|
+
//# sourceMappingURL=agent-analytics.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-analytics.controller.js","sourceRoot":"","sources":["../../../src/analytics/controllers/agent-analytics.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAwE;AAExE,+EAAkE;AAClE,uEAAkE;AAElE,iFAA4E;AAC5E,sEAAiE;AAS1D,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IACN;IAA7B,YAA6B,SAAgC;QAAhC,cAAS,GAAT,SAAS,CAAuB;IAAG,CAAC;IAG3D,AAAN,KAAK,CAAC,QAAQ,CACH,KAAoB,EACtB,GAAyB;QAEhC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC;QACnC,MAAM,GAAG,GAAG,GAAG,CAAC,gBAAgB,CAAC;QACjC,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC7C,CAAC;IAGK,AAAN,KAAK,CAAC,QAAQ,CACH,KAAoB,EACtB,GAAyB;QAEhC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC;QAClC,MAAM,GAAG,GAAG,GAAG,CAAC,gBAAgB,CAAC;QACjC,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC7C,CAAC;CACF,CAAA;AAtBY,4DAAwB;AAI7B;IADL,IAAA,YAAG,EAAC,OAAO,CAAC;IAEV,WAAA,IAAA,cAAK,GAAE,CAAA;IACP,WAAA,IAAA,YAAG,GAAE,CAAA;;qCADU,+BAAa;;wDAM9B;AAGK;IADL,IAAA,YAAG,EAAC,OAAO,CAAC;IAEV,WAAA,IAAA,cAAK,GAAE,CAAA;IACP,WAAA,IAAA,YAAG,GAAE,CAAA;;qCADU,+BAAa;;wDAM9B;mCArBU,wBAAwB;IAHpC,IAAA,mBAAU,EAAC,cAAc,CAAC;IAC1B,IAAA,yBAAM,GAAE;IACR,IAAA,kBAAS,EAAC,+BAAa,CAAC;qCAEiB,+CAAqB;GADlD,wBAAwB,CAsBpC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { ConfigService } from '@nestjs/config';
|
|
2
|
+
import { TimeseriesQueriesService } from '../services/timeseries-queries.service';
|
|
3
|
+
import { AggregationService } from '../services/aggregation.service';
|
|
4
|
+
import { ApiKeyGeneratorService } from '../../otlp/services/api-key.service';
|
|
5
|
+
import { AuthUser } from '../../auth/auth.instance';
|
|
6
|
+
import { CreateAgentDto } from '../../common/dto/create-agent.dto';
|
|
7
|
+
export declare class AgentsController {
|
|
8
|
+
private readonly timeseries;
|
|
9
|
+
private readonly aggregation;
|
|
10
|
+
private readonly apiKeyGenerator;
|
|
11
|
+
private readonly config;
|
|
12
|
+
constructor(timeseries: TimeseriesQueriesService, aggregation: AggregationService, apiKeyGenerator: ApiKeyGeneratorService, config: ConfigService);
|
|
13
|
+
getAgents(user: AuthUser): Promise<{
|
|
14
|
+
agents: {
|
|
15
|
+
agent_name: string;
|
|
16
|
+
message_count: number;
|
|
17
|
+
last_active: string;
|
|
18
|
+
total_cost: number;
|
|
19
|
+
total_tokens: number;
|
|
20
|
+
sparkline: number[];
|
|
21
|
+
}[];
|
|
22
|
+
}>;
|
|
23
|
+
createAgent(user: AuthUser, body: CreateAgentDto): Promise<{
|
|
24
|
+
agent: {
|
|
25
|
+
id: string;
|
|
26
|
+
name: string;
|
|
27
|
+
};
|
|
28
|
+
apiKey: string;
|
|
29
|
+
}>;
|
|
30
|
+
getAgentKey(user: AuthUser, agentName: string): Promise<{
|
|
31
|
+
pluginEndpoint?: string | undefined;
|
|
32
|
+
keyPrefix: string;
|
|
33
|
+
}>;
|
|
34
|
+
rotateAgentKey(user: AuthUser, agentName: string): Promise<{
|
|
35
|
+
apiKey: string;
|
|
36
|
+
}>;
|
|
37
|
+
deleteAgent(user: AuthUser, agentName: string): Promise<{
|
|
38
|
+
deleted: boolean;
|
|
39
|
+
}>;
|
|
40
|
+
}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.AgentsController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const cache_manager_1 = require("@nestjs/cache-manager");
|
|
18
|
+
const config_1 = require("@nestjs/config");
|
|
19
|
+
const timeseries_queries_service_1 = require("../services/timeseries-queries.service");
|
|
20
|
+
const aggregation_service_1 = require("../services/aggregation.service");
|
|
21
|
+
const api_key_service_1 = require("../../otlp/services/api-key.service");
|
|
22
|
+
const current_user_decorator_1 = require("../../auth/current-user.decorator");
|
|
23
|
+
const create_agent_dto_1 = require("../../common/dto/create-agent.dto");
|
|
24
|
+
const user_cache_interceptor_1 = require("../../common/interceptors/user-cache.interceptor");
|
|
25
|
+
const cache_constants_1 = require("../../common/constants/cache.constants");
|
|
26
|
+
let AgentsController = class AgentsController {
|
|
27
|
+
timeseries;
|
|
28
|
+
aggregation;
|
|
29
|
+
apiKeyGenerator;
|
|
30
|
+
config;
|
|
31
|
+
constructor(timeseries, aggregation, apiKeyGenerator, config) {
|
|
32
|
+
this.timeseries = timeseries;
|
|
33
|
+
this.aggregation = aggregation;
|
|
34
|
+
this.apiKeyGenerator = apiKeyGenerator;
|
|
35
|
+
this.config = config;
|
|
36
|
+
}
|
|
37
|
+
async getAgents(user) {
|
|
38
|
+
const agents = await this.timeseries.getAgentList(user.id);
|
|
39
|
+
return { agents };
|
|
40
|
+
}
|
|
41
|
+
async createAgent(user, body) {
|
|
42
|
+
const result = await this.apiKeyGenerator.onboardAgent({
|
|
43
|
+
tenantName: user.id,
|
|
44
|
+
agentName: body.name,
|
|
45
|
+
email: user.email,
|
|
46
|
+
});
|
|
47
|
+
return { agent: { id: result.agentId, name: body.name }, apiKey: result.apiKey };
|
|
48
|
+
}
|
|
49
|
+
async getAgentKey(user, agentName) {
|
|
50
|
+
const keyData = await this.apiKeyGenerator.getKeyForAgent(user.id, agentName);
|
|
51
|
+
const customEndpoint = this.config.get('app.pluginOtlpEndpoint', '');
|
|
52
|
+
return {
|
|
53
|
+
...keyData,
|
|
54
|
+
...(customEndpoint ? { pluginEndpoint: customEndpoint } : {}),
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
async rotateAgentKey(user, agentName) {
|
|
58
|
+
const result = await this.apiKeyGenerator.rotateKey(user.id, agentName);
|
|
59
|
+
return { apiKey: result.apiKey };
|
|
60
|
+
}
|
|
61
|
+
async deleteAgent(user, agentName) {
|
|
62
|
+
await this.aggregation.deleteAgent(user.id, agentName);
|
|
63
|
+
return { deleted: true };
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
exports.AgentsController = AgentsController;
|
|
67
|
+
__decorate([
|
|
68
|
+
(0, common_1.Get)('agents'),
|
|
69
|
+
(0, common_1.UseInterceptors)(user_cache_interceptor_1.UserCacheInterceptor),
|
|
70
|
+
(0, cache_manager_1.CacheTTL)(cache_constants_1.DASHBOARD_CACHE_TTL_MS),
|
|
71
|
+
__param(0, (0, current_user_decorator_1.CurrentUser)()),
|
|
72
|
+
__metadata("design:type", Function),
|
|
73
|
+
__metadata("design:paramtypes", [Object]),
|
|
74
|
+
__metadata("design:returntype", Promise)
|
|
75
|
+
], AgentsController.prototype, "getAgents", null);
|
|
76
|
+
__decorate([
|
|
77
|
+
(0, common_1.Post)('agents'),
|
|
78
|
+
__param(0, (0, current_user_decorator_1.CurrentUser)()),
|
|
79
|
+
__param(1, (0, common_1.Body)()),
|
|
80
|
+
__metadata("design:type", Function),
|
|
81
|
+
__metadata("design:paramtypes", [Object, create_agent_dto_1.CreateAgentDto]),
|
|
82
|
+
__metadata("design:returntype", Promise)
|
|
83
|
+
], AgentsController.prototype, "createAgent", null);
|
|
84
|
+
__decorate([
|
|
85
|
+
(0, common_1.Get)('agents/:agentName/key'),
|
|
86
|
+
__param(0, (0, current_user_decorator_1.CurrentUser)()),
|
|
87
|
+
__param(1, (0, common_1.Param)('agentName')),
|
|
88
|
+
__metadata("design:type", Function),
|
|
89
|
+
__metadata("design:paramtypes", [Object, String]),
|
|
90
|
+
__metadata("design:returntype", Promise)
|
|
91
|
+
], AgentsController.prototype, "getAgentKey", null);
|
|
92
|
+
__decorate([
|
|
93
|
+
(0, common_1.Post)('agents/:agentName/rotate-key'),
|
|
94
|
+
__param(0, (0, current_user_decorator_1.CurrentUser)()),
|
|
95
|
+
__param(1, (0, common_1.Param)('agentName')),
|
|
96
|
+
__metadata("design:type", Function),
|
|
97
|
+
__metadata("design:paramtypes", [Object, String]),
|
|
98
|
+
__metadata("design:returntype", Promise)
|
|
99
|
+
], AgentsController.prototype, "rotateAgentKey", null);
|
|
100
|
+
__decorate([
|
|
101
|
+
(0, common_1.Delete)('agents/:agentName'),
|
|
102
|
+
__param(0, (0, current_user_decorator_1.CurrentUser)()),
|
|
103
|
+
__param(1, (0, common_1.Param)('agentName')),
|
|
104
|
+
__metadata("design:type", Function),
|
|
105
|
+
__metadata("design:paramtypes", [Object, String]),
|
|
106
|
+
__metadata("design:returntype", Promise)
|
|
107
|
+
], AgentsController.prototype, "deleteAgent", null);
|
|
108
|
+
exports.AgentsController = AgentsController = __decorate([
|
|
109
|
+
(0, common_1.Controller)('api/v1'),
|
|
110
|
+
__metadata("design:paramtypes", [timeseries_queries_service_1.TimeseriesQueriesService,
|
|
111
|
+
aggregation_service_1.AggregationService,
|
|
112
|
+
api_key_service_1.ApiKeyGeneratorService,
|
|
113
|
+
config_1.ConfigService])
|
|
114
|
+
], AgentsController);
|
|
115
|
+
//# sourceMappingURL=agents.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agents.controller.js","sourceRoot":"","sources":["../../../src/analytics/controllers/agents.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA6F;AAC7F,yDAAiD;AACjD,2CAA+C;AAC/C,uFAAkF;AAClF,yEAAqE;AACrE,yEAA6E;AAC7E,8EAAgE;AAEhE,wEAAmE;AACnE,6FAAwF;AACxF,4EAAgF;AAGzE,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAER;IACA;IACA;IACA;IAJnB,YACmB,UAAoC,EACpC,WAA+B,EAC/B,eAAuC,EACvC,MAAqB;QAHrB,eAAU,GAAV,UAAU,CAA0B;QACpC,gBAAW,GAAX,WAAW,CAAoB;QAC/B,oBAAe,GAAf,eAAe,CAAwB;QACvC,WAAM,GAAN,MAAM,CAAe;IACrC,CAAC;IAKE,AAAN,KAAK,CAAC,SAAS,CAAgB,IAAc;QAC3C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC3D,OAAO,EAAE,MAAM,EAAE,CAAC;IACpB,CAAC;IAGK,AAAN,KAAK,CAAC,WAAW,CAAgB,IAAc,EAAU,IAAoB;QAC3E,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC;YACrD,UAAU,EAAE,IAAI,CAAC,EAAE;YACnB,SAAS,EAAE,IAAI,CAAC,IAAI;YACpB,KAAK,EAAE,IAAI,CAAC,KAAK;SAClB,CAAC,CAAC;QACH,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;IACnF,CAAC;IAGK,AAAN,KAAK,CAAC,WAAW,CAAgB,IAAc,EAAsB,SAAiB;QACpF,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QAC9E,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAS,wBAAwB,EAAE,EAAE,CAAC,CAAC;QAC7E,OAAO;YACL,GAAG,OAAO;YACV,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,cAAc,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC9D,CAAC;IACJ,CAAC;IAGK,AAAN,KAAK,CAAC,cAAc,CAAgB,IAAc,EAAsB,SAAiB;QACvF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QACxE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;IACnC,CAAC;IAGK,AAAN,KAAK,CAAC,WAAW,CAAgB,IAAc,EAAsB,SAAiB;QACpF,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QACvD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC3B,CAAC;CACF,CAAA;AA/CY,4CAAgB;AAWrB;IAHL,IAAA,YAAG,EAAC,QAAQ,CAAC;IACb,IAAA,wBAAe,EAAC,6CAAoB,CAAC;IACrC,IAAA,wBAAQ,EAAC,wCAAsB,CAAC;IAChB,WAAA,IAAA,oCAAW,GAAE,CAAA;;;;iDAG7B;AAGK;IADL,IAAA,aAAI,EAAC,QAAQ,CAAC;IACI,WAAA,IAAA,oCAAW,GAAE,CAAA;IAAkB,WAAA,IAAA,aAAI,GAAE,CAAA;;6CAAO,iCAAc;;mDAO5E;AAGK;IADL,IAAA,YAAG,EAAC,uBAAuB,CAAC;IACV,WAAA,IAAA,oCAAW,GAAE,CAAA;IAAkB,WAAA,IAAA,cAAK,EAAC,WAAW,CAAC,CAAA;;;;mDAOnE;AAGK;IADL,IAAA,aAAI,EAAC,8BAA8B,CAAC;IACf,WAAA,IAAA,oCAAW,GAAE,CAAA;IAAkB,WAAA,IAAA,cAAK,EAAC,WAAW,CAAC,CAAA;;;;sDAGtE;AAGK;IADL,IAAA,eAAM,EAAC,mBAAmB,CAAC;IACT,WAAA,IAAA,oCAAW,GAAE,CAAA;IAAkB,WAAA,IAAA,cAAK,EAAC,WAAW,CAAC,CAAA;;;;mDAGnE;2BA9CU,gBAAgB;IAD5B,IAAA,mBAAU,EAAC,QAAQ,CAAC;qCAGY,qDAAwB;QACvB,wCAAkB;QACd,wCAAsB;QAC/B,sBAAa;GAL7B,gBAAgB,CA+C5B"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { RangeQueryDto } from '../../common/dto/range-query.dto';
|
|
2
|
+
import { AggregationService } from '../services/aggregation.service';
|
|
3
|
+
import { TimeseriesQueriesService } from '../services/timeseries-queries.service';
|
|
4
|
+
import { AuthUser } from '../../auth/auth.instance';
|
|
5
|
+
export declare class CostsController {
|
|
6
|
+
private readonly aggregation;
|
|
7
|
+
private readonly timeseries;
|
|
8
|
+
constructor(aggregation: AggregationService, timeseries: TimeseriesQueriesService);
|
|
9
|
+
getCosts(query: RangeQueryDto, user: AuthUser): Promise<{
|
|
10
|
+
summary: {
|
|
11
|
+
weekly_cost: import("../services/query-helpers").MetricWithTrend;
|
|
12
|
+
};
|
|
13
|
+
daily: {
|
|
14
|
+
date: string;
|
|
15
|
+
cost: number;
|
|
16
|
+
}[];
|
|
17
|
+
hourly: {
|
|
18
|
+
hour: string;
|
|
19
|
+
cost: number;
|
|
20
|
+
}[];
|
|
21
|
+
by_model: {
|
|
22
|
+
model: string;
|
|
23
|
+
tokens: number;
|
|
24
|
+
share_pct: number;
|
|
25
|
+
estimated_cost: number;
|
|
26
|
+
}[];
|
|
27
|
+
}>;
|
|
28
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.CostsController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const cache_manager_1 = require("@nestjs/cache-manager");
|
|
18
|
+
const range_query_dto_1 = require("../../common/dto/range-query.dto");
|
|
19
|
+
const aggregation_service_1 = require("../services/aggregation.service");
|
|
20
|
+
const timeseries_queries_service_1 = require("../services/timeseries-queries.service");
|
|
21
|
+
const current_user_decorator_1 = require("../../auth/current-user.decorator");
|
|
22
|
+
const user_cache_interceptor_1 = require("../../common/interceptors/user-cache.interceptor");
|
|
23
|
+
const cache_constants_1 = require("../../common/constants/cache.constants");
|
|
24
|
+
let CostsController = class CostsController {
|
|
25
|
+
aggregation;
|
|
26
|
+
timeseries;
|
|
27
|
+
constructor(aggregation, timeseries) {
|
|
28
|
+
this.aggregation = aggregation;
|
|
29
|
+
this.timeseries = timeseries;
|
|
30
|
+
}
|
|
31
|
+
async getCosts(query, user) {
|
|
32
|
+
const range = query.range ?? '7d';
|
|
33
|
+
const agentName = query.agent_name;
|
|
34
|
+
const [costSummary, daily, hourly, byModel] = await Promise.all([
|
|
35
|
+
this.aggregation.getCostSummary(range, user.id, agentName),
|
|
36
|
+
this.timeseries.getDailyCosts(range, user.id, agentName),
|
|
37
|
+
this.timeseries.getHourlyCosts(range, user.id, agentName),
|
|
38
|
+
this.timeseries.getCostByModel(range, user.id, agentName),
|
|
39
|
+
]);
|
|
40
|
+
return {
|
|
41
|
+
summary: { weekly_cost: costSummary },
|
|
42
|
+
daily,
|
|
43
|
+
hourly,
|
|
44
|
+
by_model: byModel,
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
exports.CostsController = CostsController;
|
|
49
|
+
__decorate([
|
|
50
|
+
(0, common_1.Get)('costs'),
|
|
51
|
+
__param(0, (0, common_1.Query)()),
|
|
52
|
+
__param(1, (0, current_user_decorator_1.CurrentUser)()),
|
|
53
|
+
__metadata("design:type", Function),
|
|
54
|
+
__metadata("design:paramtypes", [range_query_dto_1.RangeQueryDto, Object]),
|
|
55
|
+
__metadata("design:returntype", Promise)
|
|
56
|
+
], CostsController.prototype, "getCosts", null);
|
|
57
|
+
exports.CostsController = CostsController = __decorate([
|
|
58
|
+
(0, common_1.Controller)('api/v1'),
|
|
59
|
+
(0, common_1.UseInterceptors)(user_cache_interceptor_1.UserCacheInterceptor),
|
|
60
|
+
(0, cache_manager_1.CacheTTL)(cache_constants_1.DASHBOARD_CACHE_TTL_MS),
|
|
61
|
+
__metadata("design:paramtypes", [aggregation_service_1.AggregationService,
|
|
62
|
+
timeseries_queries_service_1.TimeseriesQueriesService])
|
|
63
|
+
], CostsController);
|
|
64
|
+
//# sourceMappingURL=costs.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"costs.controller.js","sourceRoot":"","sources":["../../../src/analytics/controllers/costs.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAyE;AACzE,yDAAiD;AACjD,sEAAiE;AACjE,yEAAqE;AACrE,uFAAkF;AAClF,8EAAgE;AAEhE,6FAAwF;AACxF,4EAAgF;AAKzE,IAAM,eAAe,GAArB,MAAM,eAAe;IAEP;IACA;IAFnB,YACmB,WAA+B,EAC/B,UAAoC;QADpC,gBAAW,GAAX,WAAW,CAAoB;QAC/B,eAAU,GAAV,UAAU,CAA0B;IACpD,CAAC;IAGE,AAAN,KAAK,CAAC,QAAQ,CAAU,KAAoB,EAAiB,IAAc;QACzE,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC;QAClC,MAAM,SAAS,GAAG,KAAK,CAAC,UAAU,CAAC;QAEnC,MAAM,CAAC,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YAC9D,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,SAAS,CAAC;YAC1D,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,SAAS,CAAC;YACxD,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,SAAS,CAAC;YACzD,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,SAAS,CAAC;SAC1D,CAAC,CAAC;QAEH,OAAO;YACL,OAAO,EAAE,EAAE,WAAW,EAAE,WAAW,EAAE;YACrC,KAAK;YACL,MAAM;YACN,QAAQ,EAAE,OAAO;SAClB,CAAC;IACJ,CAAC;CACF,CAAA;AAzBY,0CAAe;AAOpB;IADL,IAAA,YAAG,EAAC,OAAO,CAAC;IACG,WAAA,IAAA,cAAK,GAAE,CAAA;IAAwB,WAAA,IAAA,oCAAW,GAAE,CAAA;;qCAA7B,+BAAa;;+CAiB3C;0BAxBU,eAAe;IAH3B,IAAA,mBAAU,EAAC,QAAQ,CAAC;IACpB,IAAA,wBAAe,EAAC,6CAAoB,CAAC;IACrC,IAAA,wBAAQ,EAAC,wCAAsB,CAAC;qCAGC,wCAAkB;QACnB,qDAAwB;GAH5C,eAAe,CAyB3B"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { MessagesQueryDto } from '../dto/messages-query.dto';
|
|
2
|
+
import { AggregationService } from '../services/aggregation.service';
|
|
3
|
+
import { AuthUser } from '../../auth/auth.instance';
|
|
4
|
+
export declare class MessagesController {
|
|
5
|
+
private readonly aggregation;
|
|
6
|
+
constructor(aggregation: AggregationService);
|
|
7
|
+
getMessages(query: MessagesQueryDto, user: AuthUser): Promise<{
|
|
8
|
+
items: any[];
|
|
9
|
+
next_cursor: string | null;
|
|
10
|
+
total_count: number;
|
|
11
|
+
models: string[];
|
|
12
|
+
}>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.MessagesController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const messages_query_dto_1 = require("../dto/messages-query.dto");
|
|
18
|
+
const aggregation_service_1 = require("../services/aggregation.service");
|
|
19
|
+
const current_user_decorator_1 = require("../../auth/current-user.decorator");
|
|
20
|
+
let MessagesController = class MessagesController {
|
|
21
|
+
aggregation;
|
|
22
|
+
constructor(aggregation) {
|
|
23
|
+
this.aggregation = aggregation;
|
|
24
|
+
}
|
|
25
|
+
async getMessages(query, user) {
|
|
26
|
+
return this.aggregation.getMessages({
|
|
27
|
+
range: query.range,
|
|
28
|
+
userId: user.id,
|
|
29
|
+
status: query.status,
|
|
30
|
+
service_type: query.service_type,
|
|
31
|
+
model: query.model,
|
|
32
|
+
cost_min: query.cost_min,
|
|
33
|
+
cost_max: query.cost_max,
|
|
34
|
+
limit: Math.min(query.limit ?? 50, 200),
|
|
35
|
+
cursor: query.cursor,
|
|
36
|
+
agent_name: query.agent_name,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
exports.MessagesController = MessagesController;
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, common_1.Get)('messages'),
|
|
43
|
+
__param(0, (0, common_1.Query)()),
|
|
44
|
+
__param(1, (0, current_user_decorator_1.CurrentUser)()),
|
|
45
|
+
__metadata("design:type", Function),
|
|
46
|
+
__metadata("design:paramtypes", [messages_query_dto_1.MessagesQueryDto, Object]),
|
|
47
|
+
__metadata("design:returntype", Promise)
|
|
48
|
+
], MessagesController.prototype, "getMessages", null);
|
|
49
|
+
exports.MessagesController = MessagesController = __decorate([
|
|
50
|
+
(0, common_1.Controller)('api/v1'),
|
|
51
|
+
__metadata("design:paramtypes", [aggregation_service_1.AggregationService])
|
|
52
|
+
], MessagesController);
|
|
53
|
+
//# sourceMappingURL=messages.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"messages.controller.js","sourceRoot":"","sources":["../../../src/analytics/controllers/messages.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAwD;AACxD,kEAA6D;AAC7D,yEAAqE;AACrE,8EAAgE;AAIzD,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IACA;IAA7B,YAA6B,WAA+B;QAA/B,gBAAW,GAAX,WAAW,CAAoB;IAAG,CAAC;IAG1D,AAAN,KAAK,CAAC,WAAW,CAAU,KAAuB,EAAiB,IAAc;QAC/E,OAAO,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC;YAClC,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,MAAM,EAAE,IAAI,CAAC,EAAE;YACf,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE,EAAE,GAAG,CAAC;YACvC,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,UAAU,EAAE,KAAK,CAAC,UAAU;SAC7B,CAAC,CAAC;IACL,CAAC;CACF,CAAA;AAlBY,gDAAkB;AAIvB;IADL,IAAA,YAAG,EAAC,UAAU,CAAC;IACG,WAAA,IAAA,cAAK,GAAE,CAAA;IAA2B,WAAA,IAAA,oCAAW,GAAE,CAAA;;qCAAhC,qCAAgB;;qDAajD;6BAjBU,kBAAkB;IAD9B,IAAA,mBAAU,EAAC,QAAQ,CAAC;qCAEuB,wCAAkB;GADjD,kBAAkB,CAkB9B"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { RangeQueryDto } from '../../common/dto/range-query.dto';
|
|
2
|
+
import { AggregationService } from '../services/aggregation.service';
|
|
3
|
+
import { TimeseriesQueriesService } from '../services/timeseries-queries.service';
|
|
4
|
+
import { AuthUser } from '../../auth/auth.instance';
|
|
5
|
+
export declare class OverviewController {
|
|
6
|
+
private readonly aggregation;
|
|
7
|
+
private readonly timeseries;
|
|
8
|
+
constructor(aggregation: AggregationService, timeseries: TimeseriesQueriesService);
|
|
9
|
+
getOverview(query: RangeQueryDto, user: AuthUser): Promise<{
|
|
10
|
+
summary: {
|
|
11
|
+
tokens_today: import("../services/query-helpers").MetricWithTrend;
|
|
12
|
+
cost_today: import("../services/query-helpers").MetricWithTrend;
|
|
13
|
+
messages: import("../services/query-helpers").MetricWithTrend;
|
|
14
|
+
services_hit: {
|
|
15
|
+
total: number;
|
|
16
|
+
healthy: number;
|
|
17
|
+
issues: number;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
token_usage: {
|
|
21
|
+
hour: string;
|
|
22
|
+
input_tokens: number;
|
|
23
|
+
output_tokens: number;
|
|
24
|
+
}[] | {
|
|
25
|
+
date: string;
|
|
26
|
+
input_tokens: number;
|
|
27
|
+
output_tokens: number;
|
|
28
|
+
}[];
|
|
29
|
+
cost_usage: {
|
|
30
|
+
hour: string;
|
|
31
|
+
cost: number;
|
|
32
|
+
}[] | {
|
|
33
|
+
date: string;
|
|
34
|
+
cost: number;
|
|
35
|
+
}[];
|
|
36
|
+
message_usage: {
|
|
37
|
+
hour: string;
|
|
38
|
+
count: number;
|
|
39
|
+
}[] | {
|
|
40
|
+
date: string;
|
|
41
|
+
count: number;
|
|
42
|
+
}[];
|
|
43
|
+
cost_by_model: {
|
|
44
|
+
model: string;
|
|
45
|
+
tokens: number;
|
|
46
|
+
share_pct: number;
|
|
47
|
+
estimated_cost: number;
|
|
48
|
+
}[];
|
|
49
|
+
recent_activity: any[];
|
|
50
|
+
active_skills: {
|
|
51
|
+
name: string;
|
|
52
|
+
agent_name: string | null;
|
|
53
|
+
run_count: number;
|
|
54
|
+
last_active_at: string;
|
|
55
|
+
status: "active";
|
|
56
|
+
}[];
|
|
57
|
+
has_data: boolean;
|
|
58
|
+
}>;
|
|
59
|
+
}
|