integration_pocket.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  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/integration/pocket"
  12. "miniflux.app/v2/internal/locale"
  13. "miniflux.app/v2/internal/ui/session"
  14. )
  15. func (h *handler) pocketAuthorize(w http.ResponseWriter, r *http.Request) {
  16. printer := locale.NewPrinter(request.UserLanguage(r))
  17. user, err := h.store.UserByID(request.UserID(r))
  18. if err != nil {
  19. html.ServerError(w, r, err)
  20. return
  21. }
  22. integration, err := h.store.Integration(user.ID)
  23. if err != nil {
  24. html.ServerError(w, r, err)
  25. return
  26. }
  27. sess := session.New(h.store, request.SessionID(r))
  28. connector := pocket.NewConnector(config.Opts.PocketConsumerKey(integration.PocketConsumerKey))
  29. redirectURL := config.Opts.RootURL() + route.Path(h.router, "pocketCallback")
  30. requestToken, err := connector.RequestToken(redirectURL)
  31. if err != nil {
  32. slog.Warn("Pocket authorization request failed",
  33. slog.Any("user_id", user.ID),
  34. slog.Any("error", err),
  35. )
  36. sess.NewFlashErrorMessage(printer.Printf("error.pocket_request_token"))
  37. html.Redirect(w, r, route.Path(h.router, "integrations"))
  38. return
  39. }
  40. sess.SetPocketRequestToken(requestToken)
  41. html.Redirect(w, r, connector.AuthorizationURL(requestToken, redirectURL))
  42. }
  43. func (h *handler) pocketCallback(w http.ResponseWriter, r *http.Request) {
  44. printer := locale.NewPrinter(request.UserLanguage(r))
  45. sess := session.New(h.store, request.SessionID(r))
  46. user, err := h.store.UserByID(request.UserID(r))
  47. if err != nil {
  48. html.ServerError(w, r, err)
  49. return
  50. }
  51. integration, err := h.store.Integration(user.ID)
  52. if err != nil {
  53. html.ServerError(w, r, err)
  54. return
  55. }
  56. connector := pocket.NewConnector(config.Opts.PocketConsumerKey(integration.PocketConsumerKey))
  57. accessToken, err := connector.AccessToken(request.PocketRequestToken(r))
  58. if err != nil {
  59. slog.Warn("Unable to get Pocket access token",
  60. slog.Any("user_id", user.ID),
  61. slog.Any("error", err),
  62. )
  63. sess.NewFlashErrorMessage(printer.Printf("error.pocket_access_token"))
  64. html.Redirect(w, r, route.Path(h.router, "integrations"))
  65. return
  66. }
  67. sess.SetPocketRequestToken("")
  68. integration.PocketAccessToken = accessToken
  69. err = h.store.UpdateIntegration(integration)
  70. if err != nil {
  71. html.ServerError(w, r, err)
  72. return
  73. }
  74. sess.NewFlashMessage(printer.Printf("alert.pocket_linked"))
  75. html.Redirect(w, r, route.Path(h.router, "integrations"))
  76. }