diff options
author | Arthur Schiwon <blizzz@arthur-schiwon.de> | 2020-07-30 21:10:54 +0200 |
---|---|---|
committer | Arthur Schiwon <blizzz@arthur-schiwon.de> | 2020-07-30 21:10:54 +0200 |
commit | b79e34c57ba74246a03a66045a6b792e35da1d32 (patch) | |
tree | 8b00bf3c8ae42109cadb7a82d1ed936243791916 | |
parent | 2698e9e0113840ab7fb9e98d43a5cb40c58518ff (diff) | |
download | nextcloud-server-b79e34c57ba74246a03a66045a6b792e35da1d32.tar.gz nextcloud-server-b79e34c57ba74246a03a66045a6b792e35da1d32.zip |
fix check for Cloud ID, missing return statements, wrong param use
Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
-rw-r--r-- | apps/dav/lib/CardDAV/CardDavBackend.php | 5 | ||||
-rw-r--r-- | apps/federatedfilesharing/lib/Notifier.php | 22 |
2 files changed, 16 insertions, 11 deletions
diff --git a/apps/dav/lib/CardDAV/CardDavBackend.php b/apps/dav/lib/CardDAV/CardDavBackend.php index 9d602025c7a..8c898271902 100644 --- a/apps/dav/lib/CardDAV/CardDavBackend.php +++ b/apps/dav/lib/CardDAV/CardDavBackend.php @@ -974,8 +974,9 @@ class CardDavBackend implements BackendInterface, SyncSupport { continue; } - if ($property === 'CLOUD' && preg_match('/[^a-zA-Z0-9 _.@\-\']/', $pattern) === 1) { - // There can be no chars in cloud ids which are not valid for user ids + if ($property === 'CLOUD' && preg_match('/[^a-zA-Z0-9 :_.@\/\-\']/', $pattern) === 1) { + // There can be no chars in cloud ids which are not valid for user ids plus :/ + // worst case: CA61590A-BBBC-423E-84AF-E6DF01455A53@https://my.nxt/srv/ continue; } } diff --git a/apps/federatedfilesharing/lib/Notifier.php b/apps/federatedfilesharing/lib/Notifier.php index 46081240d6a..cae3fc2aa99 100644 --- a/apps/federatedfilesharing/lib/Notifier.php +++ b/apps/federatedfilesharing/lib/Notifier.php @@ -107,9 +107,7 @@ class Notifier implements INotifier { ); $initiator = $params[0]; - $initiatorDisplay = isset($params[3]) ? $params[3] : null; $owner = $params[1]; - $ownerDisplay = isset($params[4]) ? $params[4] : null; $notification->setRichSubject( $l->t('You received {share} as a remote share from {user} (on behalf of {behalf})'), @@ -119,8 +117,8 @@ class Notifier implements INotifier { 'id' => $notification->getObjectId(), 'name' => $params[2], ], - 'user' => $this->createRemoteUser($initiator, $initiatorDisplay), - 'behalf' => $this->createRemoteUser($owner, $ownerDisplay), + 'user' => $this->createRemoteUser($initiator), + 'behalf' => $this->createRemoteUser($owner), ] ); } else { @@ -129,7 +127,6 @@ class Notifier implements INotifier { ); $owner = $params[0]; - $ownerDisplay = isset($params[3]) ? $params[3] : null; $notification->setRichSubject( $l->t('You received {share} as a remote share from {user}'), @@ -139,7 +136,7 @@ class Notifier implements INotifier { 'id' => $notification->getObjectId(), 'name' => $params[2], ], - 'user' => $this->createRemoteUser($owner, $ownerDisplay), + 'user' => $this->createRemoteUser($owner), ] ); } @@ -203,7 +200,7 @@ class Notifier implements INotifier { * @param ICloudId $cloudId * @return string */ - protected function getDisplayName(ICloudId $cloudId) { + protected function getDisplayName(ICloudId $cloudId): string { $server = $cloudId->getRemote(); $user = $cloudId->getUser(); if (strpos($server, 'http://') === 0) { @@ -213,17 +210,24 @@ class Notifier implements INotifier { } try { + // contains protocol in the ID return $this->getDisplayNameFromContact($cloudId->getId()); } catch (\OutOfBoundsException $e) { } try { - $this->getDisplayNameFromContact($user . '@http://' . $server); + // does not include protocol, as stored in addressbooks + return $this->getDisplayNameFromContact($cloudId->getDisplayId()); } catch (\OutOfBoundsException $e) { } try { - $this->getDisplayNameFromContact($user . '@https://' . $server); + return $this->getDisplayNameFromContact($user . '@http://' . $server); + } catch (\OutOfBoundsException $e) { + } + + try { + return $this->getDisplayNameFromContact($user . '@https://' . $server); } catch (\OutOfBoundsException $e) { } |