setting.go 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. package controller
  2. import (
  3. "errors"
  4. "strconv"
  5. "time"
  6. "github.com/mhsanaei/3x-ui/v3/util/crypto"
  7. "github.com/mhsanaei/3x-ui/v3/web/entity"
  8. "github.com/mhsanaei/3x-ui/v3/web/middleware"
  9. "github.com/mhsanaei/3x-ui/v3/web/service"
  10. "github.com/mhsanaei/3x-ui/v3/web/session"
  11. "github.com/gin-gonic/gin"
  12. )
  13. // updateUserForm represents the form for updating user credentials.
  14. type updateUserForm struct {
  15. OldUsername string `json:"oldUsername" form:"oldUsername"`
  16. OldPassword string `json:"oldPassword" form:"oldPassword"`
  17. NewUsername string `json:"newUsername" form:"newUsername"`
  18. NewPassword string `json:"newPassword" form:"newPassword"`
  19. }
  20. // SettingController handles settings and user management operations.
  21. type SettingController struct {
  22. settingService service.SettingService
  23. userService service.UserService
  24. panelService service.PanelService
  25. apiTokenService service.ApiTokenService
  26. }
  27. // NewSettingController creates a new SettingController and initializes its routes.
  28. func NewSettingController(g *gin.RouterGroup) *SettingController {
  29. a := &SettingController{}
  30. a.initRouter(g)
  31. return a
  32. }
  33. // initRouter sets up the routes for settings management.
  34. func (a *SettingController) initRouter(g *gin.RouterGroup) {
  35. g = g.Group("/setting")
  36. g.POST("/all", a.getAllSetting)
  37. g.POST("/defaultSettings", a.getDefaultSettings)
  38. g.POST("/update", a.updateSetting)
  39. g.POST("/updateUser", a.updateUser)
  40. g.POST("/restartPanel", a.restartPanel)
  41. g.GET("/getDefaultJsonConfig", a.getDefaultXrayConfig)
  42. g.GET("/apiTokens", a.listApiTokens)
  43. g.POST("/apiTokens/create", a.createApiToken)
  44. g.POST("/apiTokens/delete/:id", a.deleteApiToken)
  45. g.POST("/apiTokens/setEnabled/:id", a.setApiTokenEnabled)
  46. }
  47. // getAllSetting retrieves all current settings.
  48. func (a *SettingController) getAllSetting(c *gin.Context) {
  49. allSetting, err := a.settingService.GetAllSetting()
  50. if err != nil {
  51. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  52. return
  53. }
  54. jsonObj(c, allSetting, nil)
  55. }
  56. // getDefaultSettings retrieves the default settings based on the host.
  57. func (a *SettingController) getDefaultSettings(c *gin.Context) {
  58. result, err := a.settingService.GetDefaultSettings(c.Request.Host)
  59. if err != nil {
  60. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  61. return
  62. }
  63. jsonObj(c, result, nil)
  64. }
  65. // updateSetting updates all settings with the provided data.
  66. func (a *SettingController) updateSetting(c *gin.Context) {
  67. allSetting, ok := middleware.BindAndValidate[entity.AllSetting](c)
  68. if !ok {
  69. return
  70. }
  71. oldTwoFactor, twoFactorErr := a.settingService.GetTwoFactorEnable()
  72. err := a.settingService.UpdateAllSetting(allSetting)
  73. if err == nil && twoFactorErr == nil && !oldTwoFactor && allSetting.TwoFactorEnable {
  74. if bumpErr := a.userService.BumpLoginEpoch(); bumpErr != nil {
  75. err = bumpErr
  76. }
  77. }
  78. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  79. }
  80. // updateUser updates the current user's username and password.
  81. func (a *SettingController) updateUser(c *gin.Context) {
  82. form := &updateUserForm{}
  83. err := c.ShouldBind(form)
  84. if err != nil {
  85. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  86. return
  87. }
  88. user := session.GetLoginUser(c)
  89. if user.Username != form.OldUsername || !crypto.CheckPasswordHash(user.Password, form.OldPassword) {
  90. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUserError"), errors.New(I18nWeb(c, "pages.settings.toasts.originalUserPassIncorrect")))
  91. return
  92. }
  93. if form.NewUsername == "" || form.NewPassword == "" {
  94. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUserError"), errors.New(I18nWeb(c, "pages.settings.toasts.userPassMustBeNotEmpty")))
  95. return
  96. }
  97. err = a.userService.UpdateUser(user.Id, form.NewUsername, form.NewPassword)
  98. if err == nil {
  99. user.Username = form.NewUsername
  100. user.Password, _ = crypto.HashPasswordAsBcrypt(form.NewPassword)
  101. if saveErr := session.SetLoginUser(c, user); saveErr != nil {
  102. err = saveErr
  103. }
  104. }
  105. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifyUser"), err)
  106. }
  107. // restartPanel restarts the panel service after a delay.
  108. func (a *SettingController) restartPanel(c *gin.Context) {
  109. err := a.panelService.RestartPanel(time.Second * 3)
  110. jsonMsg(c, I18nWeb(c, "pages.settings.restartPanelSuccess"), err)
  111. }
  112. // getDefaultXrayConfig retrieves the default Xray configuration.
  113. func (a *SettingController) getDefaultXrayConfig(c *gin.Context) {
  114. defaultJsonConfig, err := a.settingService.GetDefaultXrayConfig()
  115. if err != nil {
  116. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  117. return
  118. }
  119. jsonObj(c, defaultJsonConfig, nil)
  120. }
  121. type apiTokenCreateForm struct {
  122. Name string `json:"name" form:"name"`
  123. }
  124. type apiTokenEnabledForm struct {
  125. Enabled bool `json:"enabled" form:"enabled"`
  126. }
  127. func (a *SettingController) listApiTokens(c *gin.Context) {
  128. rows, err := a.apiTokenService.List()
  129. if err != nil {
  130. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.getSettings"), err)
  131. return
  132. }
  133. jsonObj(c, rows, nil)
  134. }
  135. func (a *SettingController) createApiToken(c *gin.Context) {
  136. form := &apiTokenCreateForm{}
  137. if err := c.ShouldBind(form); err != nil {
  138. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  139. return
  140. }
  141. row, err := a.apiTokenService.Create(form.Name)
  142. if err != nil {
  143. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  144. return
  145. }
  146. jsonObj(c, row, nil)
  147. }
  148. func (a *SettingController) deleteApiToken(c *gin.Context) {
  149. id, err := strconv.Atoi(c.Param("id"))
  150. if err != nil {
  151. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  152. return
  153. }
  154. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), a.apiTokenService.Delete(id))
  155. }
  156. func (a *SettingController) setApiTokenEnabled(c *gin.Context) {
  157. id, err := strconv.Atoi(c.Param("id"))
  158. if err != nil {
  159. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), err)
  160. return
  161. }
  162. form := &apiTokenEnabledForm{}
  163. if bindErr := c.ShouldBind(form); bindErr != nil {
  164. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), bindErr)
  165. return
  166. }
  167. jsonMsg(c, I18nWeb(c, "pages.settings.toasts.modifySettings"), a.apiTokenService.SetEnabled(id, form.Enabled))
  168. }