Files
EdgeAdmin/internal/web/actions/default/clusters/index.go

168 lines
4.9 KiB
Go
Raw Normal View History

2020-09-06 16:19:34 +08:00
package clusters
import (
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
2020-09-26 08:07:18 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/configutils"
"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
2020-09-26 08:07:18 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
2020-09-06 16:19:34 +08:00
"github.com/iwind/TeaGo/maps"
2020-09-26 08:07:18 +08:00
"github.com/iwind/TeaGo/types"
2020-09-06 16:19:34 +08:00
)
type IndexAction struct {
actionutils.ParentAction
}
func (this *IndexAction) Init() {
this.Nav("", "cluster", "index")
}
func (this *IndexAction) RunGet(params struct {
Keyword string
SearchType string
}) {
2022-04-07 18:31:21 +08:00
var isSearching = len(params.Keyword) > 0
this.Data["keyword"] = params.Keyword
this.Data["searchType"] = params.SearchType
2021-05-03 11:32:59 +08:00
this.Data["isSearching"] = isSearching
2022-03-17 10:36:30 +08:00
// 集群总数
2022-04-07 18:31:21 +08:00
totalClustersResp, err := this.RPC().NodeClusterRPC().CountAllEnabledNodeClusters(this.AdminContext(), &pb.CountAllEnabledNodeClustersRequest{})
2022-03-17 10:36:30 +08:00
if err != nil {
this.ErrorPage(err)
return
}
2022-04-07 18:31:21 +08:00
this.Data["totalNodeClusters"] = totalClustersResp.Count
// 节点总数
totalNodesResp, err := this.RPC().NodeRPC().CountAllEnabledNodes(this.AdminContext(), &pb.CountAllEnabledNodesRequest{})
if err != nil {
this.ErrorPage(err)
return
}
this.Data["totalNodes"] = totalNodesResp.Count
2022-03-17 10:36:30 +08:00
2021-06-05 16:53:26 +08:00
// 常用的集群
2021-05-03 11:32:59 +08:00
latestClusterMaps := []maps.Map{}
if !isSearching {
2021-05-03 15:15:31 +08:00
clustersResp, err := this.RPC().NodeClusterRPC().FindLatestNodeClusters(this.AdminContext(), &pb.FindLatestNodeClustersRequest{Size: 6})
2021-05-03 11:32:59 +08:00
if err != nil {
this.ErrorPage(err)
return
}
for _, cluster := range clustersResp.NodeClusters {
latestClusterMaps = append(latestClusterMaps, maps.Map{
"id": cluster.Id,
"name": cluster.Name,
})
}
}
this.Data["latestClusters"] = latestClusterMaps
// 搜索集群
countResp, err := this.RPC().NodeClusterRPC().CountAllEnabledNodeClusters(this.AdminContext(), &pb.CountAllEnabledNodeClustersRequest{
Keyword: params.Keyword,
})
2020-09-06 16:19:34 +08:00
if err != nil {
this.ErrorPage(err)
return
}
this.Data["countClusters"] = countResp.Count
2020-09-06 16:19:34 +08:00
count := countResp.Count
page := this.NewPage(count)
this.Data["page"] = page.AsHTML()
clusterMaps := []maps.Map{}
if count > 0 {
clustersResp, err := this.RPC().NodeClusterRPC().ListEnabledNodeClusters(this.AdminContext(), &pb.ListEnabledNodeClustersRequest{
Keyword: params.Keyword,
Offset: page.Offset,
Size: page.Size,
2020-09-06 16:19:34 +08:00
})
if err != nil {
this.ErrorPage(err)
return
}
2020-12-17 17:35:38 +08:00
for _, cluster := range clustersResp.NodeClusters {
2020-09-26 08:07:18 +08:00
// 全部节点数量
countNodesResp, err := this.RPC().NodeRPC().CountAllEnabledNodesMatch(this.AdminContext(), &pb.CountAllEnabledNodesMatchRequest{NodeClusterId: cluster.Id})
2020-09-06 16:19:34 +08:00
if err != nil {
this.ErrorPage(err)
return
}
2020-09-26 08:07:18 +08:00
// 在线节点
countActiveNodesResp, err := this.RPC().NodeRPC().CountAllEnabledNodesMatch(this.AdminContext(), &pb.CountAllEnabledNodesMatchRequest{
NodeClusterId: cluster.Id,
ActiveState: types.Int32(configutils.BoolStateYes),
2020-09-26 08:07:18 +08:00
})
if err != nil {
this.ErrorPage(err)
return
}
// 需要升级的节点
2021-05-25 17:48:51 +08:00
countUpgradeNodesResp, err := this.RPC().NodeRPC().CountAllUpgradeNodesWithNodeClusterId(this.AdminContext(), &pb.CountAllUpgradeNodesWithNodeClusterIdRequest{NodeClusterId: cluster.Id})
if err != nil {
this.ErrorPage(err)
return
}
2020-11-16 13:03:45 +08:00
// DNS
dnsDomainName := ""
if cluster.DnsDomainId > 0 {
dnsInfoResp, err := this.RPC().NodeClusterRPC().FindEnabledNodeClusterDNS(this.AdminContext(), &pb.FindEnabledNodeClusterDNSRequest{NodeClusterId: cluster.Id})
2020-11-02 09:50:31 +08:00
if err != nil {
this.ErrorPage(err)
return
}
2020-11-16 13:03:45 +08:00
if dnsInfoResp.Domain != nil {
dnsDomainName = dnsInfoResp.Domain.Name
2020-11-02 09:50:31 +08:00
}
}
// 服务数
countServersResp, err := this.RPC().ServerRPC().CountAllEnabledServersWithNodeClusterId(this.AdminContext(), &pb.CountAllEnabledServersWithNodeClusterIdRequest{NodeClusterId: cluster.Id})
if err != nil {
this.ErrorPage(err)
}
if cluster.TimeZone == nodeconfigs.DefaultTimeZoneLocation {
cluster.TimeZone = ""
}
2020-09-06 16:19:34 +08:00
clusterMaps = append(clusterMaps, maps.Map{
"id": cluster.Id,
"name": cluster.Name,
"installDir": cluster.InstallDir,
"countAllNodes": countNodesResp.Count,
"countActiveNodes": countActiveNodesResp.Count,
"countUpgradeNodes": countUpgradeNodesResp.Count,
"dnsDomainId": cluster.DnsDomainId,
"dnsName": cluster.DnsName,
"dnsDomainName": dnsDomainName,
"countServers": countServersResp.Count,
"timeZone": cluster.TimeZone,
2022-03-17 11:12:24 +08:00
"isPinned": cluster.IsPinned,
2020-09-06 16:19:34 +08:00
})
}
}
this.Data["clusters"] = clusterMaps
this.Data["nodes"] = []maps.Map{}
if len(params.Keyword) > 0 {
// 搜索节点
countResp, err := this.RPC().NodeRPC().CountAllEnabledNodesMatch(this.AdminContext(), &pb.CountAllEnabledNodesMatchRequest{
Keyword: params.Keyword,
})
if err != nil {
this.ErrorPage(err)
return
}
this.Data["countNodes"] = countResp.Count
}
this.Show()
}