We don't support direct updates from older ownCloud versions except the previous one therefore this code is unused and can be removed.remotes/origin/fix-10825
parent
9df50c7be6
commit
8dbedbb849
@ -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'); |
||||
|
||||
} |
||||
} |
@ -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)); |
||||
} |
||||
|
||||
} |
Loading…
Reference in new issue