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 - 实现日志指纹去重和限流机制 - 完善相关模型、逻辑和文档说明
53 lines
1.7 KiB
Go
53 lines
1.7 KiB
Go
package logmessage
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
func NewModel(db *gorm.DB) Model {
|
|
return &customModel{ defaultModel: newDefaultModel(db) }
|
|
}
|
|
|
|
type FilterParams struct {
|
|
Page int
|
|
Size int
|
|
Platform string
|
|
Level uint8
|
|
UserID int64
|
|
DeviceID string
|
|
ErrorCode string
|
|
Keyword string
|
|
Start time.Time
|
|
End time.Time
|
|
}
|
|
|
|
type customLogMessageModel interface {
|
|
Filter(ctx context.Context, filter *FilterParams) ([]*LogMessage, int64, error)
|
|
}
|
|
|
|
func (m *customModel) Filter(ctx context.Context, filter *FilterParams) ([]*LogMessage, int64, error) {
|
|
tx := m.WithContext(ctx).Model(&LogMessage{}).Order("id DESC")
|
|
if filter == nil {
|
|
filter = &FilterParams{ Page: 1, Size: 10 }
|
|
}
|
|
if filter.Page < 1 { filter.Page = 1 }
|
|
if filter.Size < 1 { filter.Size = 10 }
|
|
if filter.Platform != "" { tx = tx.Where("`platform` = ?", filter.Platform) }
|
|
if filter.Level != 0 { tx = tx.Where("`level` = ?", filter.Level) }
|
|
if filter.UserID != 0 { tx = tx.Where("`user_id` = ?", filter.UserID) }
|
|
if filter.DeviceID != "" { tx = tx.Where("`device_id` = ?", filter.DeviceID) }
|
|
if filter.ErrorCode != "" { tx = tx.Where("`error_code` = ?", filter.ErrorCode) }
|
|
if !filter.Start.IsZero() { tx = tx.Where("`created_at` >= ?", filter.Start) }
|
|
if !filter.End.IsZero() { tx = tx.Where("`created_at` <= ?", filter.End) }
|
|
if filter.Keyword != "" {
|
|
like := "%" + filter.Keyword + "%"
|
|
tx = tx.Where("`message` LIKE ? OR `stack` LIKE ?", like, like)
|
|
}
|
|
var total int64
|
|
var rows []*LogMessage
|
|
err := tx.Count(&total).Limit(filter.Size).Offset((filter.Page-1)*filter.Size).Find(&rows).Error
|
|
return rows, total, err
|
|
}
|