mirror of https://github.com/1Panel-dev/1Panel
appstorecrontabdatabasedockerdocker-composedocker-containerdocker-imagedocker-uifilemanagerlamplnmppanel
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
175 lines
5.9 KiB
175 lines
5.9 KiB
package hook |
|
|
|
import ( |
|
"encoding/base64" |
|
"encoding/json" |
|
"os" |
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/model" |
|
"github.com/1Panel-dev/1Panel/backend/app/repo" |
|
"github.com/1Panel-dev/1Panel/backend/constant" |
|
"github.com/1Panel-dev/1Panel/backend/global" |
|
"github.com/1Panel-dev/1Panel/backend/utils/cmd" |
|
"github.com/1Panel-dev/1Panel/backend/utils/common" |
|
"github.com/1Panel-dev/1Panel/backend/utils/encrypt" |
|
) |
|
|
|
func Init() { |
|
settingRepo := repo.NewISettingRepo() |
|
portSetting, err := settingRepo.Get(settingRepo.WithByKey("ServerPort")) |
|
if err != nil { |
|
global.LOG.Errorf("load service port from setting failed, err: %v", err) |
|
} |
|
global.CONF.System.Port = portSetting.Value |
|
ipv6Setting, err := settingRepo.Get(settingRepo.WithByKey("Ipv6")) |
|
if err != nil { |
|
global.LOG.Errorf("load ipv6 status from setting failed, err: %v", err) |
|
} |
|
global.CONF.System.Ipv6 = ipv6Setting.Value |
|
bindAddressSetting, err := settingRepo.Get(settingRepo.WithByKey("BindAddress")) |
|
if err != nil { |
|
global.LOG.Errorf("load bind address from setting failed, err: %v", err) |
|
} |
|
global.CONF.System.BindAddress = bindAddressSetting.Value |
|
sslSetting, err := settingRepo.Get(settingRepo.WithByKey("SSL")) |
|
if err != nil { |
|
global.LOG.Errorf("load service ssl from setting failed, err: %v", err) |
|
} |
|
global.CONF.System.SSL = sslSetting.Value |
|
|
|
OneDriveID, err := settingRepo.Get(settingRepo.WithByKey("OneDriveID")) |
|
if err != nil { |
|
global.LOG.Errorf("load onedrive info from setting failed, err: %v", err) |
|
} |
|
idItem, _ := base64.StdEncoding.DecodeString(OneDriveID.Value) |
|
global.CONF.System.OneDriveID = string(idItem) |
|
OneDriveSc, err := settingRepo.Get(settingRepo.WithByKey("OneDriveSc")) |
|
if err != nil { |
|
global.LOG.Errorf("load onedrive info from setting failed, err: %v", err) |
|
} |
|
scItem, _ := base64.StdEncoding.DecodeString(OneDriveSc.Value) |
|
global.CONF.System.OneDriveSc = string(scItem) |
|
|
|
if _, err := settingRepo.Get(settingRepo.WithByKey("SystemStatus")); err != nil { |
|
_ = settingRepo.Create("SystemStatus", "Free") |
|
} |
|
if err := settingRepo.Update("SystemStatus", "Free"); err != nil { |
|
global.LOG.Fatalf("init service before start failed, err: %v", err) |
|
} |
|
|
|
if global.CONF.System.ChangeUserInfo { |
|
if err := settingRepo.Update("UserName", common.RandStrAndNum(10)); err != nil { |
|
global.LOG.Fatalf("init username before start failed, err: %v", err) |
|
} |
|
pass, _ := encrypt.StringEncrypt(common.RandStrAndNum(10)) |
|
if err := settingRepo.Update("Password", pass); err != nil { |
|
global.LOG.Fatalf("init password before start failed, err: %v", err) |
|
} |
|
if err := settingRepo.Update("SecurityEntrance", common.RandStrAndNum(10)); err != nil { |
|
global.LOG.Fatalf("init entrance before start failed, err: %v", err) |
|
} |
|
|
|
sudo := cmd.SudoHandleCmd() |
|
_, _ = cmd.Execf("%s sed -i '/CHANGE_USER_INFO=true/d' /usr/local/bin/1pctl", sudo) |
|
} |
|
|
|
handleCronjobStatus() |
|
handleSnapStatus() |
|
loadLocalDir() |
|
} |
|
|
|
func handleSnapStatus() { |
|
msgFailed := "the task was interrupted due to the restart of the 1panel service" |
|
_ = global.DB.Model(&model.Snapshot{}).Where("status = ?", "OnSaveData"). |
|
Updates(map[string]interface{}{"status": constant.StatusSuccess}).Error |
|
|
|
_ = global.DB.Model(&model.Snapshot{}).Where("status = ?", constant.StatusWaiting). |
|
Updates(map[string]interface{}{ |
|
"status": constant.StatusFailed, |
|
"message": msgFailed, |
|
}).Error |
|
|
|
_ = global.DB.Model(&model.Snapshot{}).Where("recover_status = ?", constant.StatusWaiting). |
|
Updates(map[string]interface{}{ |
|
"recover_status": constant.StatusFailed, |
|
"recover_message": msgFailed, |
|
}).Error |
|
|
|
_ = global.DB.Model(&model.Snapshot{}).Where("rollback_status = ?", constant.StatusWaiting). |
|
Updates(map[string]interface{}{ |
|
"rollback_status": constant.StatusFailed, |
|
"rollback_message": msgFailed, |
|
}).Error |
|
|
|
snapRepo := repo.NewISnapshotRepo() |
|
|
|
status, _ := snapRepo.GetStatusList() |
|
for _, item := range status { |
|
updates := make(map[string]interface{}) |
|
if item.Panel == constant.StatusRunning { |
|
updates["panel"] = constant.StatusFailed |
|
} |
|
if item.PanelInfo == constant.StatusRunning { |
|
updates["panel_info"] = constant.StatusFailed |
|
} |
|
if item.DaemonJson == constant.StatusRunning { |
|
updates["daemon_json"] = constant.StatusFailed |
|
} |
|
if item.AppData == constant.StatusRunning { |
|
updates["app_data"] = constant.StatusFailed |
|
} |
|
if item.PanelData == constant.StatusRunning { |
|
updates["panel_data"] = constant.StatusFailed |
|
} |
|
if item.BackupData == constant.StatusRunning { |
|
updates["backup_data"] = constant.StatusFailed |
|
} |
|
if item.Compress == constant.StatusRunning { |
|
updates["compress"] = constant.StatusFailed |
|
} |
|
if item.Upload == constant.StatusUploading { |
|
updates["upload"] = constant.StatusFailed |
|
} |
|
if len(updates) != 0 { |
|
_ = snapRepo.UpdateStatus(item.ID, updates) |
|
} |
|
} |
|
} |
|
|
|
func handleCronjobStatus() { |
|
_ = global.DB.Model(&model.JobRecords{}).Where("status = ?", constant.StatusWaiting). |
|
Updates(map[string]interface{}{ |
|
"status": constant.StatusFailed, |
|
"message": "the task was interrupted due to the restart of the 1panel service", |
|
}).Error |
|
} |
|
|
|
func loadLocalDir() { |
|
var backup model.BackupAccount |
|
_ = global.DB.Where("type = ?", "LOCAL").First(&backup).Error |
|
if backup.ID == 0 { |
|
global.LOG.Errorf("no such backup account `%s` in db", "LOCAL") |
|
return |
|
} |
|
varMap := make(map[string]interface{}) |
|
if err := json.Unmarshal([]byte(backup.Vars), &varMap); err != nil { |
|
global.LOG.Errorf("json unmarshal backup.Vars: %v failed, err: %v", backup.Vars, err) |
|
return |
|
} |
|
if _, ok := varMap["dir"]; !ok { |
|
global.LOG.Error("load local backup dir failed") |
|
return |
|
} |
|
baseDir, ok := varMap["dir"].(string) |
|
if ok { |
|
if _, err := os.Stat(baseDir); err != nil && os.IsNotExist(err) { |
|
if err = os.MkdirAll(baseDir, os.ModePerm); err != nil { |
|
global.LOG.Errorf("mkdir %s failed, err: %v", baseDir, err) |
|
return |
|
} |
|
} |
|
global.CONF.System.Backup = baseDir |
|
return |
|
} |
|
global.LOG.Errorf("error type dir: %T", varMap["dir"]) |
|
}
|
|
|