Merge pull request #5384 from nextcloud/allow-to-share-to-local-users-via-email

Allow to find local users by their email address
This commit is contained in:
Morris Jobke 2017-06-14 18:03:24 -05:00 committed by GitHub
commit 2398d40d98
2 changed files with 72 additions and 7 deletions

View File

@ -593,24 +593,52 @@ class ShareesAPIController extends OCSController {
* @return array * @return array
*/ */
protected function getEmail($search) { protected function getEmail($search) {
$result = ['results' => [], 'exact' => []]; $result = ['results' => [], 'exact' => [], 'exactIdMatch' => false];
// Search in contacts // Search in contacts
//@todo Pagination missing //@todo Pagination missing
$addressBookContacts = $this->contactsManager->search($search, ['EMAIL', 'FN']); $addressBookContacts = $this->contactsManager->search($search, ['EMAIL', 'FN']);
$result['exactIdMatch'] = false; $lowerSearch = strtolower($search);
foreach ($addressBookContacts as $contact) { foreach ($addressBookContacts as $contact) {
if (isset($contact['isLocalSystemBook'])) {
continue;
}
if (isset($contact['EMAIL'])) { if (isset($contact['EMAIL'])) {
$emailAddresses = $contact['EMAIL']; $emailAddresses = $contact['EMAIL'];
if (!is_array($emailAddresses)) { if (!is_array($emailAddresses)) {
$emailAddresses = [$emailAddresses]; $emailAddresses = [$emailAddresses];
} }
foreach ($emailAddresses as $emailAddress) { foreach ($emailAddresses as $emailAddress) {
if (strtolower($contact['FN']) === strtolower($search) || strtolower($emailAddress) === strtolower($search)) { $exactEmailMatch = strtolower($emailAddress) === $lowerSearch;
if (strtolower($emailAddress) === strtolower($search)) {
if (isset($contact['isLocalSystemBook'])) {
if ($exactEmailMatch) {
$cloud = $this->cloudIdManager->resolveCloudId($contact['CLOUD'][0]);
if (!$this->hasUserInResult($cloud->getUser())) {
$this->result['exact']['users'][] = [
'label' => $contact['FN'] . " ($emailAddress)",
'value' => [
'shareType' => Share::SHARE_TYPE_USER,
'shareWith' => $cloud->getUser(),
],
];
}
return ['results' => [], 'exact' => [], 'exactIdMatch' => true];
}
if ($this->shareeEnumeration) {
$cloud = $this->cloudIdManager->resolveCloudId($contact['CLOUD'][0]);
if (!$this->hasUserInResult($cloud->getUser())) {
$this->result['users'][] = [
'label' => $contact['FN'] . " ($emailAddress)",
'value' => [
'shareType' => Share::SHARE_TYPE_USER,
'shareWith' => $cloud->getUser(),
],
];
}
}
continue;
}
if ($exactEmailMatch || strtolower($contact['FN']) === $lowerSearch) {
if ($exactEmailMatch) {
$result['exactIdMatch'] = true; $result['exactIdMatch'] = true;
} }
$result['exact'][] = [ $result['exact'][] = [
@ -688,6 +716,28 @@ class ShareesAPIController extends OCSController {
$this->result['lookup'] = $result; $this->result['lookup'] = $result;
} }
/**
* Check if a given user is already part of the result
*
* @param string $userId
* @return bool
*/
protected function hasUserInResult($userId) {
foreach ($this->result['exact']['users'] as $result) {
if ($result['value']['shareWith'] === $userId) {
return true;
}
}
foreach ($this->result['users'] as $result) {
if ($result['value']['shareWith'] === $userId) {
return true;
}
}
return false;
}
/** /**
* Generates a bunch of pagination links for the current page * Generates a bunch of pagination links for the current page
* *

View File

@ -1272,6 +1272,21 @@ class ShareesAPIControllerTest extends TestCase {
['results' => [], 'exact' => [], 'exactIdMatch' => false], ['results' => [], 'exact' => [], 'exactIdMatch' => false],
true, true,
], ],
// Local user found by email
[
'test@example.com',
[
[
'FN' => 'User',
'EMAIL' => ['test@example.com'],
'CLOUD' => ['test@localhost'],
'isLocalSystemBook' => true,
]
],
false,
['results' => [], 'exact' => [], 'exactIdMatch' => true],
false,
]
]; ];
} }