2021-02-21 22:33:53 +08:00
|
|
|
// Copyright 2021 The casbin Authors. All Rights Reserved.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package idp
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
2021-12-10 00:55:27 +08:00
|
|
|
"strings"
|
2021-02-21 22:33:53 +08:00
|
|
|
|
|
|
|
"golang.org/x/oauth2"
|
|
|
|
)
|
|
|
|
|
2021-03-23 23:23:59 +08:00
|
|
|
type UserInfo struct {
|
2021-05-31 00:13:38 +08:00
|
|
|
Id string
|
|
|
|
Username string
|
|
|
|
DisplayName string
|
|
|
|
Email string
|
|
|
|
AvatarUrl string
|
2021-03-23 23:23:59 +08:00
|
|
|
}
|
|
|
|
|
2021-02-21 22:33:53 +08:00
|
|
|
type IdProvider interface {
|
2021-03-23 23:23:59 +08:00
|
|
|
SetHttpClient(client *http.Client)
|
|
|
|
GetToken(code string) (*oauth2.Token, error)
|
|
|
|
GetUserInfo(token *oauth2.Token) (*UserInfo, error)
|
2021-02-21 22:33:53 +08:00
|
|
|
}
|
|
|
|
|
2021-03-23 23:23:59 +08:00
|
|
|
func GetIdProvider(providerType string, clientId string, clientSecret string, redirectUrl string) IdProvider {
|
2021-03-28 20:20:40 +08:00
|
|
|
if providerType == "GitHub" {
|
2021-03-23 23:23:59 +08:00
|
|
|
return NewGithubIdProvider(clientId, clientSecret, redirectUrl)
|
2021-03-28 20:20:40 +08:00
|
|
|
} else if providerType == "Google" {
|
2021-03-23 23:23:59 +08:00
|
|
|
return NewGoogleIdProvider(clientId, clientSecret, redirectUrl)
|
2021-03-28 20:20:40 +08:00
|
|
|
} else if providerType == "QQ" {
|
2021-03-23 23:23:59 +08:00
|
|
|
return NewQqIdProvider(clientId, clientSecret, redirectUrl)
|
2021-05-17 14:17:46 +08:00
|
|
|
} else if providerType == "WeChat" {
|
|
|
|
return NewWeChatIdProvider(clientId, clientSecret, redirectUrl)
|
2021-06-06 10:06:54 +08:00
|
|
|
} else if providerType == "Facebook" {
|
|
|
|
return NewFacebookIdProvider(clientId, clientSecret, redirectUrl)
|
2021-06-09 11:15:49 +08:00
|
|
|
} else if providerType == "DingTalk" {
|
|
|
|
return NewDingTalkIdProvider(clientId, clientSecret, redirectUrl)
|
2021-06-10 16:55:31 +08:00
|
|
|
} else if providerType == "Weibo" {
|
|
|
|
return NewWeiBoIdProvider(clientId, clientSecret, redirectUrl)
|
2021-06-14 12:53:07 +08:00
|
|
|
} else if providerType == "Gitee" {
|
|
|
|
return NewGiteeIdProvider(clientId, clientSecret, redirectUrl)
|
2021-07-03 20:53:38 +08:00
|
|
|
} else if providerType == "LinkedIn" {
|
|
|
|
return NewLinkedInIdProvider(clientId, clientSecret, redirectUrl)
|
2021-07-28 20:36:27 +08:00
|
|
|
} else if providerType == "WeCom" {
|
|
|
|
return NewWeComIdProvider(clientId, clientSecret, redirectUrl)
|
2021-08-14 16:00:38 +08:00
|
|
|
} else if providerType == "Lark" {
|
|
|
|
return NewLarkIdProvider(clientId, clientSecret, redirectUrl)
|
2021-08-19 21:03:57 +08:00
|
|
|
} else if providerType == "GitLab" {
|
|
|
|
return NewGitlabIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-22 19:36:44 +08:00
|
|
|
} else if providerType == "Baidu" {
|
|
|
|
return NewBaiduIdProvider(clientId, clientSecret, redirectUrl)
|
2021-12-10 00:55:27 +08:00
|
|
|
} else if isGothSupport(providerType) {
|
|
|
|
return NewGothIdProvider(providerType, clientId, clientSecret, redirectUrl)
|
2021-02-21 22:33:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
2021-12-10 00:55:27 +08:00
|
|
|
|
|
|
|
var gothList = []string{"Apple", "AzureAd", "Slack"}
|
|
|
|
|
|
|
|
func isGothSupport(provider string) bool {
|
|
|
|
for _, value := range gothList {
|
|
|
|
if strings.EqualFold(value, provider) {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|