setting.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  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. expireDiff, err := a.settingService.GetExpireDiff()
  58. if err != nil {
  59. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  60. return
  61. }
  62. trafficDiff, err := a.settingService.GetTrafficDiff()
  63. if err != nil {
  64. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  65. return
  66. }
  67. defaultCert, err := a.settingService.GetCertFile()
  68. if err != nil {
  69. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  70. return
  71. }
  72. defaultKey, err := a.settingService.GetKeyFile()
  73. if err != nil {
  74. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  75. return
  76. }
  77. result := map[string]interface{}{
  78. "expireDiff": expireDiff,
  79. "trafficDiff": trafficDiff,
  80. "defaultCert": defaultCert,
  81. "defaultKey": defaultKey,
  82. }
  83. jsonObj(c, result, nil)
  84. }
  85. func (a *SettingController) updateSetting(c *gin.Context) {
  86. allSetting := &entity.AllSetting{}
  87. err := c.ShouldBind(allSetting)
  88. if err != nil {
  89. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  90. return
  91. }
  92. err = a.settingService.UpdateAllSetting(allSetting)
  93. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  94. }
  95. func (a *SettingController) updateUser(c *gin.Context) {
  96. form := &updateUserForm{}
  97. err := c.ShouldBind(form)
  98. if err != nil {
  99. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  100. return
  101. }
  102. user := session.GetLoginUser(c)
  103. if user.Username != form.OldUsername || user.Password != form.OldPassword {
  104. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), errors.New(I18nWeb(c, "pages.settings.toasts.originalUserPassIncorrect")))
  105. return
  106. }
  107. if form.NewUsername == "" || form.NewPassword == "" {
  108. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), errors.New(I18nWeb(c, "pages.settings.toasts.userPassMustBeNotEmpty")))
  109. return
  110. }
  111. err = a.userService.UpdateUser(user.Id, form.NewUsername, form.NewPassword)
  112. if err == nil {
  113. user.Username = form.NewUsername
  114. user.Password = form.NewPassword
  115. session.SetLoginUser(c, user)
  116. }
  117. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), err)
  118. }
  119. func (a *SettingController) restartPanel(c *gin.Context) {
  120. err := a.panelService.RestartPanel(time.Second * 3)
  121. jsonMsg(c, I18nWeb(c, "pages.settings.restartPanel"), err)
  122. }
  123. func (a *SettingController) updateSecret(c *gin.Context) {
  124. form := &updateSecretForm{}
  125. err := c.ShouldBind(form)
  126. if err != nil {
  127. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  128. }
  129. user := session.GetLoginUser(c)
  130. err = a.userService.UpdateUserSecret(user.Id, form.LoginSecret)
  131. if err == nil {
  132. user.LoginSecret = form.LoginSecret
  133. session.SetLoginUser(c, user)
  134. }
  135. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), err)
  136. }
  137. func (a *SettingController) getUserSecret(c *gin.Context) {
  138. loginUser := session.GetLoginUser(c)
  139. user := a.userService.GetUserSecret(loginUser.Id)
  140. if user != nil {
  141. jsonObj(c, user, nil)
  142. }
  143. }