mirror of
https://github.com/WJQSERVER-STUDIO/ghproxy.git
synced 2026-02-03 00:01:10 +08:00
52 lines
1.1 KiB
Go
52 lines
1.1 KiB
Go
package auth
|
|
|
|
import (
|
|
"fmt"
|
|
"ghproxy/config"
|
|
|
|
"github.com/WJQSERVER-STUDIO/go-utils/logger"
|
|
"github.com/cloudwego/hertz/pkg/app"
|
|
)
|
|
|
|
var (
|
|
logw = logger.Logw
|
|
logDump = logger.LogDump
|
|
logDebug = logger.LogDebug
|
|
logInfo = logger.LogInfo
|
|
logWarning = logger.LogWarning
|
|
logError = logger.LogError
|
|
)
|
|
|
|
func Init(cfg *config.Config) {
|
|
if cfg.Blacklist.Enabled {
|
|
err := InitBlacklist(cfg)
|
|
if err != nil {
|
|
logError(err.Error())
|
|
return
|
|
}
|
|
}
|
|
if cfg.Whitelist.Enabled {
|
|
err := InitWhitelist(cfg)
|
|
if err != nil {
|
|
logError(err.Error())
|
|
return
|
|
}
|
|
}
|
|
logDebug("Auth Init")
|
|
}
|
|
|
|
func AuthHandler(c *app.RequestContext, cfg *config.Config) (isValid bool, err error) {
|
|
if cfg.Auth.Method == "parameters" {
|
|
isValid, err = AuthParametersHandler(c, cfg)
|
|
return isValid, err
|
|
} else if cfg.Auth.Method == "header" {
|
|
isValid, err = AuthHeaderHandler(c, cfg)
|
|
return isValid, err
|
|
} else if cfg.Auth.Method == "" {
|
|
logError("Auth method not set")
|
|
return true, nil
|
|
} else {
|
|
logError("Auth method not supported")
|
|
return false, fmt.Errorf(fmt.Sprintf("Auth method %s not supported", cfg.Auth.Method))
|
|
}
|
|
}
|