mirror of
				https://github.com/1Panel-dev/1Panel.git
				synced 2025-10-26 00:36:12 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			93 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package repo
 | |
| 
 | |
| import (
 | |
| 	"github.com/1Panel-dev/1Panel/core/app/model"
 | |
| 	"github.com/1Panel-dev/1Panel/core/global"
 | |
| 	"gorm.io/gorm"
 | |
| )
 | |
| 
 | |
| type IScriptRepo interface {
 | |
| 	Get(opts ...global.DBOption) (model.ScriptLibrary, error)
 | |
| 	GetList(opts ...global.DBOption) ([]model.ScriptLibrary, error)
 | |
| 	Create(script *model.ScriptLibrary) error
 | |
| 	Update(id uint, vars map[string]interface{}) error
 | |
| 	Page(limit, offset int, opts ...global.DBOption) (int64, []model.ScriptLibrary, error)
 | |
| 	Delete(opts ...global.DBOption) error
 | |
| 	SyncAll(scripts []model.ScriptLibrary) error
 | |
| 
 | |
| 	WithByInfo(info string) global.DBOption
 | |
| }
 | |
| 
 | |
| func NewIScriptRepo() IScriptRepo {
 | |
| 	return &ScriptRepo{}
 | |
| }
 | |
| 
 | |
| type ScriptRepo struct{}
 | |
| 
 | |
| func (u *ScriptRepo) Get(opts ...global.DBOption) (model.ScriptLibrary, error) {
 | |
| 	var ScriptLibrary model.ScriptLibrary
 | |
| 	db := global.DB
 | |
| 	for _, opt := range opts {
 | |
| 		db = opt(db)
 | |
| 	}
 | |
| 	err := db.First(&ScriptLibrary).Error
 | |
| 	return ScriptLibrary, err
 | |
| }
 | |
| 
 | |
| func (u *ScriptRepo) GetList(opts ...global.DBOption) ([]model.ScriptLibrary, error) {
 | |
| 	var scripts []model.ScriptLibrary
 | |
| 	db := global.DB.Model(&model.ScriptLibrary{})
 | |
| 	for _, opt := range opts {
 | |
| 		db = opt(db)
 | |
| 	}
 | |
| 	err := db.Find(&scripts).Error
 | |
| 	return scripts, err
 | |
| }
 | |
| 
 | |
| func (u *ScriptRepo) Page(page, size int, opts ...global.DBOption) (int64, []model.ScriptLibrary, error) {
 | |
| 	var users []model.ScriptLibrary
 | |
| 	db := global.DB.Model(&model.ScriptLibrary{})
 | |
| 	for _, opt := range opts {
 | |
| 		db = opt(db)
 | |
| 	}
 | |
| 	count := int64(0)
 | |
| 	db = db.Count(&count)
 | |
| 	err := db.Limit(size).Offset(size * (page - 1)).Find(&users).Error
 | |
| 	return count, users, err
 | |
| }
 | |
| 
 | |
| func (u *ScriptRepo) Create(ScriptLibrary *model.ScriptLibrary) error {
 | |
| 	return global.DB.Create(ScriptLibrary).Error
 | |
| }
 | |
| 
 | |
| func (u *ScriptRepo) Update(id uint, vars map[string]interface{}) error {
 | |
| 	return global.DB.Model(&model.ScriptLibrary{}).Where("id = ?", id).Updates(vars).Error
 | |
| }
 | |
| 
 | |
| func (u *ScriptRepo) Delete(opts ...global.DBOption) error {
 | |
| 	db := global.DB
 | |
| 	for _, opt := range opts {
 | |
| 		db = opt(db)
 | |
| 	}
 | |
| 	return db.Delete(&model.ScriptLibrary{}).Error
 | |
| }
 | |
| 
 | |
| func (u *ScriptRepo) SyncAll(scripts []model.ScriptLibrary) error {
 | |
| 	tx := global.DB.Begin()
 | |
| 	if err := tx.Where("is_system = ?", 1).Delete(&model.ScriptLibrary{}).Error; err != nil {
 | |
| 		tx.Rollback()
 | |
| 		return err
 | |
| 	}
 | |
| 	if err := tx.Save(&scripts).Error; err != nil {
 | |
| 		tx.Rollback()
 | |
| 		return err
 | |
| 	}
 | |
| 	tx.Commit()
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func (u *ScriptRepo) WithByInfo(info string) global.DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("name LIKE ? OR description LIKE ?", "%"+info+"%", "%"+info+"%")
 | |
| 	}
 | |
| }
 |