Support using proxy dial-up connection to GitHub. (#46)

This commit is contained in:
三千 2025-02-10 00:45:37 +08:00 committed by GitHub
parent 09163ed4df
commit 4c5d288f03
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
8 changed files with 86 additions and 9 deletions

View file

@ -115,6 +115,10 @@ enabled = false # 是否开启速率限制
rateMethod = "total" # "ip" or "total" 速率限制方式
ratePerMinute = 180 # 每分钟限制请求数量
burst = 5 # 突发请求数量
[proxy]
enabled = false # 是否使用代理连接
url = "socks5://127.0.0.1:1080" # "http://127.0.0.1:7890" 支持HTTP代理和SOCKS5代理 支持多级SOCKS5代理
```
### 黑名单配置

View file

@ -13,6 +13,7 @@ type Config struct {
Blacklist BlacklistConfig
Whitelist WhitelistConfig
RateLimit RateLimitConfig
Proxy ProxyConfig
}
type ServerConfig struct {
@ -62,6 +63,11 @@ type RateLimitConfig struct {
Burst int `toml:"burst"`
}
type ProxyConfig struct {
Enabled bool `toml:"enabled"`
Url string `toml:"url"`
}
// LoadConfig 从 TOML 配置文件加载配置
func LoadConfig(filePath string) (*Config, error) {
var config Config

View file

@ -36,3 +36,7 @@ enabled = false
rateMethod = "total" # "ip" or "total"
ratePerMinute = 180
burst = 5
[proxy]
enabled = false
url = "socks5://127.0.0.1:1080" # "http://127.0.0.1:7890"

2
go.mod
View file

@ -6,6 +6,7 @@ require (
github.com/BurntSushi/toml v1.4.0
github.com/WJQSERVER-STUDIO/go-utils/logger v1.3.0
github.com/gin-gonic/gin v1.10.0
golang.org/x/net v0.34.0
golang.org/x/time v0.10.0
)
@ -31,7 +32,6 @@ require (
github.com/ugorji/go/codec v1.2.12 // indirect
golang.org/x/arch v0.14.0 // indirect
golang.org/x/crypto v0.33.0 // indirect
golang.org/x/net v0.34.0 // indirect
golang.org/x/sys v0.30.0 // indirect
golang.org/x/text v0.22.0 // indirect
google.golang.org/protobuf v1.36.5 // indirect

View file

@ -100,8 +100,8 @@ func setupRateLimit(cfg *config.Config) {
}
}
func InitReq() {
proxy.InitReq()
func InitReq(cfg *config.Config) {
proxy.InitReq(cfg)
}
func init() {
@ -109,7 +109,7 @@ func init() {
flag.Parse()
loadConfig()
setupLogger(cfg)
InitReq()
InitReq(cfg)
loadlist(cfg)
setupRateLimit(cfg)

View file

@ -22,9 +22,9 @@ var (
BufferPool *sync.Pool
)
func InitReq() {
initChunkedHTTPClient()
initGitHTTPClient()
func InitReq(cfg *config.Config) {
initChunkedHTTPClient(cfg)
initGitHTTPClient(cfg)
// 初始化固定大小的缓存池
BufferPool = &sync.Pool{
@ -34,7 +34,7 @@ func InitReq() {
}
}
func initChunkedHTTPClient() {
func initChunkedHTTPClient(cfg *config.Config) {
ctr = &http.Transport{
MaxIdleConns: 100,
MaxConnsPerHost: 60,
@ -47,6 +47,7 @@ func initChunkedHTTPClient() {
KeepAlive: 30 * time.Second,
}).DialContext,
}
initTransport(cfg, ctr)
cclient = &http.Client{
Transport: ctr,
}

61
proxy/dial.go Normal file
View file

@ -0,0 +1,61 @@
package proxy
import (
"ghproxy/config"
"net/http"
"net/url"
"strings"
"golang.org/x/net/proxy"
)
func newProxyDial(proxyUrls string) proxy.Dialer {
var proxyDialer proxy.Dialer = proxy.Direct
for _, proxyUrl := range strings.Split(proxyUrls, ",") {
urlInfo, err := url.Parse(proxyUrl)
if err != nil {
continue
}
if urlInfo.Scheme != "socks5" {
continue
}
var auth *proxy.Auth = nil
if urlInfo.User != nil {
pwd, ok := urlInfo.User.Password()
if !ok {
continue
}
auth = &proxy.Auth{
User: urlInfo.User.Username(),
Password: pwd,
}
}
dialer, err := proxy.SOCKS5("tcp", urlInfo.Host, auth, proxyDialer)
if err == nil {
proxyDialer = dialer
}
}
return proxyDialer
}
func initTransport(cfg *config.Config, transport *http.Transport) {
if !cfg.Proxy.Enabled {
return
}
if cfg.Proxy.Url == "" {
transport.Proxy = http.ProxyFromEnvironment
return
}
proxyInfo, err := url.Parse(cfg.Proxy.Url)
if err == nil {
if strings.HasPrefix(cfg.Proxy.Url, "http") {
transport.Proxy = http.ProxyURL(proxyInfo)
} else {
proxyDialer := newProxyDial(cfg.Proxy.Url)
transport.Dial = proxyDialer.Dial
transport.DialContext = proxyDialer.(proxy.ContextDialer).DialContext
}
}
}

View file

@ -17,12 +17,13 @@ var (
gtr *http.Transport
)
func initGitHTTPClient() {
func initGitHTTPClient(cfg *config.Config) {
gtr = &http.Transport{
MaxIdleConns: 30,
MaxConnsPerHost: 30,
IdleConnTimeout: 30 * time.Second,
}
initTransport(cfg, gtr)
gclient = &http.Client{
Transport: gtr,
}