aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/github.com/markbates/goth/providers/openidConnect/session.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/markbates/goth/providers/openidConnect/session.go')
-rw-r--r--vendor/github.com/markbates/goth/providers/openidConnect/session.go63
1 files changed, 63 insertions, 0 deletions
diff --git a/vendor/github.com/markbates/goth/providers/openidConnect/session.go b/vendor/github.com/markbates/goth/providers/openidConnect/session.go
new file mode 100644
index 0000000000..a34584fdef
--- /dev/null
+++ b/vendor/github.com/markbates/goth/providers/openidConnect/session.go
@@ -0,0 +1,63 @@
+package openidConnect
+
+import (
+ "errors"
+ "github.com/markbates/goth"
+ "encoding/json"
+ "strings"
+ "time"
+ "golang.org/x/oauth2"
+)
+
+// Session stores data during the auth process with the OpenID Connect provider.
+type Session struct {
+ AuthURL string
+ AccessToken string
+ RefreshToken string
+ ExpiresAt time.Time
+ IDToken string
+}
+
+// GetAuthURL will return the URL set by calling the `BeginAuth` function on the OpenID Connect provider.
+func (s Session) GetAuthURL() (string, error) {
+ if s.AuthURL == "" {
+ return "", errors.New("an AuthURL has not be set")
+ }
+ return s.AuthURL, nil
+}
+
+// Authorize the session with the OpenID Connect provider 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(oauth2.NoContext, params.Get("code"))
+ if err != nil {
+ return "", err
+ }
+
+ if !token.Valid() {
+ return "", errors.New("Invalid token received from provider")
+ }
+
+ s.AccessToken = token.AccessToken
+ s.RefreshToken = token.RefreshToken
+ s.ExpiresAt = token.Expiry
+ s.IDToken = token.Extra("id_token").(string)
+ return token.AccessToken, err
+}
+
+// Marshal the session into a string
+func (s Session) Marshal() string {
+ b, _ := json.Marshal(s)
+ return string(b)
+}
+
+func (s Session) String() string {
+ return s.Marshal()
+}
+
+// UnmarshalSession will unmarshal a JSON string into a session.
+func (p *Provider) UnmarshalSession(data string) (goth.Session, error) {
+ sess := &Session{}
+ err := json.NewDecoder(strings.NewReader(data)).Decode(sess)
+ return sess, err
+}