2011-06-11 20:14:24 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* ownCloud
|
|
|
|
*
|
|
|
|
* @author Michael Gapczynski
|
|
|
|
* @copyright 2011 Michael Gapczynski GapczynskiM@gmail.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/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class manages shared items within the database.
|
|
|
|
*/
|
|
|
|
class OC_SHARE {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* TODO notify user a file is being shared with them?
|
|
|
|
* Share an item, adds an entry into the database
|
|
|
|
* @param string $item
|
|
|
|
* @param user item shared with $uid_shared_with
|
|
|
|
*/
|
2011-06-16 18:59:54 +00:00
|
|
|
public function __construct($item, $uid_shared_with, $public = false) {
|
2011-06-11 20:14:24 +00:00
|
|
|
if ($item && OC_FILESYSTEM::file_exists($item) && OC_FILESYSTEM::is_readable($item)) {
|
|
|
|
$uid_owner = $_SESSION['user_id'];
|
|
|
|
if ($public) {
|
|
|
|
// TODO create token for public file
|
|
|
|
$token = sha1("$uid_owner-$item");
|
|
|
|
} else {
|
|
|
|
$query = OC_DB::prepare("INSERT INTO *PREFIX*sharing VALUES(?,?,?,?)");
|
|
|
|
foreach ($uid_shared_with as $uid) {
|
|
|
|
$query->execute(array($uid_owner, $uid, $item));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* TODO complete lib_permissions
|
|
|
|
* Change the permissions of the specified item
|
|
|
|
* @param permissions $permissions
|
|
|
|
*/
|
|
|
|
public static function setPermissions($item, $uid_shared_with, $permissions) {
|
|
|
|
$query = OC_DB::prepare("UPDATE *PREFIX*sharing SET permissions = ? WHERE item = ? AND uid_shared_with = ? AND uid_owner = ?");
|
|
|
|
$query->execute(array($permissions, $item, $uid_shared_with, $_SESSION['user_id']));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the permissions for the specified item
|
|
|
|
* @param unknown_type $item
|
|
|
|
*/
|
|
|
|
public static function getPermissions($item, $uid_shared_with) {
|
|
|
|
$query = OC_DB::prepare("SELECT permissions FROM *PREFIX*sharing WHERE item = ? AND uid_shared_with = ? AND uid_owner = ? ");
|
|
|
|
return $query->execute(array($item, $uid_shared_with, $_SESSION['user_id']))->fetchAll();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unshare the item, removes it from all users specified
|
|
|
|
* @param array $uid_shared_with
|
|
|
|
*/
|
|
|
|
public static function unshare($item, $uid_shared_with) {
|
|
|
|
$query = OC_DB::prepare("DELETE FROM *PREFIX*sharing WHERE item = ? AND uid_shared_with = ? AND uid_owner = ?");
|
|
|
|
foreach ($uid_shared_with as $uid) {
|
2011-06-16 18:40:21 +00:00
|
|
|
$query->execute(array($item, $uid, $_SESSION['user_id']));
|
2011-06-11 20:14:24 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-06-16 18:40:21 +00:00
|
|
|
/**
|
|
|
|
* Get the source location of the target item
|
2011-06-26 02:00:52 +00:00
|
|
|
* @param $target
|
2011-06-16 18:40:21 +00:00
|
|
|
* @return source path
|
|
|
|
*/
|
|
|
|
public static function getSource($target) {
|
2011-07-05 15:56:02 +00:00
|
|
|
// Remove any trailing '/'
|
|
|
|
$target = rtrim($target, "/");
|
2011-07-03 15:43:49 +00:00
|
|
|
$query = OC_DB::prepare("SELECT source FROM *PREFIX*sharing WHERE target = ? AND uid_shared_with = ? LIMIT 1");
|
2011-06-26 02:00:52 +00:00
|
|
|
$result = $query->execute(array($target, $_SESSION['user_id']))->fetchAll();
|
2011-06-24 23:38:39 +00:00
|
|
|
if (count($result) > 0) {
|
2011-06-26 02:00:52 +00:00
|
|
|
return $result[0]['source'];
|
2011-06-24 23:38:39 +00:00
|
|
|
} else {
|
2011-06-27 22:14:04 +00:00
|
|
|
// Check if the parent directory of this target is shared
|
2011-06-26 23:21:24 +00:00
|
|
|
$parentDir = dirname($target);
|
2011-07-05 15:56:02 +00:00
|
|
|
if ($parentDir != "" && $parentDir != "/" && $parentDir != ".") {
|
2011-06-26 02:00:52 +00:00
|
|
|
$result = OC_SHARE::getSource($parentDir);
|
2011-06-27 22:14:04 +00:00
|
|
|
if ($result) {
|
|
|
|
return $result."/".basename($target);
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
2011-06-26 02:00:52 +00:00
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
2011-06-24 23:20:08 +00:00
|
|
|
}
|
2011-06-16 18:40:21 +00:00
|
|
|
}
|
|
|
|
|
2011-06-26 02:00:52 +00:00
|
|
|
/**
|
|
|
|
* Set the target location to a new value
|
|
|
|
* @param $oldTarget The current target location
|
|
|
|
* @param $newTarget The new target location
|
|
|
|
*/
|
|
|
|
public static function setTarget($oldTarget, $newTarget) {
|
|
|
|
$query = OC_DB::prepare("UPDATE *PREFIX*sharing SET target = ? WHERE target = ? AND uid_shared_with = ?");
|
|
|
|
$query->execute(array($newTarget, $oldTarget, $_SESSION['user_id']));
|
|
|
|
}
|
|
|
|
|
2011-06-11 20:14:24 +00:00
|
|
|
/**
|
|
|
|
* Get all items the user is sharing
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public static function getSharedItems() {
|
|
|
|
$query = OC_DB::prepare("SELECT * FROM *PREFIX*sharing WHERE uid_owner = ?");
|
|
|
|
return $query->execute(array($_SESSION['user_id']))->fetchAll();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get all items shared with the user
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public static function getItemsSharedWith() {
|
|
|
|
$query = OC_DB::prepare("SELECT * FROM *PREFIX*sharing WHERE uid_shared_with = ?");
|
|
|
|
return $query->execute(array($_SESSION['user_id']))->fetchAll();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|