diff options
author | Joas Schilling <coding@schilljs.com> | 2020-08-03 17:03:06 +0200 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2020-08-03 17:03:06 +0200 |
commit | 5d41a3f9a2a79cecb5f7278dc4b83f9d8a6e3b6c (patch) | |
tree | e406b376ed6c71a7a48072320a4528195c1861f4 /apps/settings/lib | |
parent | 489fecac32ae8c3d5c857b803d0d597ac0b37f4a (diff) | |
download | nextcloud-server-5d41a3f9a2a79cecb5f7278dc4b83f9d8a6e3b6c.tar.gz nextcloud-server-5d41a3f9a2a79cecb5f7278dc4b83f9d8a6e3b6c.zip |
Add settings sections to unified search
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'apps/settings/lib')
-rw-r--r-- | apps/settings/lib/AppInfo/Application.php | 2 | ||||
-rw-r--r-- | apps/settings/lib/Search/SectionResult.php | 29 | ||||
-rw-r--r-- | apps/settings/lib/Search/SectionSearch.php | 134 |
3 files changed, 165 insertions, 0 deletions
diff --git a/apps/settings/lib/AppInfo/Application.php b/apps/settings/lib/AppInfo/Application.php index 6e6eb26d011..0fd39f71b36 100644 --- a/apps/settings/lib/AppInfo/Application.php +++ b/apps/settings/lib/AppInfo/Application.php @@ -46,6 +46,7 @@ use OCA\Settings\Activity\Provider; use OCA\Settings\Hooks; use OCA\Settings\Mailer\NewUserMailHelper; use OCA\Settings\Middleware\SubadminMiddleware; +use OCA\Settings\Search\SectionSearch; use OCP\Activity\IManager as IActivityManager; use OCP\AppFramework\App; use OCP\AppFramework\Bootstrap\IBootContext; @@ -77,6 +78,7 @@ class Application extends App implements IBootstrap { // Register Middleware $context->registerServiceAlias('SubadminMiddleware', SubadminMiddleware::class); $context->registerMiddleware(SubadminMiddleware::class); + $context->registerSearchProvider(SectionSearch::class); /** * Core class wrappers diff --git a/apps/settings/lib/Search/SectionResult.php b/apps/settings/lib/Search/SectionResult.php new file mode 100644 index 00000000000..d7e4e6b21fb --- /dev/null +++ b/apps/settings/lib/Search/SectionResult.php @@ -0,0 +1,29 @@ +<?php + +declare(strict_types=1); +/** + * @copyright Copyright (c) 2020 Joas Schilling <coding@schilljs.com> + * + * @license GNU AGPL version 3 or any later version + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + * + */ + +namespace OCA\Settings\Search; + +use OCP\Search\ASearchResultEntry; + +class SectionResult extends ASearchResultEntry { +} diff --git a/apps/settings/lib/Search/SectionSearch.php b/apps/settings/lib/Search/SectionSearch.php new file mode 100644 index 00000000000..818fa055bb4 --- /dev/null +++ b/apps/settings/lib/Search/SectionSearch.php @@ -0,0 +1,134 @@ +<?php + +declare(strict_types=1); +/** + * @copyright Copyright (c) 2020 Joas Schilling <coding@schilljs.com> + * + * @license GNU AGPL version 3 or any later version + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + * + */ + +namespace OCA\Settings\Search; + +use OCP\IGroupManager; +use OCP\IL10N; +use OCP\IURLGenerator; +use OCP\IUser; +use OCP\Search\IProvider; +use OCP\Search\ISearchQuery; +use OCP\Search\SearchResult; +use OCP\Settings\IIconSection; +use OCP\Settings\ISection; +use OCP\Settings\IManager; + +class SectionSearch implements IProvider { + + /** @var IManager */ + protected $settingsManager; + /** @var IGroupManager */ + protected $groupManager; + /** @var IURLGenerator */ + protected $urlGenerator; + /** @var IL10N */ + protected $l; + + public function __construct(IManager $settingsManager, + IGroupManager $groupManager, + IURLGenerator $urlGenerator, + IL10N $l) { + $this->settingsManager = $settingsManager; + $this->groupManager = $groupManager; + $this->urlGenerator = $urlGenerator; + $this->l = $l; + } + + /** + * @inheritDoc + */ + public function getId(): string { + return 'settings_sections'; + } + + /** + * @inheritDoc + */ + public function getName(): string { + return $this->l->t('Settings'); + } + + /** + * @inheritDoc + */ + public function search(IUser $user, ISearchQuery $query): SearchResult { + $isAdmin = $this->groupManager->isAdmin($user->getUID()); + + $result = $this->searchSections( + $query, + $this->settingsManager->getPersonalSections(), + $isAdmin ? $this->l->t('Personal') : '', + 'settings.PersonalSettings.index' + ); + + if ($this->groupManager->isAdmin($user->getUID())) { + $result = array_merge($result, $this->searchSections( + $query, + $this->settingsManager->getAdminSections(), + $this->l->t('Administration'), + 'settings.AdminSettings.index' + )); + } + + return SearchResult::complete( + $this->l->t('Settings'), + $result + ); + } + + /** + * @param ISearchQuery $query + * @param ISection[][] $sections + * @param string $subline + * @param string $routeName + * @return array + */ + public function searchSections(ISearchQuery $query, array $sections, string $subline, string $routeName): array { + $result = []; + foreach ($sections as $priority => $sectionsByPriority) { + foreach ($sectionsByPriority as $section) { + if ( + stripos($section->getName(), $query->getTerm()) === false && + stripos($section->getID(), $query->getTerm()) === false + ) { + continue; + } + + $iconUrl = ''; + if ($section instanceof IIconSection) { + $iconUrl = $section->getIcon(); + } + + $result[] = new SectionResult( + $iconUrl, + $section->getName(), + $subline, + $this->urlGenerator->linkToRouteAbsolute($routeName, ['section' => $section->getID()]) + ); + } + } + + return $result; + } +} |