user_update.go 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
  2. // SPDX-License-Identifier: Apache-2.0
  3. package ui // import "miniflux.app/v2/internal/ui"
  4. import (
  5. "net/http"
  6. "miniflux.app/v2/internal/http/request"
  7. "miniflux.app/v2/internal/http/response"
  8. "miniflux.app/v2/internal/locale"
  9. "miniflux.app/v2/internal/ui/form"
  10. "miniflux.app/v2/internal/ui/session"
  11. "miniflux.app/v2/internal/ui/view"
  12. )
  13. func (h *handler) updateUser(w http.ResponseWriter, r *http.Request) {
  14. loggedUser, err := h.store.UserByID(request.UserID(r))
  15. if err != nil {
  16. response.HTMLServerError(w, r, err)
  17. return
  18. }
  19. if !loggedUser.IsAdmin {
  20. response.HTMLForbidden(w, r)
  21. return
  22. }
  23. userID := request.RouteInt64Param(r, "userID")
  24. selectedUser, err := h.store.UserByID(userID)
  25. if err != nil {
  26. response.HTMLServerError(w, r, err)
  27. return
  28. }
  29. if selectedUser == nil {
  30. response.HTMLNotFound(w, r)
  31. return
  32. }
  33. userForm := form.NewUserForm(r)
  34. sess := session.New(h.store, request.SessionID(r))
  35. view := view.New(h.tpl, r, sess)
  36. view.Set("menu", "settings")
  37. view.Set("user", loggedUser)
  38. view.Set("countUnread", h.store.CountUnreadEntries(loggedUser.ID))
  39. view.Set("countErrorFeeds", h.store.CountUserFeedsWithErrors(loggedUser.ID))
  40. view.Set("selected_user", selectedUser)
  41. view.Set("form", userForm)
  42. if validationErr := userForm.ValidateModification(); validationErr != nil {
  43. view.Set("errorMessage", validationErr.Translate(loggedUser.Language))
  44. response.HTML(w, r, view.Render("edit_user"))
  45. return
  46. }
  47. if h.store.AnotherUserExists(selectedUser.ID, userForm.Username) {
  48. view.Set("errorMessage", locale.NewLocalizedError("error.user_already_exists").Translate(loggedUser.Language))
  49. response.HTML(w, r, view.Render("edit_user"))
  50. return
  51. }
  52. userForm.Merge(selectedUser)
  53. if err := h.store.UpdateUser(selectedUser); err != nil {
  54. response.HTMLServerError(w, r, err)
  55. return
  56. }
  57. response.HTMLRedirect(w, r, h.routePath("/users"))
  58. }