setting.go 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  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. "subEncrypt": func() (interface{}, error) { return a.settingService.GetSubEncrypt() },
  71. "subShowInfo": func() (interface{}, error) { return a.settingService.GetSubShowInfo() },
  72. }
  73. result := make(map[string]interface{})
  74. for key, fn := range settings {
  75. value, err := fn()
  76. if err != nil {
  77. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  78. return
  79. }
  80. result[key] = value
  81. }
  82. subTLS := false
  83. if result["subKeyFile"] != "" || result["subCertFile"] != "" {
  84. subTLS = true
  85. }
  86. result["subTLS"] = subTLS
  87. delete(result, "subKeyFile")
  88. delete(result, "subCertFile")
  89. jsonObj(c, result, nil)
  90. }
  91. func (a *SettingController) updateSetting(c *gin.Context) {
  92. allSetting := &entity.AllSetting{}
  93. err := c.ShouldBind(allSetting)
  94. if err != nil {
  95. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  96. return
  97. }
  98. err = a.settingService.UpdateAllSetting(allSetting)
  99. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  100. }
  101. func (a *SettingController) updateUser(c *gin.Context) {
  102. form := &updateUserForm{}
  103. err := c.ShouldBind(form)
  104. if err != nil {
  105. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  106. return
  107. }
  108. user := session.GetLoginUser(c)
  109. if user.Username != form.OldUsername || user.Password != form.OldPassword {
  110. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), errors.New(I18nWeb(c, "pages.settings.toasts.originalUserPassIncorrect")))
  111. return
  112. }
  113. if form.NewUsername == "" || form.NewPassword == "" {
  114. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), errors.New(I18nWeb(c, "pages.settings.toasts.userPassMustBeNotEmpty")))
  115. return
  116. }
  117. err = a.userService.UpdateUser(user.Id, form.NewUsername, form.NewPassword)
  118. if err == nil {
  119. user.Username = form.NewUsername
  120. user.Password = form.NewPassword
  121. session.SetLoginUser(c, user)
  122. }
  123. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), err)
  124. }
  125. func (a *SettingController) restartPanel(c *gin.Context) {
  126. err := a.panelService.RestartPanel(time.Second * 3)
  127. jsonMsg(c, I18nWeb(c, "pages.settings.restartPanel"), err)
  128. }
  129. func (a *SettingController) updateSecret(c *gin.Context) {
  130. form := &updateSecretForm{}
  131. err := c.ShouldBind(form)
  132. if err != nil {
  133. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  134. }
  135. user := session.GetLoginUser(c)
  136. err = a.userService.UpdateUserSecret(user.Id, form.LoginSecret)
  137. if err == nil {
  138. user.LoginSecret = form.LoginSecret
  139. session.SetLoginUser(c, user)
  140. }
  141. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), err)
  142. }
  143. func (a *SettingController) getUserSecret(c *gin.Context) {
  144. loginUser := session.GetLoginUser(c)
  145. user := a.userService.GetUserSecret(loginUser.Id)
  146. if user != nil {
  147. jsonObj(c, user, nil)
  148. }
  149. }