mirror of https://github.com/1Panel-dev/1Panel
161 lines
4.5 KiB
Go
161 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").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.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.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
|
|
}
|