summaryrefslogtreecommitdiffstats
path: root/apps/lookup_server_connector/lib/UpdateLookupServer.php
diff options
context:
space:
mode:
authorBjoern Schiessle <bjoern@schiessle.org>2017-02-23 12:27:18 +0100
committerBjoern Schiessle <bjoern@schiessle.org>2017-02-23 12:27:24 +0100
commitdda15b74cb76d5958006a5dce0f2074c5fb3bb99 (patch)
tree8b65673374644c451fc9b79d1950e513b643d0ab /apps/lookup_server_connector/lib/UpdateLookupServer.php
parent621f920d682c78b12b8a57abcf0d4af09a11757b (diff)
downloadnextcloud-server-dda15b74cb76d5958006a5dce0f2074c5fb3bb99.tar.gz
nextcloud-server-dda15b74cb76d5958006a5dce0f2074c5fb3bb99.zip
add posibility to remove all personal data from lookup server
Signed-off-by: Bjoern Schiessle <bjoern@schiessle.org>
Diffstat (limited to 'apps/lookup_server_connector/lib/UpdateLookupServer.php')
-rw-r--r--apps/lookup_server_connector/lib/UpdateLookupServer.php49
1 files changed, 30 insertions, 19 deletions
diff --git a/apps/lookup_server_connector/lib/UpdateLookupServer.php b/apps/lookup_server_connector/lib/UpdateLookupServer.php
index 7ba63c85567..86865311725 100644
--- a/apps/lookup_server_connector/lib/UpdateLookupServer.php
+++ b/apps/lookup_server_connector/lib/UpdateLookupServer.php
@@ -93,9 +93,7 @@ class UpdateLookupServer {
}
}
- if (!empty($publicData)) {
- $this->sendToLookupServer($user, $publicData);
- }
+ $this->sendToLookupServer($user, $publicData);
}
/**
@@ -105,25 +103,38 @@ class UpdateLookupServer {
* @param array $publicData
*/
protected function sendToLookupServer(IUser $user, array $publicData) {
- $dataArray = [
- 'federationId' => $user->getCloudId(),
- 'name' => isset($publicData[AccountManager::PROPERTY_DISPLAYNAME]) ? $publicData[AccountManager::PROPERTY_DISPLAYNAME]['value'] : '',
- 'email' => isset($publicData[AccountManager::PROPERTY_EMAIL]) ? $publicData[AccountManager::PROPERTY_EMAIL]['value'] : '',
- 'address' => isset($publicData[AccountManager::PROPERTY_ADDRESS]) ? $publicData[AccountManager::PROPERTY_ADDRESS]['value'] : '',
- 'website' => isset($publicData[AccountManager::PROPERTY_WEBSITE]) ? $publicData[AccountManager::PROPERTY_WEBSITE]['value'] : '',
- 'twitter' => isset($publicData[AccountManager::PROPERTY_TWITTER]) ? $publicData[AccountManager::PROPERTY_TWITTER]['value'] : '',
- 'phone' => isset($publicData[AccountManager::PROPERTY_PHONE]) ? $publicData[AccountManager::PROPERTY_PHONE]['value'] : '',
- ];
+
+ $dataArray = ['federationId' => $user->getCloudId()];
+
+ if (!empty($publicData)) {
+ $dataArray['name'] = isset($publicData[AccountManager::PROPERTY_DISPLAYNAME]) ? $publicData[AccountManager::PROPERTY_DISPLAYNAME]['value'] : '';
+ $dataArray['email'] = isset($publicData[AccountManager::PROPERTY_EMAIL]) ? $publicData[AccountManager::PROPERTY_EMAIL]['value'] : '';
+ $dataArray['address'] = isset($publicData[AccountManager::PROPERTY_ADDRESS]) ? $publicData[AccountManager::PROPERTY_ADDRESS]['value'] : '';
+ $dataArray['website'] = isset($publicData[AccountManager::PROPERTY_WEBSITE]) ? $publicData[AccountManager::PROPERTY_WEBSITE]['value'] : '';
+ $dataArray['twitter'] = isset($publicData[AccountManager::PROPERTY_TWITTER]) ? $publicData[AccountManager::PROPERTY_TWITTER]['value'] : '';
+ $dataArray['phone'] = isset($publicData[AccountManager::PROPERTY_PHONE]) ? $publicData[AccountManager::PROPERTY_PHONE]['value'] : '';
+ }
+
$dataArray = $this->signer->sign('lookupserver', $dataArray, $user);
$httpClient = $this->clientService->newClient();
try {
- $httpClient->post($this->lookupServer,
- [
- 'body' => json_encode($dataArray),
- 'timeout' => 10,
- 'connect_timeout' => 3,
- ]
- );
+ if (empty($publicData)) {
+ $httpClient->delete($this->lookupServer,
+ [
+ 'body' => json_encode($dataArray),
+ 'timeout' => 10,
+ 'connect_timeout' => 3,
+ ]
+ );
+ } else {
+ $httpClient->post($this->lookupServer,
+ [
+ 'body' => json_encode($dataArray),
+ 'timeout' => 10,
+ 'connect_timeout' => 3,
+ ]
+ );
+ }
} catch (\Exception $e) {
$this->jobList->add(RetryJob::class,
[