pods.go 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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/handlers/release"
  7. "github.com/porter-dev/porter/api/server/shared"
  8. "github.com/porter-dev/porter/api/server/shared/apierrors"
  9. "github.com/porter-dev/porter/api/server/shared/config"
  10. "github.com/porter-dev/porter/api/server/shared/requestutils"
  11. "github.com/porter-dev/porter/api/types"
  12. utils "github.com/porter-dev/porter/api/utils/porter_app"
  13. "github.com/porter-dev/porter/internal/models"
  14. "github.com/porter-dev/porter/internal/telemetry"
  15. )
  16. type PorterAppPodsGetHandler struct {
  17. handlers.PorterHandlerReadWriter
  18. authz.KubernetesAgentGetter
  19. }
  20. func NewPorterAppPodsGetHandler(
  21. config *config.Config,
  22. writer shared.ResultWriter,
  23. ) *PorterAppPodsGetHandler {
  24. return &PorterAppPodsGetHandler{
  25. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, nil, writer),
  26. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  27. }
  28. }
  29. func (c *PorterAppPodsGetHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  30. ctx := r.Context()
  31. cluster, _ := ctx.Value(types.ClusterScope).(*models.Cluster)
  32. ctx, span := telemetry.NewSpan(ctx, "serve-get-porter-app-pods")
  33. defer span.End()
  34. appName, reqErr := requestutils.GetURLParamString(r, types.URLParamPorterAppName)
  35. if reqErr != nil {
  36. err := telemetry.Error(ctx, span, reqErr, "error getting stack name from url")
  37. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusBadRequest))
  38. return
  39. }
  40. version, reqErr := requestutils.GetURLParamUint(r, types.URLParamReleaseVersion)
  41. if reqErr != nil {
  42. err := telemetry.Error(ctx, span, reqErr, "error getting version from url")
  43. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusBadRequest))
  44. return
  45. }
  46. namespace := utils.NamespaceFromPorterAppName(appName)
  47. helmAgent, err := c.GetHelmAgent(ctx, r, cluster, namespace)
  48. if err != nil {
  49. err = telemetry.Error(ctx, span, err, "error getting helm agent")
  50. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  51. return
  52. }
  53. helmRelease, err := helmAgent.GetRelease(ctx, appName, int(version), false)
  54. if err != nil {
  55. err = telemetry.Error(ctx, span, err, "error getting helm release")
  56. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  57. return
  58. }
  59. k8sAgent, err := c.GetAgent(r, cluster, namespace)
  60. if err != nil {
  61. err = telemetry.Error(ctx, span, err, "error getting k8s agent")
  62. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  63. return
  64. }
  65. pods, err := release.GetPodsForRelease(ctx, helmRelease, k8sAgent)
  66. if err != nil {
  67. err = telemetry.Error(ctx, span, err, "error getting pods for release")
  68. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  69. return
  70. }
  71. c.WriteResult(w, r, pods)
  72. }