get.go 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. package porter_app
  2. import (
  3. "net/http"
  4. "github.com/porter-dev/porter/api/server/authz"
  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 GetPorterAppHandler struct {
  15. handlers.PorterHandlerReadWriter
  16. authz.KubernetesAgentGetter
  17. }
  18. func NewGetPorterAppHandler(
  19. config *config.Config,
  20. writer shared.ResultWriter,
  21. ) *GetPorterAppHandler {
  22. return &GetPorterAppHandler{
  23. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, nil, writer),
  24. }
  25. }
  26. func (c *GetPorterAppHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  27. ctx, span := telemetry.NewSpan(r.Context(), "serve-get-porter-app")
  28. defer span.End()
  29. cluster, _ := ctx.Value(types.ClusterScope).(*models.Cluster)
  30. stackName, reqErr := requestutils.GetURLParamString(r, types.URLParamStackName)
  31. if reqErr != nil {
  32. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(reqErr, http.StatusBadRequest))
  33. return
  34. }
  35. app, err := c.Repo().PorterApp().ReadPorterAppByName(cluster.ID, stackName, 0)
  36. if err != nil {
  37. err = telemetry.Error(ctx, span, err, "Failed to read porter app")
  38. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  39. return
  40. }
  41. c.WriteResult(w, r, app.ToPorterAppType())
  42. }