oauth2_redirect.go 1.0 KB

123456789101112131415161718192021222324252627282930313233343536
  1. // Copyright 2017 Frédéric Guillot. All rights reserved.
  2. // Use of this source code is governed by the Apache 2.0
  3. // license that can be found in the LICENSE file.
  4. package ui // import "miniflux.app/ui"
  5. import (
  6. "net/http"
  7. "miniflux.app/http/request"
  8. "miniflux.app/http/response"
  9. "miniflux.app/http/route"
  10. "miniflux.app/logger"
  11. "miniflux.app/ui/session"
  12. )
  13. // OAuth2Redirect redirects the user to the consent page to ask for permission.
  14. func (c *Controller) OAuth2Redirect(w http.ResponseWriter, r *http.Request) {
  15. sess := session.New(c.store, request.SessionID(r))
  16. provider := request.Param(r, "provider", "")
  17. if provider == "" {
  18. logger.Error("[OAuth2] Invalid or missing provider: %s", provider)
  19. response.Redirect(w, r, route.Path(c.router, "login"))
  20. return
  21. }
  22. authProvider, err := getOAuth2Manager(c.cfg).Provider(provider)
  23. if err != nil {
  24. logger.Error("[OAuth2] %v", err)
  25. response.Redirect(w, r, route.Path(c.router, "login"))
  26. return
  27. }
  28. response.Redirect(w, r, authProvider.GetRedirectURL(sess.NewOAuth2State()))
  29. }