From 0459bad0f071777699751a475876aeaf00e2a73f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=99=88=E9=BC=ABRWHTYFZ?= Date: Sat, 2 Dec 2023 15:20:24 +0800 Subject: [PATCH] feat: 'testUrl' queryparam for api/httpLatency (#1193) --- service/server/controller/latency.go | 2 +- service/server/service/latency.go | 12 ++++++++---- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/service/server/controller/latency.go b/service/server/controller/latency.go index 62c26ffc4a..e05cd84829 100644 --- a/service/server/controller/latency.go +++ b/service/server/controller/latency.go @@ -62,7 +62,7 @@ func GetHttpLatency(ctx *gin.Context) { common.ResponseError(ctx, logError("bad request")) return } - wt, err = service.TestHttpLatency(wt, 8*time.Second, 32, false) + wt, err = service.TestHttpLatency(wt, 8*time.Second, 32, false, ctx.Query("testUrl")) if err != nil { common.ResponseError(ctx, logError(err)) return diff --git a/service/server/service/latency.go b/service/server/service/latency.go index ac811e32b5..b3924e66eb 100644 --- a/service/server/service/latency.go +++ b/service/server/service/latency.go @@ -90,7 +90,7 @@ func addHosts(tmpl *v2ray.Template, vms []serverObj.ServerObj) { wg.Wait() } -func TestHttpLatency(which []*configure.Which, timeout time.Duration, maxParallel int, showLog bool) ([]*configure.Which, error) { +func TestHttpLatency(which []*configure.Which, timeout time.Duration, maxParallel int, showLog bool, customTestUrl string) ([]*configure.Which, error) { var whiches = configure.NewWhiches(which) for i := len(which) - 1; i >= 0; i-- { if which[i].TYPE == configure.SubscriptionType { //去掉subscriptionType @@ -222,7 +222,7 @@ func TestHttpLatency(which []*configure.Which, timeout time.Duration, maxParalle go func(i int) { cc <- nil defer func() { <-cc; wg.Done() }() - httpLatency(which[i], inboundPortMap[i], timeout) + httpLatency(which[i], inboundPortMap[i], timeout, customTestUrl) if showLog { log.Info("Test done[%v]%v: %v", i+1, which[i].Latency, which[i].Link) } @@ -242,7 +242,7 @@ func TestHttpLatency(which []*configure.Which, timeout time.Duration, maxParalle } return which, nil } -func httpLatency(which *configure.Which, port string, timeout time.Duration) { +func httpLatency(which *configure.Which, port string, timeout time.Duration, customTestUrl string) { c, err := httpClient.GetHttpClientWithProxy("socks5://127.0.0.1:" + port) if err != nil { which.Latency = "SYSTEM ERROR" @@ -255,7 +255,11 @@ func httpLatency(which *configure.Which, port string, timeout time.Duration) { c.CheckRedirect = func(req *http.Request, via []*http.Request) error { return http.ErrUseLastResponse } - req, _ := http.NewRequest("GET", HttpTestURL, nil) + testUrl := HttpTestURL + if len(customTestUrl) != 0 { + testUrl = customTestUrl + } + req, _ := http.NewRequest("GET", testUrl, nil) //req, _ := http.NewRequest("GET", "http://www.gstatic.com/generate_204", nil) req.Header.Set("Accept", "*/*") req.Header.Set("Cache-Control", "no-cache")