1
0
mirror of https://github.com/volatiletech/authboss.git synced 2025-01-24 05:17:10 +02:00
authboss/oauth2/providers.go
Aaron L 1112987bce Rewrite oauth module
- Tried to be clear about OAuth2 vs OAuth in all places.
- Allow users to be locked from OAuth logins (if done manually for some
  reason other than failed logins)
- Cleaned up some docs and wording around the previously very confusing
  (now hopefully only somewhat confusing) oauth2 module.
2018-03-08 18:39:51 -08:00

89 lines
2.1 KiB
Go

package oauth2
import (
"context"
"encoding/json"
"io/ioutil"
"net/http"
"github.com/pkg/errors"
"golang.org/x/oauth2"
)
// Constants for returning in the FindUserDetails call
const (
OAuth2UID = "uid"
OAuth2Email = "email"
OAuth2Name = "name"
)
const (
googleInfoEndpoint = `https://www.googleapis.com/userinfo/v2/me`
facebookInfoEndpoint = `https://graph.facebook.com/me?fields=name,email`
)
type googleMeResponse struct {
ID string `json:"id"`
Email string `json:"email"`
}
// testing
var clientGet = (*http.Client).Get
// GoogleUserDetails can be used as a FindUserDetails function for an authboss.OAuth2Provider
func GoogleUserDetails(ctx context.Context, cfg oauth2.Config, token *oauth2.Token) (map[string]string, error) {
client := cfg.Client(ctx, token)
resp, err := clientGet(client, googleInfoEndpoint)
if err != nil {
return nil, err
}
defer resp.Body.Close()
byt, err := ioutil.ReadAll(resp.Body)
if err != nil {
return nil, errors.Wrap(err, "failed to read body from google oauth2 endpoint")
}
var response googleMeResponse
if err = json.Unmarshal(byt, &response); err != nil {
return nil, err
}
return map[string]string{
OAuth2UID: response.ID,
OAuth2Email: response.Email,
}, nil
}
type facebookMeResponse struct {
ID string `json:"id"`
Email string `json:"email"`
Name string `json:"name"`
}
// FacebookUserDetails can be used as a FindUserDetails function for an authboss.OAuth2Provider
func FacebookUserDetails(ctx context.Context, cfg oauth2.Config, token *oauth2.Token) (map[string]string, error) {
client := cfg.Client(ctx, token)
resp, err := clientGet(client, facebookInfoEndpoint)
if err != nil {
return nil, err
}
defer resp.Body.Close()
byt, err := ioutil.ReadAll(resp.Body)
if err != nil {
return nil, errors.Wrap(err, "failed to read body from facebook oauth2 endpoint")
}
var response facebookMeResponse
if err = json.Unmarshal(byt, &response); err != nil {
return nil, errors.Wrap(err, "failed to parse json from facebook oauth2 endpoint")
}
return map[string]string{
OAuth2UID: response.ID,
OAuth2Email: response.Email,
OAuth2Name: response.Name,
}, nil
}