From 9afd160e66f2c060cb7d77d414d0c1d13ac0c3ad Mon Sep 17 00:00:00 2001
From: Bjoern Schiessle
Date: Fri, 7 Apr 2017 11:42:33 +0200
Subject: [PATCH 1/3] allow to disable upload to lookup server, by default it
is enabled
Signed-off-by: Bjoern Schiessle
---
.../lib/FederatedShareProvider.php | 11 +++++++
.../lib/Settings/Admin.php | 1 +
.../templates/settings-admin.php | 10 +++++-
.../tests/FederatedShareProviderTest.php | 32 +++++++++++++++++++
.../tests/Settings/AdminTest.php | 5 +++
settings/personal.php | 4 +++
settings/templates/personal.php | 9 +++++-
7 files changed, 70 insertions(+), 2 deletions(-)
diff --git a/apps/federatedfilesharing/lib/FederatedShareProvider.php b/apps/federatedfilesharing/lib/FederatedShareProvider.php
index fb49978b7af16..b2f2558c80c6f 100644
--- a/apps/federatedfilesharing/lib/FederatedShareProvider.php
+++ b/apps/federatedfilesharing/lib/FederatedShareProvider.php
@@ -963,4 +963,15 @@ public function isLookupServerQueriesEnabled() {
$result = $this->config->getAppValue('files_sharing', 'lookupServerEnabled', 'no');
return ($result === 'yes') ? true : false;
}
+
+
+ /**
+ * Check if it is allowed to publish user specific data to the lookup server
+ *
+ * @return bool
+ */
+ public function isLookupServerUploadEnabled() {
+ $result = $this->config->getAppValue('files_sharing', 'lookupServerUploadEnabled', 'yes');
+ return ($result === 'yes') ? true : false;
+ }
}
diff --git a/apps/federatedfilesharing/lib/Settings/Admin.php b/apps/federatedfilesharing/lib/Settings/Admin.php
index 20ff6ae6f4a62..baac4b1086ff7 100644
--- a/apps/federatedfilesharing/lib/Settings/Admin.php
+++ b/apps/federatedfilesharing/lib/Settings/Admin.php
@@ -44,6 +44,7 @@ public function getForm() {
'outgoingServer2serverShareEnabled' => $this->fedShareProvider->isOutgoingServer2serverShareEnabled(),
'incomingServer2serverShareEnabled' => $this->fedShareProvider->isIncomingServer2serverShareEnabled(),
'lookupServerEnabled' => $this->fedShareProvider->isLookupServerQueriesEnabled(),
+ 'lookupServerUploadEnabled' => $this->fedShareProvider->isLookupServerUploadEnabled(),
];
return new TemplateResponse('federatedfilesharing', 'settings-admin', $parameters, '');
diff --git a/apps/federatedfilesharing/templates/settings-admin.php b/apps/federatedfilesharing/templates/settings-admin.php
index d71ce20d13cc4..b60ff1083b098 100644
--- a/apps/federatedfilesharing/templates/settings-admin.php
+++ b/apps/federatedfilesharing/templates/settings-admin.php
@@ -29,7 +29,15 @@
/>
+
+ />
+
+
+
diff --git a/apps/federatedfilesharing/tests/FederatedShareProviderTest.php b/apps/federatedfilesharing/tests/FederatedShareProviderTest.php
index 97d8ccd65c3ec..d9bc9a7e2ad04 100644
--- a/apps/federatedfilesharing/tests/FederatedShareProviderTest.php
+++ b/apps/federatedfilesharing/tests/FederatedShareProviderTest.php
@@ -705,6 +705,38 @@ public function testIsIncomingServer2serverShareEnabled($isEnabled, $expected) {
);
}
+ /**
+ * @dataProvider dataTestFederatedSharingSettings
+ *
+ * @param string $isEnabled
+ * @param bool $expected
+ */
+ public function testIsLookupServerQueriesEnabled($isEnabled, $expected) {
+ $this->config->expects($this->once())->method('getAppValue')
+ ->with('files_sharing', 'lookupServerEnabled', 'no')
+ ->willReturn($isEnabled);
+
+ $this->assertSame($expected,
+ $this->provider->isLookupServerQueriesEnabled()
+ );
+ }
+
+ /**
+ * @dataProvider dataTestFederatedSharingSettings
+ *
+ * @param string $isEnabled
+ * @param bool $expected
+ */
+ public function testIsLookupServerUploadEnabled($isEnabled, $expected) {
+ $this->config->expects($this->once())->method('getAppValue')
+ ->with('files_sharing', 'lookupServerUploadEnabled', 'yes')
+ ->willReturn($isEnabled);
+
+ $this->assertSame($expected,
+ $this->provider->isLookupServerUploadEnabled()
+ );
+ }
+
public function dataTestFederatedSharingSettings() {
return [
['yes', true],
diff --git a/apps/federatedfilesharing/tests/Settings/AdminTest.php b/apps/federatedfilesharing/tests/Settings/AdminTest.php
index c0b35a6427bbb..9eae6317bf71a 100644
--- a/apps/federatedfilesharing/tests/Settings/AdminTest.php
+++ b/apps/federatedfilesharing/tests/Settings/AdminTest.php
@@ -69,11 +69,16 @@ public function testGetForm($state) {
->expects($this->once())
->method('isLookupServerQueriesEnabled')
->willReturn($state);
+ $this->federatedShareProvider
+ ->expects($this->once())
+ ->method('isLookupServerUploadEnabled')
+ ->willReturn($state);
$params = [
'outgoingServer2serverShareEnabled' => $state,
'incomingServer2serverShareEnabled' => $state,
'lookupServerEnabled' => $state,
+ 'lookupServerUploadEnabled' => $state
];
$expected = new TemplateResponse('federatedfilesharing', 'settings-admin', $params, '');
$this->assertEquals($expected, $this->admin->getForm());
diff --git a/settings/personal.php b/settings/personal.php
index a4449754f644f..2c46a9f8dd291 100644
--- a/settings/personal.php
+++ b/settings/personal.php
@@ -186,6 +186,10 @@
$tmpl->assign('showCertificates', $enableCertImport);
$tmpl->assign('urlGenerator', $urlGenerator);
+$lookupServerUploadEnabled = $config->getAppValue('files_sharing', 'lookupServerUploadEnabled', 'yes');
+$lookupServerUploadEnabled = $lookupServerUploadEnabled === 'yes';
+$tmpl->assign('lookupServerUploadEnabled', $lookupServerUploadEnabled);
+
// Get array of group ids for this user
$groups = \OC::$server->getGroupManager()->getUserIdGroups(OC_User::getUser());
$groups2 = array_map(function($group) { return $group->getGID(); }, $groups);
diff --git a/settings/templates/personal.php b/settings/templates/personal.php
index d94fbb33770a2..10df437523b4e 100644
--- a/settings/templates/personal.php
+++ b/settings/templates/personal.php
@@ -67,7 +67,9 @@
+
+
@@ -86,7 +88,9 @@
t('No display name set')); } ?>
+
+
@@ -107,9 +111,12 @@
t('For password reset and notifications')); ?>
+
+
+
-
+
From d5173ac30f19de27327f302ae217e33c419b1960 Mon Sep 17 00:00:00 2001
From: Bjoern Schiessle
Date: Fri, 7 Apr 2017 11:43:12 +0200
Subject: [PATCH 2/3] make sure that the selector for the visibility always
fits next to 'Profile picture'
Signed-off-by: Bjoern Schiessle
---
settings/css/settings.css | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/settings/css/settings.css b/settings/css/settings.css
index 884fe1d50d078..5ca62248c091d 100644
--- a/settings/css/settings.css
+++ b/settings/css/settings.css
@@ -28,7 +28,7 @@ input#openid, input#webdav { width:20em; }
}
#avatarform {
- width: 145px;
+ min-width: 145px;
padding-right: 0;
}
#avatarform .avatardiv {
From 78f0b5c19fe3101e3f10b5da70411681cd9b3d3e Mon Sep 17 00:00:00 2001
From: Bjoern Schiessle
Date: Mon, 10 Apr 2017 09:44:23 +0200
Subject: [PATCH 3/3] simplify return statement
Signed-off-by: Bjoern Schiessle
---
apps/federatedfilesharing/lib/FederatedShareProvider.php | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/apps/federatedfilesharing/lib/FederatedShareProvider.php b/apps/federatedfilesharing/lib/FederatedShareProvider.php
index b2f2558c80c6f..9063bbf745074 100644
--- a/apps/federatedfilesharing/lib/FederatedShareProvider.php
+++ b/apps/federatedfilesharing/lib/FederatedShareProvider.php
@@ -941,7 +941,7 @@ public function userDeletedFromGroup($uid, $gid) {
*/
public function isOutgoingServer2serverShareEnabled() {
$result = $this->config->getAppValue('files_sharing', 'outgoing_server2server_share_enabled', 'yes');
- return ($result === 'yes') ? true : false;
+ return ($result === 'yes');
}
/**
@@ -951,7 +951,7 @@ public function isOutgoingServer2serverShareEnabled() {
*/
public function isIncomingServer2serverShareEnabled() {
$result = $this->config->getAppValue('files_sharing', 'incoming_server2server_share_enabled', 'yes');
- return ($result === 'yes') ? true : false;
+ return ($result === 'yes');
}
/**
@@ -961,7 +961,7 @@ public function isIncomingServer2serverShareEnabled() {
*/
public function isLookupServerQueriesEnabled() {
$result = $this->config->getAppValue('files_sharing', 'lookupServerEnabled', 'no');
- return ($result === 'yes') ? true : false;
+ return ($result === 'yes');
}
@@ -972,6 +972,6 @@ public function isLookupServerQueriesEnabled() {
*/
public function isLookupServerUploadEnabled() {
$result = $this->config->getAppValue('files_sharing', 'lookupServerUploadEnabled', 'yes');
- return ($result === 'yes') ? true : false;
+ return ($result === 'yes');
}
}