get_pod_metrics.go 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. package cluster
  2. import (
  3. "net/http"
  4. "github.com/porter-dev/porter/internal/kubernetes/prometheus"
  5. "github.com/porter-dev/porter/internal/telemetry"
  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/types"
  12. "github.com/porter-dev/porter/internal/models"
  13. )
  14. type GetPodMetricsHandler struct {
  15. handlers.PorterHandlerReadWriter
  16. authz.KubernetesAgentGetter
  17. }
  18. func NewGetPodMetricsHandler(
  19. config *config.Config,
  20. decoderValidator shared.RequestDecoderValidator,
  21. writer shared.ResultWriter,
  22. ) *GetPodMetricsHandler {
  23. return &GetPodMetricsHandler{
  24. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  25. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  26. }
  27. }
  28. func (c *GetPodMetricsHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  29. ctx := r.Context()
  30. ctx, span := telemetry.NewSpan(ctx, "service-get-pod-metrics")
  31. defer span.End()
  32. cluster, _ := ctx.Value(types.ClusterScope).(*models.Cluster)
  33. request := &prometheus.GetPodMetricsRequest{}
  34. if ok := c.DecodeAndValidate(w, r, request); !ok {
  35. err := telemetry.Error(ctx, span, nil, "error decoding request")
  36. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusBadRequest))
  37. return
  38. }
  39. agent, err := c.GetAgent(r, cluster, "")
  40. if err != nil {
  41. err = telemetry.Error(ctx, span, err, "error getting k8s agent")
  42. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  43. return
  44. }
  45. // get prometheus service
  46. promSvc, found, err := prometheus.GetPrometheusService(agent.Clientset)
  47. if err != nil || !found {
  48. err = telemetry.Error(ctx, span, err, "error getting prometheus service")
  49. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  50. return
  51. }
  52. rawQuery, err := prometheus.QueryPrometheus(ctx, agent.Clientset, promSvc, &request.QueryOpts)
  53. if err != nil {
  54. err = telemetry.Error(ctx, span, err, "error querying prometheus")
  55. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  56. return
  57. }
  58. c.WriteResult(w, r, rawQuery)
  59. }