cluster_status.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. package cluster
  2. import (
  3. "net/http"
  4. "connectrpc.com/connect"
  5. porterv1 "github.com/porter-dev/api-contracts/generated/go/porter/v1"
  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/config"
  10. "github.com/porter-dev/porter/api/types"
  11. "github.com/porter-dev/porter/internal/models"
  12. "github.com/porter-dev/porter/internal/telemetry"
  13. )
  14. type ClusterStatusHandler struct {
  15. handlers.PorterHandlerReadWriter
  16. authz.KubernetesAgentGetter
  17. }
  18. func NewClusterStatusHandler(
  19. config *config.Config,
  20. decoderValidator shared.RequestDecoderValidator,
  21. writer shared.ResultWriter,
  22. ) *ClusterStatusHandler {
  23. return &ClusterStatusHandler{
  24. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  25. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  26. }
  27. }
  28. type ClusterStatusResponse struct {
  29. ProjectID int `json:"project_id"`
  30. ClusterID int `json:"cluster_id"`
  31. Phase string `json:"phase"`
  32. IsInfrastructureReady bool `json:"is_infrastructure_ready"`
  33. IsControlPlaneReady bool `json:"is_control_plane_ready"`
  34. }
  35. func (c *ClusterStatusHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  36. ctx, span := telemetry.NewSpan(r.Context(), "serve-cluster-status")
  37. defer span.End()
  38. cluster, _ := ctx.Value(types.ClusterScope).(*models.Cluster)
  39. project, _ := ctx.Value(types.ProjectScope).(*models.Project)
  40. req := connect.NewRequest(&porterv1.ClusterStatusRequest{
  41. ProjectId: int64(cluster.ProjectID),
  42. ClusterId: int64(cluster.ID),
  43. })
  44. resp := ClusterStatusResponse{
  45. ProjectID: int(project.ID),
  46. ClusterID: int(cluster.ID),
  47. }
  48. status, err := c.Config().ClusterControlPlaneClient.ClusterStatus(ctx, req)
  49. if err != nil {
  50. _ = telemetry.Error(ctx, span, err, "error getting cluster status")
  51. c.WriteResult(w, r, resp)
  52. return
  53. }
  54. if status.Msg == nil {
  55. _ = telemetry.Error(ctx, span, nil, "error getting cluster status")
  56. c.WriteResult(w, r, resp)
  57. return
  58. }
  59. statusResp := status.Msg
  60. resp.Phase = statusResp.Phase
  61. resp.IsInfrastructureReady = statusResp.InfrastructureStatus
  62. resp.IsControlPlaneReady = statusResp.ControlPlaneStatus
  63. telemetry.WithAttributes(span,
  64. telemetry.AttributeKV{Key: "cluster-phase", Value: statusResp.Phase},
  65. telemetry.AttributeKV{Key: "cluster-infra-status", Value: statusResp.InfrastructureStatus},
  66. telemetry.AttributeKV{Key: "cluster-control-plane-status", Value: statusResp.ControlPlaneStatus},
  67. )
  68. c.WriteResult(w, r, resp)
  69. w.WriteHeader(http.StatusOK)
  70. }