always query the lookup server in a global scale setup and have a nicer label
Signed-off-by: Bjoern Schiessle <bjoern@schiessle.org>
This commit is contained in:
parent
ecf33a679e
commit
3fa13e791e
|
@ -27,8 +27,10 @@ namespace OC\Collaboration\Collaborators;
|
|||
use OCP\Collaboration\Collaborators\ISearchPlugin;
|
||||
use OCP\Collaboration\Collaborators\ISearchResult;
|
||||
use OCP\Collaboration\Collaborators\SearchResultType;
|
||||
use OCP\Federation\ICloudIdManager;
|
||||
use OCP\Http\Client\IClientService;
|
||||
use OCP\IConfig;
|
||||
use OCP\IUserSession;
|
||||
use OCP\Share;
|
||||
|
||||
class LookupPlugin implements ISearchPlugin {
|
||||
|
@ -37,14 +39,27 @@ class LookupPlugin implements ISearchPlugin {
|
|||
private $config;
|
||||
/** @var IClientService */
|
||||
private $clientService;
|
||||
/** @var string remote part of the current user's cloud id */
|
||||
private $currentUserRemote;
|
||||
/** @var ICloudIdManager */
|
||||
private $cloudIdManager;
|
||||
|
||||
public function __construct(IConfig $config, IClientService $clientService) {
|
||||
public function __construct(IConfig $config,
|
||||
IClientService $clientService,
|
||||
IUserSession $userSession,
|
||||
ICloudIdManager $cloudIdManager) {
|
||||
$this->config = $config;
|
||||
$this->clientService = $clientService;
|
||||
$this->cloudIdManager = $cloudIdManager;
|
||||
$currentUserCloudId = $userSession->getUser()->getCloudId();
|
||||
$this->currentUserRemote = $cloudIdManager->resolveCloudId($currentUserCloudId)->getRemote();
|
||||
}
|
||||
|
||||
public function search($search, $limit, $offset, ISearchResult $searchResult) {
|
||||
if ($this->config->getAppValue('files_sharing', 'lookupServerEnabled', 'no') !== 'yes') {
|
||||
$isGlobalScaleEnabled = $this->config->getSystemValue('gs.enabled', false);
|
||||
$isLookupServerEnabled = $this->config->getAppValue('files_sharing', 'lookupServerEnabled', 'no');
|
||||
// if case of Global Scale we always search the lookup server
|
||||
if ($isLookupServerEnabled !== 'yes' && !$isGlobalScaleEnabled) {
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -65,8 +80,12 @@ class LookupPlugin implements ISearchPlugin {
|
|||
$body = json_decode($response->getBody(), true);
|
||||
|
||||
foreach ($body as $lookup) {
|
||||
$remote = $this->cloudIdManager->resolveCloudId($lookup['federationId'])->getRemote();
|
||||
if ($this->currentUserRemote === $remote) continue;
|
||||
$name = $lookup['name']['value'];
|
||||
$label = empty($name) ? $lookup['federationId'] : $name . ' (' . $lookup['federationId'] . ')';
|
||||
$result[] = [
|
||||
'label' => $lookup['federationId'],
|
||||
'label' => $label,
|
||||
'value' => [
|
||||
'shareType' => Share::SHARE_TYPE_REMOTE,
|
||||
'shareWith' => $lookup['federationId'],
|
||||
|
|
Loading…
Reference in New Issue