summaryrefslogtreecommitdiffstats
path: root/apps/files/lib
diff options
context:
space:
mode:
Diffstat (limited to 'apps/files/lib')
-rw-r--r--apps/files/lib/AppInfo/Application.php119
1 files changed, 95 insertions, 24 deletions
diff --git a/apps/files/lib/AppInfo/Application.php b/apps/files/lib/AppInfo/Application.php
index 9ee705f11c3..82562ffe9f0 100644
--- a/apps/files/lib/AppInfo/Application.php
+++ b/apps/files/lib/AppInfo/Application.php
@@ -1,4 +1,7 @@
<?php
+
+declare(strict_types=1);
+
/**
* @copyright Copyright (c) 2016, ownCloud, Inc.
*
@@ -31,6 +34,7 @@
namespace OCA\Files\AppInfo;
+use OC\Search\Provider\File;
use OCA\Files\Capabilities;
use OCA\Files\Collaboration\Resources\Listener;
use OCA\Files\Collaboration\Resources\ResourceProvider;
@@ -42,22 +46,31 @@ use OCA\Files\Listener\LoadSidebarListener;
use OCA\Files\Notification\Notifier;
use OCA\Files\Service\TagService;
use OCP\AppFramework\App;
+use OCP\AppFramework\Bootstrap\IBootContext;
+use OCP\AppFramework\Bootstrap\IBootstrap;
+use OCP\AppFramework\Bootstrap\IRegistrationContext;
use OCP\Collaboration\Resources\IProviderManager;
-use OCP\EventDispatcher\IEventDispatcher;
use OCP\IContainer;
+use OCP\IL10N;
+use OCP\IServerContainer;
+use OCP\Notification\IManager;
+use OCP\Util;
-class Application extends App {
+class Application extends App implements IBootstrap {
public const APP_ID = 'files';
public function __construct(array $urlParams=[]) {
parent::__construct(self::APP_ID, $urlParams);
- $container = $this->getContainer();
- $server = $container->getServer();
+ }
+ public function register(IRegistrationContext $context): void {
/**
* Controllers
*/
- $container->registerService('APIController', function (IContainer $c) use ($server) {
+ $context->registerService('APIController', function (IContainer $c) {
+ /** @var IServerContainer $server */
+ $server = $c->query(IServerContainer::class);
+
return new ApiController(
$c->query('AppName'),
$c->query('Request'),
@@ -73,13 +86,15 @@ class Application extends App {
/**
* Services
*/
- $container->registerService('TagService', function (IContainer $c) use ($server) {
- $homeFolder = $c->query('ServerContainer')->getUserFolder();
+ $context->registerService('TagService', function (IContainer $c) {
+ /** @var IServerContainer $server */
+ $server = $c->query(IServerContainer::class);
+
return new TagService(
- $c->query('ServerContainer')->getUserSession(),
- $c->query('ServerContainer')->getActivityManager(),
- $c->query('ServerContainer')->getTagManager()->load(self::APP_ID),
- $homeFolder,
+ $server->getUserSession(),
+ $server->getActivityManager(),
+ $server->getTagManager()->load(self::APP_ID),
+ $server->getUserFolder(),
$server->getEventDispatcher()
);
});
@@ -87,23 +102,79 @@ class Application extends App {
/*
* Register capabilities
*/
- $container->registerCapability(Capabilities::class);
+ $context->registerCapability(Capabilities::class);
- /**
- * Register Collaboration ResourceProvider
- */
+ $context->registerEventListener(LoadAdditionalScriptsEvent::class, LegacyLoadAdditionalScriptsAdapter::class);
+ $context->registerEventListener(LoadSidebar::class, LoadSidebarListener::class);
+ }
+
+ public function boot(IBootContext $context): void {
+ $this->registerCollaboration($context);
+ Listener::register($context->getServerContainer()->getEventDispatcher());
+ $this->registerNotification($context);
+ $this->registerSearchProvider($context);
+ $this->registerTemplates();
+ $this->registerNavigation($context);
+ $this->registerHooks();
+ }
+
+ /**
+ * Register Collaboration ResourceProvider
+ */
+ private function registerCollaboration(IBootContext $context): void {
/** @var IProviderManager $providerManager */
- $providerManager = $container->query(IProviderManager::class);
+ $providerManager = $context->getAppContainer()->query(IProviderManager::class);
$providerManager->registerResourceProvider(ResourceProvider::class);
- Listener::register($server->getEventDispatcher());
-
- /** @var IEventDispatcher $dispatcher */
- $dispatcher = $container->query(IEventDispatcher::class);
- $dispatcher->addServiceListener(LoadAdditionalScriptsEvent::class, LegacyLoadAdditionalScriptsAdapter::class);
- $dispatcher->addServiceListener(LoadSidebar::class, LoadSidebarListener::class);
+ }
- /** @var \OCP\Notification\IManager $notifications */
- $notifications = $container->query(\OCP\Notification\IManager::class);
+ private function registerNotification(IBootContext $context): void {
+ /** @var IManager $notifications */
+ $notifications = $context->getAppContainer()->query(IManager::class);
$notifications->registerNotifierService(Notifier::class);
}
+
+ /**
+ * @param IBootContext $context
+ */
+ private function registerSearchProvider(IBootContext $context): void {
+ $context->getServerContainer()->getSearch()->registerProvider(File::class, ['apps' => ['files']]);
+ }
+
+ private function registerTemplates(): void {
+ $templateManager = \OC_Helper::getFileTemplateManager();
+ $templateManager->registerTemplate('application/vnd.oasis.opendocument.presentation', 'core/templates/filetemplates/template.odp');
+ $templateManager->registerTemplate('application/vnd.oasis.opendocument.text', 'core/templates/filetemplates/template.odt');
+ $templateManager->registerTemplate('application/vnd.oasis.opendocument.spreadsheet', 'core/templates/filetemplates/template.ods');
+ }
+
+ private function registerNavigation(IBootContext $context): void {
+ /** @var IL10N $l10n */
+ $l10n = $context->getAppContainer()->query(IL10N::class);
+ \OCA\Files\App::getNavigationManager()->add([
+ 'id' => 'files',
+ 'appname' => 'files',
+ 'script' => 'list.php',
+ 'order' => 0,
+ 'name' => $l10n->t('All files')
+ ]);
+ \OCA\Files\App::getNavigationManager()->add([
+ 'id' => 'recent',
+ 'appname' => 'files',
+ 'script' => 'recentlist.php',
+ 'order' => 2,
+ 'name' => $l10n->t('Recent')
+ ]);
+ \OCA\Files\App::getNavigationManager()->add([
+ 'id' => 'favorites',
+ 'appname' => 'files',
+ 'script' => 'simplelist.php',
+ 'order' => 5,
+ 'name' => $l10n->t('Favorites'),
+ 'expandedState' => 'show_Quick_Access'
+ ]);
+ }
+
+ private function registerHooks(): void {
+ Util::connectHook('\OCP\Config', 'js', '\OCA\Files\App', 'extendJsConfig');
+ }
}