remove_env_group.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. package stack
  2. import (
  3. "fmt"
  4. "net/http"
  5. "github.com/porter-dev/porter/api/server/authz"
  6. "github.com/porter-dev/porter/api/server/handlers"
  7. "github.com/porter-dev/porter/api/server/shared"
  8. "github.com/porter-dev/porter/api/server/shared/apierrors"
  9. "github.com/porter-dev/porter/api/server/shared/config"
  10. "github.com/porter-dev/porter/api/server/shared/requestutils"
  11. "github.com/porter-dev/porter/api/types"
  12. "github.com/porter-dev/porter/internal/kubernetes/envgroup"
  13. "github.com/porter-dev/porter/internal/models"
  14. "github.com/porter-dev/porter/internal/stacks"
  15. )
  16. type StackRemoveEnvGroupHandler struct {
  17. handlers.PorterHandlerWriter
  18. authz.KubernetesAgentGetter
  19. }
  20. func NewStackRemoveEnvGroupHandler(
  21. config *config.Config,
  22. writer shared.ResultWriter,
  23. ) *StackRemoveEnvGroupHandler {
  24. return &StackRemoveEnvGroupHandler{
  25. PorterHandlerWriter: handlers.NewDefaultPorterHandler(config, nil, writer),
  26. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  27. }
  28. }
  29. func (p *StackRemoveEnvGroupHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  30. stack, _ := r.Context().Value(types.StackScope).(*models.Stack)
  31. cluster, _ := r.Context().Value(types.ClusterScope).(*models.Cluster)
  32. envGroupName, reqErr := requestutils.GetURLParamString(r, "env_group_name")
  33. if reqErr != nil {
  34. p.HandleAPIError(w, r, reqErr)
  35. return
  36. }
  37. if len(stack.Revisions) == 0 {
  38. p.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(
  39. fmt.Errorf("no stack revisions exist"), http.StatusBadRequest,
  40. ))
  41. return
  42. }
  43. revision, err := p.Repo().Stack().ReadStackRevisionByNumber(stack.ID, stack.Revisions[0].RevisionNumber)
  44. if err != nil {
  45. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  46. return
  47. }
  48. k8sAgent, err := p.GetAgent(r, cluster, "")
  49. if err != nil {
  50. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  51. return
  52. }
  53. envGroupDeleted := false
  54. for _, envGroup := range revision.EnvGroups {
  55. if envGroup.Name == envGroupName {
  56. err := envgroup.DeleteEnvGroup(k8sAgent, envGroup.Name, envGroup.Namespace)
  57. if err != nil {
  58. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  59. return
  60. }
  61. envGroupDeleted = true
  62. break
  63. }
  64. }
  65. if envGroupDeleted {
  66. newSourceConfigs, err := stacks.CloneSourceConfigs(revision.SourceConfigs)
  67. if err != nil {
  68. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  69. return
  70. }
  71. appResources, err := stacks.CloneAppResources(revision.Resources, revision.SourceConfigs, newSourceConfigs)
  72. if err != nil {
  73. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  74. return
  75. }
  76. envGroups, err := stacks.CloneEnvGroups(revision.EnvGroups)
  77. if err != nil {
  78. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  79. return
  80. }
  81. var newEnvGroups []models.StackEnvGroup
  82. for _, envGroup := range envGroups {
  83. if envGroup.Name != envGroupName {
  84. newEnvGroups = append(newEnvGroups, envGroup)
  85. }
  86. }
  87. newRevision := &models.StackRevision{
  88. StackID: stack.ID,
  89. RevisionNumber: revision.RevisionNumber + 1,
  90. Status: string(types.StackRevisionStatusDeployed),
  91. SourceConfigs: newSourceConfigs,
  92. Resources: appResources,
  93. EnvGroups: newEnvGroups,
  94. }
  95. _, err = p.Repo().Stack().AppendNewRevision(newRevision)
  96. if err != nil {
  97. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  98. return
  99. }
  100. }
  101. }