get_event.go 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. package porter_app
  2. import (
  3. "net/http"
  4. "github.com/google/uuid"
  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/server/shared/requestutils"
  10. "github.com/porter-dev/porter/api/types"
  11. "github.com/porter-dev/porter/internal/models"
  12. "github.com/porter-dev/porter/internal/telemetry"
  13. )
  14. type GetPorterAppEventHandler struct {
  15. handlers.PorterHandlerWriter
  16. }
  17. func NewGetPorterAppEventHandler(
  18. config *config.Config,
  19. writer shared.ResultWriter,
  20. ) *GetPorterAppEventHandler {
  21. return &GetPorterAppEventHandler{
  22. PorterHandlerWriter: handlers.NewDefaultPorterHandler(config, nil, writer),
  23. }
  24. }
  25. func (p *GetPorterAppEventHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  26. ctx, span := telemetry.NewSpan(r.Context(), "serve-get-porter-app-event")
  27. defer span.End()
  28. cluster, _ := ctx.Value(types.ClusterScope).(*models.Cluster)
  29. telemetry.WithAttributes(span,
  30. telemetry.AttributeKV{Key: "cluster-id", Value: int(cluster.ID)},
  31. telemetry.AttributeKV{Key: "project-id", Value: int(cluster.ProjectID)},
  32. )
  33. eventId, reqErr := requestutils.GetURLParamString(r, types.URLParamPorterAppEventID)
  34. if reqErr != nil {
  35. e := telemetry.Error(ctx, span, nil, "error parsing event id from url")
  36. p.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(e, http.StatusBadRequest))
  37. return
  38. }
  39. submittedEventID, err := uuid.Parse(eventId)
  40. if err != nil {
  41. e := telemetry.Error(ctx, span, err, "error parsing porter app event id as uuid")
  42. p.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(e, http.StatusBadRequest))
  43. return
  44. }
  45. event, err := p.Repo().PorterAppEvent().ReadEvent(ctx, submittedEventID)
  46. if err != nil {
  47. e := telemetry.Error(ctx, span, err, "error retrieving porter app event")
  48. p.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(e, http.StatusBadRequest))
  49. return
  50. }
  51. res := struct {
  52. Event types.PorterAppEvent `json:"event"`
  53. }{
  54. Event: event.ToPorterAppEvent(),
  55. }
  56. p.WriteResult(w, r, res)
  57. }