Browse Source
remote now unneeded AvatarPermissions repair step
remote now unneeded AvatarPermissions repair step
Avatars are now stored in appdata Signed-off-by: Robin Appelman <robin@icewind.nl>pull/3284/head
No known key found for this signature in database
GPG Key ID: 50F2B59C6DEBBCFE
5 changed files with 0 additions and 309 deletions
-
1lib/composer/composer/autoload_classmap.php
-
1lib/composer/composer/autoload_static.php
-
2lib/private/Repair.php
-
116lib/private/Repair/AvatarPermissions.php
-
189tests/lib/Repair/AvatarPermissionsTest.php
@ -1,116 +0,0 @@ |
|||
<?php |
|||
/** |
|||
* @copyright Copyright (c) 2016, ownCloud, Inc. |
|||
* |
|||
* @author Roeland Jago Douma <roeland@famdouma.nl> |
|||
* |
|||
* @license AGPL-3.0 |
|||
* |
|||
* This code is free software: you can redistribute it and/or modify |
|||
* it under the terms of the GNU Affero General Public License, version 3, |
|||
* as published by the Free Software Foundation. |
|||
* |
|||
* 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, version 3, |
|||
* along with this program. If not, see <http://www.gnu.org/licenses/> |
|||
* |
|||
*/ |
|||
namespace OC\Repair; |
|||
|
|||
use Doctrine\DBAL\Platforms\OraclePlatform; |
|||
use OCP\IDBConnection; |
|||
use OCP\Migration\IOutput; |
|||
use OCP\Migration\IRepairStep; |
|||
|
|||
/** |
|||
* Class AvatarPermissions |
|||
* |
|||
* @package OC\Repair |
|||
*/ |
|||
class AvatarPermissions implements IRepairStep { |
|||
/** @var IDBConnection */ |
|||
private $connection; |
|||
|
|||
/** |
|||
* AvatarPermissions constructor. |
|||
* |
|||
* @param IDBConnection $connection |
|||
*/ |
|||
public function __construct(IDBConnection $connection) { |
|||
$this->connection = $connection; |
|||
} |
|||
|
|||
/** |
|||
* @return string |
|||
*/ |
|||
public function getName() { |
|||
return 'Fix permissions so avatars can be stored again'; |
|||
} |
|||
|
|||
/** |
|||
* @param IOutput $output |
|||
*/ |
|||
public function run(IOutput $output) { |
|||
$output->startProgress(2); |
|||
$this->fixUserRootPermissions(); |
|||
$output->advance(); |
|||
$this->fixAvatarPermissions(); |
|||
$output->finishProgress(); |
|||
} |
|||
|
|||
/** |
|||
* Make sure all user roots have permissions 23 (all but share) |
|||
*/ |
|||
protected function fixUserRootPermissions() { |
|||
$qb = $this->connection->getQueryBuilder(); |
|||
$qb2 = $this->connection->getQueryBuilder(); |
|||
|
|||
$qb->select('numeric_id') |
|||
->from('storages') |
|||
->where($qb->expr()->like('id', $qb2->createParameter('like'))); |
|||
|
|||
if ($this->connection->getDatabasePlatform() instanceof OraclePlatform) { |
|||
// '' is null on oracle
|
|||
$path = $qb2->expr()->isNull('path'); |
|||
} else { |
|||
$path = $qb2->expr()->eq('path', $qb2->createNamedParameter('')); |
|||
} |
|||
|
|||
$qb2->update('filecache') |
|||
->set('permissions', $qb2->createNamedParameter(23)) |
|||
->where($path) |
|||
->andWhere($qb2->expr()->in('storage', $qb2->createFunction($qb->getSQL()))) |
|||
->andWhere($qb2->expr()->neq('permissions', $qb2->createNamedParameter(23))) |
|||
->setParameter('like', 'home::%'); |
|||
|
|||
|
|||
$qb2->execute(); |
|||
} |
|||
|
|||
/** |
|||
* Make sure all avatar files in the user roots have permission 27 |
|||
*/ |
|||
protected function fixAvatarPermissions() { |
|||
$qb = $this->connection->getQueryBuilder(); |
|||
$qb2 = $this->connection->getQueryBuilder(); |
|||
|
|||
$qb->select('numeric_id') |
|||
->from('storages') |
|||
->where($qb->expr()->like('id', $qb2->createParameter('like'))); |
|||
|
|||
$qb2->update('filecache') |
|||
->set('permissions', $qb2->createNamedParameter(27)) |
|||
->where($qb2->expr()->like('path', $qb2->createNamedParameter('avatar.%'))) |
|||
->andWhere($qb2->expr()->in('storage', $qb2->createFunction($qb->getSQL()))) |
|||
->andWhere($qb2->expr()->neq('permissions', $qb2->createNamedParameter(27))) |
|||
->setParameter('like', 'home::%'); |
|||
|
|||
$qb2->execute(); |
|||
} |
|||
|
|||
} |
|||
|
|||
@ -1,189 +0,0 @@ |
|||
<?php |
|||
/** |
|||
* @author Roeland Jago Douma <rullzer@owncloud.com> |
|||
* |
|||
* @copyright Copyright (c) 2016, ownCloud, Inc. |
|||
* @license AGPL-3.0 |
|||
* |
|||
* This code is free software: you can redistribute it and/or modify |
|||
* it under the terms of the GNU Affero General Public License, version 3, |
|||
* as published by the Free Software Foundation. |
|||
* |
|||
* 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, version 3, |
|||
* along with this program. If not, see <http://www.gnu.org/licenses/> |
|||
* |
|||
*/ |
|||
namespace Test\Repair; |
|||
|
|||
/** |
|||
* Test for fixing the userRoot and avatar permissions |
|||
* |
|||
* @group DB |
|||
* |
|||
* @see \OC\Repair\AvatarPermissionsTest |
|||
*/ |
|||
class AvatarPermissionsTest extends \Test\TestCase { |
|||
|
|||
/** @var \OC\Repair\AvatarPermissions */ |
|||
protected $repair; |
|||
|
|||
/** @var \OCP\IDBConnection */ |
|||
protected $connection; |
|||
|
|||
protected function setUp() { |
|||
parent::setUp(); |
|||
|
|||
$this->connection = \OC::$server->getDatabaseConnection(); |
|||
$this->repair = new \OC\Repair\AvatarPermissions($this->connection); |
|||
$this->cleanUpTables(); |
|||
} |
|||
|
|||
protected function tearDown() { |
|||
$this->cleanUpTables(); |
|||
|
|||
parent::tearDown(); |
|||
} |
|||
|
|||
protected function cleanUpTables() { |
|||
$qb = $this->connection->getQueryBuilder(); |
|||
$qb->delete('filecache')->execute(); |
|||
$qb->delete('storages')->execute(); |
|||
} |
|||
|
|||
public function dataFixUserRootPermissions() { |
|||
return [ |
|||
['home::user', '', 0, 23], |
|||
['home::user', 'foo', 0, 0], |
|||
['home::user', 'avatar.jpg', 0, 0], |
|||
['ABC::user', '', 0, 0], |
|||
['ABC::user', 'foo', 0, 0], |
|||
]; |
|||
} |
|||
|
|||
/** |
|||
* @dataProvider dataFixUserRootPermissions |
|||
* |
|||
* @param string $storageId |
|||
* @param string $path |
|||
* @param int $permissionsBefore |
|||
* @param int $permissionsAfter |
|||
*/ |
|||
public function testFixUserRootPermissions($storageId, $path, $permissionsBefore, $permissionsAfter) { |
|||
$userStorage = $this->addStorage($storageId); |
|||
$userHome = $this->addFileCacheEntry($userStorage, $path, $permissionsBefore); |
|||
|
|||
$this->invokePrivate($this->repair, 'fixUserRootPermissions', []); |
|||
|
|||
$this->verifyPermissions($userHome, $permissionsAfter); |
|||
} |
|||
|
|||
public function dataFixAvatarPermissions() { |
|||
return [ |
|||
['home::user', '', 0, 0], |
|||
['home::user', 'avatar.jpg', 0, 27], |
|||
['home::user', 'avatar.png', 0, 27], |
|||
['home::user', 'avatar.32.png', 0, 27], |
|||
['home::user', 'mine.txt', 0, 0], |
|||
['ABC::user', '', 0, 0], |
|||
['ABC::user', 'avatar.jpg', 0, 0], |
|||
['ABC::user', 'avatar.png', 0, 0], |
|||
['ABC::user', 'avatar.32.png', 0, 0], |
|||
['ABC::user', 'mine.txt', 0, 0], |
|||
]; |
|||
} |
|||
|
|||
/** |
|||
* @dataProvider dataFixAvatarPermissions |
|||
* |
|||
* @param string $storageId |
|||
* @param string $path |
|||
* @param int $permissionsBefore |
|||
* @param int $permissionsAfter |
|||
*/ |
|||
public function testFixAvatarPermissions($storageId, $path, $permissionsBefore, $permissionsAfter) { |
|||
$userStorage = $this->addStorage($storageId); |
|||
$userHome = $this->addFileCacheEntry($userStorage, $path, $permissionsBefore); |
|||
|
|||
$this->invokePrivate($this->repair, 'fixAvatarPermissions', []); |
|||
|
|||
$this->verifyPermissions($userHome, $permissionsAfter); |
|||
} |
|||
|
|||
/** |
|||
* Add a new storage |
|||
* |
|||
* @param string $id |
|||
* @return int The numeric id |
|||
*/ |
|||
protected function addStorage($id) { |
|||
$qb = $this->connection->getQueryBuilder(); |
|||
|
|||
$qb->insert('storages') |
|||
->values([ |
|||
'id' => $qb->createNamedParameter($id) |
|||
]); |
|||
|
|||
$qb->execute(); |
|||
|
|||
return $qb->getLastInsertId(); |
|||
} |
|||
|
|||
/** |
|||
* Add a filecache entry |
|||
* |
|||
* @param int $storage |
|||
* @param string $path |
|||
* @param int $permissions |
|||
* |
|||
* @return int The fileid |
|||
*/ |
|||
protected function addFileCacheEntry($storage, $path, $permissions) { |
|||
$qb = $this->connection->getQueryBuilder(); |
|||
|
|||
$qb->insert('filecache') |
|||
->values([ |
|||
'path' => $qb->createNamedParameter($path), |
|||
'path_hash' => $qb->createNamedParameter(md5($path)), |
|||
'parent' => $qb->createNamedParameter(42), |
|||
'mimetype' => $qb->createNamedParameter(23), |
|||
'mimepart' => $qb->createNamedParameter(32), |
|||
'size' => $qb->createNamedParameter(16), |
|||
'mtime' => $qb->createNamedParameter(1), |
|||
'storage_mtime' => $qb->createNamedParameter(2), |
|||
'encrypted' => $qb->createNamedParameter(0), |
|||
'unencrypted_size' => $qb->createNamedParameter(0), |
|||
'storage' => $qb->createNamedParameter($storage), |
|||
'permissions' => $qb->createNamedParameter($permissions), |
|||
]); |
|||
|
|||
$qb->execute(); |
|||
|
|||
return $qb->getLastInsertId(); |
|||
} |
|||
|
|||
/** |
|||
* @param int $fileId |
|||
* @param int $permissions |
|||
*/ |
|||
protected function verifyPermissions($fileId, $permissions) { |
|||
$qb = $this->connection->getQueryBuilder(); |
|||
|
|||
$qb->select('permissions') |
|||
->from('filecache') |
|||
->where($qb->expr()->eq('fileid', $qb->createNamedParameter($fileId))); |
|||
|
|||
$cursor = $qb->execute(); |
|||
|
|||
$data = $cursor->fetch(); |
|||
$cursor->closeCursor(); |
|||
|
|||
$this->assertSame($permissions, (int)$data['permissions']); |
|||
} |
|||
|
|||
|
|||
} |
|||
Write
Preview
Loading…
Cancel
Save
Reference in new issue