mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-04 04:54:32 +08:00
293 lines
7.9 KiB
Go
293 lines
7.9 KiB
Go
package servers
|
|
|
|
import (
|
|
"encoding/json"
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/configloaders"
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/utils/numberutils"
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/configutils"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs"
|
|
"github.com/iwind/TeaGo/maps"
|
|
timeutil "github.com/iwind/TeaGo/utils/time"
|
|
)
|
|
|
|
type IndexAction struct {
|
|
actionutils.ParentAction
|
|
}
|
|
|
|
func (this *IndexAction) Init() {
|
|
this.Nav("", "server", "index")
|
|
}
|
|
|
|
func (this *IndexAction) RunGet(params struct {
|
|
ClusterId int64
|
|
GroupId int64
|
|
Keyword string
|
|
AuditingFlag int32
|
|
CheckDNS bool
|
|
|
|
TrafficOutOrder string
|
|
}) {
|
|
this.Data["clusterId"] = params.ClusterId
|
|
this.Data["groupId"] = params.GroupId
|
|
this.Data["keyword"] = params.Keyword
|
|
this.Data["auditingFlag"] = params.AuditingFlag
|
|
this.Data["checkDNS"] = params.CheckDNS
|
|
this.Data["hasOrder"] = len(params.TrafficOutOrder) > 0
|
|
|
|
isSearching := params.AuditingFlag == 1 || params.ClusterId > 0 || params.GroupId > 0 || len(params.Keyword) > 0
|
|
|
|
if params.AuditingFlag > 0 {
|
|
this.Data["firstMenuItem"] = "auditing"
|
|
}
|
|
|
|
// 常用的服务
|
|
latestServerMaps := []maps.Map{}
|
|
if !isSearching {
|
|
serversResp, err := this.RPC().ServerRPC().FindLatestServers(this.AdminContext(), &pb.FindLatestServersRequest{Size: 6})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
for _, server := range serversResp.Servers {
|
|
latestServerMaps = append(latestServerMaps, maps.Map{
|
|
"id": server.Id,
|
|
"name": server.Name,
|
|
})
|
|
}
|
|
}
|
|
this.Data["latestServers"] = latestServerMaps
|
|
|
|
// 审核中的数量
|
|
countAuditingResp, err := this.RPC().ServerRPC().CountAllEnabledServersMatch(this.AdminContext(), &pb.CountAllEnabledServersMatchRequest{
|
|
AuditingFlag: 1,
|
|
})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
this.Data["countAuditing"] = countAuditingResp.Count
|
|
|
|
// 全部数量
|
|
countResp, err := this.RPC().ServerRPC().CountAllEnabledServersMatch(this.AdminContext(), &pb.CountAllEnabledServersMatchRequest{
|
|
NodeClusterId: params.ClusterId,
|
|
ServerGroupId: params.GroupId,
|
|
Keyword: params.Keyword,
|
|
AuditingFlag: params.AuditingFlag,
|
|
})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
count := countResp.Count
|
|
page := this.NewPage(count)
|
|
this.Data["page"] = page.AsHTML()
|
|
|
|
// 服务列表
|
|
serversResp, err := this.RPC().ServerRPC().ListEnabledServersMatch(this.AdminContext(), &pb.ListEnabledServersMatchRequest{
|
|
Offset: page.Offset,
|
|
Size: page.Size,
|
|
NodeClusterId: params.ClusterId,
|
|
ServerGroupId: params.GroupId,
|
|
Keyword: params.Keyword,
|
|
AuditingFlag: params.AuditingFlag,
|
|
TrafficOutDesc: params.TrafficOutOrder == "desc",
|
|
TrafficOutAsc: params.TrafficOutOrder == "asc",
|
|
})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
serverMaps := []maps.Map{}
|
|
for _, server := range serversResp.Servers {
|
|
config := &serverconfigs.ServerConfig{}
|
|
err = json.Unmarshal(server.Config, config)
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
|
|
// 端口列表
|
|
portMaps := []maps.Map{}
|
|
if len(server.HttpJSON) > 0 && config.HTTP.IsOn {
|
|
for _, listen := range config.HTTP.Listen {
|
|
portMaps = append(portMaps, maps.Map{
|
|
"protocol": listen.Protocol,
|
|
"portRange": listen.PortRange,
|
|
})
|
|
}
|
|
}
|
|
if config.HTTPS != nil && config.HTTPS.IsOn {
|
|
for _, listen := range config.HTTPS.Listen {
|
|
portMaps = append(portMaps, maps.Map{
|
|
"protocol": listen.Protocol,
|
|
"portRange": listen.PortRange,
|
|
})
|
|
}
|
|
}
|
|
if config.TCP != nil && config.TCP.IsOn {
|
|
for _, listen := range config.TCP.Listen {
|
|
portMaps = append(portMaps, maps.Map{
|
|
"protocol": listen.Protocol,
|
|
"portRange": listen.PortRange,
|
|
})
|
|
}
|
|
}
|
|
if config.TLS != nil && config.TLS.IsOn {
|
|
for _, listen := range config.TLS.Listen {
|
|
portMaps = append(portMaps, maps.Map{
|
|
"protocol": listen.Protocol,
|
|
"portRange": listen.PortRange,
|
|
})
|
|
}
|
|
}
|
|
if config.Unix != nil && config.Unix.IsOn {
|
|
for _, listen := range config.Unix.Listen {
|
|
portMaps = append(portMaps, maps.Map{
|
|
"protocol": listen.Protocol,
|
|
"portRange": listen.Host,
|
|
})
|
|
}
|
|
}
|
|
if config.UDP != nil && config.UDP.IsOn {
|
|
for _, listen := range config.UDP.Listen {
|
|
portMaps = append(portMaps, maps.Map{
|
|
"protocol": listen.Protocol,
|
|
"portRange": listen.PortRange,
|
|
})
|
|
}
|
|
}
|
|
|
|
// 分组
|
|
groupMaps := []maps.Map{}
|
|
if len(server.ServerGroups) > 0 {
|
|
for _, group := range server.ServerGroups {
|
|
groupMaps = append(groupMaps, maps.Map{
|
|
"id": group.Id,
|
|
"name": group.Name,
|
|
})
|
|
}
|
|
}
|
|
|
|
// 域名列表
|
|
serverNames := []*serverconfigs.ServerNameConfig{}
|
|
if server.IsAuditing || (server.AuditingResult != nil && !server.AuditingResult.IsOk) {
|
|
server.ServerNamesJSON = server.AuditingServerNamesJSON
|
|
}
|
|
auditingIsOk := true
|
|
if !server.IsAuditing && server.AuditingResult != nil && !server.AuditingResult.IsOk {
|
|
auditingIsOk = false
|
|
}
|
|
if len(server.ServerNamesJSON) > 0 {
|
|
err = json.Unmarshal(server.ServerNamesJSON, &serverNames)
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
}
|
|
countServerNames := 0
|
|
for _, serverName := range serverNames {
|
|
if len(serverName.SubNames) == 0 {
|
|
countServerNames++
|
|
} else {
|
|
countServerNames += len(serverName.SubNames)
|
|
}
|
|
}
|
|
|
|
// 用户
|
|
var userMap maps.Map = nil
|
|
if server.User != nil {
|
|
userMap = maps.Map{
|
|
"id": server.User.Id,
|
|
"fullname": server.User.Fullname,
|
|
}
|
|
}
|
|
|
|
// 提交审核时间
|
|
var auditingTime = ""
|
|
if server.AuditingAt > 0 {
|
|
auditingTime = timeutil.FormatTime("Y-m-d", server.AuditingAt)
|
|
}
|
|
|
|
// 统计数据
|
|
var bandwidth = ""
|
|
if server.LatestServerDailyStat != nil {
|
|
var bytesPerSecond = server.LatestServerDailyStat.Bytes / 300
|
|
if bytesPerSecond > 0 {
|
|
bandwidth = numberutils.FormatBytes(bytesPerSecond)
|
|
}
|
|
}
|
|
|
|
serverMaps = append(serverMaps, maps.Map{
|
|
"id": server.Id,
|
|
"isOn": server.IsOn,
|
|
"name": server.Name,
|
|
"cluster": maps.Map{
|
|
"id": server.NodeCluster.Id,
|
|
"name": server.NodeCluster.Name,
|
|
},
|
|
"ports": portMaps,
|
|
"serverTypeName": serverconfigs.FindServerType(server.Type).GetString("name"),
|
|
"groups": groupMaps,
|
|
"serverNames": serverNames,
|
|
"countServerNames": countServerNames,
|
|
"isAuditing": server.IsAuditing,
|
|
"auditingIsOk": auditingIsOk,
|
|
"user": userMap,
|
|
"auditingTime": auditingTime,
|
|
"bandwidth": bandwidth,
|
|
})
|
|
}
|
|
this.Data["servers"] = serverMaps
|
|
|
|
// 集群
|
|
clustersResp, err := this.RPC().NodeClusterRPC().FindAllEnabledNodeClusters(this.AdminContext(), &pb.FindAllEnabledNodeClustersRequest{})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
clusterMaps := []maps.Map{}
|
|
for _, cluster := range clustersResp.NodeClusters {
|
|
clusterMaps = append(clusterMaps, maps.Map{
|
|
"id": cluster.Id,
|
|
"name": cluster.Name,
|
|
})
|
|
}
|
|
this.Data["clusters"] = clusterMaps
|
|
|
|
// 分组
|
|
groupsResp, err := this.RPC().ServerGroupRPC().FindAllEnabledServerGroups(this.AdminContext(), &pb.FindAllEnabledServerGroupsRequest{})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
groupMaps := []maps.Map{}
|
|
for _, group := range groupsResp.ServerGroups {
|
|
groupName := group.Name
|
|
groupMaps = append(groupMaps, maps.Map{
|
|
"id": group.Id,
|
|
"name": groupName,
|
|
})
|
|
}
|
|
this.Data["groups"] = groupMaps
|
|
|
|
// 是否有用户管理权限
|
|
this.Data["canVisitUser"] = configloaders.AllowModule(this.AdminId(), configloaders.AdminModuleCodeUser)
|
|
|
|
// 显示服务需要修复的日志数量
|
|
countNeedFixLogsResp, err := this.RPC().NodeLogRPC().CountNodeLogs(this.AdminContext(), &pb.CountNodeLogsRequest{
|
|
Role: nodeconfigs.NodeRoleNode,
|
|
AllServers: true,
|
|
FixedState: int32(configutils.BoolStateNo),
|
|
})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
this.Data["countNeedFixLogs"] = countNeedFixLogsResp.Count
|
|
|
|
this.Show()
|
|
}
|