summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@arthur-schiwon.de>2018-10-17 13:09:11 +0200
committerArthur Schiwon <blizzz@arthur-schiwon.de>2018-10-18 17:49:28 +0200
commit8e4ae23c487b29bd8ea1a6d7d81e6996957e86fb (patch)
tree988f2f5d48e5e0cd958867849f36674245d8ee05
parent7c8b3c1056d2549734ec4bb9ed547468ca2c2331 (diff)
downloadnextcloud-server-8e4ae23c487b29bd8ea1a6d7d81e6996957e86fb.tar.gz
nextcloud-server-8e4ae23c487b29bd8ea1a6d7d81e6996957e86fb.zip
Do not try to contact lookup server without internet connection or URL
Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
-rw-r--r--apps/lookup_server_connector/lib/BackgroundJobs/RetryJob.php12
-rw-r--r--apps/lookup_server_connector/lib/UpdateLookupServer.php14
-rw-r--r--lib/private/Collaboration/Collaborators/LookupPlugin.php7
-rw-r--r--settings/BackgroundJobs/VerifyUserData.php3
-rw-r--r--tests/lib/Collaboration/Collaborators/LookupPluginTest.php99
5 files changed, 108 insertions, 27 deletions
diff --git a/apps/lookup_server_connector/lib/BackgroundJobs/RetryJob.php b/apps/lookup_server_connector/lib/BackgroundJobs/RetryJob.php
index c0fba230a26..5a7212a6522 100644
--- a/apps/lookup_server_connector/lib/BackgroundJobs/RetryJob.php
+++ b/apps/lookup_server_connector/lib/BackgroundJobs/RetryJob.php
@@ -50,9 +50,15 @@ class RetryJob extends Job {
$this->clientService = $clientService;
$this->jobList = $jobList;
+ if ($config->getSystemValue('has_internet_connection', true) === false) {
+ return;
+ }
+
$this->lookupServer = $config->getSystemValue('lookup_server', 'https://lookup.nextcloud.com');
- $this->lookupServer = rtrim($this->lookupServer, '/');
- $this->lookupServer .= '/users';
+ if (!empty($this->lookupServer)) {
+ $this->lookupServer = rtrim($this->lookupServer, '/');
+ $this->lookupServer .= '/users';
+ }
}
/**
@@ -69,7 +75,7 @@ class RetryJob extends Job {
}
protected function run($argument) {
- if($argument['retryNo'] === 5) {
+ if ($argument['retryNo'] === 5 || empty($this->lookupServer)) {
return;
}
diff --git a/apps/lookup_server_connector/lib/UpdateLookupServer.php b/apps/lookup_server_connector/lib/UpdateLookupServer.php
index ae8fcbd67ca..7902ede8816 100644
--- a/apps/lookup_server_connector/lib/UpdateLookupServer.php
+++ b/apps/lookup_server_connector/lib/UpdateLookupServer.php
@@ -64,15 +64,25 @@ class UpdateLookupServer {
$this->signer = $signer;
$this->jobList = $jobList;
+ if($config->getSystemValue('has_internet_connection', true) === false) {
+ return;
+ }
+
$this->lookupServer = $config->getSystemValue('lookup_server', 'https://lookup.nextcloud.com');
- $this->lookupServer = rtrim($this->lookupServer, '/');
- $this->lookupServer .= '/users';
+ if(!empty($this->lookupServer)) {
+ $this->lookupServer = rtrim($this->lookupServer, '/');
+ $this->lookupServer .= '/users';
+ }
}
/**
* @param IUser $user
*/
public function userUpdated(IUser $user) {
+ if(empty($this->lookupServer)) {
+ return;
+ }
+
$userData = $this->accountManager->getUser($user);
$publicData = [];
diff --git a/lib/private/Collaboration/Collaborators/LookupPlugin.php b/lib/private/Collaboration/Collaborators/LookupPlugin.php
index ae5f7fd0cbc..fb7c872c30c 100644
--- a/lib/private/Collaboration/Collaborators/LookupPlugin.php
+++ b/lib/private/Collaboration/Collaborators/LookupPlugin.php
@@ -63,12 +63,17 @@ class LookupPlugin implements ISearchPlugin {
public function search($search, $limit, $offset, ISearchResult $searchResult) {
$isGlobalScaleEnabled = $this->config->getSystemValue('gs.enabled', false);
$isLookupServerEnabled = $this->config->getAppValue('files_sharing', 'lookupServerEnabled', 'no') === 'yes';
+ $hasInternetConnection = (bool)$this->config->getSystemValue('has_internet_connection', true);
+
// if case of Global Scale we always search the lookup server
- if (!$isLookupServerEnabled && !$isGlobalScaleEnabled) {
+ if ((!$isLookupServerEnabled && !$isGlobalScaleEnabled) || !$hasInternetConnection) {
return false;
}
$lookupServerUrl = $this->config->getSystemValue('lookup_server', 'https://lookup.nextcloud.com');
+ if(empty($lookupServerUrl)) {
+ return false;
+ }
$lookupServerUrl = rtrim($lookupServerUrl, '/');
$result = [];
diff --git a/settings/BackgroundJobs/VerifyUserData.php b/settings/BackgroundJobs/VerifyUserData.php
index 8d54cde9dd9..b4a60ec8405 100644
--- a/settings/BackgroundJobs/VerifyUserData.php
+++ b/settings/BackgroundJobs/VerifyUserData.php
@@ -182,6 +182,9 @@ class VerifyUserData extends Job {
* @return bool true if we could check the verification code, otherwise false
*/
protected function verifyViaLookupServer(array $argument, $dataType) {
+ if(empty($this->lookupServerUrl) || $this->config->getSystemValue('has_internet_connection', true) === false) {
+ return false;
+ }
$user = $this->userManager->get($argument['uid']);
diff --git a/tests/lib/Collaboration/Collaborators/LookupPluginTest.php b/tests/lib/Collaboration/Collaborators/LookupPluginTest.php
index 9019176d246..98e4adf2a7c 100644
--- a/tests/lib/Collaboration/Collaborators/LookupPluginTest.php
+++ b/tests/lib/Collaboration/Collaborators/LookupPluginTest.php
@@ -70,7 +70,7 @@ class LookupPluginTest extends TestCase {
$this->userSession->expects($this->any())->method('getUser')
->willReturn($user);
$this->cloudIdManager->expects($this->any())->method('resolveCloudId')
- ->willReturnCallback(function($cloudId) {
+ ->willReturnCallback(function ($cloudId) {
if ($cloudId === 'user@myNextcloud.net') {
return new CloudId('user@myNextcloud.net', 'user', 'myNextcloud.net');
}
@@ -87,6 +87,58 @@ class LookupPluginTest extends TestCase {
);
}
+ public function testSearchNoLookupServerURI() {
+ $this->config->expects($this->once())
+ ->method('getAppValue')
+ ->with('files_sharing', 'lookupServerEnabled', 'no')
+ ->willReturn('yes');
+ $this->config->expects($this->at(0))
+ ->method('getSystemValue')
+ ->with('gs.enabled', false)
+ ->willReturn(false);
+
+ $this->config->expects($this->at(2))
+ ->method('getSystemValue')
+ ->with('has_internet_connection', true)
+ ->willReturn(true);
+ $this->config->expects($this->at(3))
+ ->method('getSystemValue')
+ ->with('lookup_server', 'https://lookup.nextcloud.com')
+ ->willReturn('');
+
+ $this->clientService->expects($this->never())
+ ->method('newClient');
+
+ /** @var ISearchResult|\PHPUnit_Framework_MockObject_MockObject $searchResult */
+ $searchResult = $this->createMock(ISearchResult::class);
+
+ $this->plugin->search('foobar', 10, 0, $searchResult);
+ }
+
+ public function testSearchNoInternet() {
+ $this->config->expects($this->once())
+ ->method('getAppValue')
+ ->with('files_sharing', 'lookupServerEnabled', 'no')
+ ->willReturn('yes');
+ $this->config->expects($this->at(0))
+ ->method('getSystemValue')
+ ->with('gs.enabled', false)
+ ->willReturn(false);
+
+ $this->config->expects($this->at(2))
+ ->method('getSystemValue')
+ ->with('has_internet_connection', true)
+ ->willReturn(false);
+
+ $this->clientService->expects($this->never())
+ ->method('newClient');
+
+ /** @var ISearchResult|\PHPUnit_Framework_MockObject_MockObject $searchResult */
+ $searchResult = $this->createMock(ISearchResult::class);
+
+ $this->plugin->search('foobar', 10, 0, $searchResult);
+ }
+
/**
* @dataProvider searchDataProvider
* @param array $searchParams
@@ -108,8 +160,13 @@ class LookupPluginTest extends TestCase {
->method('getSystemValue')
->with('gs.enabled', false)
->willReturn(false);
+
$this->config->expects($this->at(2))
->method('getSystemValue')
+ ->with('has_internet_connection', true)
+ ->willReturn(true);
+ $this->config->expects($this->at(3))
+ ->method('getSystemValue')
->with('lookup_server', 'https://lookup.nextcloud.com')
->willReturn($searchParams['server']);
@@ -121,7 +178,7 @@ class LookupPluginTest extends TestCase {
$client = $this->createMock(IClient::class);
$client->expects($this->once())
->method('get')
- ->willReturnCallback(function($url) use ($searchParams, $response) {
+ ->willReturnCallback(function ($url) use ($searchParams, $response) {
$this->assertSame(strpos($url, $searchParams['server'] . '/users?search='), 0);
$this->assertNotFalse(strpos($url, urlencode($searchParams['search'])));
return $response;
@@ -138,8 +195,6 @@ class LookupPluginTest extends TestCase {
$searchResult
);
-
-
$this->assertFalse($moreResults);
}
@@ -171,6 +226,10 @@ class LookupPluginTest extends TestCase {
$this->config->expects($this->at(2))
->method('getSystemValue')
+ ->with('has_internet_connection', true)
+ ->willReturn(true);
+ $this->config->expects($this->at(3))
+ ->method('getSystemValue')
->with('lookup_server', 'https://lookup.nextcloud.com')
->willReturn($searchParams['server']);
@@ -201,8 +260,6 @@ class LookupPluginTest extends TestCase {
$searchResult
);
-
-
$this->assertFalse($moreResults);
}
@@ -237,9 +294,9 @@ class LookupPluginTest extends TestCase {
'offset' => 0,
'server' => 'https://lookup.example.io',
'resultBody' => [
- [ 'federationId' => $fedIDs[0] ],
- [ 'federationId' => $fedIDs[1] ],
- [ 'federationId' => $fedIDs[2] ],
+ ['federationId' => $fedIDs[0]],
+ ['federationId' => $fedIDs[1]],
+ ['federationId' => $fedIDs[2]],
],
'expectedResult' => [
[
@@ -276,9 +333,9 @@ class LookupPluginTest extends TestCase {
'offset' => 0,
'server' => 'https://lookup.example.io',
'resultBody' => [
- [ 'federationId' => $fedIDs[0] ],
- [ 'federationId' => $fedIDs[1] ],
- [ 'federationId' => $fedIDs[2] ],
+ ['federationId' => $fedIDs[0]],
+ ['federationId' => $fedIDs[1]],
+ ['federationId' => $fedIDs[2]],
],
'expectedResult' => [
[
@@ -315,9 +372,9 @@ class LookupPluginTest extends TestCase {
'offset' => 0,
'server' => 'https://lookup.example.io',
'resultBody' => [
- [ 'federationId' => $fedIDs[0] ],
- [ 'federationId' => $fedIDs[1] ],
- [ 'federationId' => $fedIDs[2] ],
+ ['federationId' => $fedIDs[0]],
+ ['federationId' => $fedIDs[1]],
+ ['federationId' => $fedIDs[2]],
],
'expectedResult' => [
[
@@ -354,9 +411,9 @@ class LookupPluginTest extends TestCase {
'offset' => 0,
'server' => 'https://lookup.example.io',
'resultBody' => [
- [ 'federationId' => $fedIDs[0] ],
- [ 'federationId' => $fedIDs[1] ],
- [ 'federationId' => $fedIDs[2] ],
+ ['federationId' => $fedIDs[0]],
+ ['federationId' => $fedIDs[1]],
+ ['federationId' => $fedIDs[2]],
],
'expectedResult' => [
[
@@ -405,9 +462,9 @@ class LookupPluginTest extends TestCase {
'offset' => 0,
'server' => 'https://lookup.example.io',
'resultBody' => [
- [ 'federationId' => $fedIDs[0] ],
- [ 'federationId' => $fedIDs[1] ],
- [ 'federationId' => $fedIDs[2] ],
+ ['federationId' => $fedIDs[0]],
+ ['federationId' => $fedIDs[1]],
+ ['federationId' => $fedIDs[2]],
],
'expectedResult' => [
[