oauth2_unlink.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  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. "log/slog"
  6. "net/http"
  7. "miniflux.app/v2/internal/config"
  8. "miniflux.app/v2/internal/http/request"
  9. "miniflux.app/v2/internal/http/response/html"
  10. "miniflux.app/v2/internal/http/route"
  11. "miniflux.app/v2/internal/locale"
  12. "miniflux.app/v2/internal/ui/session"
  13. )
  14. func (h *handler) oauth2Unlink(w http.ResponseWriter, r *http.Request) {
  15. if config.Opts.DisableLocalAuth() {
  16. slog.Warn("blocking oauth2 unlink attempt, local auth is disabled",
  17. slog.String("user_agent", r.UserAgent()),
  18. )
  19. html.Redirect(w, r, route.Path(h.router, "login"))
  20. return
  21. }
  22. printer := locale.NewPrinter(request.UserLanguage(r))
  23. provider := request.RouteStringParam(r, "provider")
  24. if provider == "" {
  25. slog.Warn("Invalid or missing OAuth2 provider")
  26. html.Redirect(w, r, route.Path(h.router, "login"))
  27. return
  28. }
  29. authProvider, err := getOAuth2Manager(r.Context()).FindProvider(provider)
  30. if err != nil {
  31. slog.Error("Unable to initialize OAuth2 provider",
  32. slog.String("provider", provider),
  33. slog.Any("error", err),
  34. )
  35. html.Redirect(w, r, route.Path(h.router, "settings"))
  36. return
  37. }
  38. sess := session.New(h.store, request.SessionID(r))
  39. user, err := h.store.UserByID(request.UserID(r))
  40. if err != nil {
  41. html.ServerError(w, r, err)
  42. return
  43. }
  44. hasPassword, err := h.store.HasPassword(request.UserID(r))
  45. if err != nil {
  46. html.ServerError(w, r, err)
  47. return
  48. }
  49. if !hasPassword {
  50. sess.NewFlashErrorMessage(printer.Print("error.unlink_account_without_password"))
  51. html.Redirect(w, r, route.Path(h.router, "settings"))
  52. return
  53. }
  54. authProvider.UnsetUserProfileID(user)
  55. if err := h.store.UpdateUser(user); err != nil {
  56. html.ServerError(w, r, err)
  57. return
  58. }
  59. sess.NewFlashMessage(printer.Print("alert.account_unlinked"))
  60. html.Redirect(w, r, route.Path(h.router, "settings"))
  61. }