2012-12-16 00:44:46 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* ownCloud
|
|
|
|
*
|
|
|
|
* @author Michael Gapczynski
|
|
|
|
* @copyright 2012 Michael Gapczynski mtgap@owncloud.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/>.
|
|
|
|
*/
|
|
|
|
namespace OC\Files\Cache;
|
|
|
|
|
2013-01-07 23:17:14 +00:00
|
|
|
class Shared_Permissions extends Permissions {
|
2012-12-16 00:44:46 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* get the permissions for a single file
|
|
|
|
*
|
|
|
|
* @param int $fileId
|
|
|
|
* @param string $user
|
2014-05-23 15:15:05 +00:00
|
|
|
* @return int permissions
|
2012-12-16 00:44:46 +00:00
|
|
|
*/
|
2013-01-07 23:17:14 +00:00
|
|
|
public function get($fileId, $user) {
|
2014-05-13 13:22:18 +00:00
|
|
|
|
2014-05-23 15:15:05 +00:00
|
|
|
$permissions = $this->storage->getPermissions();
|
2014-05-13 13:22:18 +00:00
|
|
|
|
2014-05-23 15:15:05 +00:00
|
|
|
return $this->updatePermissions($permissions);
|
2012-12-16 00:44:46 +00:00
|
|
|
}
|
|
|
|
|
2014-02-06 15:30:58 +00:00
|
|
|
/**
|
|
|
|
* @param integer $fileId
|
|
|
|
* @param string $user
|
|
|
|
*/
|
2013-12-09 17:14:58 +00:00
|
|
|
private function getFile($fileId, $user) {
|
2014-05-23 15:15:05 +00:00
|
|
|
return $this->get($fileId, $user);
|
2013-12-09 17:14:58 +00:00
|
|
|
}
|
|
|
|
|
2012-12-16 00:44:46 +00:00
|
|
|
/**
|
|
|
|
* set the permissions of a file
|
|
|
|
*
|
|
|
|
* @param int $fileId
|
|
|
|
* @param string $user
|
|
|
|
* @param int $permissions
|
|
|
|
*/
|
2013-01-07 23:17:14 +00:00
|
|
|
public function set($fileId, $user, $permissions) {
|
2012-12-16 00:44:46 +00:00
|
|
|
// Not a valid action for Shared Permissions
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* get the permissions of multiply files
|
|
|
|
*
|
|
|
|
* @param int[] $fileIds
|
|
|
|
* @param string $user
|
|
|
|
* @return int[]
|
|
|
|
*/
|
2013-01-07 23:17:14 +00:00
|
|
|
public function getMultiple($fileIds, $user) {
|
2014-06-02 16:53:01 +00:00
|
|
|
$filePermissions = array();
|
2012-12-16 00:44:46 +00:00
|
|
|
foreach ($fileIds as $fileId) {
|
2014-05-23 15:15:05 +00:00
|
|
|
$filePermissions[$fileId] = $this->get($fileId, $user);
|
2012-12-16 00:44:46 +00:00
|
|
|
}
|
|
|
|
return $filePermissions;
|
|
|
|
}
|
|
|
|
|
2013-05-29 22:22:54 +00:00
|
|
|
/**
|
|
|
|
* get the permissions for all files in a folder
|
|
|
|
*
|
|
|
|
* @param int $parentId
|
|
|
|
* @param string $user
|
|
|
|
* @return int[]
|
|
|
|
*/
|
|
|
|
public function getDirectoryPermissions($parentId, $user) {
|
2014-05-23 15:15:05 +00:00
|
|
|
|
2014-06-02 18:39:20 +00:00
|
|
|
if ($parentId === -1 && $this->storage->instanceOfStorage('\OC\Files\Storage\Shared')) {
|
|
|
|
$fileCacheId = $this->storage->getSourceId();
|
|
|
|
} else {
|
|
|
|
$fileCacheId = $parentId;
|
|
|
|
}
|
2014-05-23 15:15:05 +00:00
|
|
|
|
2013-05-29 22:22:54 +00:00
|
|
|
$query = \OC_DB::prepare('SELECT `fileid` FROM `*PREFIX*filecache` WHERE `parent` = ?');
|
2014-05-23 15:15:05 +00:00
|
|
|
$result = $query->execute(array($fileCacheId));
|
|
|
|
$permissions = $this->get($parentId, $user);
|
2013-05-29 22:22:54 +00:00
|
|
|
$filePermissions = array();
|
|
|
|
while ($row = $result->fetchRow()) {
|
2014-05-23 15:15:05 +00:00
|
|
|
$filePermissions[$row['fileid']] = $permissions;
|
2013-05-29 22:22:54 +00:00
|
|
|
}
|
|
|
|
return $filePermissions;
|
|
|
|
}
|
|
|
|
|
2012-12-16 00:44:46 +00:00
|
|
|
/**
|
|
|
|
* remove the permissions for a file
|
|
|
|
*
|
|
|
|
* @param int $fileId
|
|
|
|
* @param string $user
|
|
|
|
*/
|
2013-03-04 16:44:09 +00:00
|
|
|
public function remove($fileId, $user = null) {
|
2012-12-16 00:44:46 +00:00
|
|
|
// Not a valid action for Shared Permissions
|
|
|
|
}
|
|
|
|
|
2013-01-07 23:17:14 +00:00
|
|
|
public function removeMultiple($fileIds, $user) {
|
2012-12-16 00:44:46 +00:00
|
|
|
// Not a valid action for Shared Permissions
|
|
|
|
}
|
2013-05-29 22:22:54 +00:00
|
|
|
|
2013-08-18 09:02:08 +00:00
|
|
|
}
|