1Panel/backend/app/repo/app_install.go

242 lines
7.0 KiB
Go
Raw Normal View History

package repo
import (
"context"
2022-11-29 09:39:10 +00:00
"encoding/json"
"github.com/1Panel-dev/1Panel/backend/constant"
2023-08-29 02:50:15 +00:00
"gorm.io/gorm/clause"
"github.com/1Panel-dev/1Panel/backend/app/model"
2022-11-29 09:39:10 +00:00
"github.com/1Panel-dev/1Panel/backend/global"
2022-10-03 09:35:39 +00:00
"gorm.io/gorm"
)
type AppInstallRepo struct{}
2023-03-28 10:00:06 +00:00
type IAppInstallRepo interface {
WithDetailIdsIn(detailIds []uint) DBOption
WithDetailIdNotIn(detailIds []uint) DBOption
WithAppId(appId uint) DBOption
WithAppIdsIn(appIds []uint) DBOption
WithStatus(status string) DBOption
WithServiceName(serviceName string) DBOption
WithContainerName(containerName string) DBOption
2023-03-28 10:00:06 +00:00
WithPort(port int) DBOption
WithIdNotInWebsite() DBOption
WithIDNotIs(id uint) DBOption
2023-03-28 10:00:06 +00:00
ListBy(opts ...DBOption) ([]model.AppInstall, error)
GetFirst(opts ...DBOption) (model.AppInstall, error)
Create(ctx context.Context, install *model.AppInstall) error
Save(ctx context.Context, install *model.AppInstall) error
2023-03-28 10:00:06 +00:00
DeleteBy(opts ...DBOption) error
Delete(ctx context.Context, install model.AppInstall) error
Page(page, size int, opts ...DBOption) (int64, []model.AppInstall, error)
BatchUpdateBy(maps map[string]interface{}, opts ...DBOption) error
LoadBaseInfo(key string, name string) (*RootInfo, error)
GetFirstByCtx(ctx context.Context, opts ...DBOption) (model.AppInstall, error)
2023-03-28 10:00:06 +00:00
}
func NewIAppInstallRepo() IAppInstallRepo {
return &AppInstallRepo{}
}
func (a *AppInstallRepo) WithDetailIdsIn(detailIds []uint) DBOption {
2022-10-03 09:35:39 +00:00
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 {
2022-10-07 07:49:39 +00:00
return func(g *gorm.DB) *gorm.DB {
return g.Where("app_id = ?", appId)
}
}
2022-10-28 09:04:57 +00:00
func (a *AppInstallRepo) WithIDNotIs(id uint) DBOption {
return func(g *gorm.DB) *gorm.DB {
return g.Where("id != ?", id)
}
}
func (a *AppInstallRepo) WithAppIdsIn(appIds []uint) DBOption {
2022-10-28 09:04:57 +00:00
return func(g *gorm.DB) *gorm.DB {
return g.Where("app_id in (?)", appIds)
}
}
func (a *AppInstallRepo) WithStatus(status string) DBOption {
2022-10-07 07:49:39 +00:00
return func(g *gorm.DB) *gorm.DB {
return g.Where("status = ?", status)
}
}
2022-10-03 09:35:39 +00:00
func (a *AppInstallRepo) WithServiceName(serviceName string) DBOption {
return func(db *gorm.DB) *gorm.DB {
return db.Where("service_name = ?", serviceName)
}
}
func (a *AppInstallRepo) WithContainerName(containerName string) DBOption {
return func(db *gorm.DB) *gorm.DB {
return db.Where("container_name = ?", containerName)
}
}
2023-02-07 08:29:54 +00: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)
}
}
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 08:29:54 +00:00
func (a *AppInstallRepo) ListBy(opts ...DBOption) ([]model.AppInstall, error) {
var install []model.AppInstall
db := getDb(opts...).Model(&model.AppInstall{})
2023-03-02 10:47:48 +00:00
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{})
2023-03-02 10:47:48 +00:00
err := db.Preload("App").First(&install).Error
return install, err
}
func (a *AppInstallRepo) GetFirstByCtx(ctx context.Context, opts ...DBOption) (model.AppInstall, error) {
var install model.AppInstall
db := getTx(ctx, 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.Omit(clause.Associations).Create(&install).Error
}
2022-09-26 14:54:38 +00:00
func (a *AppInstallRepo) Save(ctx context.Context, install *model.AppInstall) error {
return getTx(ctx).Save(&install).Error
}
func (a *AppInstallRepo) DeleteBy(opts ...DBOption) error {
return getDb(opts...).Delete(&model.AppInstall{}).Error
2022-09-26 14:54:38 +00:00
}
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)
2023-03-02 10:47:48 +00:00
err := db.Limit(size).Offset(size * (page - 1)).Preload("App").Find(&apps).Error
return count, apps, err
}
2022-10-03 09:35:39 +00:00
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")
2022-10-03 09:35:39 +00:00
}
2023-02-09 08:13:06 +00:00
return db.Updates(&maps).Error
2022-10-03 09:35:39 +00:00
}
2022-11-29 09:39:10 +00:00
type RootInfo struct {
ID uint `json:"id"`
Name string `json:"name"`
Status string `json:"status"`
2022-11-29 09:39:10 +00:00
Port int64 `json:"port"`
2023-03-31 16:51:25 +00:00
HttpsPort int64 `json:"httpsPort"`
UserName string `json:"userName"`
2022-11-29 09:39:10 +00:00
Password string `json:"password"`
UserPassword string `json:"userPassword"`
2022-11-29 09:39:10 +00:00
ContainerName string `json:"containerName"`
ServiceName string `json:"serviceName"`
2022-11-29 09:39:10 +00:00
Param string `json:"param"`
Env string `json:"env"`
Key string `json:"key"`
Version string `json:"version"`
AppPath string `json:"app_path"`
2022-11-29 09:39:10 +00:00
}
func (a *AppInstallRepo) LoadBaseInfo(key string, name string) (*RootInfo, error) {
2022-11-29 09:39:10 +00: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
}
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 09:39:10 +00:00
}
envMap := make(map[string]interface{})
if err := json.Unmarshal([]byte(appInstall.Env), &envMap); err != nil {
return nil, err
}
switch app.Key {
2023-08-29 02:50:15 +00:00
case "mysql", "mariadb":
password, ok := envMap["PANEL_DB_ROOT_PASSWORD"].(string)
if ok {
info.Password = password
}
case "redis":
password, ok := envMap["PANEL_REDIS_ROOT_PASSWORD"].(string)
if ok {
info.Password = password
}
case "mongodb", constant.AppPostgresql:
user, ok := envMap["PANEL_DB_ROOT_USER"].(string)
if ok {
info.UserName = user
}
password, ok := envMap["PANEL_DB_ROOT_PASSWORD"].(string)
if ok {
info.Password = password
}
2022-11-29 09:39:10 +00:00
}
userPassword, ok := envMap["PANEL_DB_USER_PASSWORD"].(string)
if ok {
info.UserPassword = userPassword
}
info.Port = int64(appInstall.HttpPort)
2023-03-31 16:51:25 +00:00
info.HttpsPort = int64(appInstall.HttpsPort)
2022-11-29 09:39:10 +00:00
info.ID = appInstall.ID
info.ServiceName = appInstall.ServiceName
2022-11-29 09:39:10 +00:00
info.ContainerName = appInstall.ContainerName
info.Name = appInstall.Name
info.Env = appInstall.Env
info.Param = appInstall.Param
info.Version = appInstall.Version
info.Key = app.Key
appInstall.App = app
info.AppPath = appInstall.GetAppPath()
info.Status = appInstall.Status
2022-11-29 09:39:10 +00:00
return &info, nil
}