shanshanzhong c582087c0f refactor: 更新项目引用路径从perfect-panel/ppanel-server到perfect-panel/server
feat: 添加版本和构建时间变量
fix: 修正短信队列类型注释错误
style: 清理未使用的代码和测试文件
docs: 更新安装文档中的下载链接
chore: 迁移数据库脚本添加日志和订阅配置
2025-10-13 01:33:03 -07:00

118 lines
3.0 KiB
Go

package announcement
import (
"context"
"errors"
"fmt"
"github.com/perfect-panel/server/pkg/cache"
"github.com/redis/go-redis/v9"
"gorm.io/gorm"
)
var _ Model = (*customAnnouncementModel)(nil)
var (
cacheAnnouncementIdPrefix = "cache:announcement:id:"
)
type (
Model interface {
announcementModel
customAnnouncementLogicModel
}
announcementModel interface {
Insert(ctx context.Context, data *Announcement) error
FindOne(ctx context.Context, id int64) (*Announcement, error)
Update(ctx context.Context, data *Announcement) error
Delete(ctx context.Context, id int64) error
Transaction(ctx context.Context, fn func(db *gorm.DB) error) error
}
customAnnouncementModel struct {
*defaultAnnouncementModel
}
defaultAnnouncementModel struct {
cache.CachedConn
table string
}
)
func newAnnouncementModel(db *gorm.DB, c *redis.Client) *defaultAnnouncementModel {
return &defaultAnnouncementModel{
CachedConn: cache.NewConn(db, c),
table: "`announcement`",
}
}
//nolint:unused
func (m *defaultAnnouncementModel) batchGetCacheKeys(Announcements ...*Announcement) []string {
var keys []string
for _, announcement := range Announcements {
keys = append(keys, m.getCacheKeys(announcement)...)
}
return keys
}
func (m *defaultAnnouncementModel) getCacheKeys(data *Announcement) []string {
if data == nil {
return []string{}
}
announcementIdKey := fmt.Sprintf("%s%v", cacheAnnouncementIdPrefix, data.Id)
cacheKeys := []string{
announcementIdKey,
}
return cacheKeys
}
func (m *defaultAnnouncementModel) Insert(ctx context.Context, data *Announcement) error {
err := m.ExecCtx(ctx, func(conn *gorm.DB) error {
return conn.Create(&data).Error
}, m.getCacheKeys(data)...)
return err
}
func (m *defaultAnnouncementModel) FindOne(ctx context.Context, id int64) (*Announcement, error) {
AnnouncementIdKey := fmt.Sprintf("%s%v", cacheAnnouncementIdPrefix, id)
var resp Announcement
err := m.QueryCtx(ctx, &resp, AnnouncementIdKey, func(conn *gorm.DB, v interface{}) error {
return conn.Model(&Announcement{}).Where("`id` = ?", id).First(&resp).Error
})
switch {
case err == nil:
return &resp, nil
default:
return nil, err
}
}
func (m *defaultAnnouncementModel) Update(ctx context.Context, data *Announcement) error {
old, err := m.FindOne(ctx, data.Id)
if err != nil && !errors.Is(err, gorm.ErrRecordNotFound) {
return err
}
err = m.ExecCtx(ctx, func(conn *gorm.DB) error {
db := conn
return db.Save(data).Error
}, m.getCacheKeys(old)...)
return err
}
func (m *defaultAnnouncementModel) Delete(ctx context.Context, id int64) error {
data, err := m.FindOne(ctx, id)
if err != nil {
if errors.Is(err, gorm.ErrRecordNotFound) {
return nil
}
return err
}
err = m.ExecCtx(ctx, func(conn *gorm.DB) error {
db := conn
return db.Delete(&Announcement{}, id).Error
}, m.getCacheKeys(data)...)
return err
}
func (m *defaultAnnouncementModel) Transaction(ctx context.Context, fn func(db *gorm.DB) error) error {
return m.TransactCtx(ctx, fn)
}