Files
EdgeAPI/internal/rpc/services/service_node_log.go

156 lines
4.4 KiB
Go
Raw Normal View History

2020-10-09 11:06:37 +08:00
package services
import (
"context"
"github.com/TeaOSLab/EdgeAPI/internal/db/models"
rpcutils "github.com/TeaOSLab/EdgeAPI/internal/rpc/utils"
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
2021-06-06 13:40:33 +08:00
"github.com/iwind/TeaGo/lists"
"github.com/iwind/TeaGo/types"
2020-10-09 11:06:37 +08:00
)
// NodeLogService 节点日志相关服务
2020-10-09 11:06:37 +08:00
type NodeLogService struct {
2020-11-24 17:36:47 +08:00
BaseService
2020-10-09 11:06:37 +08:00
}
// CreateNodeLogs 创建日志
2020-10-09 11:06:37 +08:00
func (this *NodeLogService) CreateNodeLogs(ctx context.Context, req *pb.CreateNodeLogsRequest) (*pb.CreateNodeLogsResponse, error) {
2021-07-11 18:05:57 +08:00
_, _, _, err := rpcutils.ValidateRequest(ctx)
2020-10-09 11:06:37 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
2020-10-09 11:06:37 +08:00
for _, nodeLog := range req.NodeLogs {
2021-11-30 16:43:16 +08:00
err := models.SharedNodeLogDAO.CreateLog(tx, nodeLog.Role, nodeLog.NodeId, nodeLog.ServerId, nodeLog.OriginId, nodeLog.Level, nodeLog.Tag, nodeLog.Description, nodeLog.CreatedAt, nodeLog.Type, nodeLog.ParamsJSON)
2020-10-09 11:06:37 +08:00
if err != nil {
return nil, err
}
}
return &pb.CreateNodeLogsResponse{}, nil
}
// CountNodeLogs 查询日志数量
2020-11-12 14:41:28 +08:00
func (this *NodeLogService) CountNodeLogs(ctx context.Context, req *pb.CountNodeLogsRequest) (*pb.RPCCountResponse, error) {
2021-07-11 18:05:57 +08:00
_, err := this.ValidateAdmin(ctx, 0)
2020-10-09 11:06:37 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
count, err := models.SharedNodeLogDAO.CountNodeLogs(tx, req.Role, req.NodeClusterId, req.NodeId, req.ServerId, req.OriginId, req.DayFrom, req.DayTo, req.Keyword, req.Level, req.IsUnread, req.Tag)
2020-10-09 11:06:37 +08:00
if err != nil {
return nil, err
}
2020-11-24 17:36:47 +08:00
return this.SuccessCount(count)
2020-10-09 11:06:37 +08:00
}
// ListNodeLogs 列出单页日志
2020-10-09 11:06:37 +08:00
func (this *NodeLogService) ListNodeLogs(ctx context.Context, req *pb.ListNodeLogsRequest) (*pb.ListNodeLogsResponse, error) {
2021-07-11 18:05:57 +08:00
_, err := this.ValidateAdmin(ctx, 0)
2020-10-09 11:06:37 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
logs, err := models.SharedNodeLogDAO.ListNodeLogs(tx, req.Role, req.NodeClusterId, req.NodeId, req.ServerId, req.OriginId, req.AllServers, req.DayFrom, req.DayTo, req.Keyword, req.Level, types.Int8(req.FixedState), req.IsUnread, req.Tag, req.Offset, req.Size)
2020-10-09 11:06:37 +08:00
if err != nil {
return nil, err
}
2021-06-06 13:40:33 +08:00
hashList := []string{}
2020-10-09 11:06:37 +08:00
result := []*pb.NodeLog{}
for _, log := range logs {
2021-06-06 13:40:33 +08:00
// 如果是需要修复的日志,我们需要去重
if req.FixedState > 0 {
if lists.ContainsString(hashList, log.Hash) {
continue
}
hashList = append(hashList, log.Hash)
}
2020-10-09 11:06:37 +08:00
result = append(result, &pb.NodeLog{
Id: int64(log.Id),
2020-10-09 11:06:37 +08:00
Role: log.Role,
Tag: log.Tag,
Description: log.Description,
Level: log.Level,
NodeId: int64(log.NodeId),
ServerId: int64(log.ServerId),
2020-10-09 11:06:37 +08:00
CreatedAt: int64(log.CreatedAt),
Count: types.Int32(log.Count),
2022-03-22 22:11:32 +08:00
IsFixed: log.IsFixed,
IsRead: log.IsRead,
2020-10-09 11:06:37 +08:00
})
}
return &pb.ListNodeLogsResponse{NodeLogs: result}, nil
}
2021-11-30 16:43:16 +08:00
// FixNodeLogs 设置日志为已修复
func (this *NodeLogService) FixNodeLogs(ctx context.Context, req *pb.FixNodeLogsRequest) (*pb.RPCSuccess, error) {
_, err := this.ValidateAdmin(ctx, 0)
if err != nil {
return nil, err
}
var tx = this.NullTx()
2021-11-30 16:43:16 +08:00
for _, logId := range req.NodeLogIds {
err = models.SharedNodeLogDAO.UpdateNodeLogFixed(tx, logId)
if err != nil {
return nil, err
}
}
return this.Success()
}
2021-10-14 17:29:54 +08:00
// CountAllUnreadNodeLogs 计算未读的日志数量
func (this *NodeLogService) CountAllUnreadNodeLogs(ctx context.Context, req *pb.CountAllUnreadNodeLogsRequest) (*pb.RPCCountResponse, error) {
_, err := this.ValidateAdmin(ctx, 0)
if err != nil {
return nil, err
}
var tx = this.NullTx()
count, err := models.SharedNodeLogDAO.CountAllUnreadNodeLogs(tx)
if err != nil {
return nil, err
}
return this.SuccessCount(count)
}
// UpdateNodeLogsRead 设置日志为已读
func (this *NodeLogService) UpdateNodeLogsRead(ctx context.Context, req *pb.UpdateNodeLogsReadRequest) (*pb.RPCSuccess, error) {
_, err := this.ValidateAdmin(ctx, 0)
if err != nil {
return nil, err
}
var tx = this.NullTx()
err = models.SharedNodeLogDAO.UpdateNodeLogsRead(tx, req.NodeLogIds)
if err != nil {
return nil, err
}
return this.Success()
}
2021-11-15 11:31:27 +08:00
// UpdateAllNodeLogsRead 设置所有日志未已读
func (this *NodeLogService) UpdateAllNodeLogsRead(ctx context.Context, req *pb.UpdateAllNodeLogsReadRequest) (*pb.RPCSuccess, error) {
_, err := this.ValidateAdmin(ctx, 0)
if err != nil {
return nil, err
}
var tx = this.NullTx()
err = models.SharedNodeLogDAO.UpdateAllNodeLogsRead(tx)
if err != nil {
return nil, err
}
return this.Success()
}