2024-07-19 19:04:11 +08:00
|
|
|
package repo
|
|
|
|
|
|
|
|
import (
|
2024-08-19 18:04:43 +08:00
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/1Panel-dev/1Panel/core/constant"
|
2024-07-19 19:04:11 +08:00
|
|
|
"gorm.io/gorm"
|
|
|
|
)
|
|
|
|
|
|
|
|
type DBOption func(*gorm.DB) *gorm.DB
|
|
|
|
|
|
|
|
type ICommonRepo interface {
|
2024-07-25 14:43:41 +08:00
|
|
|
WithByID(id uint) DBOption
|
2024-08-13 15:33:34 +08:00
|
|
|
WithByIDs(ids []uint) DBOption
|
2024-08-21 18:04:51 +08:00
|
|
|
WithByName(name string) DBOption
|
|
|
|
WithLikeName(name string) DBOption
|
2024-08-08 15:38:37 +08:00
|
|
|
WithByType(ty string) DBOption
|
2024-10-30 15:58:40 +08:00
|
|
|
WithByKey(key string) DBOption
|
2024-07-19 19:04:11 +08:00
|
|
|
WithOrderBy(orderStr string) DBOption
|
2024-08-19 18:04:43 +08:00
|
|
|
|
|
|
|
WithOrderRuleBy(orderBy, order string) DBOption
|
2024-07-19 19:04:11 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
type CommonRepo struct{}
|
|
|
|
|
2024-07-25 14:43:41 +08:00
|
|
|
func NewICommonRepo() ICommonRepo {
|
2024-07-19 19:04:11 +08:00
|
|
|
return &CommonRepo{}
|
|
|
|
}
|
2024-07-25 14:43:41 +08:00
|
|
|
|
|
|
|
func (c *CommonRepo) WithByID(id uint) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("id = ?", id)
|
|
|
|
}
|
|
|
|
}
|
2024-08-21 18:04:51 +08:00
|
|
|
func (c *CommonRepo) WithByIDs(ids []uint) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("id in (?)", ids)
|
|
|
|
}
|
|
|
|
}
|
2024-08-08 15:38:37 +08:00
|
|
|
func (c *CommonRepo) WithByName(name string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
if len(name) == 0 {
|
|
|
|
return g
|
|
|
|
}
|
|
|
|
return g.Where("`name` = ?", name)
|
|
|
|
}
|
|
|
|
}
|
2024-08-21 18:04:51 +08:00
|
|
|
func (c *CommonRepo) WithLikeName(name string) DBOption {
|
2024-08-13 15:33:34 +08:00
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
2024-08-21 18:04:51 +08:00
|
|
|
if len(name) == 0 {
|
|
|
|
return g
|
|
|
|
}
|
|
|
|
return g.Where("name like ? or command like ?", "%"+name+"%", "%"+name+"%")
|
2024-08-13 15:33:34 +08:00
|
|
|
}
|
|
|
|
}
|
2024-08-08 15:38:37 +08:00
|
|
|
func (c *CommonRepo) WithByType(ty string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
if len(ty) == 0 {
|
|
|
|
return g
|
|
|
|
}
|
|
|
|
return g.Where("`type` = ?", ty)
|
|
|
|
}
|
|
|
|
}
|
2024-10-30 15:58:40 +08:00
|
|
|
func (c *CommonRepo) WithByKey(key string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("key = ?", key)
|
|
|
|
}
|
|
|
|
}
|
2024-07-19 19:04:11 +08:00
|
|
|
func (c *CommonRepo) WithOrderBy(orderStr string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Order(orderStr)
|
|
|
|
}
|
|
|
|
}
|
2024-08-19 18:04:43 +08:00
|
|
|
|
|
|
|
func (c *CommonRepo) WithOrderRuleBy(orderBy, order string) DBOption {
|
|
|
|
switch order {
|
|
|
|
case constant.OrderDesc:
|
|
|
|
order = "desc"
|
|
|
|
case constant.OrderAsc:
|
|
|
|
order = "asc"
|
|
|
|
default:
|
|
|
|
orderBy = "created_at"
|
|
|
|
order = "desc"
|
|
|
|
}
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Order(fmt.Sprintf("%s %s", orderBy, order))
|
|
|
|
}
|
|
|
|
}
|