2025-09-27 10:17:16 +08:00

42 lines
1.1 KiB
Go

package ads
import (
"context"
"github.com/redis/go-redis/v9"
"gorm.io/gorm"
)
type customAdsLogicModel interface {
GetAdsListByPage(ctx context.Context, page, size int, filter Filter) (int64, []*Ads, error)
}
// NewModel returns a model for the database table.
func NewModel(conn *gorm.DB, c *redis.Client) Model {
return &customAdsModel{
defaultAdsModel: newAdsModel(conn, c),
}
}
type Filter struct {
Status *int
Search string
}
// GetAdsListByPage get ads list by page
func (m *customAdsModel) GetAdsListByPage(ctx context.Context, page, size int, filter Filter) (int64, []*Ads, error) {
var list []*Ads
var total int64
err := m.QueryNoCacheCtx(ctx, &list, func(conn *gorm.DB, v interface{}) error {
conn = conn.Model(&Ads{})
if filter.Status != nil {
conn = conn.Where("`status` = ?", *filter.Status)
}
if filter.Search != "" {
conn = conn.Where("`title` LIKE ? OR `content` LIKE ?", "%"+filter.Search+"%", "%"+filter.Search+"%")
}
return conn.Count(&total).Offset((page - 1) * size).Limit(size).Find(v).Error
})
return total, list, err
}