2023-11-14 10:44:09 +00:00
|
|
|
package migrations
|
|
|
|
|
|
|
|
import (
|
2023-11-29 14:04:08 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/dto/request"
|
2023-11-14 10:44:09 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/model"
|
2023-12-18 09:54:15 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/repo"
|
2023-11-29 14:04:08 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/service"
|
2024-01-08 09:40:42 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/global"
|
2023-11-14 10:44:09 +00:00
|
|
|
"github.com/go-gormigrate/gormigrate/v2"
|
|
|
|
"gorm.io/gorm"
|
|
|
|
)
|
|
|
|
|
|
|
|
var UpdateAcmeAccount = &gormigrate.Migration{
|
2023-11-16 06:38:07 +00:00
|
|
|
ID: "20231117-update-acme-account",
|
2023-11-14 10:44:09 +00:00
|
|
|
Migrate: func(tx *gorm.DB) error {
|
|
|
|
if err := tx.AutoMigrate(&model.WebsiteAcmeAccount{}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2023-11-20 02:44:10 +00:00
|
|
|
|
2023-11-27 06:00:09 +00:00
|
|
|
var AddWebsiteCA = &gormigrate.Migration{
|
2023-12-01 08:54:09 +00:00
|
|
|
ID: "20231125-add-website-ca",
|
2023-11-20 02:44:10 +00:00
|
|
|
Migrate: func(tx *gorm.DB) error {
|
2023-11-27 06:00:09 +00:00
|
|
|
if err := tx.AutoMigrate(&model.WebsiteCA{}); err != nil {
|
2023-11-20 02:44:10 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2023-11-27 04:04:09 +00:00
|
|
|
|
2023-11-27 06:00:09 +00:00
|
|
|
var UpdateWebsiteSSL = &gormigrate.Migration{
|
2023-11-28 07:42:10 +00:00
|
|
|
ID: "20231128-update-website-ssl",
|
2023-11-27 04:04:09 +00:00
|
|
|
Migrate: func(tx *gorm.DB) error {
|
2023-11-27 06:00:09 +00:00
|
|
|
if err := tx.AutoMigrate(&model.WebsiteSSL{}); err != nil {
|
2023-11-27 04:04:09 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2023-11-28 07:00:10 +00:00
|
|
|
|
|
|
|
var AddDockerSockPath = &gormigrate.Migration{
|
|
|
|
ID: "20231128-add-docker-sock-path",
|
|
|
|
Migrate: func(tx *gorm.DB) error {
|
|
|
|
if err := tx.Create(&model.Setting{Key: "DockerSockPath", Value: "unix:///var/run/docker.sock"}).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2023-11-29 02:46:07 +00:00
|
|
|
|
|
|
|
var AddDatabaseSSL = &gormigrate.Migration{
|
|
|
|
ID: "20231126-add-database-ssl",
|
|
|
|
Migrate: func(tx *gorm.DB) error {
|
|
|
|
if err := tx.AutoMigrate(&model.Database{}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2023-11-29 14:04:08 +00:00
|
|
|
|
|
|
|
var AddDefaultCA = &gormigrate.Migration{
|
2023-12-01 08:54:09 +00:00
|
|
|
ID: "20231129-add-default-ca",
|
2023-11-29 14:04:08 +00:00
|
|
|
Migrate: func(tx *gorm.DB) error {
|
|
|
|
caService := service.NewIWebsiteCAService()
|
|
|
|
if _, err := caService.Create(request.WebsiteCACreate{
|
|
|
|
CommonName: "1Panel-CA",
|
|
|
|
Country: "CN",
|
|
|
|
KeyType: "P256",
|
|
|
|
Name: "1Panel",
|
|
|
|
Organization: "FIT2CLOUD",
|
|
|
|
OrganizationUint: "1Panel",
|
|
|
|
Province: "Beijing",
|
|
|
|
City: "Beijing",
|
|
|
|
}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2023-12-04 06:56:09 +00:00
|
|
|
|
|
|
|
var AddSettingRecycleBin = &gormigrate.Migration{
|
|
|
|
ID: "20231129-add-setting-recycle-bin",
|
|
|
|
Migrate: func(tx *gorm.DB) error {
|
|
|
|
if err := tx.Create(&model.Setting{Key: "FileRecycleBin", Value: "enable"}).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2023-12-18 09:54:15 +00:00
|
|
|
|
|
|
|
var UpdateWebsiteBackupRecord = &gormigrate.Migration{
|
|
|
|
ID: "20231218-update-backup-record-for-website",
|
|
|
|
Migrate: func(tx *gorm.DB) error {
|
|
|
|
backupRepo := repo.NewIBackupRepo()
|
|
|
|
websitesBackups, _ := backupRepo.ListRecord(repo.NewCommonRepo().WithByType("website"))
|
|
|
|
if len(websitesBackups) > 0 {
|
|
|
|
for _, backup := range websitesBackups {
|
|
|
|
backup.DetailName = backup.Name
|
|
|
|
_ = backupRepo.UpdateRecord(&backup)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2024-01-02 13:54:28 +00:00
|
|
|
|
|
|
|
var AddTablePHPExtensions = &gormigrate.Migration{
|
|
|
|
ID: "20240102-add-php-extensions",
|
|
|
|
Migrate: func(tx *gorm.DB) error {
|
|
|
|
if err := tx.AutoMigrate(&model.PHPExtensions{}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := tx.Create(&model.PHPExtensions{Name: "默认", Extensions: "bcmath,gd,gettext,intl,pcntl,shmop,soap,sockets,sysvsem,xmlrpc,zip"}).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2024-01-07 14:52:41 +00:00
|
|
|
|
|
|
|
var AddTableDatabasePostgresql = &gormigrate.Migration{
|
|
|
|
ID: "20231225-add-table-database_postgresql",
|
|
|
|
Migrate: func(tx *gorm.DB) error {
|
|
|
|
if err := tx.AutoMigrate(&model.DatabasePostgresql{}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := tx.AutoMigrate(&model.Cronjob{}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
var jobs []model.Cronjob
|
|
|
|
if err := tx.Where("type == ?", "database").Find(&jobs).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
for _, job := range jobs {
|
2024-01-11 03:01:40 +00:00
|
|
|
if job.DBName == "all" {
|
|
|
|
if err := tx.Model(&model.Cronjob{}).Where("id = ?", job.ID).Update("db_type", "mysql").Error; err != nil {
|
|
|
|
global.LOG.Errorf("update db type of cronjob %s failed, err: %v", job.Name, err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
}
|
2024-01-07 14:52:41 +00:00
|
|
|
var db model.DatabaseMysql
|
|
|
|
if err := tx.Where("id == ?", job.DBName).First(&db).Error; err != nil {
|
2024-01-08 09:40:42 +00:00
|
|
|
continue
|
2024-01-07 14:52:41 +00:00
|
|
|
}
|
|
|
|
var database model.Database
|
|
|
|
if err := tx.Where("name == ?", db.MysqlName).First(&database).Error; err != nil {
|
2024-01-08 09:40:42 +00:00
|
|
|
continue
|
2024-01-07 14:52:41 +00:00
|
|
|
}
|
|
|
|
if err := tx.Model(&model.Cronjob{}).Where("id = ?", job.ID).Update("db_type", database.Type).Error; err != nil {
|
2024-01-08 09:40:42 +00:00
|
|
|
global.LOG.Errorf("update db type of cronjob %s failed, err: %v", job.Name, err)
|
|
|
|
continue
|
2024-01-07 14:52:41 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2024-01-09 04:43:33 +00:00
|
|
|
|
|
|
|
var AddPostgresqlSuperUser = &gormigrate.Migration{
|
|
|
|
ID: "20231225-add-postgresql-super_user",
|
|
|
|
Migrate: func(tx *gorm.DB) error {
|
|
|
|
if err := tx.AutoMigrate(&model.DatabasePostgresql{}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2024-01-11 03:01:40 +00:00
|
|
|
|
|
|
|
var UpdateCronjobWithWebsite = &gormigrate.Migration{
|
|
|
|
ID: "20230809-update-cronjob-with-website",
|
|
|
|
Migrate: func(tx *gorm.DB) error {
|
|
|
|
var cronjobs []model.Cronjob
|
|
|
|
if err := tx.Where("(type = ? OR type = ?) AND website != ?", "website", "cutWebsiteLog", "all").Find(&cronjobs).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, job := range cronjobs {
|
|
|
|
var web model.Website
|
|
|
|
if err := tx.Where("primary_domain = ?", job.Website).First(&web).Error; err != nil {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if err := tx.Model(&model.Cronjob{}).
|
|
|
|
Where("id = ?", job.ID).
|
|
|
|
Updates(map[string]interface{}{"website": web.ID}).Error; err != nil {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|