ingest.go 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. // NewGetUsageDashboardHandler returns a new GetUsageDashboardHandler
  2. package billing
  3. import (
  4. "net/http"
  5. "github.com/porter-dev/porter/api/server/handlers"
  6. "github.com/porter-dev/porter/api/server/shared"
  7. "github.com/porter-dev/porter/api/server/shared/apierrors"
  8. "github.com/porter-dev/porter/api/server/shared/config"
  9. "github.com/porter-dev/porter/api/types"
  10. "github.com/porter-dev/porter/internal/models"
  11. "github.com/porter-dev/porter/internal/telemetry"
  12. )
  13. // IngestEventsHandler is a handler for ingesting billing events
  14. type IngestEventsHandler struct {
  15. handlers.PorterHandlerReadWriter
  16. }
  17. // NewIngestEventsHandler returns a new IngestEventsHandler
  18. func NewIngestEventsHandler(
  19. config *config.Config,
  20. decoderValidator shared.RequestDecoderValidator,
  21. writer shared.ResultWriter,
  22. ) *IngestEventsHandler {
  23. return &IngestEventsHandler{
  24. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  25. }
  26. }
  27. func (c *IngestEventsHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  28. ctx, span := telemetry.NewSpan(r.Context(), "serve-ingest-events")
  29. defer span.End()
  30. proj, _ := ctx.Value(types.ProjectScope).(*models.Project)
  31. if !c.Config().BillingManager.MetronomeEnabled || !proj.GetFeatureFlag(models.MetronomeEnabled, c.Config().LaunchDarklyClient) {
  32. c.WriteResult(w, r, "")
  33. telemetry.WithAttributes(span,
  34. telemetry.AttributeKV{Key: "metronome-enabled", Value: false},
  35. )
  36. return
  37. }
  38. telemetry.WithAttributes(span,
  39. telemetry.AttributeKV{Key: "metronome-enabled", Value: true},
  40. telemetry.AttributeKV{Key: "usage-id", Value: proj.UsageID},
  41. )
  42. ingestEventsRequest := struct {
  43. Events []types.BillingEvent `json:"billing_events"`
  44. }{}
  45. if ok := c.DecodeAndValidate(w, r, &ingestEventsRequest); !ok {
  46. err := telemetry.Error(ctx, span, nil, "error decoding ingest events request")
  47. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusBadRequest))
  48. return
  49. }
  50. telemetry.WithAttributes(span,
  51. telemetry.AttributeKV{Key: "usage-events-count", Value: len(ingestEventsRequest.Events)},
  52. )
  53. err := c.Config().BillingManager.MetronomeClient.IngestEvents(ctx, ingestEventsRequest.Events)
  54. if err != nil {
  55. err := telemetry.Error(ctx, span, err, "error ingesting events")
  56. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  57. return
  58. }
  59. c.WriteResult(w, r, "")
  60. }