mirror of https://github.com/1Panel-dev/1Panel
152 lines
4.0 KiB
Go
152 lines
4.0 KiB
Go
package service
|
|
|
|
import (
|
|
"encoding/json"
|
|
"strconv"
|
|
"time"
|
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/dto"
|
|
"github.com/1Panel-dev/1Panel/backend/buserr"
|
|
"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"
|
|
"github.com/gin-gonic/gin"
|
|
)
|
|
|
|
type SettingService struct{}
|
|
|
|
type ISettingService interface {
|
|
GetSettingInfo() (*dto.SettingInfo, error)
|
|
Update(key, value string) error
|
|
UpdateEntrance(value string) error
|
|
UpdatePassword(c *gin.Context, old, new string) error
|
|
UpdatePort(port uint) error
|
|
HandlePasswordExpired(c *gin.Context, old, new string) error
|
|
}
|
|
|
|
func NewISettingService() ISettingService {
|
|
return &SettingService{}
|
|
}
|
|
|
|
func (u *SettingService) GetSettingInfo() (*dto.SettingInfo, error) {
|
|
setting, err := settingRepo.GetList()
|
|
if err != nil {
|
|
return nil, constant.ErrRecordNotFound
|
|
}
|
|
settingMap := make(map[string]string)
|
|
for _, set := range setting {
|
|
settingMap[set.Key] = set.Value
|
|
}
|
|
var info dto.SettingInfo
|
|
arr, err := json.Marshal(settingMap)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if err := json.Unmarshal(arr, &info); err != nil {
|
|
return nil, err
|
|
}
|
|
info.LocalTime = time.Now().Format("2006-01-02 15:04:05 MST -0700")
|
|
return &info, err
|
|
}
|
|
|
|
func (u *SettingService) Update(key, value string) error {
|
|
if key == "ExpirationDays" {
|
|
timeout, _ := strconv.Atoi(value)
|
|
if err := settingRepo.Update("ExpirationTime", time.Now().AddDate(0, 0, timeout).Format("2006-01-02 15:04:05")); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if key == "SecurityEntrance" {
|
|
if err := settingRepo.Update("SecurityEntranceStatus", "enable"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if key == "SecurityEntranceStatus" {
|
|
if err := settingRepo.Update("SecurityEntrance", ""); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if err := settingRepo.Update(key, value); err != nil {
|
|
return err
|
|
}
|
|
if key == "UserName" {
|
|
_ = global.SESSION.Clean()
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (u *SettingService) UpdateEntrance(value string) error {
|
|
if err := settingRepo.Update("SecurityEntranceStatus", "enable"); err != nil {
|
|
return err
|
|
}
|
|
if err := settingRepo.Update("SecurityEntrance", value); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (u *SettingService) UpdatePort(port uint) error {
|
|
if common.ScanPort(int(port)) {
|
|
return buserr.WithDetail(constant.ErrPortInUsed, port, nil)
|
|
}
|
|
serverPort, err := settingRepo.Get(settingRepo.WithByKey("ServerPort"))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
portValue, _ := strconv.Atoi(serverPort.Value)
|
|
if err := OperateFirewallPort([]int{portValue}, []int{int(port)}); err != nil {
|
|
global.LOG.Errorf("set system firewall ports failed, err: %v", err)
|
|
}
|
|
if err := settingRepo.Update("ServerPort", strconv.Itoa(int(port))); err != nil {
|
|
return err
|
|
}
|
|
go func() {
|
|
_, err := cmd.Exec("systemctl restart 1panel.service")
|
|
if err != nil {
|
|
global.LOG.Errorf("restart system port failed, err: %v", err)
|
|
}
|
|
}()
|
|
return nil
|
|
}
|
|
|
|
func (u *SettingService) HandlePasswordExpired(c *gin.Context, old, new string) error {
|
|
setting, err := settingRepo.Get(settingRepo.WithByKey("Password"))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
passwordFromDB, err := encrypt.StringDecrypt(setting.Value)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if passwordFromDB == old {
|
|
newPassword, err := encrypt.StringEncrypt(new)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if err := settingRepo.Update("Password", newPassword); err != nil {
|
|
return err
|
|
}
|
|
|
|
expiredSetting, err := settingRepo.Get(settingRepo.WithByKey("ExpirationDays"))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
timeout, _ := strconv.Atoi(expiredSetting.Value)
|
|
if err := settingRepo.Update("ExpirationTime", time.Now().AddDate(0, 0, timeout).Format("2006-01-02 15:04:05")); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
return constant.ErrInitialPassword
|
|
}
|
|
|
|
func (u *SettingService) UpdatePassword(c *gin.Context, old, new string) error {
|
|
if err := u.HandlePasswordExpired(c, old, new); err != nil {
|
|
return err
|
|
}
|
|
_ = global.SESSION.Clean()
|
|
return nil
|
|
}
|