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. provider := request.RouteStringParam(r, "provider")
  23. if provider == "" {
  24. slog.Warn("Invalid or missing OAuth2 provider")
  25. html.Redirect(w, r, route.Path(h.router, "login"))
  26. return
  27. }
  28. authProvider, err := getOAuth2Manager(r.Context()).FindProvider(provider)
  29. if err != nil {
  30. slog.Error("Unable to initialize OAuth2 provider",
  31. slog.String("provider", provider),
  32. slog.Any("error", err),
  33. )
  34. html.Redirect(w, r, route.Path(h.router, "settings"))
  35. return
  36. }
  37. user, err := h.store.UserByID(request.UserID(r))
  38. if err != nil {
  39. html.ServerError(w, r, err)
  40. return
  41. }
  42. hasPassword, err := h.store.HasPassword(request.UserID(r))
  43. if err != nil {
  44. html.ServerError(w, r, err)
  45. return
  46. }
  47. sess := session.New(h.store, request.SessionID(r))
  48. printer := locale.NewPrinter(request.UserLanguage(r))
  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. }