1
0
mirror of https://github.com/1Panel-dev/1Panel.git synced 2025-01-20 00:39:17 +08:00
1Panel/backend/app/service/setting.go

94 lines
2.2 KiB
Go
Raw Normal View History

2022-09-15 10:44:43 +08:00
package service
import (
"encoding/json"
"time"
2022-09-15 10:44:43 +08:00
"github.com/1Panel-dev/1Panel/app/dto"
"github.com/1Panel-dev/1Panel/constant"
2022-09-08 18:47:15 +08:00
"github.com/1Panel-dev/1Panel/global"
"github.com/1Panel-dev/1Panel/utils/encrypt"
"github.com/gin-gonic/gin"
2022-09-15 10:44:43 +08:00
)
type SettingService struct{}
type ISettingService interface {
GetSettingInfo() (*dto.SettingInfo, error)
2022-09-08 18:47:15 +08:00
Update(c *gin.Context, key, value string) error
UpdatePassword(c *gin.Context, old, new string) error
2022-09-15 10:44:43 +08:00
}
func NewISettingService() ISettingService {
return &SettingService{}
}
func (u *SettingService) GetSettingInfo() (*dto.SettingInfo, error) {
2022-09-08 18:47:15 +08:00
setting, err := settingRepo.GetList()
2022-09-15 10:44:43 +08:00
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")
2022-09-15 10:44:43 +08:00
return &info, err
}
2022-09-08 18:47:15 +08:00
func (u *SettingService) Update(c *gin.Context, key, value string) error {
if err := settingRepo.Update(key, value); err != nil {
return err
}
switch key {
case "UserName":
sID, _ := c.Cookie(constant.SessionName)
if sID != "" {
c.SetCookie(constant.SessionName, sID, -1, "", "", false, false)
err := global.SESSION.Delete(sID)
if err != nil {
return err
}
}
}
2022-09-15 10:44:43 +08:00
return settingRepo.Update(key, value)
}
2022-09-08 18:47:15 +08:00
func (u *SettingService) UpdatePassword(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
}
sID, _ := c.Cookie(constant.SessionName)
if sID != "" {
c.SetCookie(constant.SessionName, sID, -1, "", "", false, false)
err := global.SESSION.Delete(sID)
if err != nil {
return err
}
}
return nil
}
return constant.ErrInitialPassword
}