diff options
author | techknowlogick <techknowlogick@gitea.io> | 2019-09-14 06:02:39 -0400 |
---|---|---|
committer | Antoine GIRARD <sapk@users.noreply.github.com> | 2019-09-14 12:02:39 +0200 |
commit | 7a8e299c7c7b4f83b8280ab2b069ddaed9f34d0f (patch) | |
tree | 4faf85c56ea34c5dcbf59f09e3a76ba41194ce94 /vendor/github.com/markbates | |
parent | 107d57a9256cdfbbb4f59665ea08311e14eb59de (diff) | |
download | gitea-7a8e299c7c7b4f83b8280ab2b069ddaed9f34d0f.tar.gz gitea-7a8e299c7c7b4f83b8280ab2b069ddaed9f34d0f.zip |
migrate gplus to google oauth2 provider (#7885)
* migrate gplus to google oauth2 provider. this still provides support for old gplus connections.
* Update models/oauth2.go
Co-Authored-By: Antoine GIRARD <sapk@users.noreply.github.com>
* make vendor
Diffstat (limited to 'vendor/github.com/markbates')
-rw-r--r-- | vendor/github.com/markbates/goth/providers/google/endpoint.go | 10 | ||||
-rw-r--r-- | vendor/github.com/markbates/goth/providers/google/endpoint_legacy.go | 13 | ||||
-rw-r--r-- | vendor/github.com/markbates/goth/providers/google/google.go (renamed from vendor/github.com/markbates/goth/providers/gplus/gplus.go) | 89 | ||||
-rw-r--r-- | vendor/github.com/markbates/goth/providers/google/session.go (renamed from vendor/github.com/markbates/goth/providers/gplus/session.go) | 8 |
4 files changed, 64 insertions, 56 deletions
diff --git a/vendor/github.com/markbates/goth/providers/google/endpoint.go b/vendor/github.com/markbates/goth/providers/google/endpoint.go new file mode 100644 index 0000000000..90067bed26 --- /dev/null +++ b/vendor/github.com/markbates/goth/providers/google/endpoint.go @@ -0,0 +1,10 @@ +// +build go1.9 + +package google + +import ( + goog "golang.org/x/oauth2/google" +) + +// Endpoint is Google's OAuth 2.0 endpoint. +var Endpoint = goog.Endpoint diff --git a/vendor/github.com/markbates/goth/providers/google/endpoint_legacy.go b/vendor/github.com/markbates/goth/providers/google/endpoint_legacy.go new file mode 100644 index 0000000000..f9fbee7911 --- /dev/null +++ b/vendor/github.com/markbates/goth/providers/google/endpoint_legacy.go @@ -0,0 +1,13 @@ +// +build !go1.9 + +package google + +import ( + "golang.org/x/oauth2" +) + +// Endpoint is Google's OAuth 2.0 endpoint. +var Endpoint = oauth2.Endpoint{ + AuthURL: "https://accounts.google.com/o/oauth2/auth", + TokenURL: "https://accounts.google.com/o/oauth2/token", +} diff --git a/vendor/github.com/markbates/goth/providers/gplus/gplus.go b/vendor/github.com/markbates/goth/providers/google/google.go index 4726aa349e..33c7b86ce1 100644 --- a/vendor/github.com/markbates/goth/providers/gplus/gplus.go +++ b/vendor/github.com/markbates/goth/providers/google/google.go @@ -1,42 +1,36 @@ -// Package gplus implements the OAuth2 protocol for authenticating users through Google+. -// This package can be used as a reference implementation of an OAuth2 provider for Goth. -package gplus +// Package google implements the OAuth2 protocol for authenticating users +// through Google. +package google import ( - "bytes" "encoding/json" - "io" + "fmt" "io/ioutil" "net/http" "net/url" "strings" - "fmt" "github.com/markbates/goth" "golang.org/x/oauth2" ) -const ( - authURL string = "https://accounts.google.com/o/oauth2/auth?access_type=offline" - tokenURL string = "https://accounts.google.com/o/oauth2/token" - endpointProfile string = "https://www.googleapis.com/oauth2/v2/userinfo" -) +const endpointProfile string = "https://www.googleapis.com/oauth2/v2/userinfo" -// New creates a new Google+ provider, and sets up important connection details. -// You should always call `gplus.New` to get a new Provider. Never try to create +// New creates a new Google provider, and sets up important connection details. +// You should always call `google.New` to get a new Provider. Never try to create // one manually. func New(clientKey, secret, callbackURL string, scopes ...string) *Provider { p := &Provider{ ClientKey: clientKey, Secret: secret, CallbackURL: callbackURL, - providerName: "gplus", + providerName: "google", } p.config = newConfig(p, scopes) return p } -// Provider is the implementation of `goth.Provider` for accessing Google+. +// Provider is the implementation of `goth.Provider` for accessing Google. type Provider struct { ClientKey string Secret string @@ -57,14 +51,15 @@ func (p *Provider) SetName(name string) { p.providerName = name } +// Client returns an HTTP client to be used in all fetch operations. func (p *Provider) Client() *http.Client { return goth.HTTPClientWithFallBack(p.HTTPClient) } -// Debug is a no-op for the gplus package. +// Debug is a no-op for the google package. func (p *Provider) Debug(debug bool) {} -// BeginAuth asks Google+ for an authentication end-point. +// BeginAuth asks Google for an authentication endpoint. func (p *Provider) BeginAuth(state string) (goth.Session, error) { var opts []oauth2.AuthCodeOption if p.prompt != nil { @@ -77,7 +72,17 @@ func (p *Provider) BeginAuth(state string) (goth.Session, error) { return session, nil } -// FetchUser will go to Google+ and access basic information about the user. +type googleUser struct { + ID string `json:"id"` + Email string `json:"email"` + Name string `json:"name"` + FirstName string `json:"given_name"` + LastName string `json:"family_name"` + Link string `json:"link"` + Picture string `json:"picture"` +} + +// FetchUser will go to Google and access basic information about the user. func (p *Provider) FetchUser(session goth.Session) (goth.User, error) { sess := session.(*Session) user := goth.User{ @@ -88,7 +93,7 @@ func (p *Provider) FetchUser(session goth.Session) (goth.User, error) { } if user.AccessToken == "" { - // data is not yet retrieved since accessToken is still empty + // Data is not yet retrieved, since accessToken is still empty. return user, fmt.Errorf("%s cannot get user information without accessToken", p.providerName) } @@ -102,47 +107,30 @@ func (p *Provider) FetchUser(session goth.Session) (goth.User, error) { return user, fmt.Errorf("%s responded with a %d trying to fetch user information", p.providerName, response.StatusCode) } - bits, err := ioutil.ReadAll(response.Body) + responseBytes, err := ioutil.ReadAll(response.Body) if err != nil { return user, err } - err = json.NewDecoder(bytes.NewReader(bits)).Decode(&user.RawData) - if err != nil { + var u googleUser + if err := json.Unmarshal(responseBytes, &u); err != nil { return user, err } - err = userFromReader(bytes.NewReader(bits), &user) - return user, err -} - -func userFromReader(reader io.Reader, user *goth.User) error { - u := struct { - ID string `json:"id"` - Email string `json:"email"` - Name string `json:"name"` - FirstName string `json:"given_name"` - LastName string `json:"family_name"` - Link string `json:"link"` - Picture string `json:"picture"` - }{} - - err := json.NewDecoder(reader).Decode(&u) - if err != nil { - return err - } - + // Extract the user data we got from Google into our goth.User. user.Name = u.Name user.FirstName = u.FirstName user.LastName = u.LastName user.NickName = u.Name user.Email = u.Email - //user.Description = u.Bio user.AvatarURL = u.Picture user.UserID = u.ID - //user.Location = u.Location.Name + // Google provides other useful fields such as 'hd'; get them from RawData + if err := json.Unmarshal(responseBytes, &user.RawData); err != nil { + return user, err + } - return err + return user, nil } func newConfig(provider *Provider, scopes []string) *oauth2.Config { @@ -150,11 +138,8 @@ func newConfig(provider *Provider, scopes []string) *oauth2.Config { ClientID: provider.ClientKey, ClientSecret: provider.Secret, RedirectURL: provider.CallbackURL, - Endpoint: oauth2.Endpoint{ - AuthURL: authURL, - TokenURL: tokenURL, - }, - Scopes: []string{}, + Endpoint: Endpoint, + Scopes: []string{}, } if len(scopes) > 0 { @@ -162,7 +147,7 @@ func newConfig(provider *Provider, scopes []string) *oauth2.Config { c.Scopes = append(c.Scopes, scope) } } else { - c.Scopes = []string{"profile", "email", "openid"} + c.Scopes = []string{"email"} } return c } @@ -183,7 +168,7 @@ func (p *Provider) RefreshToken(refreshToken string) (*oauth2.Token, error) { return newToken, err } -// SetPrompt sets the prompt values for the GPlus OAuth call. Use this to +// SetPrompt sets the prompt values for the google OAuth call. Use this to // force users to choose and account every time by passing "select_account", // for example. // See https://developers.google.com/identity/protocols/OpenIDConnect#authenticationuriparameters diff --git a/vendor/github.com/markbates/goth/providers/gplus/session.go b/vendor/github.com/markbates/goth/providers/google/session.go index 9710031f4d..47df1601bc 100644 --- a/vendor/github.com/markbates/goth/providers/gplus/session.go +++ b/vendor/github.com/markbates/goth/providers/google/session.go @@ -1,4 +1,4 @@ -package gplus +package google import ( "encoding/json" @@ -9,7 +9,7 @@ import ( "github.com/markbates/goth" ) -// Session stores data during the auth process with Google+. +// Session stores data during the auth process with Google. type Session struct { AuthURL string AccessToken string @@ -17,7 +17,7 @@ type Session struct { ExpiresAt time.Time } -// GetAuthURL will return the URL set by calling the `BeginAuth` function on the Google+ provider. +// GetAuthURL will return the URL set by calling the `BeginAuth` function on the Google provider. func (s Session) GetAuthURL() (string, error) { if s.AuthURL == "" { return "", errors.New(goth.NoAuthUrlErrorMessage) @@ -25,7 +25,7 @@ func (s Session) GetAuthURL() (string, error) { return s.AuthURL, nil } -// Authorize the session with Google+ and return the access token to be stored for future use. +// Authorize the session with Google and return the access token to be stored for future use. func (s *Session) Authorize(provider goth.Provider, params goth.Params) (string, error) { p := provider.(*Provider) token, err := p.config.Exchange(goth.ContextForClient(p.Client()), params.Get("code")) |