stream_pod_logs.go 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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/server/shared/websocket"
  13. "github.com/porter-dev/porter/api/types"
  14. "github.com/porter-dev/porter/internal/kubernetes"
  15. "github.com/porter-dev/porter/internal/models"
  16. )
  17. type StreamPodLogsHandler struct {
  18. handlers.PorterHandlerReadWriter
  19. authz.KubernetesAgentGetter
  20. }
  21. func NewStreamPodLogsHandler(
  22. config *config.Config,
  23. decoderValidator shared.RequestDecoderValidator,
  24. writer shared.ResultWriter,
  25. ) *StreamPodLogsHandler {
  26. return &StreamPodLogsHandler{
  27. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  28. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  29. }
  30. }
  31. func (c *StreamPodLogsHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  32. request := &types.GetPodLogsRequest{}
  33. if ok := c.DecodeAndValidate(w, r, request); !ok {
  34. return
  35. }
  36. safeRW := r.Context().Value(types.RequestCtxWebsocketKey).(*websocket.WebsocketSafeReadWriter)
  37. namespace := r.Context().Value(types.NamespaceScope).(string)
  38. name, _ := requestutils.GetURLParamString(r, types.URLParamPodName)
  39. cluster, _ := r.Context().Value(types.ClusterScope).(*models.Cluster)
  40. agent, err := c.GetAgent(r, cluster, "")
  41. if err != nil {
  42. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  43. return
  44. }
  45. err = agent.GetPodLogs(namespace, name, request.Container, safeRW)
  46. if targetErr := kubernetes.IsNotFoundError; errors.Is(err, targetErr) {
  47. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(
  48. fmt.Errorf("pod %s/%s was not found", namespace, name),
  49. http.StatusNotFound,
  50. ))
  51. return
  52. } else if brErr := (kubernetes.BadRequestError{}); errors.As(err, &targetErr) {
  53. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(
  54. &brErr,
  55. http.StatusBadRequest,
  56. ))
  57. return
  58. } else if err != nil {
  59. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  60. return
  61. }
  62. }