setting.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. package controller
  2. import (
  3. "errors"
  4. "time"
  5. "x-ui/web/entity"
  6. "x-ui/web/service"
  7. "x-ui/web/session"
  8. "github.com/gin-gonic/gin"
  9. )
  10. type updateUserForm struct {
  11. OldUsername string `json:"oldUsername" form:"oldUsername"`
  12. OldPassword string `json:"oldPassword" form:"oldPassword"`
  13. NewUsername string `json:"newUsername" form:"newUsername"`
  14. NewPassword string `json:"newPassword" form:"newPassword"`
  15. }
  16. type updateSecretForm struct {
  17. LoginSecret string `json:"loginSecret" form:"loginSecret"`
  18. }
  19. type SettingController struct {
  20. settingService service.SettingService
  21. userService service.UserService
  22. panelService service.PanelService
  23. }
  24. func NewSettingController(g *gin.RouterGroup) *SettingController {
  25. a := &SettingController{}
  26. a.initRouter(g)
  27. return a
  28. }
  29. func (a *SettingController) initRouter(g *gin.RouterGroup) {
  30. g = g.Group("/setting")
  31. g.POST("/all", a.getAllSetting)
  32. g.POST("/defaultSettings", a.getDefaultSettings)
  33. g.POST("/update", a.updateSetting)
  34. g.POST("/updateUser", a.updateUser)
  35. g.POST("/restartPanel", a.restartPanel)
  36. g.GET("/getDefaultJsonConfig", a.getDefaultJsonConfig)
  37. g.POST("/updateUserSecret", a.updateSecret)
  38. g.POST("/getUserSecret", a.getUserSecret)
  39. }
  40. func (a *SettingController) getAllSetting(c *gin.Context) {
  41. allSetting, err := a.settingService.GetAllSetting()
  42. if err != nil {
  43. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  44. return
  45. }
  46. jsonObj(c, allSetting, nil)
  47. }
  48. func (a *SettingController) getDefaultJsonConfig(c *gin.Context) {
  49. defaultJsonConfig, err := a.settingService.GetDefaultJsonConfig()
  50. if err != nil {
  51. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  52. return
  53. }
  54. jsonObj(c, defaultJsonConfig, nil)
  55. }
  56. func (a *SettingController) getDefaultSettings(c *gin.Context) {
  57. type settingFunc func() (interface{}, error)
  58. settings := map[string]settingFunc{
  59. "expireDiff": func() (interface{}, error) { return a.settingService.GetExpireDiff() },
  60. "trafficDiff": func() (interface{}, error) { return a.settingService.GetTrafficDiff() },
  61. "defaultCert": func() (interface{}, error) { return a.settingService.GetCertFile() },
  62. "defaultKey": func() (interface{}, error) { return a.settingService.GetKeyFile() },
  63. "tgBotEnable": func() (interface{}, error) { return a.settingService.GetTgbotenabled() },
  64. "subEnable": func() (interface{}, error) { return a.settingService.GetSubEnable() },
  65. "subPort": func() (interface{}, error) { return a.settingService.GetSubPort() },
  66. "subPath": func() (interface{}, error) { return a.settingService.GetSubPath() },
  67. "subDomain": func() (interface{}, error) { return a.settingService.GetSubDomain() },
  68. "subKeyFile": func() (interface{}, error) { return a.settingService.GetSubKeyFile() },
  69. "subCertFile": func() (interface{}, error) { return a.settingService.GetSubCertFile() },
  70. "subShowInfo": func() (interface{}, error) { return a.settingService.GetSubShowInfo() },
  71. }
  72. result := make(map[string]interface{})
  73. for key, fn := range settings {
  74. value, err := fn()
  75. if err != nil {
  76. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  77. return
  78. }
  79. result[key] = value
  80. }
  81. subTLS := false
  82. if result["subKeyFile"] != "" || result["subCertFile"] != "" {
  83. subTLS = true
  84. }
  85. result["subTLS"] = subTLS
  86. delete(result, "subKeyFile")
  87. delete(result, "subCertFile")
  88. jsonObj(c, result, nil)
  89. }
  90. func (a *SettingController) updateSetting(c *gin.Context) {
  91. allSetting := &entity.AllSetting{}
  92. err := c.ShouldBind(allSetting)
  93. if err != nil {
  94. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  95. return
  96. }
  97. err = a.settingService.UpdateAllSetting(allSetting)
  98. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  99. }
  100. func (a *SettingController) updateUser(c *gin.Context) {
  101. form := &updateUserForm{}
  102. err := c.ShouldBind(form)
  103. if err != nil {
  104. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  105. return
  106. }
  107. user := session.GetLoginUser(c)
  108. if user.Username != form.OldUsername || user.Password != form.OldPassword {
  109. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), errors.New(I18nWeb(c, "pages.settings.toasts.originalUserPassIncorrect")))
  110. return
  111. }
  112. if form.NewUsername == "" || form.NewPassword == "" {
  113. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), errors.New(I18nWeb(c, "pages.settings.toasts.userPassMustBeNotEmpty")))
  114. return
  115. }
  116. err = a.userService.UpdateUser(user.Id, form.NewUsername, form.NewPassword)
  117. if err == nil {
  118. user.Username = form.NewUsername
  119. user.Password = form.NewPassword
  120. session.SetLoginUser(c, user)
  121. }
  122. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), err)
  123. }
  124. func (a *SettingController) restartPanel(c *gin.Context) {
  125. err := a.panelService.RestartPanel(time.Second * 3)
  126. jsonMsg(c, I18nWeb(c, "pages.settings.restartPanel"), err)
  127. }
  128. func (a *SettingController) updateSecret(c *gin.Context) {
  129. form := &updateSecretForm{}
  130. err := c.ShouldBind(form)
  131. if err != nil {
  132. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  133. }
  134. user := session.GetLoginUser(c)
  135. err = a.userService.UpdateUserSecret(user.Id, form.LoginSecret)
  136. if err == nil {
  137. user.LoginSecret = form.LoginSecret
  138. session.SetLoginUser(c, user)
  139. }
  140. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), err)
  141. }
  142. func (a *SettingController) getUserSecret(c *gin.Context) {
  143. loginUser := session.GetLoginUser(c)
  144. user := a.userService.GetUserSecret(loginUser.Id)
  145. if user != nil {
  146. jsonObj(c, user, nil)
  147. }
  148. }