aboutsummaryrefslogtreecommitdiffhomepage
path: root/oauth2
diff options
context:
space:
mode:
authorGravatar Frédéric Guillot <fred@miniflux.net>2018-01-02 22:04:48 -0800
committerGravatar Frédéric Guillot <fred@miniflux.net>2018-01-02 22:04:48 -0800
commit320d1b016747ba4501da9417d9ce5f99368a5768 (patch)
tree1054d96afde6022951b76cc4a09b78e1e3f05058 /oauth2
parentc39f2e1a8d2de6d412bcc673d29eb0f7a2d1f5f7 (diff)
Refactor packages to have more idiomatic code base
Diffstat (limited to 'oauth2')
-rw-r--r--oauth2/google.go74
-rw-r--r--oauth2/manager.go33
-rw-r--r--oauth2/profile.go12
-rw-r--r--oauth2/provider.go12
4 files changed, 131 insertions, 0 deletions
diff --git a/oauth2/google.go b/oauth2/google.go
new file mode 100644
index 0000000..e57e027
--- /dev/null
+++ b/oauth2/google.go
@@ -0,0 +1,74 @@
+// 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/oauth2/manager.go b/oauth2/manager.go
new file mode 100644
index 0000000..08360a9
--- /dev/null
+++ b/oauth2/manager.go
@@ -0,0 +1,33 @@
+// 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/oauth2/profile.go b/oauth2/profile.go
new file mode 100644
index 0000000..488ffb2
--- /dev/null
+++ b/oauth2/profile.go
@@ -0,0 +1,12 @@
+// 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/oauth2/provider.go b/oauth2/provider.go
new file mode 100644
index 0000000..c43931c
--- /dev/null
+++ b/oauth2/provider.go
@@ -0,0 +1,12 @@
+// 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)
+}