package cluster import ( "github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils" "github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb" ) type DeleteAction struct { actionutils.ParentAction } func (this *DeleteAction) Init() { this.Nav("", "delete", "index") this.SecondMenu("nodes") } func (this *DeleteAction) RunGet(params struct{}) { this.Show() } func (this *DeleteAction) RunPost(params struct { ClusterId int64 }) { // 检查有无服务正在使用 countResp, err := this.RPC().ServerRPC().CountAllEnabledServersWithNodeClusterId(this.AdminContext(), &pb.CountAllEnabledServersWithNodeClusterIdRequest{NodeClusterId: params.ClusterId}) if err != nil { this.ErrorPage(err) return } if countResp.Count > 0 { this.Fail("有代理服务正在使用此集群,请修改这些代理服务后再删除") } // 删除 _, err = this.RPC().NodeClusterRPC().DeleteNodeCluster(this.AdminContext(), &pb.DeleteNodeClusterRequest{ClusterId: params.ClusterId}) if err != nil { this.ErrorPage(err) return } this.Success() }