grafana/pkg/social/social.go

171 lines
4.5 KiB
Go
Raw Normal View History

2014-10-07 14:54:38 -05:00
package social
import (
"net/http"
2014-10-07 14:54:38 -05:00
"strings"
"context"
2014-12-30 03:10:13 -06:00
"golang.org/x/oauth2"
2018-01-18 16:17:51 -06:00
"github.com/grafana/grafana/pkg/log"
"github.com/grafana/grafana/pkg/setting"
"github.com/grafana/grafana/pkg/util"
2014-10-07 14:54:38 -05:00
)
type BasicUserInfo struct {
Id string
2016-12-13 21:15:35 -06:00
Name string
Email string
Login string
Company string
Role string
2014-10-07 14:54:38 -05:00
}
type SocialConnector interface {
Type() int
2018-01-18 16:17:51 -06:00
UserInfo(client *http.Client, token *oauth2.Token) (*BasicUserInfo, error)
IsEmailAllowed(email string) bool
IsSignupAllowed() bool
2014-10-07 14:54:38 -05:00
2014-12-30 03:10:13 -06:00
AuthCodeURL(state string, opts ...oauth2.AuthCodeOption) string
Exchange(ctx context.Context, code string) (*oauth2.Token, error)
Client(ctx context.Context, t *oauth2.Token) *http.Client
2014-10-07 14:54:38 -05:00
}
2018-01-18 16:17:51 -06:00
type SocialBase struct {
*oauth2.Config
log log.Logger
}
type Error struct {
s string
}
func (e *Error) Error() string {
return e.s
}
2014-10-07 14:54:38 -05:00
var (
2014-10-07 16:56:37 -05:00
SocialBaseUrl = "/login/"
2014-10-07 14:54:38 -05:00
SocialMap = make(map[string]SocialConnector)
)
2014-10-07 16:56:37 -05:00
func NewOAuthService() {
2014-10-07 14:54:38 -05:00
setting.OAuthService = &setting.OAuther{}
setting.OAuthService.OAuthInfos = make(map[string]*setting.OAuthInfo)
allOauthes := []string{"github", "google", "generic_oauth", "grafananet", "grafana_com"}
2014-10-07 14:54:38 -05:00
for _, name := range allOauthes {
sec := setting.Raw.Section("auth." + name)
2014-10-07 14:54:38 -05:00
info := &setting.OAuthInfo{
ClientId: sec.Key("client_id").String(),
ClientSecret: sec.Key("client_secret").String(),
Scopes: util.SplitString(sec.Key("scopes").String()),
AuthUrl: sec.Key("auth_url").String(),
TokenUrl: sec.Key("token_url").String(),
ApiUrl: sec.Key("api_url").String(),
Enabled: sec.Key("enabled").MustBool(),
AllowedDomains: util.SplitString(sec.Key("allowed_domains").String()),
HostedDomain: sec.Key("hosted_domain").String(),
AllowSignup: sec.Key("allow_sign_up").MustBool(),
2016-09-28 08:10:50 -05:00
Name: sec.Key("name").MustString(name),
TlsClientCert: sec.Key("tls_client_cert").String(),
TlsClientKey: sec.Key("tls_client_key").String(),
TlsClientCa: sec.Key("tls_client_ca").String(),
TlsSkipVerify: sec.Key("tls_skip_verify_insecure").MustBool(),
2014-10-07 16:56:37 -05:00
}
if !info.Enabled {
continue
2014-10-07 14:54:38 -05:00
}
if name == "grafananet" {
name = "grafana_com"
}
2014-10-07 14:54:38 -05:00
setting.OAuthService.OAuthInfos[name] = info
2014-12-30 03:10:13 -06:00
config := oauth2.Config{
ClientID: info.ClientId,
ClientSecret: info.ClientSecret,
Endpoint: oauth2.Endpoint{
AuthURL: info.AuthUrl,
TokenURL: info.TokenUrl,
},
RedirectURL: strings.TrimSuffix(setting.AppUrl, "/") + SocialBaseUrl + name,
Scopes: info.Scopes,
2014-10-07 14:54:38 -05:00
}
logger := log.New("oauth." + name)
2018-01-18 16:17:51 -06:00
2014-10-07 16:56:37 -05:00
// GitHub.
if name == "github" {
2015-04-29 02:49:22 -05:00
SocialMap["github"] = &SocialGithub{
2018-01-18 18:17:05 -06:00
SocialBase: &SocialBase{
Config: &config,
log: logger,
2018-01-18 16:17:51 -06:00
},
2015-05-23 09:06:51 -05:00
allowedDomains: info.AllowedDomains,
apiUrl: info.ApiUrl,
allowSignup: info.AllowSignup,
2016-09-28 08:10:50 -05:00
teamIds: sec.Key("team_ids").Ints(","),
allowedOrganizations: util.SplitString(sec.Key("allowed_organizations").String()),
2015-04-29 02:49:22 -05:00
}
2014-10-07 16:56:37 -05:00
}
2014-10-07 14:54:38 -05:00
2014-10-07 16:56:37 -05:00
// Google.
if name == "google" {
2015-04-29 02:49:22 -05:00
SocialMap["google"] = &SocialGoogle{
2018-01-18 18:17:05 -06:00
SocialBase: &SocialBase{
Config: &config,
log: logger,
2018-01-18 16:17:51 -06:00
},
2016-12-13 21:15:35 -06:00
allowedDomains: info.AllowedDomains,
hostedDomain: info.HostedDomain,
apiUrl: info.ApiUrl,
allowSignup: info.AllowSignup,
2015-04-29 02:49:22 -05:00
}
2014-10-07 16:56:37 -05:00
}
// Generic - Uses the same scheme as Github.
if name == "generic_oauth" {
2018-01-18 16:17:51 -06:00
SocialMap["generic_oauth"] = &SocialGenericOAuth{
2018-01-18 18:17:05 -06:00
SocialBase: &SocialBase{
Config: &config,
log: logger,
2018-01-18 16:17:51 -06:00
},
allowedDomains: info.AllowedDomains,
apiUrl: info.ApiUrl,
allowSignup: info.AllowSignup,
2016-09-28 08:10:50 -05:00
teamIds: sec.Key("team_ids").Ints(","),
allowedOrganizations: util.SplitString(sec.Key("allowed_organizations").String()),
}
}
if name == "grafana_com" {
config = oauth2.Config{
ClientID: info.ClientId,
ClientSecret: info.ClientSecret,
2016-12-13 21:15:35 -06:00
Endpoint: oauth2.Endpoint{
AuthURL: setting.GrafanaComUrl + "/oauth2/authorize",
TokenURL: setting.GrafanaComUrl + "/api/oauth2/token",
},
2016-12-13 21:15:35 -06:00
RedirectURL: strings.TrimSuffix(setting.AppUrl, "/") + SocialBaseUrl + name,
Scopes: info.Scopes,
}
SocialMap["grafana_com"] = &SocialGrafanaCom{
2018-01-18 18:17:05 -06:00
SocialBase: &SocialBase{
Config: &config,
log: logger,
2018-01-18 16:17:51 -06:00
},
url: setting.GrafanaComUrl,
allowSignup: info.AllowSignup,
allowedOrganizations: util.SplitString(sec.Key("allowed_organizations").String()),
}
}
2014-10-07 14:54:38 -05:00
}
}