All checks were successful
Build docker and publish / build (20.15.1) (push) Successful in 6m50s
- 创建 log_message 表用于存储客户端错误日志 - 实现客户端日志上报接口 POST /v1/common/log/message/report - 添加管理端日志查询接口 GET /v1/admin/log/message/error/list 和 GET /v1/admin/log/message/error/detail - 实现日志指纹去重和限流机制 - 完善相关模型、逻辑和文档说明
50 lines
1.6 KiB
Go
50 lines
1.6 KiB
Go
package log
|
|
|
|
import (
|
|
"context"
|
|
"strconv"
|
|
"github.com/perfect-panel/server/internal/svc"
|
|
"github.com/perfect-panel/server/internal/types"
|
|
"github.com/perfect-panel/server/pkg/logger"
|
|
)
|
|
|
|
type GetErrorLogMessageDetailLogic struct {
|
|
logger.Logger
|
|
ctx context.Context
|
|
svcCtx *svc.ServiceContext
|
|
}
|
|
|
|
func NewGetErrorLogMessageDetailLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetErrorLogMessageDetailLogic {
|
|
return &GetErrorLogMessageDetailLogic{ Logger: logger.WithContext(ctx), ctx: ctx, svcCtx: svcCtx }
|
|
}
|
|
|
|
func (l *GetErrorLogMessageDetailLogic) GetErrorLogMessageDetail(idStr string) (resp *types.GetErrorLogMessageDetailResponse, err error) {
|
|
if idStr == "" { return &types.GetErrorLogMessageDetailResponse{}, nil }
|
|
id, _ := strconv.ParseInt(idStr, 10, 64)
|
|
row, err := l.svcCtx.LogMessageModel.FindOne(l.ctx, id)
|
|
if err != nil { return nil, err }
|
|
var uid int64
|
|
if row.UserId != nil { uid = *row.UserId }
|
|
var occurred int64
|
|
if row.OccurredAt != nil { occurred = row.OccurredAt.UnixMilli() }
|
|
return &types.GetErrorLogMessageDetailResponse{
|
|
Id: row.Id,
|
|
Platform: row.Platform,
|
|
AppVersion: row.AppVersion,
|
|
OsName: row.OsName,
|
|
OsVersion: row.OsVersion,
|
|
DeviceId: row.DeviceId,
|
|
UserId: uid,
|
|
SessionId: row.SessionId,
|
|
Level: row.Level,
|
|
ErrorCode: row.ErrorCode,
|
|
Message: row.Message,
|
|
Stack: row.Stack,
|
|
ClientIP: row.ClientIP,
|
|
UserAgent: row.UserAgent,
|
|
Locale: row.Locale,
|
|
OccurredAt: occurred,
|
|
CreatedAt: row.CreatedAt.UnixMilli(),
|
|
}, nil
|
|
}
|