2020-07-22 22:19:39 +08:00
|
|
|
package servers
|
|
|
|
|
|
2020-07-29 19:34:54 +08:00
|
|
|
import (
|
|
|
|
|
"encoding/json"
|
2020-12-07 11:45:45 +08:00
|
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/configloaders"
|
2020-07-29 19:34:54 +08:00
|
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
|
2021-05-23 20:44:51 +08:00
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/configutils"
|
2021-06-06 13:40:47 +08:00
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
|
2020-09-15 14:44:52 +08:00
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
2020-09-13 20:37:07 +08:00
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs"
|
2020-07-29 19:34:54 +08:00
|
|
|
"github.com/iwind/TeaGo/maps"
|
2021-05-23 20:44:51 +08:00
|
|
|
timeutil "github.com/iwind/TeaGo/utils/time"
|
2020-07-29 19:34:54 +08:00
|
|
|
)
|
2020-07-22 22:19:39 +08:00
|
|
|
|
|
|
|
|
type IndexAction struct {
|
|
|
|
|
actionutils.ParentAction
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (this *IndexAction) Init() {
|
2020-08-21 12:32:16 +08:00
|
|
|
this.Nav("", "server", "index")
|
2020-07-22 22:19:39 +08:00
|
|
|
}
|
|
|
|
|
|
2020-10-31 15:21:24 +08:00
|
|
|
func (this *IndexAction) RunGet(params struct {
|
2020-12-19 15:53:57 +08:00
|
|
|
ClusterId int64
|
|
|
|
|
GroupId int64
|
|
|
|
|
Keyword string
|
|
|
|
|
AuditingFlag int32
|
2020-12-23 10:31:00 +08:00
|
|
|
CheckDNS bool
|
2020-10-31 15:21:24 +08:00
|
|
|
}) {
|
2020-12-19 15:53:57 +08:00
|
|
|
this.Data["clusterId"] = params.ClusterId
|
2020-10-31 15:21:24 +08:00
|
|
|
this.Data["groupId"] = params.GroupId
|
|
|
|
|
this.Data["keyword"] = params.Keyword
|
2020-12-19 15:53:57 +08:00
|
|
|
this.Data["auditingFlag"] = params.AuditingFlag
|
2020-12-23 10:31:00 +08:00
|
|
|
this.Data["checkDNS"] = params.CheckDNS
|
2020-10-31 15:21:24 +08:00
|
|
|
|
2021-05-03 15:15:31 +08:00
|
|
|
isSearching := params.AuditingFlag == 1 || params.ClusterId > 0 || params.GroupId > 0 || len(params.Keyword) > 0
|
|
|
|
|
|
2020-12-19 15:53:57 +08:00
|
|
|
if params.AuditingFlag > 0 {
|
|
|
|
|
this.Data["firstMenuItem"] = "auditing"
|
|
|
|
|
}
|
|
|
|
|
|
2021-05-03 15:15:31 +08:00
|
|
|
// 常用的服务
|
|
|
|
|
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
|
|
|
|
|
|
2020-12-19 15:53:57 +08:00
|
|
|
// 审核中的数量
|
|
|
|
|
countAuditingResp, err := this.RPC().ServerRPC().CountAllEnabledServersMatch(this.AdminContext(), &pb.CountAllEnabledServersMatchRequest{
|
|
|
|
|
AuditingFlag: 1,
|
|
|
|
|
})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
this.Data["countAuditing"] = countAuditingResp.Count
|
|
|
|
|
|
|
|
|
|
// 全部数量
|
2020-10-31 15:21:24 +08:00
|
|
|
countResp, err := this.RPC().ServerRPC().CountAllEnabledServersMatch(this.AdminContext(), &pb.CountAllEnabledServersMatchRequest{
|
2021-05-25 17:48:51 +08:00
|
|
|
NodeClusterId: params.ClusterId,
|
|
|
|
|
ServerGroupId: params.GroupId,
|
|
|
|
|
Keyword: params.Keyword,
|
|
|
|
|
AuditingFlag: params.AuditingFlag,
|
2020-10-31 15:21:24 +08:00
|
|
|
})
|
2020-07-29 19:34:54 +08:00
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
count := countResp.Count
|
|
|
|
|
page := this.NewPage(count)
|
|
|
|
|
this.Data["page"] = page.AsHTML()
|
|
|
|
|
|
|
|
|
|
// 服务列表
|
2020-10-31 15:21:24 +08:00
|
|
|
serversResp, err := this.RPC().ServerRPC().ListEnabledServersMatch(this.AdminContext(), &pb.ListEnabledServersMatchRequest{
|
2021-05-25 17:48:51 +08:00
|
|
|
Offset: page.Offset,
|
|
|
|
|
Size: page.Size,
|
|
|
|
|
NodeClusterId: params.ClusterId,
|
|
|
|
|
ServerGroupId: params.GroupId,
|
|
|
|
|
Keyword: params.Keyword,
|
|
|
|
|
AuditingFlag: params.AuditingFlag,
|
2020-07-29 19:34:54 +08:00
|
|
|
})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
serverMaps := []maps.Map{}
|
|
|
|
|
for _, server := range serversResp.Servers {
|
2020-09-15 14:44:52 +08:00
|
|
|
config := &serverconfigs.ServerConfig{}
|
|
|
|
|
err = json.Unmarshal(server.Config, config)
|
2020-07-29 19:34:54 +08:00
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
2020-08-21 12:32:16 +08:00
|
|
|
|
|
|
|
|
// 端口列表
|
|
|
|
|
portMaps := []maps.Map{}
|
2020-09-15 14:44:52 +08:00
|
|
|
if len(server.HttpJSON) > 0 && config.HTTP.IsOn {
|
|
|
|
|
for _, listen := range config.HTTP.Listen {
|
2020-08-21 12:32:16 +08:00
|
|
|
portMaps = append(portMaps, maps.Map{
|
|
|
|
|
"protocol": listen.Protocol,
|
|
|
|
|
"portRange": listen.PortRange,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-09-15 14:44:52 +08:00
|
|
|
if config.HTTPS != nil && config.HTTPS.IsOn {
|
|
|
|
|
for _, listen := range config.HTTPS.Listen {
|
2020-08-21 12:32:16 +08:00
|
|
|
portMaps = append(portMaps, maps.Map{
|
|
|
|
|
"protocol": listen.Protocol,
|
|
|
|
|
"portRange": listen.PortRange,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-09-15 14:44:52 +08:00
|
|
|
if config.TCP != nil && config.TCP.IsOn {
|
|
|
|
|
for _, listen := range config.TCP.Listen {
|
2020-08-21 12:32:16 +08:00
|
|
|
portMaps = append(portMaps, maps.Map{
|
|
|
|
|
"protocol": listen.Protocol,
|
|
|
|
|
"portRange": listen.PortRange,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-09-15 14:44:52 +08:00
|
|
|
if config.TLS != nil && config.TLS.IsOn {
|
|
|
|
|
for _, listen := range config.TLS.Listen {
|
2020-08-21 12:32:16 +08:00
|
|
|
portMaps = append(portMaps, maps.Map{
|
|
|
|
|
"protocol": listen.Protocol,
|
|
|
|
|
"portRange": listen.PortRange,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-09-15 14:44:52 +08:00
|
|
|
if config.Unix != nil && config.Unix.IsOn {
|
|
|
|
|
for _, listen := range config.Unix.Listen {
|
2020-08-21 12:32:16 +08:00
|
|
|
portMaps = append(portMaps, maps.Map{
|
|
|
|
|
"protocol": listen.Protocol,
|
|
|
|
|
"portRange": listen.Host,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-09-15 14:44:52 +08:00
|
|
|
if config.UDP != nil && config.UDP.IsOn {
|
|
|
|
|
for _, listen := range config.UDP.Listen {
|
2020-08-21 12:32:16 +08:00
|
|
|
portMaps = append(portMaps, maps.Map{
|
|
|
|
|
"protocol": listen.Protocol,
|
|
|
|
|
"portRange": listen.PortRange,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-07-29 19:34:54 +08:00
|
|
|
|
2020-10-29 21:37:48 +08:00
|
|
|
// 分组
|
|
|
|
|
groupMaps := []maps.Map{}
|
2021-05-25 17:48:51 +08:00
|
|
|
if len(server.ServerGroups) > 0 {
|
|
|
|
|
for _, group := range server.ServerGroups {
|
2020-10-29 21:37:48 +08:00
|
|
|
groupMaps = append(groupMaps, maps.Map{
|
|
|
|
|
"id": group.Id,
|
|
|
|
|
"name": group.Name,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-31 15:21:24 +08:00
|
|
|
// 域名列表
|
|
|
|
|
serverNames := []*serverconfigs.ServerNameConfig{}
|
2020-12-19 19:08:39 +08:00
|
|
|
if server.IsAuditing || (server.AuditingResult != nil && !server.AuditingResult.IsOk) {
|
2020-12-19 15:53:57 +08:00
|
|
|
server.ServerNamesJSON = server.AuditingServerNamesJSON
|
|
|
|
|
}
|
2020-12-19 19:08:39 +08:00
|
|
|
auditingIsOk := true
|
|
|
|
|
if !server.IsAuditing && server.AuditingResult != nil && !server.AuditingResult.IsOk {
|
|
|
|
|
auditingIsOk = false
|
|
|
|
|
}
|
2020-12-03 21:07:08 +08:00
|
|
|
if len(server.ServerNamesJSON) > 0 {
|
|
|
|
|
err = json.Unmarshal(server.ServerNamesJSON, &serverNames)
|
2020-10-31 15:21:24 +08:00
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-11-15 16:28:25 +08:00
|
|
|
countServerNames := 0
|
|
|
|
|
for _, serverName := range serverNames {
|
|
|
|
|
if len(serverName.SubNames) == 0 {
|
|
|
|
|
countServerNames++
|
|
|
|
|
} else {
|
|
|
|
|
countServerNames += len(serverName.SubNames)
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-10-31 15:21:24 +08:00
|
|
|
|
2020-12-07 11:45:45 +08:00
|
|
|
// 用户
|
|
|
|
|
var userMap maps.Map = nil
|
|
|
|
|
if server.User != nil {
|
|
|
|
|
userMap = maps.Map{
|
|
|
|
|
"id": server.User.Id,
|
|
|
|
|
"fullname": server.User.Fullname,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-07-29 19:34:54 +08:00
|
|
|
serverMaps = append(serverMaps, maps.Map{
|
|
|
|
|
"id": server.Id,
|
2020-10-09 12:03:32 +08:00
|
|
|
"isOn": server.IsOn,
|
2020-09-13 20:37:07 +08:00
|
|
|
"name": server.Name,
|
2020-07-29 19:34:54 +08:00
|
|
|
"cluster": maps.Map{
|
2020-12-17 17:35:38 +08:00
|
|
|
"id": server.NodeCluster.Id,
|
|
|
|
|
"name": server.NodeCluster.Name,
|
2020-07-29 19:34:54 +08:00
|
|
|
},
|
2020-11-15 16:28:25 +08:00
|
|
|
"ports": portMaps,
|
|
|
|
|
"serverTypeName": serverconfigs.FindServerType(server.Type).GetString("name"),
|
|
|
|
|
"groups": groupMaps,
|
|
|
|
|
"serverNames": serverNames,
|
|
|
|
|
"countServerNames": countServerNames,
|
2020-12-19 15:53:57 +08:00
|
|
|
"isAuditing": server.IsAuditing,
|
2020-12-19 19:08:39 +08:00
|
|
|
"auditingIsOk": auditingIsOk,
|
2020-12-07 11:45:45 +08:00
|
|
|
"user": userMap,
|
2020-07-29 19:34:54 +08:00
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
this.Data["servers"] = serverMaps
|
|
|
|
|
|
2020-12-19 15:53:57 +08:00
|
|
|
// 集群
|
|
|
|
|
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
|
|
|
|
|
|
2020-10-31 15:21:24 +08:00
|
|
|
// 分组
|
|
|
|
|
groupsResp, err := this.RPC().ServerGroupRPC().FindAllEnabledServerGroups(this.AdminContext(), &pb.FindAllEnabledServerGroupsRequest{})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
groupMaps := []maps.Map{}
|
2021-05-25 17:48:51 +08:00
|
|
|
for _, group := range groupsResp.ServerGroups {
|
2020-11-02 09:37:20 +08:00
|
|
|
groupName := group.Name
|
2020-10-31 15:21:24 +08:00
|
|
|
groupMaps = append(groupMaps, maps.Map{
|
|
|
|
|
"id": group.Id,
|
2020-11-02 09:37:20 +08:00
|
|
|
"name": groupName,
|
2020-10-31 15:21:24 +08:00
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
this.Data["groups"] = groupMaps
|
|
|
|
|
|
2020-12-07 11:45:45 +08:00
|
|
|
// 是否有用户管理权限
|
|
|
|
|
this.Data["canVisitUser"] = configloaders.AllowModule(this.AdminId(), configloaders.AdminModuleCodeUser)
|
|
|
|
|
|
2021-05-23 20:44:51 +08:00
|
|
|
// 显示服务相关的日志
|
|
|
|
|
errorLogsResp, err := this.RPC().NodeLogRPC().ListNodeLogs(this.AdminContext(), &pb.ListNodeLogsRequest{
|
|
|
|
|
NodeId: 0,
|
2021-06-06 13:40:47 +08:00
|
|
|
Role: nodeconfigs.NodeRoleNode,
|
2021-05-23 20:44:51 +08:00
|
|
|
Offset: 0,
|
2021-11-30 16:43:44 +08:00
|
|
|
Size: 20,
|
2021-06-06 13:40:47 +08:00
|
|
|
Level: "",
|
2021-05-23 20:44:51 +08:00
|
|
|
FixedState: int32(configutils.BoolStateNo),
|
|
|
|
|
AllServers: true,
|
|
|
|
|
})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
errorLogMaps := []maps.Map{}
|
|
|
|
|
for _, errorLog := range errorLogsResp.NodeLogs {
|
|
|
|
|
serverResp, err := this.RPC().ServerRPC().FindEnabledUserServerBasic(this.AdminContext(), &pb.FindEnabledUserServerBasicRequest{ServerId: errorLog.ServerId})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
2021-07-27 10:48:42 +08:00
|
|
|
|
|
|
|
|
// 服务
|
|
|
|
|
var server = serverResp.Server
|
2021-05-23 20:44:51 +08:00
|
|
|
if server == nil {
|
|
|
|
|
// 设置为已修复
|
2021-11-30 16:43:44 +08:00
|
|
|
_, err = this.RPC().NodeLogRPC().FixNodeLogs(this.AdminContext(), &pb.FixNodeLogsRequest{NodeLogIds: []int64{errorLog.Id}})
|
2021-05-23 20:44:51 +08:00
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-27 10:48:42 +08:00
|
|
|
// 节点
|
|
|
|
|
nodeResp, err := this.RPC().NodeRPC().FindEnabledNode(this.AdminContext(), &pb.FindEnabledNodeRequest{NodeId: errorLog.NodeId})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
var node = nodeResp.Node
|
|
|
|
|
if node == nil || node.NodeCluster == nil {
|
|
|
|
|
// 设置为已修复
|
2021-11-30 16:43:44 +08:00
|
|
|
_, err = this.RPC().NodeLogRPC().FixNodeLogs(this.AdminContext(), &pb.FixNodeLogsRequest{NodeLogIds: []int64{errorLog.Id}})
|
2021-07-27 10:48:42 +08:00
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
|
2021-05-23 20:44:51 +08:00
|
|
|
errorLogMaps = append(errorLogMaps, maps.Map{
|
|
|
|
|
"id": errorLog.Id,
|
|
|
|
|
"description": errorLog.Description,
|
|
|
|
|
"createdTime": timeutil.FormatTime("Y-m-d H:i:s", errorLog.CreatedAt),
|
|
|
|
|
"serverId": errorLog.ServerId,
|
2021-06-06 13:40:47 +08:00
|
|
|
"level": errorLog.Level,
|
2021-05-23 20:44:51 +08:00
|
|
|
"serverName": server.Name,
|
2021-07-27 10:48:42 +08:00
|
|
|
"nodeId": node.Id,
|
|
|
|
|
"nodeName": node.Name,
|
|
|
|
|
"clusterId": node.NodeCluster.Id,
|
2021-05-23 20:44:51 +08:00
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
this.Data["errorLogs"] = errorLogMaps
|
|
|
|
|
|
2020-07-22 22:19:39 +08:00
|
|
|
this.Show()
|
|
|
|
|
}
|