setting.go 6.1 KB

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