stream_pod_logs.go 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. package namespace
  2. import (
  3. "errors"
  4. "fmt"
  5. "net/http"
  6. "github.com/porter-dev/porter/api/server/authz"
  7. "github.com/porter-dev/porter/api/server/handlers"
  8. "github.com/porter-dev/porter/api/server/shared"
  9. "github.com/porter-dev/porter/api/server/shared/apierrors"
  10. "github.com/porter-dev/porter/api/server/shared/config"
  11. "github.com/porter-dev/porter/api/server/shared/requestutils"
  12. "github.com/porter-dev/porter/api/types"
  13. "github.com/porter-dev/porter/internal/kubernetes"
  14. "github.com/porter-dev/porter/internal/models"
  15. )
  16. type StreamPodLogsHandler struct {
  17. handlers.PorterHandlerReadWriter
  18. authz.KubernetesAgentGetter
  19. }
  20. func NewStreamPodLogsHandler(
  21. config *config.Config,
  22. decoderValidator shared.RequestDecoderValidator,
  23. writer shared.ResultWriter,
  24. ) *StreamPodLogsHandler {
  25. return &StreamPodLogsHandler{
  26. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  27. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  28. }
  29. }
  30. func (c *StreamPodLogsHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  31. conn, err := c.Config().WSUpgrader.Upgrade(w, r, nil)
  32. if err != nil {
  33. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  34. return
  35. }
  36. namespace := r.Context().Value(types.NamespaceScope).(string)
  37. name, _ := requestutils.GetURLParamString(r, types.URLParamPodName)
  38. cluster, _ := r.Context().Value(types.ClusterScope).(*models.Cluster)
  39. agent, err := c.GetAgent(r, cluster, "")
  40. if err != nil {
  41. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  42. return
  43. }
  44. err = agent.GetPodLogs(namespace, name, conn)
  45. if targetErr := kubernetes.IsNotFoundError; errors.Is(err, targetErr) {
  46. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(
  47. fmt.Errorf("pod %s/%s was not found", namespace, name),
  48. http.StatusNotFound,
  49. ))
  50. return
  51. } else if err != nil {
  52. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  53. return
  54. }
  55. }