mirror of
				https://github.com/1Panel-dev/1Panel.git
				synced 2025-10-26 00:36:12 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			107 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			107 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package repo
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 
 | |
| 	"github.com/1Panel-dev/1Panel/backend/app/model"
 | |
| 	"github.com/1Panel-dev/1Panel/backend/global"
 | |
| 	"gorm.io/gorm"
 | |
| )
 | |
| 
 | |
| type RuntimeRepo struct {
 | |
| }
 | |
| 
 | |
| type IRuntimeRepo interface {
 | |
| 	WithName(name string) DBOption
 | |
| 	WithImage(image string) DBOption
 | |
| 	WithNotId(id uint) DBOption
 | |
| 	WithStatus(status string) DBOption
 | |
| 	WithDetailId(id uint) DBOption
 | |
| 	WithPort(port int) DBOption
 | |
| 	Page(page, size int, opts ...DBOption) (int64, []model.Runtime, error)
 | |
| 	Create(ctx context.Context, runtime *model.Runtime) error
 | |
| 	Save(runtime *model.Runtime) error
 | |
| 	DeleteBy(opts ...DBOption) error
 | |
| 	GetFirst(opts ...DBOption) (*model.Runtime, error)
 | |
| 	List(opts ...DBOption) ([]model.Runtime, error)
 | |
| }
 | |
| 
 | |
| func NewIRunTimeRepo() IRuntimeRepo {
 | |
| 	return &RuntimeRepo{}
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) WithName(name string) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("name = ?", name)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) WithStatus(status string) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("status = ?", status)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) WithImage(image string) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("image = ?", image)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) WithDetailId(id uint) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("app_detail_id = ?", id)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) WithNotId(id uint) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("id != ?", id)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) WithPort(port int) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("port = ?", port)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) Page(page, size int, opts ...DBOption) (int64, []model.Runtime, error) {
 | |
| 	var runtimes []model.Runtime
 | |
| 	db := getDb(opts...).Model(&model.Runtime{})
 | |
| 	count := int64(0)
 | |
| 	db = db.Count(&count)
 | |
| 	err := db.Limit(size).Offset(size * (page - 1)).Find(&runtimes).Error
 | |
| 	return count, runtimes, err
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) List(opts ...DBOption) ([]model.Runtime, error) {
 | |
| 	var runtimes []model.Runtime
 | |
| 	db := global.DB.Model(&model.Runtime{})
 | |
| 	for _, opt := range opts {
 | |
| 		db = opt(db)
 | |
| 	}
 | |
| 	err := db.Find(&runtimes).Error
 | |
| 	return runtimes, err
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) Create(ctx context.Context, runtime *model.Runtime) error {
 | |
| 	db := getTx(ctx).Model(&model.Runtime{})
 | |
| 	return db.Create(&runtime).Error
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) Save(runtime *model.Runtime) error {
 | |
| 	return getDb().Save(&runtime).Error
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) DeleteBy(opts ...DBOption) error {
 | |
| 	return getDb(opts...).Delete(&model.Runtime{}).Error
 | |
| }
 | |
| 
 | |
| func (r *RuntimeRepo) GetFirst(opts ...DBOption) (*model.Runtime, error) {
 | |
| 	var runtime model.Runtime
 | |
| 	if err := getDb(opts...).First(&runtime).Error; err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return &runtime, nil
 | |
| }
 |