2022-09-26 16:32:40 +08:00
|
|
|
package repo
|
|
|
|
|
|
|
|
import (
|
2022-10-09 23:35:24 +08:00
|
|
|
"context"
|
2022-11-29 17:39:10 +08:00
|
|
|
"encoding/json"
|
2022-12-21 12:21:27 +08:00
|
|
|
|
2022-10-17 16:32:31 +08:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/model"
|
2022-11-29 17:39:10 +08:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/global"
|
2022-10-03 17:35:39 +08:00
|
|
|
"gorm.io/gorm"
|
2022-09-26 16:32:40 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
type AppInstallRepo struct{}
|
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) WithDetailIdsIn(detailIds []uint) DBOption {
|
2022-10-03 17:35:39 +08:00
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("app_detail_id in (?)", detailIds)
|
|
|
|
}
|
|
|
|
}
|
2022-10-12 10:54:09 +08:00
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) WithDetailIdNotIn(detailIds []uint) DBOption {
|
2022-10-12 10:54:09 +08:00
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("app_detail_id not in (?)", detailIds)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) WithAppId(appId uint) DBOption {
|
2022-10-07 15:49:39 +08:00
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("app_id = ?", appId)
|
|
|
|
}
|
|
|
|
}
|
2022-10-28 17:04:57 +08:00
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) WithAppIdsIn(appIds []uint) DBOption {
|
2022-10-28 17:04:57 +08:00
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("app_id in (?)", appIds)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) WithStatus(status string) DBOption {
|
2022-10-07 15:49:39 +08:00
|
|
|
return func(g *gorm.DB) *gorm.DB {
|
|
|
|
return g.Where("status = ?", status)
|
|
|
|
}
|
|
|
|
}
|
2022-10-03 17:35:39 +08:00
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) WithServiceName(serviceName string) DBOption {
|
2022-10-11 16:27:58 +08:00
|
|
|
return func(db *gorm.DB) *gorm.DB {
|
|
|
|
return db.Where("service_name = ?", serviceName)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-02-07 16:29:54 +08:00
|
|
|
func (a *AppInstallRepo) WithPort(port int) DBOption {
|
|
|
|
return func(db *gorm.DB) *gorm.DB {
|
|
|
|
return db.Where("https_port = ? or http_port = ?", port, port)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) WithIdNotInWebsite() DBOption {
|
|
|
|
return func(db *gorm.DB) *gorm.DB {
|
|
|
|
return db.Where("id not in (select app_install_id from websites)")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-02-07 16:29:54 +08:00
|
|
|
func (a *AppInstallRepo) ListBy(opts ...DBOption) ([]model.AppInstall, error) {
|
2022-09-26 16:32:40 +08:00
|
|
|
var install []model.AppInstall
|
2022-10-12 10:54:09 +08:00
|
|
|
db := getDb(opts...).Model(&model.AppInstall{})
|
2022-10-12 18:57:22 +08:00
|
|
|
err := db.Preload("App").Preload("Backups").Find(&install).Error
|
2022-09-29 18:16:56 +08:00
|
|
|
return install, err
|
|
|
|
}
|
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) GetFirst(opts ...DBOption) (model.AppInstall, error) {
|
2022-09-29 18:16:56 +08:00
|
|
|
var install model.AppInstall
|
2022-10-12 10:54:09 +08:00
|
|
|
db := getDb(opts...).Model(&model.AppInstall{})
|
2022-11-22 22:47:38 +08:00
|
|
|
err := db.Preload("App").Preload("Backups", func(db *gorm.DB) *gorm.DB {
|
|
|
|
db = db.Order("created_at desc")
|
|
|
|
return db
|
|
|
|
}).First(&install).Error
|
2022-09-26 16:32:40 +08:00
|
|
|
return install, err
|
|
|
|
}
|
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) Create(ctx context.Context, install *model.AppInstall) error {
|
2022-10-11 16:27:58 +08:00
|
|
|
db := getTx(ctx).Model(&model.AppInstall{})
|
2022-09-26 16:32:40 +08:00
|
|
|
return db.Create(&install).Error
|
|
|
|
}
|
2022-09-26 22:54:38 +08:00
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) Save(install *model.AppInstall) error {
|
2022-10-11 16:27:58 +08:00
|
|
|
return getDb().Save(&install).Error
|
2022-09-26 16:32:40 +08:00
|
|
|
}
|
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) DeleteBy(opts ...DBOption) error {
|
2022-10-11 16:27:58 +08:00
|
|
|
return getDb(opts...).Delete(&model.AppInstall{}).Error
|
2022-09-26 22:54:38 +08:00
|
|
|
}
|
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) Delete(ctx context.Context, install model.AppInstall) error {
|
2022-10-12 10:54:09 +08:00
|
|
|
db := getTx(ctx).Model(&model.AppInstall{})
|
2022-10-09 23:35:24 +08:00
|
|
|
return db.Delete(&install).Error
|
|
|
|
}
|
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) Page(page, size int, opts ...DBOption) (int64, []model.AppInstall, error) {
|
2022-09-26 16:32:40 +08:00
|
|
|
var apps []model.AppInstall
|
2022-10-12 10:54:09 +08:00
|
|
|
db := getDb(opts...).Model(&model.AppInstall{})
|
2022-09-26 16:32:40 +08:00
|
|
|
count := int64(0)
|
|
|
|
db = db.Count(&count)
|
2022-10-12 18:57:22 +08:00
|
|
|
err := db.Debug().Limit(size).Offset(size * (page - 1)).Preload("App").Preload("Backups").Find(&apps).Error
|
2022-09-26 16:32:40 +08:00
|
|
|
return count, apps, err
|
|
|
|
}
|
2022-10-03 17:35:39 +08:00
|
|
|
|
2022-12-20 21:22:36 +08:00
|
|
|
func (a *AppInstallRepo) BatchUpdateBy(maps map[string]interface{}, opts ...DBOption) error {
|
2022-10-12 10:54:09 +08:00
|
|
|
db := getDb(opts...).Model(&model.AppInstall{})
|
|
|
|
if len(opts) == 0 {
|
|
|
|
db = db.Where("1=1")
|
2022-10-03 17:35:39 +08:00
|
|
|
}
|
2022-10-14 14:48:55 +08:00
|
|
|
return db.Debug().Updates(&maps).Error
|
2022-10-03 17:35:39 +08:00
|
|
|
}
|
2022-11-29 17:39:10 +08:00
|
|
|
|
|
|
|
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"`
|
|
|
|
}
|
|
|
|
|
2022-12-21 12:21:27 +08:00
|
|
|
func (a *AppInstallRepo) LoadBaseInfo(key string, name string) (*RootInfo, error) {
|
2022-11-29 17:39:10 +08:00
|
|
|
var (
|
|
|
|
app model.App
|
|
|
|
appInstall model.AppInstall
|
|
|
|
info RootInfo
|
|
|
|
)
|
|
|
|
if err := global.DB.Where("key = ?", key).First(&app).Error; err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2022-12-21 12:21:27 +08:00
|
|
|
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
|
|
|
|
}
|
2022-11-29 17:39:10 +08:00
|
|
|
}
|
|
|
|
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
|
|
|
|
}
|
2022-12-09 16:03:00 +08:00
|
|
|
info.Port = int64(appInstall.HttpPort)
|
2022-11-29 17:39:10 +08:00
|
|
|
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
|
|
|
|
}
|