user_edit.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  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/html"
  8. "miniflux.app/v2/internal/ui/form"
  9. "miniflux.app/v2/internal/ui/session"
  10. "miniflux.app/v2/internal/ui/view"
  11. )
  12. // EditUser shows the form to edit a user.
  13. func (h *handler) showEditUserPage(w http.ResponseWriter, r *http.Request) {
  14. sess := session.New(h.store, request.SessionID(r))
  15. view := view.New(h.tpl, r, sess)
  16. user, err := h.store.UserByID(request.UserID(r))
  17. if err != nil {
  18. html.ServerError(w, r, err)
  19. return
  20. }
  21. if !user.IsAdmin {
  22. html.Forbidden(w, r)
  23. return
  24. }
  25. userID := request.RouteInt64Param(r, "userID")
  26. selectedUser, err := h.store.UserByID(userID)
  27. if err != nil {
  28. html.ServerError(w, r, err)
  29. return
  30. }
  31. if selectedUser == nil {
  32. html.NotFound(w, r)
  33. return
  34. }
  35. userForm := &form.UserForm{
  36. Username: selectedUser.Username,
  37. IsAdmin: selectedUser.IsAdmin,
  38. }
  39. view.Set("form", userForm)
  40. view.Set("selected_user", selectedUser)
  41. view.Set("menu", "settings")
  42. view.Set("user", user)
  43. view.Set("countUnread", h.store.CountUnreadEntries(user.ID))
  44. view.Set("countErrorFeeds", h.store.CountUserFeedsWithErrors(user.ID))
  45. html.OK(w, r, view.Render("edit_user"))
  46. }