mirror of
https://github.com/volatiletech/authboss.git
synced 2025-01-24 05:17:10 +02:00
1112987bce
- 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.
89 lines
2.1 KiB
Go
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
|
|
}
|