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").Preload("Backups").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").Preload("Backups", func(db *gorm.DB) *gorm.DB { db = db.Order("created_at desc") return db }).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.Debug().Limit(size).Offset(size * (page - 1)).Preload("App").Preload("Backups").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.Debug().Updates(&maps).Error } type RootInfo struct { ID uint `json:"id"` Name string `json:"name"` Port int64 `json:"port"` Password string `json:"password"` 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 } 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 }