cluster_status.go 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. package cluster
  2. import (
  3. "fmt"
  4. "net/http"
  5. "connectrpc.com/connect"
  6. porterv1 "github.com/porter-dev/api-contracts/generated/go/porter/v1"
  7. "github.com/porter-dev/porter/api/server/authz"
  8. "github.com/porter-dev/porter/api/server/handlers"
  9. "github.com/porter-dev/porter/api/server/shared"
  10. "github.com/porter-dev/porter/api/server/shared/apierrors"
  11. "github.com/porter-dev/porter/api/server/shared/config"
  12. "github.com/porter-dev/porter/api/types"
  13. "github.com/porter-dev/porter/internal/models"
  14. )
  15. type ClusterStatusHandler struct {
  16. handlers.PorterHandlerReadWriter
  17. authz.KubernetesAgentGetter
  18. }
  19. func NewClusterStatusHandler(
  20. config *config.Config,
  21. decoderValidator shared.RequestDecoderValidator,
  22. writer shared.ResultWriter,
  23. ) *ClusterStatusHandler {
  24. return &ClusterStatusHandler{
  25. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  26. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  27. }
  28. }
  29. type ClusterStatusResponse struct {
  30. ProjectID int `json:"project_id"`
  31. ClusterID int `json:"cluster_id"`
  32. Phase string `json:"phase"`
  33. IsInfrastructureReady bool `json:"is_infrastructure_ready"`
  34. IsControlPlaneReady bool `json:"is_control_plane_ready"`
  35. }
  36. func (c *ClusterStatusHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  37. ctx := r.Context()
  38. cluster, _ := ctx.Value(types.ClusterScope).(*models.Cluster)
  39. req := connect.NewRequest(&porterv1.ClusterStatusRequest{
  40. ProjectId: int64(cluster.ProjectID),
  41. ClusterId: int64(cluster.ID),
  42. })
  43. status, err := c.Config().ClusterControlPlaneClient.ClusterStatus(ctx, req)
  44. if err != nil {
  45. e := fmt.Errorf("unable to retrieve status for cluster: %w", err)
  46. c.HandleAPIError(w, r, apierrors.NewErrInternal(e))
  47. return
  48. }
  49. if status.Msg == nil {
  50. e := fmt.Errorf("unable to parse status for cluster: %w", err)
  51. c.HandleAPIError(w, r, apierrors.NewErrInternal(e))
  52. return
  53. }
  54. statusResp := status.Msg
  55. resp := ClusterStatusResponse{
  56. ProjectID: int(statusResp.ProjectId),
  57. ClusterID: int(statusResp.ClusterId),
  58. Phase: statusResp.Phase,
  59. IsInfrastructureReady: statusResp.InfrastructureStatus,
  60. IsControlPlaneReady: statusResp.ControlPlaneStatus,
  61. }
  62. c.WriteResult(w, r, resp)
  63. w.WriteHeader(http.StatusOK)
  64. }