mirror of
https://github.com/songquanpeng/one-api.git
synced 2025-09-27 21:56:39 +08:00
81 lines
1.8 KiB
Go
81 lines
1.8 KiB
Go
package middleware
|
||
|
||
import (
|
||
"encoding/json"
|
||
"github.com/gin-contrib/sessions"
|
||
"github.com/gin-gonic/gin"
|
||
"net/http"
|
||
"net/url"
|
||
"one-api/common"
|
||
)
|
||
|
||
type turnstileCheckResponse struct {
|
||
Success bool `json:"success"`
|
||
}
|
||
|
||
func TurnstileCheck() gin.HandlerFunc {
|
||
return func(c *gin.Context) {
|
||
if common.TurnstileCheckEnabled {
|
||
session := sessions.Default(c)
|
||
turnstileChecked := session.Get("turnstile")
|
||
if turnstileChecked != nil {
|
||
c.Next()
|
||
return
|
||
}
|
||
response := c.Query("turnstile")
|
||
if response == "" {
|
||
c.JSON(http.StatusOK, gin.H{
|
||
"success": false,
|
||
"message": "Turnstile token is empty",
|
||
})
|
||
c.Abort()
|
||
return
|
||
}
|
||
rawRes, err := http.PostForm("https://challenges.cloudflare.com/turnstile/v0/siteverify", url.Values{
|
||
"secret": {common.TurnstileSecretKey},
|
||
"response": {response},
|
||
"remoteip": {c.ClientIP()},
|
||
})
|
||
if err != nil {
|
||
common.SysError(err.Error())
|
||
c.JSON(http.StatusOK, gin.H{
|
||
"success": false,
|
||
"message": err.Error(),
|
||
})
|
||
c.Abort()
|
||
return
|
||
}
|
||
defer rawRes.Body.Close()
|
||
var res turnstileCheckResponse
|
||
err = json.NewDecoder(rawRes.Body).Decode(&res)
|
||
if err != nil {
|
||
common.SysError(err.Error())
|
||
c.JSON(http.StatusOK, gin.H{
|
||
"success": false,
|
||
"message": err.Error(),
|
||
})
|
||
c.Abort()
|
||
return
|
||
}
|
||
if !res.Success {
|
||
c.JSON(http.StatusOK, gin.H{
|
||
"success": false,
|
||
"message": "Turnstile Verification failed, please refresh and try again.!",
|
||
})
|
||
c.Abort()
|
||
return
|
||
}
|
||
session.Set("turnstile", true)
|
||
err = session.Save()
|
||
if err != nil {
|
||
c.JSON(http.StatusOK, gin.H{
|
||
"message": "Unable to save session information, please try again.",
|
||
"success": false,
|
||
})
|
||
return
|
||
}
|
||
}
|
||
c.Next()
|
||
}
|
||
}
|