mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-05 14:20:25 +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()
|
||
|
|
}
|