stream_pod_logs_loki.go 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. package namespace
  2. import (
  3. "fmt"
  4. "net/http"
  5. "time"
  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/websocket"
  12. "github.com/porter-dev/porter/api/types"
  13. "github.com/porter-dev/porter/internal/models"
  14. )
  15. type StreamPodLogsLokiHandler struct {
  16. handlers.PorterHandlerReadWriter
  17. authz.KubernetesAgentGetter
  18. }
  19. func NewStreamPodLogsLokiHandler(
  20. config *config.Config,
  21. decoderValidator shared.RequestDecoderValidator,
  22. writer shared.ResultWriter,
  23. ) *StreamPodLogsLokiHandler {
  24. return &StreamPodLogsLokiHandler{
  25. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  26. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  27. }
  28. }
  29. func (c *StreamPodLogsLokiHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  30. request := &types.GetLogRequest{}
  31. if ok := c.DecodeAndValidate(w, r, request); !ok {
  32. return
  33. }
  34. safeRW := r.Context().Value(types.RequestCtxWebsocketKey).(*websocket.WebsocketSafeReadWriter)
  35. cluster, _ := r.Context().Value(types.ClusterScope).(*models.Cluster)
  36. agent, err := c.GetAgent(r, cluster, "")
  37. if err != nil {
  38. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  39. return
  40. }
  41. if request.StartRange == nil {
  42. dayAgo := time.Now().Add(-24 * time.Hour)
  43. request.StartRange = &dayAgo
  44. }
  45. startTime, err := request.StartRange.MarshalText()
  46. if err != nil {
  47. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  48. return
  49. }
  50. err = agent.StreamPorterAgentLokiLog([]string{
  51. fmt.Sprintf("pod=%s", request.PodSelector),
  52. fmt.Sprintf("namespace=%s", request.Namespace),
  53. }, string(startTime), request.SearchParam, 0, safeRW)
  54. if err != nil {
  55. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  56. return
  57. }
  58. }