2022-02-13 23:39:27 +08:00
|
|
|
// Copyright 2021 The Casdoor Authors. All Rights Reserved.
|
2021-02-21 22:33:53 +08:00
|
|
|
//
|
|
|
|
// 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
|
|
|
}
|
|
|
|
|
2022-04-16 17:17:45 +08:00
|
|
|
func GetIdProvider(typ string, subType string, clientId string, clientSecret string, appId string, redirectUrl string, hostUrl string, authUrl string, tokenUrl string, userInfoUrl string) IdProvider {
|
2022-01-29 09:52:10 +08:00
|
|
|
if typ == "GitHub" {
|
2021-03-23 23:23:59 +08:00
|
|
|
return NewGithubIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "Google" {
|
2021-03-23 23:23:59 +08:00
|
|
|
return NewGoogleIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "QQ" {
|
2021-03-23 23:23:59 +08:00
|
|
|
return NewQqIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "WeChat" {
|
2021-05-17 14:17:46 +08:00
|
|
|
return NewWeChatIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "Facebook" {
|
2021-06-06 10:06:54 +08:00
|
|
|
return NewFacebookIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "DingTalk" {
|
2021-06-09 11:15:49 +08:00
|
|
|
return NewDingTalkIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "Weibo" {
|
2021-06-10 16:55:31 +08:00
|
|
|
return NewWeiBoIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "Gitee" {
|
2021-06-14 12:53:07 +08:00
|
|
|
return NewGiteeIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "LinkedIn" {
|
2021-07-03 20:53:38 +08:00
|
|
|
return NewLinkedInIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "WeCom" {
|
|
|
|
if subType == "Internal" {
|
|
|
|
return NewWeComInternalIdProvider(clientId, clientSecret, redirectUrl)
|
|
|
|
} else if subType == "Third-party" {
|
|
|
|
return NewWeComIdProvider(clientId, clientSecret, redirectUrl)
|
|
|
|
} else {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
} else if typ == "Lark" {
|
2021-08-14 16:00:38 +08:00
|
|
|
return NewLarkIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "GitLab" {
|
2021-08-19 21:03:57 +08:00
|
|
|
return NewGitlabIdProvider(clientId, clientSecret, redirectUrl)
|
2022-02-20 15:01:48 +08:00
|
|
|
} else if typ == "Adfs" {
|
|
|
|
return NewAdfsIdProvider(clientId, clientSecret, redirectUrl, hostUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if typ == "Baidu" {
|
2022-01-22 19:36:44 +08:00
|
|
|
return NewBaiduIdProvider(clientId, clientSecret, redirectUrl)
|
2022-04-02 22:37:13 +08:00
|
|
|
} else if typ == "Alipay" {
|
|
|
|
return NewAlipayIdProvider(clientId, clientSecret, redirectUrl)
|
2022-04-16 17:17:45 +08:00
|
|
|
} else if typ == "Custom" {
|
|
|
|
return NewCustomIdProvider(clientId, clientSecret, redirectUrl, authUrl, tokenUrl, userInfoUrl)
|
2022-02-05 21:54:38 +08:00
|
|
|
} else if typ == "Infoflow" {
|
|
|
|
if subType == "Internal" {
|
2022-02-07 21:50:51 +08:00
|
|
|
return NewInfoflowInternalIdProvider(clientId, clientSecret, appId, redirectUrl)
|
2022-02-05 21:54:38 +08:00
|
|
|
} else if subType == "Third-party" {
|
|
|
|
return NewInfoflowIdProvider(clientId, clientSecret, appId, redirectUrl)
|
|
|
|
} else {
|
|
|
|
return nil
|
|
|
|
}
|
2022-03-18 18:28:46 +08:00
|
|
|
} else if typ == "Casdoor" {
|
|
|
|
return NewCasdoorIdProvider(clientId, clientSecret, redirectUrl, hostUrl)
|
2022-05-01 18:31:42 +08:00
|
|
|
} else if typ == "Okta" {
|
|
|
|
return NewOktaIdProvider(clientId, clientSecret, redirectUrl, hostUrl)
|
2022-05-15 20:59:21 +08:00
|
|
|
} else if typ == "Douyin" {
|
|
|
|
return NewDouyinIdProvider(clientId, clientSecret, redirectUrl)
|
2022-01-29 09:52:10 +08:00
|
|
|
} else if isGothSupport(typ) {
|
|
|
|
return NewGothIdProvider(typ, clientId, clientSecret, redirectUrl)
|
2022-05-12 10:07:52 +08:00
|
|
|
} else if typ == "Bilibili" {
|
|
|
|
return NewBilibiliIdProvider(clientId, clientSecret, redirectUrl)
|
2021-02-21 22:33:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
2021-12-10 00:55:27 +08:00
|
|
|
|
2022-02-16 19:57:46 +08:00
|
|
|
var gothList = []string{"Apple", "AzureAd", "Slack", "Steam"}
|
2021-12-10 00:55:27 +08:00
|
|
|
|
|
|
|
func isGothSupport(provider string) bool {
|
|
|
|
for _, value := range gothList {
|
|
|
|
if strings.EqualFold(value, provider) {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|