diff options
Diffstat (limited to 'server/oauth2')
-rw-r--r-- | server/oauth2/google.go | 74 | ||||
-rw-r--r-- | server/oauth2/manager.go | 33 | ||||
-rw-r--r-- | server/oauth2/profile.go | 12 | ||||
-rw-r--r-- | server/oauth2/provider.go | 12 |
4 files changed, 0 insertions, 131 deletions
diff --git a/server/oauth2/google.go b/server/oauth2/google.go deleted file mode 100644 index e57e027f..00000000 --- a/server/oauth2/google.go +++ /dev/null @@ -1,74 +0,0 @@ -// Copyright 2017 Frédéric Guillot. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package oauth2 - -import ( - "context" - "encoding/json" - "fmt" - - "golang.org/x/oauth2" -) - -type googleProfile struct { - Sub string `json:"sub"` - Email string `json:"email"` -} - -type googleProvider struct { - clientID string - clientSecret string - redirectURL string -} - -func (g googleProvider) GetUserExtraKey() string { - return "google_id" -} - -func (g googleProvider) GetRedirectURL(state string) string { - return g.config().AuthCodeURL(state) -} - -func (g googleProvider) GetProfile(code string) (*Profile, error) { - conf := g.config() - ctx := context.Background() - token, err := conf.Exchange(ctx, code) - if err != nil { - return nil, err - } - - client := conf.Client(ctx, token) - resp, err := client.Get("https://www.googleapis.com/oauth2/v3/userinfo") - if err != nil { - return nil, err - } - defer resp.Body.Close() - - var user googleProfile - decoder := json.NewDecoder(resp.Body) - if err := decoder.Decode(&user); err != nil { - return nil, fmt.Errorf("unable to unserialize google profile: %v", err) - } - - profile := &Profile{Key: g.GetUserExtraKey(), ID: user.Sub, Username: user.Email} - return profile, nil -} - -func (g googleProvider) config() *oauth2.Config { - return &oauth2.Config{ - RedirectURL: g.redirectURL, - ClientID: g.clientID, - ClientSecret: g.clientSecret, - Scopes: []string{"email"}, - Endpoint: oauth2.Endpoint{ - AuthURL: "https://accounts.google.com/o/oauth2/auth", - TokenURL: "https://accounts.google.com/o/oauth2/token", - }, - } -} - -func newGoogleProvider(clientID, clientSecret, redirectURL string) *googleProvider { - return &googleProvider{clientID: clientID, clientSecret: clientSecret, redirectURL: redirectURL} -} diff --git a/server/oauth2/manager.go b/server/oauth2/manager.go deleted file mode 100644 index 08360a97..00000000 --- a/server/oauth2/manager.go +++ /dev/null @@ -1,33 +0,0 @@ -// Copyright 2017 Frédéric Guillot. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package oauth2 - -import "errors" - -// Manager handles OAuth2 providers. -type Manager struct { - providers map[string]Provider -} - -// Provider returns the given provider. -func (m *Manager) Provider(name string) (Provider, error) { - if provider, found := m.providers[name]; found { - return provider, nil - } - - return nil, errors.New("oauth2 provider not found") -} - -// AddProvider add a new OAuth2 provider. -func (m *Manager) AddProvider(name string, provider Provider) { - m.providers[name] = provider -} - -// NewManager returns a new Manager. -func NewManager(clientID, clientSecret, redirectURL string) *Manager { - m := &Manager{providers: make(map[string]Provider)} - m.AddProvider("google", newGoogleProvider(clientID, clientSecret, redirectURL)) - return m -} diff --git a/server/oauth2/profile.go b/server/oauth2/profile.go deleted file mode 100644 index 488ffb29..00000000 --- a/server/oauth2/profile.go +++ /dev/null @@ -1,12 +0,0 @@ -// Copyright 2017 Frédéric Guillot. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package oauth2 - -// Profile is the OAuth2 user profile. -type Profile struct { - Key string - ID string - Username string -} diff --git a/server/oauth2/provider.go b/server/oauth2/provider.go deleted file mode 100644 index c43931c0..00000000 --- a/server/oauth2/provider.go +++ /dev/null @@ -1,12 +0,0 @@ -// Copyright 2017 Frédéric Guillot. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package oauth2 - -// Provider is an interface for OAuth2 providers. -type Provider interface { - GetUserExtraKey() string - GetRedirectURL(state string) string - GetProfile(code string) (*Profile, error) -} |