2020-11-10 20:30:55 +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-07-11 18:05:57 +08:00
|
|
|
// LogService 管理员、用户或者其他系统用户日志
|
2020-11-10 20:30:55 +08:00
|
|
|
type LogService struct {
|
2020-11-24 17:36:47 +08:00
|
|
|
BaseService
|
2020-11-10 20:30:55 +08:00
|
|
|
}
|
|
|
|
|
|
2021-07-11 18:05:57 +08:00
|
|
|
// CreateLog 创建日志
|
2020-11-10 20:30:55 +08:00
|
|
|
func (this *LogService) CreateLog(ctx context.Context, req *pb.CreateLogRequest) (*pb.CreateLogResponse, error) {
|
|
|
|
|
// 校验请求
|
2021-07-11 18:05:57 +08:00
|
|
|
userType, _, userId, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin, rpcutils.UserTypeUser, rpcutils.UserTypeProvider)
|
2020-11-10 20:30:55 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-01 23:31:30 +08:00
|
|
|
tx := this.NullTx()
|
|
|
|
|
|
|
|
|
|
err = models.SharedLogDAO.CreateLog(tx, userType, userId, req.Level, req.Description, req.Action, req.Ip)
|
2020-11-10 20:30:55 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
return &pb.CreateLogResponse{}, nil
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-11 18:05:57 +08:00
|
|
|
// CountLogs 计算日志数量
|
2020-11-12 14:41:28 +08:00
|
|
|
func (this *LogService) CountLogs(ctx context.Context, req *pb.CountLogRequest) (*pb.RPCCountResponse, error) {
|
2020-11-10 20:30:55 +08:00
|
|
|
// 校验请求
|
2021-07-11 18:05:57 +08:00
|
|
|
_, err := this.ValidateAdmin(ctx, 0)
|
2020-11-10 20:30:55 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-01 23:31:30 +08:00
|
|
|
tx := this.NullTx()
|
|
|
|
|
|
|
|
|
|
count, err := models.SharedLogDAO.CountLogs(tx, req.DayFrom, req.DayTo, req.Keyword, req.UserType)
|
2020-11-10 20:30:55 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
2020-11-24 17:36:47 +08:00
|
|
|
return this.SuccessCount(count)
|
2020-11-10 20:30:55 +08:00
|
|
|
}
|
|
|
|
|
|
2021-07-11 18:05:57 +08:00
|
|
|
// ListLogs 列出单页日志
|
2020-11-10 20:30:55 +08:00
|
|
|
func (this *LogService) ListLogs(ctx context.Context, req *pb.ListLogsRequest) (*pb.ListLogsResponse, error) {
|
|
|
|
|
// 校验请求
|
2021-07-11 18:05:57 +08:00
|
|
|
_, err := this.ValidateAdmin(ctx, 0)
|
2020-11-10 20:30:55 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-01 23:31:30 +08:00
|
|
|
tx := this.NullTx()
|
|
|
|
|
|
|
|
|
|
logs, err := models.SharedLogDAO.ListLogs(tx, req.Offset, req.Size, req.DayFrom, req.DayTo, req.Keyword, req.UserType)
|
2020-11-10 20:30:55 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
result := []*pb.Log{}
|
|
|
|
|
for _, log := range logs {
|
|
|
|
|
userName := ""
|
|
|
|
|
if log.AdminId > 0 {
|
2021-01-01 23:31:30 +08:00
|
|
|
userName, err = models.SharedAdminDAO.FindAdminFullname(tx, int64(log.AdminId))
|
2020-11-10 20:30:55 +08:00
|
|
|
} else if log.UserId > 0 {
|
2021-01-01 23:31:30 +08:00
|
|
|
userName, err = models.SharedUserDAO.FindUserFullname(tx, int64(log.UserId))
|
2020-11-10 20:30:55 +08:00
|
|
|
} else if log.ProviderId > 0 {
|
2021-01-01 23:31:30 +08:00
|
|
|
userName, err = models.SharedProviderDAO.FindProviderName(tx, int64(log.ProviderId))
|
2020-11-10 20:30:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
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
|
|
|
|
|
}
|
2020-12-02 20:31:29 +08:00
|
|
|
|
2021-07-11 18:05:57 +08:00
|
|
|
// DeleteLogPermanently 删除单条
|
2020-12-02 20:31:29 +08:00
|
|
|
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 校验权限
|
|
|
|
|
|
2021-01-01 23:31:30 +08:00
|
|
|
tx := this.NullTx()
|
|
|
|
|
|
2020-12-02 20:31:29 +08:00
|
|
|
// 执行物理删除
|
2021-01-01 23:31:30 +08:00
|
|
|
err = models.SharedLogDAO.DeleteLogPermanently(tx, req.LogId)
|
2020-12-02 20:31:29 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return this.Success()
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-11 18:05:57 +08:00
|
|
|
// DeleteLogsPermanently 批量删除
|
2020-12-02 20:31:29 +08:00
|
|
|
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 校验权限
|
|
|
|
|
|
2021-01-01 23:31:30 +08:00
|
|
|
tx := this.NullTx()
|
|
|
|
|
|
2020-12-02 20:31:29 +08:00
|
|
|
// 执行物理删除
|
|
|
|
|
for _, logId := range req.LogIds {
|
2021-01-01 23:31:30 +08:00
|
|
|
err = models.SharedLogDAO.DeleteLogPermanently(tx, logId)
|
2020-12-02 20:31:29 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return this.Success()
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-11 18:05:57 +08:00
|
|
|
// CleanLogsPermanently 清理日志
|
2020-12-02 20:31:29 +08:00
|
|
|
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 校验权限
|
|
|
|
|
|
2021-01-01 23:31:30 +08:00
|
|
|
tx := this.NullTx()
|
|
|
|
|
|
2020-12-02 20:31:29 +08:00
|
|
|
if req.ClearAll {
|
2021-01-01 23:31:30 +08:00
|
|
|
err = models.SharedLogDAO.DeleteAllLogsPermanently(tx)
|
2020-12-02 20:31:29 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
} else if req.Days > 0 {
|
2021-01-01 23:31:30 +08:00
|
|
|
err = models.SharedLogDAO.DeleteLogsPermanentlyBeforeDays(tx, int(req.Days))
|
2020-12-02 20:31:29 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return this.Success()
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-11 18:05:57 +08:00
|
|
|
// SumLogsSize 计算日志容量大小
|
2020-12-02 20:31:29 +08:00
|
|
|
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
|
|
|
|
|
}
|