x/auth/auth.go
2019-09-29 11:26:11 -07:00

41 lines
764 B
Go

package auth
import (
"context"
"log"
"golang.org/x/oauth2"
oidc "github.com/coreos/go-oidc"
)
type Authenticator struct {
Provider *oidc.Provider
Config oauth2.Config
Ctx context.Context
}
func NewAuthenticator(domain, clientID, clientSecret, callback string) (*Authenticator, error) {
ctx := context.Background()
provider, err := oidc.NewProvider(ctx, domain)
if err != nil {
log.Printf("failed to get provider: %v", err)
return nil, err
}
conf := oauth2.Config{
ClientID: clientID,
ClientSecret: clientSecret,
RedirectURL: callback,
Endpoint: provider.Endpoint(),
Scopes: []string{oidc.ScopeOpenID, "profile"},
}
return &Authenticator{
Provider: provider,
Config: conf,
Ctx: ctx,
}, nil
}