mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 07:50:25 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			180 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			180 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
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"
 | 
						|
)
 | 
						|
 | 
						|
// LogService 管理员、用户或者其他系统用户日志
 | 
						|
type LogService struct {
 | 
						|
	BaseService
 | 
						|
}
 | 
						|
 | 
						|
// CreateLog 创建日志
 | 
						|
func (this *LogService) CreateLog(ctx context.Context, req *pb.CreateLogRequest) (*pb.CreateLogResponse, error) {
 | 
						|
	// 校验请求
 | 
						|
	userType, _, userId, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin, rpcutils.UserTypeUser, rpcutils.UserTypeProvider)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	tx := this.NullTx()
 | 
						|
 | 
						|
	err = models.SharedLogDAO.CreateLog(tx, userType, userId, req.Level, req.Description, req.Action, req.Ip)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	return &pb.CreateLogResponse{}, nil
 | 
						|
}
 | 
						|
 | 
						|
// CountLogs 计算日志数量
 | 
						|
func (this *LogService) CountLogs(ctx context.Context, req *pb.CountLogRequest) (*pb.RPCCountResponse, error) {
 | 
						|
	// 校验请求
 | 
						|
	_, err := this.ValidateAdmin(ctx, 0)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	tx := this.NullTx()
 | 
						|
 | 
						|
	count, err := models.SharedLogDAO.CountLogs(tx, req.DayFrom, req.DayTo, req.Keyword, req.UserType)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	return this.SuccessCount(count)
 | 
						|
}
 | 
						|
 | 
						|
// ListLogs 列出单页日志
 | 
						|
func (this *LogService) ListLogs(ctx context.Context, req *pb.ListLogsRequest) (*pb.ListLogsResponse, error) {
 | 
						|
	// 校验请求
 | 
						|
	_, err := this.ValidateAdmin(ctx, 0)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	tx := this.NullTx()
 | 
						|
 | 
						|
	logs, err := models.SharedLogDAO.ListLogs(tx, req.Offset, req.Size, req.DayFrom, req.DayTo, req.Keyword, req.UserType)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	result := []*pb.Log{}
 | 
						|
	for _, log := range logs {
 | 
						|
		userName := ""
 | 
						|
		if log.AdminId > 0 {
 | 
						|
			userName, err = models.SharedAdminDAO.FindAdminFullname(tx, int64(log.AdminId))
 | 
						|
		} else if log.UserId > 0 {
 | 
						|
			userName, err = models.SharedUserDAO.FindUserFullname(tx, int64(log.UserId))
 | 
						|
		} else if log.ProviderId > 0 {
 | 
						|
			userName, err = models.SharedProviderDAO.FindProviderName(tx, int64(log.ProviderId))
 | 
						|
		}
 | 
						|
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
 | 
						|
		result = append(result, &pb.Log{
 | 
						|
			Id:          int64(log.Id),
 | 
						|
			Level:       log.Level,
 | 
						|
			Action:      log.Action,
 | 
						|
			AdminId:     int64(log.AdminId),
 | 
						|
			UserId:      int64(log.UserId),
 | 
						|
			ProviderId:  int64(log.ProviderId),
 | 
						|
			CreatedAt:   int64(log.CreatedAt),
 | 
						|
			Type:        log.Type,
 | 
						|
			Ip:          log.Ip,
 | 
						|
			UserName:    userName,
 | 
						|
			Description: log.Description,
 | 
						|
		})
 | 
						|
	}
 | 
						|
 | 
						|
	return &pb.ListLogsResponse{Logs: result}, nil
 | 
						|
}
 | 
						|
 | 
						|
// DeleteLogPermanently 删除单条
 | 
						|
func (this *LogService) DeleteLogPermanently(ctx context.Context, req *pb.DeleteLogPermanentlyRequest) (*pb.RPCSuccess, error) {
 | 
						|
	_, err := this.ValidateAdmin(ctx, 0)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	// TODO 校验权限
 | 
						|
 | 
						|
	tx := this.NullTx()
 | 
						|
 | 
						|
	// 执行物理删除
 | 
						|
	err = models.SharedLogDAO.DeleteLogPermanently(tx, req.LogId)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	return this.Success()
 | 
						|
}
 | 
						|
 | 
						|
// DeleteLogsPermanently 批量删除
 | 
						|
func (this *LogService) DeleteLogsPermanently(ctx context.Context, req *pb.DeleteLogsPermanentlyRequest) (*pb.RPCSuccess, error) {
 | 
						|
	_, err := this.ValidateAdmin(ctx, 0)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	// TODO 校验权限
 | 
						|
 | 
						|
	tx := this.NullTx()
 | 
						|
 | 
						|
	// 执行物理删除
 | 
						|
	for _, logId := range req.LogIds {
 | 
						|
		err = models.SharedLogDAO.DeleteLogPermanently(tx, logId)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	return this.Success()
 | 
						|
}
 | 
						|
 | 
						|
// CleanLogsPermanently 清理日志
 | 
						|
func (this *LogService) CleanLogsPermanently(ctx context.Context, req *pb.CleanLogsPermanentlyRequest) (*pb.RPCSuccess, error) {
 | 
						|
	_, err := this.ValidateAdmin(ctx, 0)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	// TODO 校验权限
 | 
						|
 | 
						|
	tx := this.NullTx()
 | 
						|
 | 
						|
	if req.ClearAll {
 | 
						|
		err = models.SharedLogDAO.DeleteAllLogsPermanently(tx)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	} else if req.Days > 0 {
 | 
						|
		err = models.SharedLogDAO.DeleteLogsPermanentlyBeforeDays(tx, int(req.Days))
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	return this.Success()
 | 
						|
}
 | 
						|
 | 
						|
// SumLogsSize 计算日志容量大小
 | 
						|
func (this *LogService) SumLogsSize(ctx context.Context, req *pb.SumLogsSizeRequest) (*pb.SumLogsResponse, error) {
 | 
						|
	_, err := this.ValidateAdmin(ctx, 0)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	// TODO 校验权限
 | 
						|
 | 
						|
	size, err := models.SharedLogDAO.SumLogsSize()
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	return &pb.SumLogsResponse{SizeBytes: size}, nil
 | 
						|
}
 |