user_remove.go 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  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. "errors"
  6. "net/http"
  7. "miniflux.app/v2/internal/http/request"
  8. "miniflux.app/v2/internal/http/response/html"
  9. "miniflux.app/v2/internal/http/route"
  10. )
  11. func (h *handler) removeUser(w http.ResponseWriter, r *http.Request) {
  12. loggedUser, err := h.store.UserByID(request.UserID(r))
  13. if err != nil {
  14. html.ServerError(w, r, err)
  15. return
  16. }
  17. if !loggedUser.IsAdmin {
  18. html.Forbidden(w, r)
  19. return
  20. }
  21. selectedUserID := request.RouteInt64Param(r, "userID")
  22. selectedUser, err := h.store.UserByID(selectedUserID)
  23. if err != nil {
  24. html.ServerError(w, r, err)
  25. return
  26. }
  27. if selectedUser == nil {
  28. html.NotFound(w, r)
  29. return
  30. }
  31. if selectedUser.ID == loggedUser.ID {
  32. html.BadRequest(w, r, errors.New("you cannot remove yourself"))
  33. return
  34. }
  35. if err := h.store.RemoveUser(selectedUser.ID); err != nil {
  36. html.ServerError(w, r, err)
  37. return
  38. }
  39. html.Redirect(w, r, route.Path(h.router, "users"))
  40. }