aboutsummaryrefslogtreecommitdiffstats
path: root/apps/settings
diff options
context:
space:
mode:
authorJosh <josh.t.richards@gmail.com>2025-01-09 12:09:33 -0500
committerGitHub <noreply@github.com>2025-01-09 12:09:33 -0500
commit1304590d6c8ef3a37c8d2346b3a010999734b5b4 (patch)
treea00e1a909a8616ed4c84980d03a6a24fa630e63f /apps/settings
parent2f754529cefbfe43bd042b9ae64cac9ccf8026ea (diff)
parent35cb5d84caf5fb2a9e9d28f53b9f3f97805c0dc3 (diff)
downloadnextcloud-server-1304590d6c8ef3a37c8d2346b3a010999734b5b4.tar.gz
nextcloud-server-1304590d6c8ef3a37c8d2346b3a010999734b5b4.zip
Merge pull request #49977 from nextcloud/jtr-perf-checks-connectivity-https-proto
perf(settings): Speed up InternetConnectivity setup check
Diffstat (limited to 'apps/settings')
-rw-r--r--apps/settings/lib/SetupChecks/InternetConnectivity.php20
1 files changed, 10 insertions, 10 deletions
diff --git a/apps/settings/lib/SetupChecks/InternetConnectivity.php b/apps/settings/lib/SetupChecks/InternetConnectivity.php
index 3a0af06e71b..18f2af63b8d 100644
--- a/apps/settings/lib/SetupChecks/InternetConnectivity.php
+++ b/apps/settings/lib/SetupChecks/InternetConnectivity.php
@@ -41,11 +41,12 @@ class InternetConnectivity implements ISetupCheck {
}
$siteArray = $this->config->getSystemValue('connectivity_check_domains', [
- 'www.nextcloud.com', 'www.startpage.com', 'www.eff.org', 'www.edri.org'
+ 'https://www.nextcloud.com', 'https://www.startpage.com', 'https://www.eff.org', 'https://www.edri.org'
]);
foreach ($siteArray as $site) {
if ($this->isSiteReachable($site)) {
+ // successful as soon as one connection succeeds
return SetupResult::success();
}
}
@@ -55,19 +56,18 @@ class InternetConnectivity implements ISetupCheck {
/**
* Checks if the Nextcloud server can connect to a specific URL
* @param string $site site domain or full URL with http/https protocol
+ * @return bool success/failure
*/
private function isSiteReachable(string $site): bool {
+ // if there is no protocol specified, test http:// first then, if necessary, https://
+ if (preg_match('/^https?:\/\//', $site) !== 1) {
+ $httpSite = 'http://' . $site . '/';
+ $httpsSite = 'https://' . $site . '/';
+ return $this->isSiteReachable($httpSite) || $this->isSiteReachable($httpsSite);
+ }
try {
$client = $this->clientService->newClient();
- // if there is no protocol, test http:// AND https://
- if (preg_match('/^https?:\/\//', $site) !== 1) {
- $httpSite = 'http://' . $site . '/';
- $client->get($httpSite);
- $httpsSite = 'https://' . $site . '/';
- $client->get($httpsSite);
- } else {
- $client->get($site);
- }
+ $client->get($site);
} catch (\Exception $e) {
$this->logger->error('Cannot connect to: ' . $site, [
'app' => 'internet_connection_check',