2022-08-16 15:30:23 +00:00
|
|
|
package repo
|
|
|
|
|
2022-10-11 08:27:58 +00:00
|
|
|
import (
|
|
|
|
"context"
|
2023-01-09 14:55:10 +00:00
|
|
|
"time"
|
2023-01-06 10:53:25 +00:00
|
|
|
|
2022-11-02 07:19:14 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/constant"
|
2022-10-17 08:32:31 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/global"
|
2022-10-11 08:27:58 +00:00
|
|
|
"gorm.io/gorm"
|
|
|
|
)
|
2022-08-16 15:30:23 +00:00
|
|
|
|
|
|
|
type DBOption func(*gorm.DB) *gorm.DB
|
|
|
|
|
|
|
|
type ICommonRepo interface {
|
|
|
|
WithByID(id uint) DBOption
|
|
|
|
WithByName(name string) DBOption
|
2023-01-06 10:53:25 +00:00
|
|
|
WithByType(tp string) DBOption
|
2022-08-16 15:30:23 +00:00
|
|
|
WithOrderBy(orderStr string) DBOption
|
2023-03-06 09:18:13 +00:00
|
|
|
WithByGroupID(groupID uint) DBOption
|
2022-08-16 15:30:23 +00:00
|
|
|
WithLikeName(name string) DBOption
|
|
|
|
WithIdsIn(ids []uint) DBOption
|
2023-01-09 14:55:10 +00:00
|
|
|
WithByDate(startTime, endTime time.Time) DBOption
|
|
|
|
WithByStartDate(startTime time.Time) DBOption
|
2022-08-16 15:30:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type CommonRepo struct{}
|
|
|
|
|
|
|
|
func (c *CommonRepo) WithByID(id uint) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("id = ?", id)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *CommonRepo) WithByName(name string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("name = ?", name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-09 14:55:10 +00:00
|
|
|
func (c *CommonRepo) WithByDate(startTime, endTime time.Time) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("start_time > ? AND start_time < ?", startTime, endTime)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *CommonRepo) WithByStartDate(startTime time.Time) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("start_time < ?", startTime)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-06 10:53:25 +00:00
|
|
|
func (c *CommonRepo) WithByType(tp string) DBOption {
|
2022-09-19 11:42:06 +00:00
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
2023-01-06 10:53:25 +00:00
|
|
|
return g.Where("type = ?", tp)
|
2022-09-19 11:42:06 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-03-06 09:18:13 +00:00
|
|
|
func (c *CommonRepo) WithByGroupID(groupID uint) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
if groupID == 0 {
|
|
|
|
return g
|
|
|
|
}
|
|
|
|
return g.Where("group_id = ?", groupID)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-23 09:21:27 +00:00
|
|
|
func (c *CommonRepo) WithByStatus(status string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
if len(status) == 0 {
|
|
|
|
return g
|
|
|
|
}
|
|
|
|
return g.Where("status = ?", status)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-08-16 15:30:23 +00:00
|
|
|
func (c *CommonRepo) WithLikeName(name string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
2023-02-07 10:48:32 +00:00
|
|
|
if len(name) == 0 {
|
|
|
|
return g
|
|
|
|
}
|
2022-08-16 15:30:23 +00:00
|
|
|
return g.Where("name like ?", "%"+name+"%")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *CommonRepo) WithOrderBy(orderStr string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Order(orderStr)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *CommonRepo) WithIdsIn(ids []uint) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("id in (?)", ids)
|
|
|
|
}
|
|
|
|
}
|
2022-10-11 08:27:58 +00:00
|
|
|
|
2022-10-12 02:54:09 +00:00
|
|
|
func (c *CommonRepo) WithIdsNotIn(ids []uint) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("id not in (?)", ids)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-11 08:27:58 +00:00
|
|
|
func getTx(ctx context.Context, opts ...DBOption) *gorm.DB {
|
2022-11-03 09:06:48 +00:00
|
|
|
tx, ok := ctx.Value(constant.DB).(*gorm.DB)
|
|
|
|
if ok {
|
|
|
|
for _, opt := range opts {
|
|
|
|
tx = opt(tx)
|
|
|
|
}
|
2022-11-22 14:47:38 +00:00
|
|
|
return tx
|
2022-10-11 08:27:58 +00:00
|
|
|
}
|
2022-11-22 14:47:38 +00:00
|
|
|
return getDb(opts...)
|
2022-10-11 08:27:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func getDb(opts ...DBOption) *gorm.DB {
|
|
|
|
db := global.DB
|
|
|
|
for _, opt := range opts {
|
|
|
|
db = opt(db)
|
|
|
|
}
|
|
|
|
return db
|
|
|
|
}
|