mirror of
https://github.com/WJQSERVER-STUDIO/ghproxy.git
synced 2026-02-03 00:01:10 +08:00
2.1.0 --- - RELEASE: v2.1.0正式版发布; - CHANGE: 加入`FreeBSD`与`Darwin`系统支持 - CHANGE: 更新安全政策, v1和24w版本序列生命周期正式结束 - ADD: 加入`timing`中间件记录响应时间 - ADD: 加入`loggin`中间件包装日志输出 - CHANGE: 更新logger版本至v1.3.0 - CHANGE: 改进日志相关 - ADD: 加入日志等级配置项
37 lines
1.3 KiB
Go
37 lines
1.3 KiB
Go
package proxy
|
|
|
|
import (
|
|
"ghproxy/config"
|
|
"net/http"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
)
|
|
|
|
func AuthPassThrough(c *gin.Context, cfg *config.Config, req *http.Request) {
|
|
if cfg.Auth.PassThrough {
|
|
token := c.Query("token")
|
|
if token != "" {
|
|
logDebug("%s %s %s %s %s Auth-PassThrough: token %s", c.ClientIP(), c.Request.Method, c.Request.URL.String(), c.Request.Header.Get("User-Agent"), c.Request.Proto, token)
|
|
switch cfg.Auth.AuthMethod {
|
|
case "parameters":
|
|
if !cfg.Auth.Enabled {
|
|
req.Header.Set("Authorization", "token "+token)
|
|
} else {
|
|
logWarning("%s %s %s %s %s Auth-Error: Conflict Auth Method", c.ClientIP(), c.Request.Method, c.Request.URL.String(), c.Request.Header.Get("User-Agent"), c.Request.Proto)
|
|
// 500 Internal Server Error
|
|
c.JSON(http.StatusInternalServerError, gin.H{"error": "Conflict Auth Method"})
|
|
return
|
|
}
|
|
case "header":
|
|
if cfg.Auth.Enabled {
|
|
req.Header.Set("Authorization", "token "+token)
|
|
}
|
|
default:
|
|
logWarning("%s %s %s %s %s Invalid Auth Method / Auth Method is not be set", c.ClientIP(), c.Request.Method, c.Request.URL.String(), c.Request.Header.Get("User-Agent"), c.Request.Proto)
|
|
// 500 Internal Server Error
|
|
c.JSON(http.StatusInternalServerError, gin.H{"error": "Invalid Auth Method / Auth Method is not be set"})
|
|
return
|
|
}
|
|
}
|
|
}
|
|
}
|