2024-07-23 14:48:37 +08:00
|
|
|
package repo
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2024-08-22 15:08:55 +08:00
|
|
|
"fmt"
|
2024-07-23 14:48:37 +08:00
|
|
|
|
|
|
|
"github.com/1Panel-dev/1Panel/agent/app/model"
|
|
|
|
"gorm.io/gorm"
|
|
|
|
"gorm.io/gorm/clause"
|
|
|
|
)
|
|
|
|
|
|
|
|
type AppRepo struct {
|
|
|
|
}
|
|
|
|
|
|
|
|
type IAppRepo interface {
|
|
|
|
WithKey(key string) DBOption
|
|
|
|
WithType(typeStr string) DBOption
|
|
|
|
OrderByRecommend() DBOption
|
|
|
|
GetRecommend() DBOption
|
|
|
|
WithResource(resource string) DBOption
|
2024-12-30 21:04:11 +08:00
|
|
|
WithNotLocal() DBOption
|
2024-08-21 18:04:51 +08:00
|
|
|
WithByLikeName(name string) DBOption
|
2024-09-02 21:56:24 +08:00
|
|
|
WithArch(arch string) DBOption
|
|
|
|
WithPanelVersion(panelVersion string) DBOption
|
|
|
|
|
2024-07-23 14:48:37 +08:00
|
|
|
Page(page, size int, opts ...DBOption) (int64, []model.App, error)
|
|
|
|
GetFirst(opts ...DBOption) (model.App, error)
|
|
|
|
GetBy(opts ...DBOption) ([]model.App, error)
|
|
|
|
BatchCreate(ctx context.Context, apps []model.App) error
|
|
|
|
GetByKey(ctx context.Context, key string) (model.App, error)
|
|
|
|
Create(ctx context.Context, app *model.App) error
|
|
|
|
Save(ctx context.Context, app *model.App) error
|
|
|
|
BatchDelete(ctx context.Context, apps []model.App) error
|
2024-10-14 10:37:34 +08:00
|
|
|
DeleteByIDs(ctx context.Context, ids []uint) error
|
2025-01-03 16:54:09 +08:00
|
|
|
DeleteBy(opts ...DBOption) error
|
2024-07-23 14:48:37 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewIAppRepo() IAppRepo {
|
|
|
|
return &AppRepo{}
|
|
|
|
}
|
|
|
|
|
2024-08-21 18:04:51 +08:00
|
|
|
func (a AppRepo) WithByLikeName(name string) DBOption {
|
2024-07-23 14:48:37 +08:00
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
if len(name) == 0 {
|
|
|
|
return g
|
|
|
|
}
|
|
|
|
return g.Where("name like ? or short_desc_zh like ? or short_desc_en like ?", "%"+name+"%", "%"+name+"%", "%"+name+"%")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) WithKey(key string) DBOption {
|
|
|
|
return func(db *gorm.DB) *gorm.DB {
|
|
|
|
return db.Where("key = ?", key)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) WithType(typeStr string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("type = ?", typeStr)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) OrderByRecommend() DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Order("recommend asc")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) GetRecommend() DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("recommend < 9999")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) WithResource(resource string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("resource = ?", resource)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-12-30 21:04:11 +08:00
|
|
|
func (a AppRepo) WithNotLocal() DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
2025-01-03 16:54:09 +08:00
|
|
|
return g.Where("resource != 'local'")
|
2024-12-30 21:04:11 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-08-22 15:08:55 +08:00
|
|
|
func (a AppRepo) WithArch(arch string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("architectures like ?", fmt.Sprintf("%%%s%%", arch))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-09-02 21:56:24 +08:00
|
|
|
func (a AppRepo) WithPanelVersion(panelVersion string) DBOption {
|
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("required_panel_version >= ?", panelVersion)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-07-23 14:48:37 +08:00
|
|
|
func (a AppRepo) Page(page, size int, opts ...DBOption) (int64, []model.App, error) {
|
|
|
|
var apps []model.App
|
|
|
|
db := getDb(opts...).Model(&model.App{})
|
|
|
|
count := int64(0)
|
2024-11-26 16:00:29 +08:00
|
|
|
db = db.Count(&count)
|
2024-07-23 14:48:37 +08:00
|
|
|
err := db.Limit(size).Offset(size * (page - 1)).Preload("AppTags").Find(&apps).Error
|
|
|
|
return count, apps, err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) GetFirst(opts ...DBOption) (model.App, error) {
|
|
|
|
var app model.App
|
|
|
|
db := getDb(opts...).Model(&model.App{})
|
|
|
|
if err := db.Preload("AppTags").First(&app).Error; err != nil {
|
|
|
|
return app, err
|
|
|
|
}
|
|
|
|
return app, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) GetBy(opts ...DBOption) ([]model.App, error) {
|
|
|
|
var apps []model.App
|
|
|
|
db := getDb(opts...).Model(&model.App{})
|
|
|
|
if err := db.Preload("Details").Preload("AppTags").Find(&apps).Error; err != nil {
|
|
|
|
return apps, err
|
|
|
|
}
|
|
|
|
return apps, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) BatchCreate(ctx context.Context, apps []model.App) error {
|
|
|
|
return getTx(ctx).Omit(clause.Associations).Create(&apps).Error
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) GetByKey(ctx context.Context, key string) (model.App, error) {
|
|
|
|
var app model.App
|
|
|
|
if err := getTx(ctx).Where("key = ?", key).First(&app).Error; err != nil {
|
|
|
|
return app, err
|
|
|
|
}
|
|
|
|
return app, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) Create(ctx context.Context, app *model.App) error {
|
|
|
|
return getTx(ctx).Omit(clause.Associations).Create(app).Error
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) Save(ctx context.Context, app *model.App) error {
|
|
|
|
return getTx(ctx).Omit(clause.Associations).Save(app).Error
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a AppRepo) BatchDelete(ctx context.Context, apps []model.App) error {
|
|
|
|
return getTx(ctx).Omit(clause.Associations).Delete(&apps).Error
|
|
|
|
}
|
2024-10-14 10:37:34 +08:00
|
|
|
|
|
|
|
func (a AppRepo) DeleteByIDs(ctx context.Context, ids []uint) error {
|
|
|
|
return getTx(ctx).Where("id in (?)", ids).Delete(&model.App{}).Error
|
|
|
|
}
|
2025-01-03 16:54:09 +08:00
|
|
|
|
|
|
|
func (a AppRepo) DeleteBy(opts ...DBOption) error {
|
|
|
|
return getDb().Delete(&model.App{}, opts).Error
|
|
|
|
}
|