feat(captcha): add Cap version config for 1.x/2.x compatibility

pull/2573/head
WittF 2025-06-26 05:03:00 +08:00
parent 26fde303c5
commit 37d4341693
4 changed files with 22 additions and 4 deletions

View File

@ -147,10 +147,24 @@ func CaptchaRequired(enabled func(c *gin.Context) bool) gin.HandlerFunc {
request2.WithHeader(http.Header{"Content-Type": []string{"application/json"}}), request2.WithHeader(http.Header{"Content-Type": []string{"application/json"}}),
) )
capEndpoint := strings.TrimSuffix(captchaSetting.InstanceURL, "/") + "/" + captchaSetting.SiteKey + "/siteverify" var capEndpoint string
requestBody := map[string]string{ var requestBody map[string]string
"secret": captchaSetting.SecretKey,
"response": service.Ticket, // Support both 1.x and 2.x API formats
if captchaSetting.Version == "1.x" {
// Version 1.x: /api/{keyID}/siteverify
capEndpoint = strings.TrimSuffix(captchaSetting.InstanceURL, "/") + "/api/" + captchaSetting.SiteKey + "/siteverify"
requestBody = map[string]string{
"secret": captchaSetting.SecretKey,
"response": service.Ticket,
}
} else {
// Version 2.x (default): /{siteKey}/siteverify
capEndpoint = strings.TrimSuffix(captchaSetting.InstanceURL, "/") + "/" + captchaSetting.SiteKey + "/siteverify"
requestBody = map[string]string{
"secret": captchaSetting.SecretKey,
"response": service.Ticket,
}
} }
requestData, err := json.Marshal(requestBody) requestData, err := json.Marshal(requestBody)
if err != nil { if err != nil {

View File

@ -671,6 +671,7 @@ func (s *settingProvider) CapCaptcha(ctx context.Context) *Cap {
InstanceURL: s.getString(ctx, "captcha_cap_instance_url", ""), InstanceURL: s.getString(ctx, "captcha_cap_instance_url", ""),
SiteKey: s.getString(ctx, "captcha_cap_key_id", ""), SiteKey: s.getString(ctx, "captcha_cap_key_id", ""),
SecretKey: s.getString(ctx, "captcha_cap_key_secret", ""), SecretKey: s.getString(ctx, "captcha_cap_key_secret", ""),
Version: s.getString(ctx, "captcha_cap_version", "2.x"),
} }
} }

View File

@ -52,6 +52,7 @@ type Cap struct {
InstanceURL string InstanceURL string
SiteKey string SiteKey string
SecretKey string SecretKey string
Version string // "1.x" or "2.x"
} }
type SMTP struct { type SMTP struct {

View File

@ -31,6 +31,7 @@ type SiteConfig struct {
TurnstileSiteID string `json:"turnstile_site_id,omitempty"` TurnstileSiteID string `json:"turnstile_site_id,omitempty"`
CapInstanceURL string `json:"captcha_cap_instance_url,omitempty"` CapInstanceURL string `json:"captcha_cap_instance_url,omitempty"`
CapKeyID string `json:"captcha_cap_key_id,omitempty"` CapKeyID string `json:"captcha_cap_key_id,omitempty"`
CapVersion string `json:"captcha_cap_version,omitempty"`
RegisterEnabled bool `json:"register_enabled,omitempty"` RegisterEnabled bool `json:"register_enabled,omitempty"`
TosUrl string `json:"tos_url,omitempty"` TosUrl string `json:"tos_url,omitempty"`
PrivacyPolicyUrl string `json:"privacy_policy_url,omitempty"` PrivacyPolicyUrl string `json:"privacy_policy_url,omitempty"`
@ -138,6 +139,7 @@ func (s *GetSettingService) GetSiteConfig(c *gin.Context) (*SiteConfig, error) {
ReCaptchaKey: reCaptcha.Key, ReCaptchaKey: reCaptcha.Key,
CapInstanceURL: capCaptcha.InstanceURL, CapInstanceURL: capCaptcha.InstanceURL,
CapKeyID: capCaptcha.SiteKey, CapKeyID: capCaptcha.SiteKey,
CapVersion: capCaptcha.Version,
AppPromotion: appSetting.Promotion, AppPromotion: appSetting.Promotion,
}, nil }, nil
} }