mirror of
https://github.com/casdoor/casdoor.git
synced 2025-05-23 02:35:49 +08:00

* Fix bug in GetAcceptLanguage() * feat: allow captcha to be enabled when logging in * feat: when the login password is wrong, enable captcha * feat: Restrict captcha from frontend * fix: modify CaptchaModal component * fix: modify the words of i18n * Update data.json Co-authored-by: Gucheng Wang <nomeguy@qq.com> Co-authored-by: hsluoyz <hsluoyz@qq.com>
46 lines
1.4 KiB
Go
46 lines
1.4 KiB
Go
// Copyright 2022 The Casdoor 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 captcha
|
|
|
|
import "fmt"
|
|
|
|
type CaptchaProvider interface {
|
|
VerifyCaptcha(token, clientSecret string) (bool, error)
|
|
}
|
|
|
|
func GetCaptchaProvider(captchaType string) CaptchaProvider {
|
|
if captchaType == "Default" {
|
|
return NewDefaultCaptchaProvider()
|
|
} else if captchaType == "reCAPTCHA" {
|
|
return NewReCaptchaProvider()
|
|
} else if captchaType == "hCaptcha" {
|
|
return NewHCaptchaProvider()
|
|
} else if captchaType == "Aliyun Captcha" {
|
|
return NewAliyunCaptchaProvider()
|
|
} else if captchaType == "GEETEST" {
|
|
return NewGEETESTCaptchaProvider()
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func VerifyCaptchaByCaptchaType(captchaType, token, clientSecret string) (bool, error) {
|
|
provider := GetCaptchaProvider(captchaType)
|
|
if provider == nil {
|
|
return false, fmt.Errorf("invalid captcha provider: %s", captchaType)
|
|
}
|
|
|
|
return provider.VerifyCaptcha(token, clientSecret)
|
|
}
|