]> source.dussan.org Git - nextcloud-server.git/commitdiff
Try to delete the cypress folder of the viewer app 16297/head
authorMorris Jobke <hey@morrisjobke.de>
Mon, 8 Jul 2019 09:54:31 +0000 (11:54 +0200)
committerBackportbot <backportbot-noreply@rullzer.com>
Mon, 8 Jul 2019 17:19:34 +0000 (17:19 +0000)
Signed-off-by: Morris Jobke <hey@morrisjobke.de>
lib/composer/composer/autoload_classmap.php
lib/composer/composer/autoload_static.php
lib/private/Repair.php
lib/private/Repair/NC16/RemoveCypressFiles.php [new file with mode: 0644]

index 3130c2edd9849e6c5c1ddf0abdc4628cd05098e3..23baaf4bb3a52232d14c7492f6aba3f855088d8c 100644 (file)
@@ -1022,6 +1022,7 @@ return array(
     'OC\\Repair\\NC15\\SetVcardDatabaseUID' => $baseDir . '/lib/private/Repair/NC15/SetVcardDatabaseUID.php',
     'OC\\Repair\\NC16\\AddClenupLoginFlowV2BackgroundJob' => $baseDir . '/lib/private/Repair/NC16/AddClenupLoginFlowV2BackgroundJob.php',
     'OC\\Repair\\NC16\\CleanupCardDAVPhotoCache' => $baseDir . '/lib/private/Repair/NC16/CleanupCardDAVPhotoCache.php',
+    'OC\\Repair\\NC16\\RemoveCypressFiles' => $baseDir . '/lib/private/Repair/NC16/RemoveCypressFiles.php',
     'OC\\Repair\\OldGroupMembershipShares' => $baseDir . '/lib/private/Repair/OldGroupMembershipShares.php',
     'OC\\Repair\\Owncloud\\DropAccountTermsTable' => $baseDir . '/lib/private/Repair/Owncloud/DropAccountTermsTable.php',
     'OC\\Repair\\Owncloud\\SaveAccountsTableData' => $baseDir . '/lib/private/Repair/Owncloud/SaveAccountsTableData.php',
index 12b1fc03404c0ba473f76df53af75f4e924fd7e9..a32eddb2acd2ae59a42a3d3643cc580d61f31105 100644 (file)
@@ -1052,6 +1052,7 @@ class ComposerStaticInit53792487c5a8370acc0b06b1a864ff4c
         'OC\\Repair\\NC15\\SetVcardDatabaseUID' => __DIR__ . '/../../..' . '/lib/private/Repair/NC15/SetVcardDatabaseUID.php',
         'OC\\Repair\\NC16\\AddClenupLoginFlowV2BackgroundJob' => __DIR__ . '/../../..' . '/lib/private/Repair/NC16/AddClenupLoginFlowV2BackgroundJob.php',
         'OC\\Repair\\NC16\\CleanupCardDAVPhotoCache' => __DIR__ . '/../../..' . '/lib/private/Repair/NC16/CleanupCardDAVPhotoCache.php',
+        'OC\\Repair\\NC16\\RemoveCypressFiles' => __DIR__ . '/../../..' . '/lib/private/Repair/NC16/RemoveCypressFiles.php',
         'OC\\Repair\\OldGroupMembershipShares' => __DIR__ . '/../../..' . '/lib/private/Repair/OldGroupMembershipShares.php',
         'OC\\Repair\\Owncloud\\DropAccountTermsTable' => __DIR__ . '/../../..' . '/lib/private/Repair/Owncloud/DropAccountTermsTable.php',
         'OC\\Repair\\Owncloud\\SaveAccountsTableData' => __DIR__ . '/../../..' . '/lib/private/Repair/Owncloud/SaveAccountsTableData.php',
index d27e6b812b33e511d52cd04a8e8090f750289034..fa89e95e9f18fee2b0cd29f21f6ab66617b81df9 100644 (file)
@@ -45,6 +45,7 @@ use OC\Repair\NC14\RepairPendingCronJobs;
 use OC\Repair\NC15\SetVcardDatabaseUID;
 use OC\Repair\NC16\AddClenupLoginFlowV2BackgroundJob;
 use OC\Repair\NC16\CleanupCardDAVPhotoCache;
+use OC\Repair\NC16\RemoveCypressFiles;
 use OC\Repair\OldGroupMembershipShares;
 use OC\Repair\Owncloud\DropAccountTermsTable;
 use OC\Repair\Owncloud\SaveAccountsTableData;
@@ -155,6 +156,7 @@ class Repair implements IOutput {
                        new CleanupCardDAVPhotoCache(\OC::$server->getConfig(), \OC::$server->getAppDataDir('dav-photocache'), \OC::$server->getLogger()),
                        new AddClenupLoginFlowV2BackgroundJob(\OC::$server->getJobList()),
                        new RemoveLinkShares(\OC::$server->getDatabaseConnection(), \OC::$server->getConfig(), \OC::$server->getGroupManager(), \OC::$server->getNotificationManager(), \OC::$server->query(ITimeFactory::class)),
+                       \OC::$server->query(RemoveCypressFiles::class),
                ];
        }
 
diff --git a/lib/private/Repair/NC16/RemoveCypressFiles.php b/lib/private/Repair/NC16/RemoveCypressFiles.php
new file mode 100644 (file)
index 0000000..4b6108d
--- /dev/null
@@ -0,0 +1,82 @@
+<?php
+declare(strict_types=1);
+/**
+ * @copyright Copyright (c) 2019, Morris Jobke <hey@morrisjobke.de>
+ *
+ * @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 OC\Repair\NC16;
+
+use OC\IntegrityCheck\Checker;
+use OCP\Migration\IOutput;
+use OCP\Migration\IRepairStep;
+
+/**
+ * Class CleanupCypressFiles
+ *
+ * This repair step removes "cypress" files and folder created by viewer app in 16.0.1
+ *
+ * See https://github.com/nextcloud/server/issues/16229 for more details.
+ *
+ * @deprecated - can be removed in 18 because this is the first version where no migration from 16 can happen
+ */
+class RemoveCypressFiles implements IRepairStep {
+
+       /** @var Checker $checker */
+       private $checker;
+
+       private $pathToViewerApp = __DIR__ . '/../../../../apps/viewer';
+
+       public function getName(): string {
+               return 'Cleanup cypress files from viewer app';
+       }
+
+       public function __construct(Checker $checker) {
+               $this->checker = $checker;
+       }
+
+       public function run(IOutput $output): void {
+               $file = $this->pathToViewerApp . '/cypress.json';
+               if (file_exists($file)) {
+                       unlink($file);
+               }
+
+               $dir = $this->pathToViewerApp . '/cypress';
+               if (is_dir($dir)) {
+                       $files = new \RecursiveIteratorIterator(
+                               new \RecursiveDirectoryIterator($dir, \RecursiveDirectoryIterator::SKIP_DOTS),
+                               \RecursiveIteratorIterator::CHILD_FIRST
+                       );
+
+                       foreach ($files as $fileInfo) {
+                               /** @var \SplFileInfo $fileInfo */
+                               if ($fileInfo->isLink()) {
+                                       unlink($fileInfo->getPathname());
+                               } else if ($fileInfo->isDir()) {
+                                       rmdir($fileInfo->getRealPath());
+                               } else {
+                                       unlink($fileInfo->getRealPath());
+                               }
+                       }
+                       rmdir($dir);
+               }
+
+               // re-run the instance verification
+               $this->checker->runInstanceVerification();
+       }
+}