]> source.dussan.org Git - nextcloud-server.git/commitdiff
Remove unused code
authorLukas Reschke <lukas@owncloud.com>
Mon, 17 Nov 2014 10:11:19 +0000 (11:11 +0100)
committerLukas Reschke <lukas@owncloud.com>
Mon, 17 Nov 2014 13:01:39 +0000 (14:01 +0100)
We don't support direct updates from older ownCloud versions except the previous one therefore this code is unused and can be removed.

apps/files_sharing/appinfo/update.php [deleted file]
apps/files_sharing/tests/update.php [deleted file]
apps/files_sharing/tests/updater.php

diff --git a/apps/files_sharing/appinfo/update.php b/apps/files_sharing/appinfo/update.php
deleted file mode 100644 (file)
index e393b15..0000000
+++ /dev/null
@@ -1,120 +0,0 @@
-<?php
-
-$installedVersion = OCP\Config::getAppValue('files_sharing', 'installed_version');
-
-if (version_compare($installedVersion, '0.5', '<')) {
-       updateFilePermissions();
-}
-
-if (version_compare($installedVersion, '0.4', '<')) {
-       removeSharedFolder();
-}
-
-// clean up oc_share table from files which are no longer exists
-if (version_compare($installedVersion, '0.3.5.6', '<')) {
-       \OC\Files\Cache\Shared_Updater::fixBrokenSharesOnAppUpdate();
-}
-
-
-/**
- * it is no longer possible to share single files with delete permissions. User
- * should only be able to unshare single files but never to delete them.
- */
-function updateFilePermissions($chunkSize = 99) {
-       $query = OCP\DB::prepare('SELECT * FROM `*PREFIX*share` WHERE `item_type` = ?');
-       $result = $query->execute(array('file'));
-
-       $updatedRows = array();
-
-       while ($row = $result->fetchRow()) {
-               if ($row['permissions'] & \OCP\PERMISSION_DELETE) {
-                       $updatedRows[$row['id']] = (int)$row['permissions'] & ~\OCP\PERMISSION_DELETE;
-               }
-       }
-
-       $connection = \OC_DB::getConnection();
-       $chunkedPermissionList = array_chunk($updatedRows, $chunkSize, true);
-
-       foreach ($chunkedPermissionList as $subList) {
-               $statement = "UPDATE `*PREFIX*share` SET `permissions` = CASE `id` ";
-               //update share table
-               $ids = implode(',', array_keys($subList));
-               foreach ($subList as $id => $permission) {
-                       $statement .= "WHEN " . $connection->quote($id, \PDO::PARAM_INT) . " THEN " . $permission . " ";
-               }
-               $statement .= ' END WHERE `id` IN (' . $ids . ')';
-
-               $query = OCP\DB::prepare($statement);
-               $query->execute();
-       }
-
-}
-
-/**
- * update script for the removal of the logical "Shared" folder, we create physical "Shared" folder and
- * update the users file_target so that it doesn't make any difference for the user
- * @note parameters are just for testing, please ignore them
- */
-function removeSharedFolder($mkdirs = true, $chunkSize = 99) {
-       $query = OCP\DB::prepare('SELECT * FROM `*PREFIX*share`');
-       $result = $query->execute();
-       $view = new \OC\Files\View('/');
-       $users = array();
-       $shares = array();
-       //we need to set up user backends
-       OC_User::useBackend(new OC_User_Database());
-       OC_Group::useBackend(new OC_Group_Database());
-       OC_App::loadApps(array('authentication'));
-       //we need to set up user backends, otherwise creating the shares will fail with "because user does not exist"
-       while ($row = $result->fetchRow()) {
-               //collect all user shares
-               if ((int)$row['share_type'] === 0 && ($row['item_type'] === 'file' || $row['item_type'] === 'folder')) {
-                       $users[] = $row['share_with'];
-                       $shares[$row['id']] = $row['file_target'];
-               } else if ((int)$row['share_type'] === 1 && ($row['item_type'] === 'file' || $row['item_type'] === 'folder')) {
-                       //collect all group shares
-                       $users = array_merge($users, \OC_group::usersInGroup($row['share_with']));
-                       $shares[$row['id']] = $row['file_target'];
-               } else if ((int)$row['share_type'] === 2) {
-                       $shares[$row['id']] = $row['file_target'];
-               }
-       }
-
-       $unique_users = array_unique($users);
-
-       if (!empty($unique_users) && !empty($shares)) {
-
-               // create folder Shared for each user
-
-               if ($mkdirs) {
-                       foreach ($unique_users as $user) {
-                               \OC\Files\Filesystem::initMountPoints($user);
-                               if (!$view->file_exists('/' . $user . '/files/Shared')) {
-                                       $view->mkdir('/' . $user . '/files/Shared');
-                               }
-                       }
-               }
-
-               $chunkedShareList = array_chunk($shares, $chunkSize, true);
-               $connection = \OC_DB::getConnection();
-
-               foreach ($chunkedShareList as $subList) {
-
-                       $statement = "UPDATE `*PREFIX*share` SET `file_target` = CASE `id` ";
-                       //update share table
-                       $ids = implode(',', array_keys($subList));
-                       foreach ($subList as $id => $target) {
-                               $statement .= "WHEN " . $connection->quote($id, \PDO::PARAM_INT) . " THEN " . $connection->quote('/Shared' . $target, \PDO::PARAM_STR);
-                       }
-                       $statement .= ' END WHERE `id` IN (' . $ids . ')';
-
-                       $query = OCP\DB::prepare($statement);
-
-                       $query->execute(array());
-               }
-
-               // set config to keep the Shared folder as the default location for new shares
-               \OCA\Files_Sharing\Helper::setShareFolder('/Shared');
-
-       }
-}
diff --git a/apps/files_sharing/tests/update.php b/apps/files_sharing/tests/update.php
deleted file mode 100644 (file)
index 583f607..0000000
+++ /dev/null
@@ -1,252 +0,0 @@
-<?php
-/**
- * ownCloud
- *
- * @author Morris Jobke, Bjoern Schiessle
- * @copyright 2014 Morris Jobke <morris.jobke@gmail.com>
- *            2014 Bjoern Schiessle <schiessle@ownlcoud.com>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or any later version.
- *
- * This library 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 library.  If not, see <http://www.gnu.org/licenses/>.
- *
- */
-
-require_once __DIR__ . '/../appinfo/update.php';
-
-/**
- * Class Test_Files_Sharing_Update
- */
-class Test_Files_Sharing_Update_Routine extends OCA\Files_Sharing\Tests\TestCase {
-
-       const TEST_FOLDER_NAME = '/folder_share_api_test';
-
-       function setUp() {
-               parent::setUp();
-
-               $this->folder = self::TEST_FOLDER_NAME;
-
-               $this->filename = '/share-api-test.txt';
-
-               // save file with content
-               $this->view->file_put_contents($this->filename, $this->data);
-               $this->view->mkdir($this->folder);
-               $this->view->file_put_contents($this->folder . '/' . $this->filename, $this->data);
-       }
-
-       function tearDown() {
-               $this->view->unlink($this->filename);
-               $this->view->deleteAll($this->folder);
-
-               $removeShares = \OC_DB::prepare('DELETE FROM `*PREFIX*share`');
-               $removeShares->execute();
-               $removeItems = \OC_DB::prepare('DELETE FROM `*PREFIX*filecache`');
-               $removeItems->execute();
-
-               parent::tearDown();
-       }
-
-       /**
-        * test update of file permission. The update should remove from all shared
-        * files the delete permission
-        */
-       function testUpdateFilePermissions() {
-
-               self::prepareDBUpdateFilePermissions();
-               // run the update routine to update the share permission
-               updateFilePermissions(2);
-
-               // verify results
-               $query = \OC_DB::prepare('SELECT * FROM `*PREFIX*share`');
-               $result = $query->execute(array());
-
-               while ($row = $result->fetchRow()) {
-                       if ($row['item_type'] === 'file') {
-                               // for all files the delete permission should be removed
-                               $this->assertSame(0, (int)$row['permissions'] & \OCP\PERMISSION_DELETE);
-                       } else {
-                               // for all other the permission shouldn't change
-                               $this->assertSame(31, (int)$row['permissions'] & \OCP\PERMISSION_ALL);
-                       }
-               }
-
-               // cleanup
-               $this->cleanupSharedTable();
-       }
-
-       /**
-        * @medium
-        */
-       function testRemoveBrokenFileShares() {
-
-               $this->prepareFileCache();
-
-               // check if there are just 4 shares (see setUp - precondition: empty table)
-               $countAllShares = \OC_DB::prepare('SELECT COUNT(`id`) FROM `*PREFIX*share`');
-               $result = $countAllShares->execute()->fetchOne();
-               $this->assertEquals(4, $result);
-
-               // check if there are just 3 file shares (see setUp - precondition: empty table)
-               $countFileShares = \OC_DB::prepare('SELECT COUNT(`id`) FROM `*PREFIX*share` WHERE `item_type` IN (\'file\', \'folder\')');
-               $result = $countFileShares->execute()->fetchOne();
-               $this->assertEquals(3, $result);
-
-               // check if there are just 2 items (see setUp - precondition: empty table)
-               $countItems = \OC_DB::prepare('SELECT COUNT(`fileid`) FROM `*PREFIX*filecache`');
-               $result = $countItems->execute()->fetchOne();
-               $this->assertEquals(2, $result);
-
-               // execute actual code which should be tested
-               \OC\Files\Cache\Shared_Updater::fixBrokenSharesOnAppUpdate();
-
-               // check if there are just 2 shares (one gets killed by the code as there is no filecache entry for this)
-               $result = $countFileShares->execute()->fetchOne();
-               $this->assertEquals(2, $result);
-
-               // check if the share of file '200' is removed as there is no entry for this in filecache table
-               $countFileShares = \OC_DB::prepare('SELECT COUNT(`id`) FROM `*PREFIX*share` WHERE `file_source` = 200');
-               $result = $countFileShares->execute()->fetchOne();
-               $this->assertEquals(0, $result);
-
-               // check if there are just 2 items
-               $countItems = \OC_DB::prepare('SELECT COUNT(`fileid`) FROM `*PREFIX*filecache`');
-               $result = $countItems->execute()->fetchOne();
-               $this->assertEquals(2, $result);
-
-               // the calendar share survived
-               $countOtherShares = \OC_DB::prepare('SELECT COUNT(`id`) FROM `*PREFIX*share` WHERE `item_source` = \'999\'');
-               $result = $countOtherShares->execute()->fetchOne();
-               $this->assertEquals(1, $result);
-       }
-
-       /**
-        * test update for the removal of the logical "Shared" folder. It should update
-        * the file_target for every share and create a physical "Shared" folder for each user
-        */
-       function testRemoveSharedFolder() {
-               self::prepareDB();
-               // run the update routine to remove the shared folder and replace it with a real folder
-               removeSharedFolder(false, 2);
-
-               // verify results
-               $query = \OC_DB::prepare('SELECT * FROM `*PREFIX*share`');
-               $result = $query->execute(array());
-
-               $newDBContent = $result->fetchAll();
-
-               foreach ($newDBContent as $row) {
-                       if ((int)$row['share_type'] === \OCP\Share::SHARE_TYPE_USER) {
-                               $this->assertSame('/Shared', substr($row['file_target'], 0, strlen('/Shared')));
-                       } else {
-                               $this->assertSame('/ShouldNotChange', $row['file_target']);
-                       }
-               }
-
-               $shareFolder = \OCP\Config::getSystemValue('share_folder', '/');
-
-               $this->assertSame('/Shared', $shareFolder);
-
-               // cleanup
-               $this->cleanupSharedTable();
-               \OCP\Config::deleteSystemValue('share_folder');
-
-       }
-
-       private function cleanupSharedTable() {
-               $query = \OC_DB::prepare('DELETE FROM `*PREFIX*share`');
-               $query->execute();
-       }
-
-       /**
-        * prepare sharing table for testRemoveSharedFolder()
-        */
-       private function prepareDB() {
-               $this->cleanupSharedTable();
-               // add items except one - because this is the test case for the broken share table
-               $addItems = \OC_DB::prepare('INSERT INTO `*PREFIX*share` (`share_type`, `item_type`, ' .
-                       '`share_with`, `uid_owner` , `file_target`) ' .
-                       'VALUES (?, ?, ?, ?, ?)');
-               $items = array(
-                       array(\OCP\Share::SHARE_TYPE_USER, 'file', 'user1', 'admin' , '/foo'),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'folder', 'user2', 'admin', '/foo2'),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'file', 'user3', 'admin', '/foo3'),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'folder', 'user4', 'admin', '/foo4'),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'folder', 'user4', 'admin', "/foo'4"),
-                       array(\OCP\Share::SHARE_TYPE_LINK, 'file', 'user1', 'admin', '/ShouldNotChange'),
-                       array(\OCP\Share::SHARE_TYPE_CONTACT, 'contact', 'admin', 'user1', '/ShouldNotChange'),
-
-                       );
-               foreach($items as $item) {
-                       // the number is used as path_hash
-                       $addItems->execute($item);
-               }
-       }
-
-       /**
-        * prepare sharing table for testUpdateFilePermissions()
-        */
-       private function prepareDBUpdateFilePermissions() {
-               $this->cleanupSharedTable();
-               // add items except one - because this is the test case for the broken share table
-               $addItems = \OC_DB::prepare('INSERT INTO `*PREFIX*share` (`share_type`, `item_type`, ' .
-                       '`share_with`, `uid_owner` , `file_target`, `permissions`) ' .
-                       'VALUES (?, ?, ?, ?, ?, ?)');
-               $items = array(
-                       array(\OCP\Share::SHARE_TYPE_LINK, 'file', 'user1', 'admin', '/foo', \OCP\PERMISSION_ALL),
-                       array(\OCP\Share::SHARE_TYPE_CONTACT, 'contact', 'admin', 'user1', '/foo', \OCP\PERMISSION_ALL),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'folder', 'user4', 'admin', '/foo', \OCP\PERMISSION_ALL),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'file', 'user3', 'admin', '/foo3', \OCP\PERMISSION_ALL),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'file', 'user1', 'admin' , '/foo', \OCP\PERMISSION_DELETE),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'file', 'user1', 'admin' , '/foo', \OCP\PERMISSION_READ & \OCP\PERMISSION_DELETE),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'file', 'user1', 'admin' , '/foo', \OCP\PERMISSION_SHARE & \OCP\PERMISSION_UPDATE),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'file', 'user1', 'admin' , '/foo', \OCP\PERMISSION_ALL),
-                       array(\OCP\Share::SHARE_TYPE_USER, 'file', 'user1', 'admin' , '/foo', \OCP\PERMISSION_SHARE & \OCP\PERMISSION_READ & \OCP\PERMISSION_DELETE),
-                       );
-               foreach($items as $item) {
-                       // the number is used as path_hash
-                       $addItems->execute($item);
-               }
-       }
-
-       /**
-        * prepare file cache for testRemoveBrokenShares()
-        */
-       private function prepareFileCache() {
-               // some previous tests didn't clean up and therefore this has to be done here
-               // FIXME: DIRTY HACK - TODO: find tests, that don't clean up and fix it there
-               $this->tearDown();
-
-               // add items except one - because this is the test case for the broken share table
-               $addItems = \OC_DB::prepare('INSERT INTO `*PREFIX*filecache` (`storage`, `path_hash`, ' .
-                       '`parent`, `mimetype`, `mimepart`, `size`, `mtime`, `storage_mtime`) ' .
-                       'VALUES (1, ?, 1, 1, 1, 1, 1, 1)');
-               $items = array(1, 3);
-               $fileIds = array();
-               foreach($items as $item) {
-                       // the number is used as path_hash
-                       $addItems->execute(array($item));
-                       $fileIds[] = \OC_DB::insertId('*PREFIX*filecache');
-               }
-
-               $addShares = \OC_DB::prepare('INSERT INTO `*PREFIX*share` (`file_source`, `item_type`, `uid_owner`) VALUES (?, \'file\', 1)');
-               // the number is used as item_source
-               $addShares->execute(array($fileIds[0]));
-               $addShares->execute(array(200)); // id of "deleted" file
-               $addShares->execute(array($fileIds[1]));
-
-               // add a few unrelated shares, calendar share that must be left untouched
-               $addShares = \OC_DB::prepare('INSERT INTO `*PREFIX*share` (`item_source`, `item_type`, `uid_owner`) VALUES (?, \'calendar\', 1)');
-               // the number is used as item_source
-               $addShares->execute(array(999));
-       }
-
-}
index 07349c1334dbe6ab4d52d425828b255b3e268333..861516dff7f15cf9120bf51c6e46020a3896c17e 100644 (file)
@@ -20,7 +20,6 @@
  *
  */
 
-require_once __DIR__ . '/../appinfo/update.php';
 
 /**
  * Class Test_Files_Sharing_Updater