nextcloud/apps/files_sharing/lib/ShareBackend/Folder.php

108 lines
3.5 KiB
PHP
Raw Normal View History

2012-07-11 02:56:22 +04:00
<?php
/**
2016-07-21 17:49:16 +03:00
* @copyright Copyright (c) 2016, ownCloud, Inc.
*
2015-03-26 13:44:34 +03:00
* @author Bart Visscher <bartv@thisnet.nl>
2016-05-26 20:56:05 +03:00
* @author Björn Schießle <bjoern@schiessle.org>
2015-03-26 13:44:34 +03:00
* @author Michael Gapczynski <GapczynskiM@gmail.com>
* @author Morris Jobke <hey@morrisjobke.de>
2016-01-12 17:02:16 +03:00
* @author Robin McCorkell <robin@mccorkell.me.uk>
2016-07-21 17:49:16 +03:00
* @author Roeland Jago Douma <roeland@famdouma.nl>
2015-03-26 13:44:34 +03:00
*
* @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 OCA\Files_Sharing\ShareBackend;
class Folder extends File implements \OCP\Share_Backend_Collection {
2012-07-11 02:56:22 +04:00
2014-10-01 17:13:10 +04:00
/**
* get shared parents
*
* @param int $itemSource item source ID
* @param string $shareWith with whom should the item be shared
* @param string $owner owner of the item
2014-10-01 17:13:10 +04:00
* @return array with shares
*/
public function getParents($itemSource, $shareWith = null, $owner = null) {
2014-10-01 17:13:10 +04:00
$result = array();
$parent = $this->getParentId($itemSource);
while ($parent) {
$shares = \OCP\Share::getItemSharedWithUser('folder', $parent, $shareWith, $owner);
2014-10-01 17:13:10 +04:00
if ($shares) {
foreach ($shares as $share) {
$name = basename($share['path']);
2014-10-01 17:13:10 +04:00
$share['collection']['path'] = $name;
$share['collection']['item_type'] = 'folder';
$share['file_path'] = $name;
$displayNameOwner = \OCP\User::getDisplayName($share['uid_owner']);
$displayNameShareWith = \OCP\User::getDisplayName($share['share_with']);
$share['displayname_owner'] = $displayNameOwner ? $displayNameOwner : $share['uid_owner'];
$share['share_with_displayname'] = $displayNameShareWith ? $displayNameShareWith : $share['uid_owner'];
2014-10-01 17:13:10 +04:00
$result[] = $share;
}
}
$parent = $this->getParentId($parent);
}
return $result;
}
/**
* get file cache ID of parent
*
* @param int $child file cache ID of child
* @return mixed parent ID or null
*/
private function getParentId($child) {
$query = \OCP\DB::prepare('SELECT `parent` FROM `*PREFIX*filecache` WHERE `fileid` = ?');
2014-10-01 17:13:10 +04:00
$result = $query->execute(array($child));
$row = $result->fetchRow();
$parent = $row ? $row['parent'] : null;
2014-10-01 17:13:10 +04:00
return $parent;
}
2012-08-06 19:27:13 +04:00
public function getChildren($itemSource) {
$children = array();
$parents = array($itemSource);
$query = \OCP\DB::prepare('SELECT `id` FROM `*PREFIX*mimetypes` WHERE `mimetype` = ?');
2013-01-08 05:52:51 +04:00
$result = $query->execute(array('httpd/unix-directory'));
if ($row = $result->fetchRow()) {
$mimetype = (int) $row['id'];
2013-01-08 05:52:51 +04:00
} else {
$mimetype = -1;
}
while (!empty($parents)) {
$parents = "'".implode("','", $parents)."'";
$query = \OCP\DB::prepare('SELECT `fileid`, `name`, `mimetype` FROM `*PREFIX*filecache`'
2013-02-15 01:37:49 +04:00
.' WHERE `parent` IN ('.$parents.')');
$result = $query->execute();
$parents = array();
while ($file = $result->fetchRow()) {
2012-12-27 01:20:10 +04:00
$children[] = array('source' => $file['fileid'], 'file_path' => $file['name']);
2012-10-14 23:04:08 +04:00
// If a child folder is found look inside it
if ((int) $file['mimetype'] === $mimetype) {
2013-01-08 05:52:51 +04:00
$parents[] = $file['fileid'];
}
}
2012-08-06 19:27:13 +04:00
}
return $children;
2012-07-11 02:56:22 +04:00
}
2013-02-15 01:37:49 +04:00
}