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 - 实现日志指纹去重和限流机制 - 完善相关模型、逻辑和文档说明
51 lines
1.3 KiB
Go
51 lines
1.3 KiB
Go
package logmessage
|
|
|
|
import (
|
|
"context"
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
type (
|
|
Model interface {
|
|
logMessageModel
|
|
customLogMessageModel
|
|
}
|
|
logMessageModel interface {
|
|
Insert(ctx context.Context, data *LogMessage) error
|
|
FindOne(ctx context.Context, id int64) (*LogMessage, error)
|
|
Update(ctx context.Context, data *LogMessage) error
|
|
Delete(ctx context.Context, id int64) error
|
|
}
|
|
customModel struct{
|
|
*defaultModel
|
|
}
|
|
defaultModel struct{
|
|
*gorm.DB
|
|
}
|
|
)
|
|
|
|
func newDefaultModel(db *gorm.DB) *defaultModel {
|
|
return &defaultModel{DB: db}
|
|
}
|
|
|
|
func (m *defaultModel) Insert(ctx context.Context, data *LogMessage) error {
|
|
return m.WithContext(ctx).Create(data).Error
|
|
}
|
|
|
|
func (m *defaultModel) FindOne(ctx context.Context, id int64) (*LogMessage, error) {
|
|
var v LogMessage
|
|
err := m.WithContext(ctx).Where("id = ?", id).First(&v).Error
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &v, nil
|
|
}
|
|
|
|
func (m *defaultModel) Update(ctx context.Context, data *LogMessage) error {
|
|
return m.WithContext(ctx).Where("`id` = ?", data.Id).Save(data).Error
|
|
}
|
|
|
|
func (m *defaultModel) Delete(ctx context.Context, id int64) error {
|
|
return m.WithContext(ctx).Where("`id` = ?", id).Delete(&LogMessage{}).Error
|
|
}
|