mirror of
				https://github.com/TeaOSLab/EdgeAdmin.git
				synced 2025-11-04 21:50:28 +08:00 
			
		
		
		
	
		
			
	
	
		
			165 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
		
		
			
		
	
	
			165 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| 
								 | 
							
								package node
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								import (
							 | 
						||
| 
								 | 
							
									"encoding/json"
							 | 
						||
| 
								 | 
							
									"github.com/TeaOSLab/EdgeAdmin/internal/oplogs"
							 | 
						||
| 
								 | 
							
									"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
							 | 
						||
| 
								 | 
							
									"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/default/nodes/ipAddresses/ipaddressutils"
							 | 
						||
| 
								 | 
							
									"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
							 | 
						||
| 
								 | 
							
									"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
							 | 
						||
| 
								 | 
							
									"github.com/iwind/TeaGo/actions"
							 | 
						||
| 
								 | 
							
									"github.com/iwind/TeaGo/maps"
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								type UpdateAction struct {
							 | 
						||
| 
								 | 
							
									actionutils.ParentAction
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func (this *UpdateAction) Init() {
							 | 
						||
| 
								 | 
							
									this.Nav("", "node", "update")
							 | 
						||
| 
								 | 
							
									this.SecondMenu("nodes")
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func (this *UpdateAction) RunGet(params struct {
							 | 
						||
| 
								 | 
							
									NodeId int64
							 | 
						||
| 
								 | 
							
								}) {
							 | 
						||
| 
								 | 
							
									this.Data["nodeId"] = params.NodeId
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									nodeResp, err := this.RPC().NSNodeRPC().FindEnabledNSNode(this.AdminContext(), &pb.FindEnabledNSNodeRequest{NsNodeId: params.NodeId})
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										this.ErrorPage(err)
							 | 
						||
| 
								 | 
							
										return
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									node := nodeResp.NsNode
							 | 
						||
| 
								 | 
							
									if node == nil {
							 | 
						||
| 
								 | 
							
										this.WriteString("找不到要操作的节点")
							 | 
						||
| 
								 | 
							
										return
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									var clusterMap maps.Map = nil
							 | 
						||
| 
								 | 
							
									if node.NsCluster != nil {
							 | 
						||
| 
								 | 
							
										clusterMap = maps.Map{
							 | 
						||
| 
								 | 
							
											"id":   node.NsCluster.Id,
							 | 
						||
| 
								 | 
							
											"name": node.NsCluster.Name,
							 | 
						||
| 
								 | 
							
										}
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// IP地址
							 | 
						||
| 
								 | 
							
									ipAddressesResp, err := this.RPC().NodeIPAddressRPC().FindAllEnabledIPAddressesWithNodeId(this.AdminContext(), &pb.FindAllEnabledIPAddressesWithNodeIdRequest{
							 | 
						||
| 
								 | 
							
										NodeId: params.NodeId,
							 | 
						||
| 
								 | 
							
										Role:   nodeconfigs.NodeRoleDNS,
							 | 
						||
| 
								 | 
							
									})
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										this.ErrorPage(err)
							 | 
						||
| 
								 | 
							
										return
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									ipAddressMaps := []maps.Map{}
							 | 
						||
| 
								 | 
							
									for _, addr := range ipAddressesResp.Addresses {
							 | 
						||
| 
								 | 
							
										ipAddressMaps = append(ipAddressMaps, maps.Map{
							 | 
						||
| 
								 | 
							
											"id":        addr.Id,
							 | 
						||
| 
								 | 
							
											"name":      addr.Name,
							 | 
						||
| 
								 | 
							
											"ip":        addr.Ip,
							 | 
						||
| 
								 | 
							
											"canAccess": addr.CanAccess,
							 | 
						||
| 
								 | 
							
										})
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									this.Data["node"] = maps.Map{
							 | 
						||
| 
								 | 
							
										"id":          node.Id,
							 | 
						||
| 
								 | 
							
										"name":        node.Name,
							 | 
						||
| 
								 | 
							
										"ipAddresses": ipAddressMaps,
							 | 
						||
| 
								 | 
							
										"cluster":     clusterMap,
							 | 
						||
| 
								 | 
							
										"isOn":        node.IsOn,
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// 所有集群
							 | 
						||
| 
								 | 
							
									resp, err := this.RPC().NSClusterRPC().FindAllEnabledNSClusters(this.AdminContext(), &pb.FindAllEnabledNSClustersRequest{})
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										this.ErrorPage(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										this.ErrorPage(err)
							 | 
						||
| 
								 | 
							
										return
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									clusterMaps := []maps.Map{}
							 | 
						||
| 
								 | 
							
									for _, cluster := range resp.NsClusters {
							 | 
						||
| 
								 | 
							
										clusterMaps = append(clusterMaps, maps.Map{
							 | 
						||
| 
								 | 
							
											"id":   cluster.Id,
							 | 
						||
| 
								 | 
							
											"name": cluster.Name,
							 | 
						||
| 
								 | 
							
										})
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									this.Data["clusters"] = clusterMaps
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									this.Show()
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func (this *UpdateAction) RunPost(params struct {
							 | 
						||
| 
								 | 
							
									LoginId         int64
							 | 
						||
| 
								 | 
							
									NodeId          int64
							 | 
						||
| 
								 | 
							
									Name            string
							 | 
						||
| 
								 | 
							
									IPAddressesJSON []byte `alias:"ipAddressesJSON"`
							 | 
						||
| 
								 | 
							
									ClusterId       int64
							 | 
						||
| 
								 | 
							
									IsOn            bool
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									Must *actions.Must
							 | 
						||
| 
								 | 
							
								}) {
							 | 
						||
| 
								 | 
							
									// 创建日志
							 | 
						||
| 
								 | 
							
									defer this.CreateLog(oplogs.LevelInfo, "修改节点 %d", params.NodeId)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									if params.NodeId <= 0 {
							 | 
						||
| 
								 | 
							
										this.Fail("要操作的节点不存在")
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									params.Must.
							 | 
						||
| 
								 | 
							
										Field("name", params.Name).
							 | 
						||
| 
								 | 
							
										Require("请输入节点名称")
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// TODO 检查cluster
							 | 
						||
| 
								 | 
							
									if params.ClusterId <= 0 {
							 | 
						||
| 
								 | 
							
										this.Fail("请选择所在集群")
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// IP地址
							 | 
						||
| 
								 | 
							
									ipAddresses := []maps.Map{}
							 | 
						||
| 
								 | 
							
									if len(params.IPAddressesJSON) > 0 {
							 | 
						||
| 
								 | 
							
										err := json.Unmarshal(params.IPAddressesJSON, &ipAddresses)
							 | 
						||
| 
								 | 
							
										if err != nil {
							 | 
						||
| 
								 | 
							
											this.ErrorPage(err)
							 | 
						||
| 
								 | 
							
											return
							 | 
						||
| 
								 | 
							
										}
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									if len(ipAddresses) == 0 {
							 | 
						||
| 
								 | 
							
										this.Fail("请至少输入一个IP地址")
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// 保存
							 | 
						||
| 
								 | 
							
									_, err := this.RPC().NSNodeRPC().UpdateNSNode(this.AdminContext(), &pb.UpdateNSNodeRequest{
							 | 
						||
| 
								 | 
							
										NsNodeId:    params.NodeId,
							 | 
						||
| 
								 | 
							
										Name:        params.Name,
							 | 
						||
| 
								 | 
							
										NsClusterId: params.ClusterId,
							 | 
						||
| 
								 | 
							
										IsOn:        params.IsOn,
							 | 
						||
| 
								 | 
							
									})
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										this.ErrorPage(err)
							 | 
						||
| 
								 | 
							
										return
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// 禁用老的IP地址
							 | 
						||
| 
								 | 
							
									_, err = this.RPC().NodeIPAddressRPC().DisableAllIPAddressesWithNodeId(this.AdminContext(), &pb.DisableAllIPAddressesWithNodeIdRequest{
							 | 
						||
| 
								 | 
							
										NodeId: params.NodeId,
							 | 
						||
| 
								 | 
							
										Role:   nodeconfigs.NodeRoleDNS,
							 | 
						||
| 
								 | 
							
									})
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										this.ErrorPage(err)
							 | 
						||
| 
								 | 
							
										return
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// 添加新的IP地址
							 | 
						||
| 
								 | 
							
									err = ipaddressutils.UpdateNodeIPAddresses(this.Parent(), params.NodeId, nodeconfigs.NodeRoleDNS, params.IPAddressesJSON)
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										this.ErrorPage(err)
							 | 
						||
| 
								 | 
							
										return
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									this.Success()
							 | 
						||
| 
								 | 
							
								}
							 |