]> source.dussan.org Git - nextcloud-server.git/commitdiff
Only load direct editing capabilities when required 32715/head
authorJulius Härtl <jus@bitgrid.net>
Fri, 3 Jun 2022 05:15:17 +0000 (07:15 +0200)
committerJulius Härtl <jus@bitgrid.net>
Fri, 3 Jun 2022 05:15:17 +0000 (07:15 +0200)
Signed-off-by: Julius Härtl <jus@bitgrid.net>
apps/files/composer/composer/autoload_classmap.php
apps/files/composer/composer/autoload_static.php
apps/files/lib/AppInfo/Application.php
apps/files/lib/Capabilities.php
apps/files/lib/DirectEditingCapabilities.php [new file with mode: 0644]

index 05ea0a46ca14a346a6f9c7e32b50af136e8c0752..46da43165b982eaa34ea893b0629e53a8cc30ea2 100644 (file)
@@ -40,6 +40,7 @@ return array(
     'OCA\\Files\\Controller\\ViewController' => $baseDir . '/../lib/Controller/ViewController.php',
     'OCA\\Files\\Db\\TransferOwnership' => $baseDir . '/../lib/Db/TransferOwnership.php',
     'OCA\\Files\\Db\\TransferOwnershipMapper' => $baseDir . '/../lib/Db/TransferOwnershipMapper.php',
+    'OCA\\Files\\DirectEditingCapabilities' => $baseDir . '/../lib/DirectEditingCapabilities.php',
     'OCA\\Files\\Event\\LoadAdditionalScriptsEvent' => $baseDir . '/../lib/Event/LoadAdditionalScriptsEvent.php',
     'OCA\\Files\\Event\\LoadSidebar' => $baseDir . '/../lib/Event/LoadSidebar.php',
     'OCA\\Files\\Exception\\TransferOwnershipException' => $baseDir . '/../lib/Exception/TransferOwnershipException.php',
index ba39b2c57073ae077513870cd11cd108b782b9d3..ea9d9715fd3b0cb3c3315b318caf3c5fa7fd7e2d 100644 (file)
@@ -55,6 +55,7 @@ class ComposerStaticInitFiles
         'OCA\\Files\\Controller\\ViewController' => __DIR__ . '/..' . '/../lib/Controller/ViewController.php',
         'OCA\\Files\\Db\\TransferOwnership' => __DIR__ . '/..' . '/../lib/Db/TransferOwnership.php',
         'OCA\\Files\\Db\\TransferOwnershipMapper' => __DIR__ . '/..' . '/../lib/Db/TransferOwnershipMapper.php',
+        'OCA\\Files\\DirectEditingCapabilities' => __DIR__ . '/..' . '/../lib/DirectEditingCapabilities.php',
         'OCA\\Files\\Event\\LoadAdditionalScriptsEvent' => __DIR__ . '/..' . '/../lib/Event/LoadAdditionalScriptsEvent.php',
         'OCA\\Files\\Event\\LoadSidebar' => __DIR__ . '/..' . '/../lib/Event/LoadSidebar.php',
         'OCA\\Files\\Exception\\TransferOwnershipException' => __DIR__ . '/..' . '/../lib/Exception/TransferOwnershipException.php',
index 26d541f57e832e133ff573d8ca0f790b64da94bc..2662f2d6e9b48b5ea62ee648435ce887684b02f4 100644 (file)
@@ -39,6 +39,7 @@ use OCA\Files\Capabilities;
 use OCA\Files\Collaboration\Resources\Listener;
 use OCA\Files\Collaboration\Resources\ResourceProvider;
 use OCA\Files\Controller\ApiController;
+use OCA\Files\DirectEditingCapabilities;
 use OCA\Files\Event\LoadAdditionalScriptsEvent;
 use OCA\Files\Event\LoadSidebar;
 use OCA\Files\Listener\LegacyLoadAdditionalScriptsAdapter;
@@ -111,6 +112,7 @@ class Application extends App implements IBootstrap {
                 * Register capabilities
                 */
                $context->registerCapability(Capabilities::class);
+               $context->registerCapability(DirectEditingCapabilities::class);
 
                $context->registerEventListener(LoadAdditionalScriptsEvent::class, LegacyLoadAdditionalScriptsAdapter::class);
                $context->registerEventListener(LoadSidebar::class, LoadSidebarListener::class);
index 29abfb5b25315b3bec4cc045ad61674fefb2ef13..3eb43578351802701c6907bbb78b19b1b300d33e 100644 (file)
  */
 namespace OCA\Files;
 
-use OCA\Files\Service\DirectEditingService;
 use OCP\Capabilities\ICapability;
 use OCP\IConfig;
-use OCP\IURLGenerator;
 
-/**
- * Class Capabilities
- *
- * @package OCA\Files
- */
 class Capabilities implements ICapability {
 
-       /** @var IConfig */
-       protected $config;
-
-       /** @var DirectEditingService */
-       protected $directEditingService;
+       protected IConfig $config;
 
-       /** @var IURLGenerator */
-       private $urlGenerator;
-
-       /**
-        * Capabilities constructor.
-        *
-        * @param IConfig $config
-        */
-       public function __construct(IConfig $config, DirectEditingService $directEditingService, IURLGenerator $urlGenerator) {
+       public function __construct(IConfig $config) {
                $this->config = $config;
-               $this->directEditingService = $directEditingService;
-               $this->urlGenerator = $urlGenerator;
        }
 
        /**
@@ -66,11 +45,7 @@ class Capabilities implements ICapability {
                return [
                        'files' => [
                                'bigfilechunking' => true,
-                               'blacklisted_files' => $this->config->getSystemValue('blacklisted_files', ['.htaccess']),
-                               'directEditing' => [
-                                       'url' => $this->urlGenerator->linkToOCSRouteAbsolute('files.DirectEditing.info'),
-                                       'etag' => $this->directEditingService->getDirectEditingETag()
-                               ]
+                               'blacklisted_files' => $this->config->getSystemValue('blacklisted_files', ['.htaccess'])
                        ],
                ];
        }
diff --git a/apps/files/lib/DirectEditingCapabilities.php b/apps/files/lib/DirectEditingCapabilities.php
new file mode 100644 (file)
index 0000000..782f701
--- /dev/null
@@ -0,0 +1,51 @@
+<?php
+declare(strict_types=1);
+/**
+ * @copyright Copyright (c) 2022 Julius Härtl <jus@bitgrid.net>
+ *
+ * @author Julius Härtl <jus@bitgrid.net>
+ *
+ * @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\Files;
+
+use OCA\Files\Service\DirectEditingService;
+use OCP\Capabilities\ICapability;
+use OCP\Capabilities\IInitialStateExcludedCapability;
+use OCP\IURLGenerator;
+
+class DirectEditingCapabilities implements ICapability, IInitialStateExcludedCapability {
+
+       protected DirectEditingService $directEditingService;
+       protected IURLGenerator $urlGenerator;
+
+       public function __construct(DirectEditingService $directEditingService, IURLGenerator $urlGenerator) {
+               $this->directEditingService = $directEditingService;
+               $this->urlGenerator = $urlGenerator;
+       }
+
+       public function getCapabilities() {
+               return [
+                       'files' => [
+                               'directEditing' => [
+                                       'url' => $this->urlGenerator->linkToOCSRouteAbsolute('files.DirectEditing.info'),
+                                       'etag' => $this->directEditingService->getDirectEditingETag()
+                               ]
+                       ],
+               ];
+       }
+}