mirror of
				https://github.com/1Panel-dev/1Panel.git
				synced 2025-10-25 06:56:32 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			162 lines
		
	
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			162 lines
		
	
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package repo
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"encoding/json"
 | |
| 
 | |
| 	"github.com/1Panel-dev/1Panel/backend/app/model"
 | |
| 	"github.com/1Panel-dev/1Panel/backend/global"
 | |
| 	"gorm.io/gorm"
 | |
| )
 | |
| 
 | |
| type AppInstallRepo struct{}
 | |
| 
 | |
| func (a *AppInstallRepo) WithDetailIdsIn(detailIds []uint) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("app_detail_id in (?)", detailIds)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) WithDetailIdNotIn(detailIds []uint) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("app_detail_id not in (?)", detailIds)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) WithAppId(appId uint) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("app_id = ?", appId)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) WithAppIdsIn(appIds []uint) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("app_id in (?)", appIds)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) WithStatus(status string) DBOption {
 | |
| 	return func(g *gorm.DB) *gorm.DB {
 | |
| 		return g.Where("status = ?", status)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) WithServiceName(serviceName string) DBOption {
 | |
| 	return func(db *gorm.DB) *gorm.DB {
 | |
| 		return db.Where("service_name = ?", serviceName)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) WithPort(port int) DBOption {
 | |
| 	return func(db *gorm.DB) *gorm.DB {
 | |
| 		return db.Where("https_port = ? or  http_port = ?", port, port)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) WithIdNotInWebsite() DBOption {
 | |
| 	return func(db *gorm.DB) *gorm.DB {
 | |
| 		return db.Where("id not in (select app_install_id from websites)")
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) ListBy(opts ...DBOption) ([]model.AppInstall, error) {
 | |
| 	var install []model.AppInstall
 | |
| 	db := getDb(opts...).Model(&model.AppInstall{})
 | |
| 	err := db.Preload("App").Find(&install).Error
 | |
| 	return install, err
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) GetFirst(opts ...DBOption) (model.AppInstall, error) {
 | |
| 	var install model.AppInstall
 | |
| 	db := getDb(opts...).Model(&model.AppInstall{})
 | |
| 	err := db.Preload("App").First(&install).Error
 | |
| 	return install, err
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) Create(ctx context.Context, install *model.AppInstall) error {
 | |
| 	db := getTx(ctx).Model(&model.AppInstall{})
 | |
| 	return db.Create(&install).Error
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) Save(install *model.AppInstall) error {
 | |
| 	return getDb().Save(&install).Error
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) DeleteBy(opts ...DBOption) error {
 | |
| 	return getDb(opts...).Delete(&model.AppInstall{}).Error
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) Delete(ctx context.Context, install model.AppInstall) error {
 | |
| 	db := getTx(ctx).Model(&model.AppInstall{})
 | |
| 	return db.Delete(&install).Error
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) Page(page, size int, opts ...DBOption) (int64, []model.AppInstall, error) {
 | |
| 	var apps []model.AppInstall
 | |
| 	db := getDb(opts...).Model(&model.AppInstall{})
 | |
| 	count := int64(0)
 | |
| 	db = db.Count(&count)
 | |
| 	err := db.Limit(size).Offset(size * (page - 1)).Preload("App").Find(&apps).Error
 | |
| 	return count, apps, err
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) BatchUpdateBy(maps map[string]interface{}, opts ...DBOption) error {
 | |
| 	db := getDb(opts...).Model(&model.AppInstall{})
 | |
| 	if len(opts) == 0 {
 | |
| 		db = db.Where("1=1")
 | |
| 	}
 | |
| 	return db.Updates(&maps).Error
 | |
| }
 | |
| 
 | |
| type RootInfo struct {
 | |
| 	ID            uint   `json:"id"`
 | |
| 	Name          string `json:"name"`
 | |
| 	Port          int64  `json:"port"`
 | |
| 	Password      string `json:"password"`
 | |
| 	UserPassword  string `json:"userPassword"`
 | |
| 	ContainerName string `json:"containerName"`
 | |
| 	Param         string `json:"param"`
 | |
| 	Env           string `json:"env"`
 | |
| 	Key           string `json:"key"`
 | |
| 	Version       string `json:"version"`
 | |
| }
 | |
| 
 | |
| func (a *AppInstallRepo) LoadBaseInfo(key string, name string) (*RootInfo, error) {
 | |
| 	var (
 | |
| 		app        model.App
 | |
| 		appInstall model.AppInstall
 | |
| 		info       RootInfo
 | |
| 	)
 | |
| 	if err := global.DB.Where("key = ?", key).First(&app).Error; err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	if len(name) == 0 {
 | |
| 		if err := global.DB.Where("app_id = ?", app.ID).First(&appInstall).Error; err != nil {
 | |
| 			return nil, err
 | |
| 		}
 | |
| 	} else {
 | |
| 		if err := global.DB.Where("app_id = ? AND name = ?", app.ID, name).First(&appInstall).Error; err != nil {
 | |
| 			return nil, err
 | |
| 		}
 | |
| 	}
 | |
| 	envMap := make(map[string]interface{})
 | |
| 	if err := json.Unmarshal([]byte(appInstall.Env), &envMap); err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	password, ok := envMap["PANEL_DB_ROOT_PASSWORD"].(string)
 | |
| 	if ok {
 | |
| 		info.Password = password
 | |
| 	}
 | |
| 	userPassword, ok := envMap["PANEL_DB_USER_PASSWORD"].(string)
 | |
| 	if ok {
 | |
| 		info.UserPassword = userPassword
 | |
| 	}
 | |
| 	info.Port = int64(appInstall.HttpPort)
 | |
| 	info.ID = appInstall.ID
 | |
| 	info.ContainerName = appInstall.ContainerName
 | |
| 	info.Name = appInstall.Name
 | |
| 	info.Env = appInstall.Env
 | |
| 	info.Param = appInstall.Param
 | |
| 	info.Version = appInstall.Version
 | |
| 	return &info, nil
 | |
| }
 |