delete_node_group.go 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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/internal/telemetry"
  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. // DeleteNodeGroupHandler is the handler for the /delete-node-group endpoint
  16. type DeleteNodeGroupHandler struct {
  17. handlers.PorterHandlerReadWriter
  18. authz.KubernetesAgentGetter
  19. }
  20. // NewDeleteNodeGroupHandler returns a handler for handling node group requests
  21. func NewDeleteNodeGroupHandler(
  22. config *config.Config,
  23. decoderValidator shared.RequestDecoderValidator,
  24. writer shared.ResultWriter,
  25. ) *DeleteNodeGroupHandler {
  26. return &DeleteNodeGroupHandler{
  27. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  28. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  29. }
  30. }
  31. // DeleteNodeGroupRequest represents the request to delete a node group
  32. type DeleteNodeGroupRequest struct {
  33. // NodeGroupId is the id of the node group to delete
  34. NodeGroupId string `json:"node_group_id"`
  35. }
  36. // DeleteNodeGroupResponse represents the response from deleting a node group
  37. type DeleteNodeGroupResponse struct {
  38. // ContractRevisionId is the id of the contract revision created by the deletion
  39. ContractRevisionId string `json:"contract_revision_id"`
  40. }
  41. // ServeHTTP handles GET requests to list node groups
  42. func (c *DeleteNodeGroupHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  43. ctx, span := telemetry.NewSpan(r.Context(), "serve-list-nodes")
  44. defer span.End()
  45. project, _ := r.Context().Value(types.ProjectScope).(*models.Project)
  46. cluster, _ := r.Context().Value(types.ClusterScope).(*models.Cluster)
  47. request := &DeleteNodeGroupRequest{}
  48. ok := c.DecodeAndValidate(w, r, request)
  49. if !ok {
  50. err := telemetry.Error(ctx, span, nil, "error decoding delete node group request")
  51. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusBadRequest))
  52. }
  53. if request.NodeGroupId == "" {
  54. err := telemetry.Error(ctx, span, nil, "node group id is empty")
  55. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusBadRequest))
  56. }
  57. userNodeGroupReq := connect.NewRequest(&porterv1.DeleteUserNodeGroupRequest{
  58. ProjectId: int64(project.ID),
  59. ClusterId: int64(cluster.ID),
  60. UserNodeGroupId: request.NodeGroupId,
  61. })
  62. ccpResp, err := c.Config().ClusterControlPlaneClient.DeleteUserNodeGroup(ctx, userNodeGroupReq)
  63. if err != nil {
  64. err := telemetry.Error(ctx, span, err, "error deleting user node group")
  65. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  66. return
  67. }
  68. if ccpResp == nil || ccpResp.Msg == nil {
  69. err := telemetry.Error(ctx, span, err, "ccp resp msg is nil")
  70. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  71. return
  72. }
  73. resp := &DeleteNodeGroupResponse{
  74. ContractRevisionId: ccpResp.Msg.ContractRevisionId,
  75. }
  76. c.WriteResult(w, r, resp)
  77. }