Files
EdgeAdmin/internal/web/actions/default/clusters/cluster/node/logs.go

75 lines
1.8 KiB
Go
Raw Normal View History

2020-10-09 11:07:01 +08:00
package node
import (
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
"github.com/iwind/TeaGo/maps"
timeutil "github.com/iwind/TeaGo/utils/time"
)
type LogsAction struct {
actionutils.ParentAction
}
func (this *LogsAction) Init() {
this.Nav("", "node", "log")
this.SecondMenu("nodes")
}
func (this *LogsAction) RunGet(params struct {
2021-05-19 20:52:41 +08:00
NodeId int64
DayFrom string
DayTo string
Keyword string
Level string
2020-10-09 11:07:01 +08:00
}) {
this.Data["nodeId"] = params.NodeId
2021-05-19 20:52:41 +08:00
this.Data["dayFrom"] = params.DayFrom
this.Data["dayTo"] = params.DayTo
this.Data["keyword"] = params.Keyword
this.Data["level"] = params.Level
2020-10-09 11:07:01 +08:00
countResp, err := this.RPC().NodeLogRPC().CountNodeLogs(this.AdminContext(), &pb.CountNodeLogsRequest{
2021-05-19 20:52:41 +08:00
Role: "node",
NodeId: params.NodeId,
DayFrom: params.DayFrom,
DayTo: params.DayTo,
Keyword: params.Keyword,
Level: params.Level,
2020-10-09 11:07:01 +08:00
})
if err != nil {
this.ErrorPage(err)
return
}
count := countResp.Count
2020-10-10 11:48:07 +08:00
page := this.NewPage(count, 20)
2020-10-09 11:07:01 +08:00
logsResp, err := this.RPC().NodeLogRPC().ListNodeLogs(this.AdminContext(), &pb.ListNodeLogsRequest{
2021-05-19 20:52:41 +08:00
NodeId: params.NodeId,
Role: "node",
DayFrom: params.DayFrom,
DayTo: params.DayTo,
Keyword: params.Keyword,
Level: params.Level,
Offset: page.Offset,
Size: page.Size,
2020-10-09 11:07:01 +08:00
})
logs := []maps.Map{}
for _, log := range logsResp.NodeLogs {
logs = append(logs, maps.Map{
"tag": log.Tag,
"description": log.Description,
"createdTime": timeutil.FormatTime("Y-m-d H:i:s", log.CreatedAt),
"level": log.Level,
"isToday": timeutil.FormatTime("Y-m-d", log.CreatedAt) == timeutil.Format("Y-m-d"),
2021-05-19 20:52:41 +08:00
"count": log.Count,
2020-10-09 11:07:01 +08:00
})
}
this.Data["logs"] = logs
this.Data["page"] = page.AsHTML()
this.Show()
}