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
|
2022-09-08 14:44:06 +08:00
|
|
|
UnionId string
|
2021-05-31 00:13:38 +08:00
|
|
|
Email string
|
2023-04-29 01:11:58 +08:00
|
|
|
Phone string
|
|
|
|
CountryCode string
|
2021-05-31 00:13:38 +08:00
|
|
|
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) {
|
2023-03-31 19:24:03 +08:00
|
|
|
return NewGothIdProvider(typ, clientId, clientSecret, redirectUrl, hostUrl)
|
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
|
|
|
|
2023-02-04 12:20:18 +08:00
|
|
|
var gothList = []string{
|
|
|
|
"Apple",
|
|
|
|
"AzureAD",
|
|
|
|
"Slack",
|
|
|
|
"Steam",
|
|
|
|
"Line",
|
|
|
|
"Amazon",
|
|
|
|
"Auth0",
|
|
|
|
"BattleNet",
|
|
|
|
"Bitbucket",
|
|
|
|
"Box",
|
|
|
|
"CloudFoundry",
|
|
|
|
"Dailymotion",
|
|
|
|
"Deezer",
|
|
|
|
"DigitalOcean",
|
|
|
|
"Discord",
|
|
|
|
"Dropbox",
|
|
|
|
"EveOnline",
|
|
|
|
"Fitbit",
|
|
|
|
"Gitea",
|
|
|
|
"Heroku",
|
|
|
|
"InfluxCloud",
|
|
|
|
"Instagram",
|
|
|
|
"Intercom",
|
|
|
|
"Kakao",
|
|
|
|
"Lastfm",
|
|
|
|
"Mailru",
|
|
|
|
"Meetup",
|
|
|
|
"MicrosoftOnline",
|
|
|
|
"Naver",
|
|
|
|
"Nextcloud",
|
|
|
|
"OneDrive",
|
|
|
|
"Oura",
|
|
|
|
"Patreon",
|
|
|
|
"Paypal",
|
|
|
|
"SalesForce",
|
|
|
|
"Shopify",
|
|
|
|
"Soundcloud",
|
|
|
|
"Spotify",
|
|
|
|
"Strava",
|
|
|
|
"Stripe",
|
|
|
|
"TikTok",
|
|
|
|
"Tumblr",
|
|
|
|
"Twitch",
|
|
|
|
"Twitter",
|
|
|
|
"Typetalk",
|
|
|
|
"Uber",
|
|
|
|
"VK",
|
|
|
|
"Wepay",
|
|
|
|
"Xero",
|
|
|
|
"Yahoo",
|
|
|
|
"Yammer",
|
|
|
|
"Yandex",
|
|
|
|
"Zoom",
|
|
|
|
}
|
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
|
|
|
|
}
|