From 2c8bd0b65b0b29a3b51eb481a115376b9dde2ae1 Mon Sep 17 00:00:00 2001 From: Sergey Komlev Date: Thu, 30 Mar 2023 15:57:10 +0300 Subject: [PATCH] Full support for socks5 proxies --- src/Config.php | 2 +- src/Speedtest.php | 31 ++++++++++++++++++++----------- 2 files changed, 21 insertions(+), 12 deletions(-) diff --git a/src/Config.php b/src/Config.php index ed4762c..10e2b60 100644 --- a/src/Config.php +++ b/src/Config.php @@ -308,7 +308,7 @@ public function setProxy($proxy) { $proxy = str_replace("https://", "", $proxy); $proxy = str_replace("http://", "", $proxy); - if (strpos("socks5://", $proxy) !== false) { + if (strpos($proxy, "socks5://") !== false) { $proxy = str_replace("socks5://", "", $proxy); $this->proxyType = "socks5"; } diff --git a/src/Speedtest.php b/src/Speedtest.php index ff02068..616c5a2 100644 --- a/src/Speedtest.php +++ b/src/Speedtest.php @@ -112,21 +112,25 @@ protected function getRemoteConfig() { ], "headers" => [ "accept-language" => "en-US" - ] + ], + // "debug" => true ]; - if (!empty($this->config->getProxy())) { - $proxy_parts = explode('://', $this->config->getProxy()); - $options["proxy"] = $proxy_parts[0] == "https" ? $proxy_parts[1] : $this->config->getProxy(); + if ($this->config->getProxyType() == "socks5") { + $options["proxy"] = "socks5://" . $this->config->getProxy(); + } else { + $options["proxy"] = "http://" . $this->config->getProxy(); } $res = $client->request('GET', 'https://www.speedtest.net/speedtest-config.php', $options); $data = $res->getBody()->getContents(); $xml = simplexml_load_string($data); + if (empty($xml)) { throw new SpeedtestException("Couldn't get remote client config. Reason: empty xml data."); } + $server_config = $xml->{'server-config'}; $download = $xml->download; $upload = $xml->upload; @@ -189,9 +193,10 @@ public function getServers() { ] ]; - if (!empty($this->config->getProxy())) { - $proxy_parts = explode('://', $this->config->getProxy()); - $options["proxy"] = $proxy_parts[0] == "https" ? $proxy_parts[1] : $this->config->getProxy(); + if ($this->config->getProxyType() == "socks5") { + $options["proxy"] = "socks5://" . $this->config->getProxy(); + } else { + $options["proxy"] = "http://" . $this->config->getProxy(); } $res = $client->request('GET', 'https://c.speedtest.net/speedtest-servers-static.php', $options); @@ -299,10 +304,11 @@ public function getBestServer($checkCount = 100, $skipLatencyRetries = false) { $ping_time = $stats->getHandlerStat('starttransfer_time') - $stats->getHandlerStat('pretransfer_time'); } ]; - - if (!empty($this->config->getProxy())) { - $proxy_parts = explode('://', $this->config->getProxy()); - $options["proxy"] = $proxy_parts[0] == "https" ? $proxy_parts[1] : $this->config->getProxy(); + + if ($this->config->getProxyType() == "socks5") { + $options["proxy"] = "socks5://" . $this->config->getProxy(); + } else { + $options["proxy"] = "http://" . $this->config->getProxy(); } $res = $client->request('GET', $url, $options); @@ -375,6 +381,7 @@ public function download($threads = null) { } if (!empty($this->config->getProxy())) { if ($this->config->getProxyType() == "socks5") { + curl_setopt($ch, CURLOPT_PROXYTYPE, CURLPROXY_SOCKS5); $urlParts = parse_url("socks5://" . $this->config->getProxy()); } else { $urlParts = parse_url("http://" . $this->config->getProxy()); @@ -457,6 +464,7 @@ public function upload($threads = null) { } if (!empty($this->config->getProxy())) { if ($this->config->getProxyType() == "socks5") { + curl_setopt($ch, CURLOPT_PROXYTYPE, CURLPROXY_SOCKS5); $urlParts = parse_url("socks5://" . $this->config->getProxy()); } else { $urlParts = parse_url("http://" . $this->config->getProxy()); @@ -548,6 +556,7 @@ public function share() { } if (!empty($this->config->getProxy())) { if ($this->config->getProxyType() == "socks5") { + curl_setopt($ch, CURLOPT_PROXYTYPE, CURLPROXY_SOCKS5); $urlParts = parse_url("socks5://" . $this->config->getProxy()); } else { $urlParts = parse_url("http://" . $this->config->getProxy());