summaryrefslogtreecommitdiffstats
path: root/lib/private/Share/Share.php
diff options
context:
space:
mode:
Diffstat (limited to 'lib/private/Share/Share.php')
-rw-r--r--lib/private/Share/Share.php677
1 files changed, 2 insertions, 675 deletions
diff --git a/lib/private/Share/Share.php b/lib/private/Share/Share.php
index 93117bf3c7e..52b382e6678 100644
--- a/lib/private/Share/Share.php
+++ b/lib/private/Share/Share.php
@@ -84,7 +84,7 @@ class Share extends Constants {
* @return boolean true if backend is registered or false if error
*/
public static function registerBackend($itemType, $class, $collectionOf = null, $supportedFileExtensions = null) {
- if (self::isEnabled()) {
+ if (\OC::$server->getAppConfig()->getValue('core', 'shareapi_enabled', 'yes') == 'yes') {
if (!isset(self::$backendTypes[$itemType])) {
self::$backendTypes[$itemType] = array(
'class' => $class,
@@ -106,255 +106,6 @@ class Share extends Constants {
}
/**
- * Check if the Share API is enabled
- * @return boolean true if enabled or false
- *
- * The Share API is enabled by default if not configured
- */
- public static function isEnabled() {
- if (\OC::$server->getAppConfig()->getValue('core', 'shareapi_enabled', 'yes') == 'yes') {
- return true;
- }
- return false;
- }
-
- /**
- * Find which users can access a shared item
- * @param string $path to the file
- * @param string $ownerUser owner of the file
- * @param IUserManager $userManager
- * @param ILogger $logger
- * @param boolean $includeOwner include owner to the list of users with access to the file
- * @param boolean $returnUserPaths Return an array with the user => path map
- * @param boolean $recursive take all parent folders into account (default true)
- * @return array
- * @note $path needs to be relative to user data dir, e.g. 'file.txt'
- * not '/admin/data/file.txt'
- * @throws \OC\User\NoUserException
- */
- public static function getUsersSharingFile($path,
- $ownerUser,
- IUserManager $userManager,
- ILogger $logger,
- $includeOwner = false,
- $returnUserPaths = false,
- $recursive = true) {
- $userObject = $userManager->get($ownerUser);
-
- if (is_null($userObject)) {
- $logger->error(
- sprintf(
- 'Backends provided no user object for %s',
- $ownerUser
- ),
- [
- 'app' => 'files',
- ]
- );
- throw new \OC\User\NoUserException('Backends provided no user object');
- }
-
- $ownerUser = $userObject->getUID();
-
- Filesystem::initMountPoints($ownerUser);
- $shares = $sharePaths = $fileTargets = array();
- $publicShare = false;
- $remoteShare = false;
- $source = -1;
- $cache = $mountPath = false;
-
- $view = new \OC\Files\View('/' . $ownerUser . '/files');
- $meta = $view->getFileInfo($path);
- if ($meta) {
- $path = substr($meta->getPath(), strlen('/' . $ownerUser . '/files'));
- } else {
- // if the file doesn't exists yet we start with the parent folder
- $meta = $view->getFileInfo(dirname($path));
- }
-
- if($meta !== false) {
- $source = $meta['fileid'];
- $cache = new \OC\Files\Cache\Cache($meta['storage']);
-
- $mountPath = $meta->getMountPoint()->getMountPoint();
- if ($mountPath !== false) {
- $mountPath = substr($mountPath, strlen('/' . $ownerUser . '/files'));
- }
- }
-
- $paths = [];
- while ($source !== -1) {
- // Fetch all shares with another user
- if (!$returnUserPaths) {
- $query = \OC_DB::prepare(
- 'SELECT `share_with`, `file_source`, `file_target`
- FROM
- `*PREFIX*share`
- WHERE
- `item_source` = ? AND `share_type` = ? AND `item_type` IN (\'file\', \'folder\')'
- );
- $result = $query->execute(array($source, self::SHARE_TYPE_USER));
- } else {
- $query = \OC_DB::prepare(
- 'SELECT `share_with`, `file_source`, `file_target`
- FROM
- `*PREFIX*share`
- WHERE
- `item_source` = ? AND `share_type` IN (?, ?) AND `item_type` IN (\'file\', \'folder\')'
- );
- $result = $query->execute(array($source, self::SHARE_TYPE_USER, self::$shareTypeGroupUserUnique));
- }
-
- if (\OCP\DB::isError($result)) {
- \OCP\Util::writeLog('OCP\Share', \OC_DB::getErrorMessage(), \OCP\Util::ERROR);
- } else {
- while ($row = $result->fetchRow()) {
- $shares[] = $row['share_with'];
- if ($returnUserPaths) {
- $fileTargets[(int) $row['file_source']][$row['share_with']] = $row;
- }
- }
- }
-
- // We also need to take group shares into account
- $query = \OC_DB::prepare(
- 'SELECT `share_with`, `file_source`, `file_target`
- FROM
- `*PREFIX*share`
- WHERE
- `item_source` = ? AND `share_type` = ? AND `item_type` IN (\'file\', \'folder\')'
- );
-
- $result = $query->execute(array($source, self::SHARE_TYPE_GROUP));
-
- if (\OCP\DB::isError($result)) {
- \OCP\Util::writeLog('OCP\Share', \OC_DB::getErrorMessage(), \OCP\Util::ERROR);
- } else {
- $groupManager = \OC::$server->getGroupManager();
- while ($row = $result->fetchRow()) {
-
- $usersInGroup = [];
- $group = $groupManager->get($row['share_with']);
- if ($group) {
- $users = $group->searchUsers('', -1, 0);
- $userIds = array();
- foreach ($users as $user) {
- $userIds[] = $user->getUID();
- }
- $usersInGroup = $userIds;
- }
- $shares = array_merge($shares, $usersInGroup);
- if ($returnUserPaths) {
- foreach ($usersInGroup as $user) {
- if (!isset($fileTargets[(int) $row['file_source']][$user])) {
- // When the user already has an entry for this file source
- // the file is either shared directly with him as well, or
- // he has an exception entry (because of naming conflict).
- $fileTargets[(int) $row['file_source']][$user] = $row;
- }
- }
- }
- }
- }
-
- //check for public link shares
- if (!$publicShare) {
- $query = \OC_DB::prepare('
- SELECT `share_with`
- FROM `*PREFIX*share`
- WHERE `item_source` = ? AND `share_type` IN (?, ?) AND `item_type` IN (\'file\', \'folder\')', 1
- );
-
- $result = $query->execute(array($source, self::SHARE_TYPE_LINK, self::SHARE_TYPE_EMAIL));
-
- if (\OCP\DB::isError($result)) {
- \OCP\Util::writeLog('OCP\Share', \OC_DB::getErrorMessage(), \OCP\Util::ERROR);
- } else {
- if ($result->fetchRow()) {
- $publicShare = true;
- }
- }
- }
-
- //check for remote share
- if (!$remoteShare) {
- $query = \OC_DB::prepare('
- SELECT `share_with`
- FROM `*PREFIX*share`
- WHERE `item_source` = ? AND `share_type` = ? AND `item_type` IN (\'file\', \'folder\')', 1
- );
-
- $result = $query->execute(array($source, self::SHARE_TYPE_REMOTE));
-
- if (\OCP\DB::isError($result)) {
- \OCP\Util::writeLog('OCP\Share', \OC_DB::getErrorMessage(), \OCP\Util::ERROR);
- } else {
- if ($result->fetchRow()) {
- $remoteShare = true;
- }
- }
- }
-
- // let's get the parent for the next round
- $meta = $cache->get((int)$source);
- if ($recursive === true && $meta !== false) {
- $paths[$source] = $meta['path'];
- $source = (int)$meta['parent'];
- } else {
- $source = -1;
- }
- }
-
- // Include owner in list of users, if requested
- if ($includeOwner) {
- $shares[] = $ownerUser;
- }
-
- if ($returnUserPaths) {
- $fileTargetIDs = array_keys($fileTargets);
- $fileTargetIDs = array_unique($fileTargetIDs);
-
- if (!empty($fileTargetIDs)) {
- $query = \OC_DB::prepare(
- 'SELECT `fileid`, `path`
- FROM `*PREFIX*filecache`
- WHERE `fileid` IN (' . implode(',', $fileTargetIDs) . ')'
- );
- $result = $query->execute();
-
- if (\OCP\DB::isError($result)) {
- \OCP\Util::writeLog('OCP\Share', \OC_DB::getErrorMessage(), \OCP\Util::ERROR);
- } else {
- while ($row = $result->fetchRow()) {
- foreach ($fileTargets[$row['fileid']] as $uid => $shareData) {
- if ($mountPath !== false) {
- $sharedPath = $shareData['file_target'];
- $sharedPath .= substr($path, strlen($mountPath) + strlen($paths[$row['fileid']]));
- $sharePaths[$uid] = $sharedPath;
- } else {
- $sharedPath = $shareData['file_target'];
- $sharedPath .= substr($path, strlen($row['path']) -5);
- $sharePaths[$uid] = $sharedPath;
- }
- }
- }
- $result->closeCursor();
- }
- }
-
- if ($includeOwner) {
- $sharePaths[$ownerUser] = $path;
- } else {
- unset($sharePaths[$ownerUser]);
- }
-
- return $sharePaths;
- }
-
- return array('users' => array_unique($shares), 'public' => $publicShare, 'remote' => $remoteShare);
- }
-
- /**
* Get the items of item type shared with the current user
* @param string $itemType
* @param int $format (optional) Format type must be defined by the backend
@@ -386,21 +137,6 @@ class Share extends Constants {
}
/**
- * Get the item of item type shared with the current user
- * @param string $itemType
- * @param string $itemTarget
- * @param int $format (optional) Format type must be defined by the backend
- * @param mixed $parameters (optional)
- * @param boolean $includeCollections (optional)
- * @return mixed Return depends on format
- */
- public static function getItemSharedWith($itemType, $itemTarget, $format = self::FORMAT_NONE,
- $parameters = null, $includeCollections = false) {
- return self::getItems($itemType, $itemTarget, self::$shareTypeUserAndGroups, \OC_User::getUser(), null, $format,
- $parameters, 1, $includeCollections);
- }
-
- /**
* Get the item of item type shared with a given user by source
* @param string $itemType
* @param string $itemSource
@@ -527,18 +263,6 @@ class Share extends Constants {
}
/**
- * Get the item of item type shared by a link
- * @param string $itemType
- * @param string $itemSource
- * @param string $uidOwner Owner of link
- * @return array
- */
- public static function getItemSharedWithByLink($itemType, $itemSource, $uidOwner) {
- return self::getItems($itemType, $itemSource, self::SHARE_TYPE_LINK, null, $uidOwner, self::FORMAT_NONE,
- null, 1);
- }
-
- /**
* Based on the given token the share information will be returned - password protected shares will be verified
* @param string $token
* @param bool $checkPasswordProtection
@@ -620,42 +344,6 @@ class Share extends Constants {
}
/**
- * Get all users an item is shared with
- * @param string $itemType
- * @param string $itemSource
- * @param string $uidOwner
- * @param boolean $includeCollections
- * @param boolean $checkExpireDate
- * @return array Return array of users
- */
- public static function getUsersItemShared($itemType, $itemSource, $uidOwner, $includeCollections = false, $checkExpireDate = true) {
-
- $users = array();
- $items = self::getItems($itemType, $itemSource, null, null, $uidOwner, self::FORMAT_NONE, null, -1, $includeCollections, false, $checkExpireDate);
- if ($items) {
- foreach ($items as $item) {
- if ((int)$item['share_type'] === self::SHARE_TYPE_USER) {
- $users[] = $item['share_with'];
- } else if ((int)$item['share_type'] === self::SHARE_TYPE_GROUP) {
-
- $group = \OC::$server->getGroupManager()->get($item['share_with']);
- $userIds = [];
- if ($group) {
- $users = $group->searchUsers('', -1, 0);
- foreach ($users as $user) {
- $userIds[] = $user->getUID();
- }
- return $userIds;
- }
-
- $users = array_merge($users, $userIds);
- }
- }
- }
- return $users;
- }
-
- /**
* Share an item with a user, group, or via private link
* @param string $itemType
* @param string $itemSource
@@ -1027,140 +715,6 @@ class Share extends Constants {
}
/**
- * Unshare an item from all users, groups, and remove all links
- * @param string $itemType
- * @param string $itemSource
- * @return boolean true on success or false on failure
- */
- public static function unshareAll($itemType, $itemSource) {
- // Get all of the owners of shares of this item.
- $query = \OC_DB::prepare( 'SELECT `uid_owner` from `*PREFIX*share` WHERE `item_type`=? AND `item_source`=?' );
- $result = $query->execute(array($itemType, $itemSource));
- $shares = array();
- // Add each owner's shares to the array of all shares for this item.
- while ($row = $result->fetchRow()) {
- $shares = array_merge($shares, self::getItems($itemType, $itemSource, null, null, $row['uid_owner']));
- }
- if (!empty($shares)) {
- // Pass all the vars we have for now, they may be useful
- $hookParams = array(
- 'itemType' => $itemType,
- 'itemSource' => $itemSource,
- 'shares' => $shares,
- );
- \OC_Hook::emit('OCP\Share', 'pre_unshareAll', $hookParams);
- foreach ($shares as $share) {
- self::unshareItem($share);
- }
- \OC_Hook::emit('OCP\Share', 'post_unshareAll', $hookParams);
- return true;
- }
- return false;
- }
-
- /**
- * Unshare an item shared with the current user
- * @param string $itemType
- * @param string $itemOrigin Item target or source
- * @param boolean $originIsSource true if $itemOrigin is the source, false if $itemOrigin is the target (optional)
- * @return boolean true on success or false on failure
- *
- * Unsharing from self is not allowed for items inside collections
- */
- public static function unshareFromSelf($itemType, $itemOrigin, $originIsSource = false) {
- $originType = ($originIsSource) ? 'source' : 'target';
- $uid = \OCP\User::getUser();
-
- if ($itemType === 'file' || $itemType === 'folder') {
- $statement = 'SELECT * FROM `*PREFIX*share` WHERE `item_type` = ? and `file_' . $originType . '` = ?';
- } else {
- $statement = 'SELECT * FROM `*PREFIX*share` WHERE `item_type` = ? and `item_' . $originType . '` = ?';
- }
-
- $query = \OCP\DB::prepare($statement);
- $result = $query->execute(array($itemType, $itemOrigin));
-
- $shares = $result->fetchAll();
-
- $listOfUnsharedItems = array();
-
- $itemUnshared = false;
- foreach ($shares as $share) {
- if ((int)$share['share_type'] === \OCP\Share::SHARE_TYPE_USER &&
- $share['share_with'] === $uid) {
- $deletedShares = Helper::delete($share['id']);
- $shareTmp = array(
- 'id' => $share['id'],
- 'shareWith' => $share['share_with'],
- 'itemTarget' => $share['item_target'],
- 'itemType' => $share['item_type'],
- 'shareType' => (int)$share['share_type'],
- );
- if (isset($share['file_target'])) {
- $shareTmp['fileTarget'] = $share['file_target'];
- }
- $listOfUnsharedItems = array_merge($listOfUnsharedItems, $deletedShares, array($shareTmp));
- $itemUnshared = true;
- break;
- } elseif ((int)$share['share_type'] === \OCP\Share::SHARE_TYPE_GROUP) {
- $group = \OC::$server->getGroupManager()->get($share['share_with']);
- $user = \OC::$server->getUserManager()->get($uid);
- if ($group && $user && $group->inGroup($user)) {
- $groupShare = $share;
- }
- } elseif ((int)$share['share_type'] === self::$shareTypeGroupUserUnique &&
- $share['share_with'] === $uid) {
- $uniqueGroupShare = $share;
- }
- }
-
- if (!$itemUnshared && isset($groupShare) && !isset($uniqueGroupShare)) {
- $query = \OC_DB::prepare('INSERT INTO `*PREFIX*share`'
- .' (`item_type`, `item_source`, `item_target`, `parent`, `share_type`,'
- .' `share_with`, `uid_owner`, `permissions`, `stime`, `file_source`, `file_target`)'
- .' VALUES (?,?,?,?,?,?,?,?,?,?,?)');
- $query->execute(array($groupShare['item_type'], $groupShare['item_source'], $groupShare['item_target'],
- $groupShare['id'], self::$shareTypeGroupUserUnique,
- \OC_User::getUser(), $groupShare['uid_owner'], 0, $groupShare['stime'], $groupShare['file_source'],
- $groupShare['file_target']));
- $shareTmp = array(
- 'id' => $groupShare['id'],
- 'shareWith' => $groupShare['share_with'],
- 'itemTarget' => $groupShare['item_target'],
- 'itemType' => $groupShare['item_type'],
- 'shareType' => (int)$groupShare['share_type'],
- );
- if (isset($groupShare['file_target'])) {
- $shareTmp['fileTarget'] = $groupShare['file_target'];
- }
- $listOfUnsharedItems = array_merge($listOfUnsharedItems, [$shareTmp]);
- $itemUnshared = true;
- } elseif (!$itemUnshared && isset($uniqueGroupShare)) {
- $query = \OC_DB::prepare('UPDATE `*PREFIX*share` SET `permissions` = ? WHERE `id` = ?');
- $query->execute(array(0, $uniqueGroupShare['id']));
- $shareTmp = array(
- 'id' => $uniqueGroupShare['id'],
- 'shareWith' => $uniqueGroupShare['share_with'],
- 'itemTarget' => $uniqueGroupShare['item_target'],
- 'itemType' => $uniqueGroupShare['item_type'],
- 'shareType' => (int)$uniqueGroupShare['share_type'],
- );
- if (isset($uniqueGroupShare['file_target'])) {
- $shareTmp['fileTarget'] = $uniqueGroupShare['file_target'];
- }
- $listOfUnsharedItems = array_merge($listOfUnsharedItems, [$shareTmp]);
- $itemUnshared = true;
- }
-
- if ($itemUnshared) {
- \OC_Hook::emit('OCP\Share', 'post_unshareFromSelf',
- array('unsharedItems' => $listOfUnsharedItems, 'itemType' => $itemType));
- }
-
- return $itemUnshared;
- }
-
- /**
* sent status if users got informed by mail about share
* @param string $itemType
* @param string $itemSource
@@ -1184,177 +738,6 @@ class Share extends Constants {
}
/**
- * Set the permissions of an item for a specific user or group
- * @param string $itemType
- * @param string $itemSource
- * @param int $shareType SHARE_TYPE_USER, SHARE_TYPE_GROUP, or SHARE_TYPE_LINK
- * @param string $shareWith User or group the item is being shared with
- * @param int $permissions CRUDS permissions
- * @return boolean true on success or false on failure
- * @throws \Exception when trying to grant more permissions then the user has himself
- */
- public static function setPermissions($itemType, $itemSource, $shareType, $shareWith, $permissions) {
- $l = \OC::$server->getL10N('lib');
- $connection = \OC::$server->getDatabaseConnection();
-
- $intArrayToLiteralArray = function($intArray, $eb) {
- return array_map(function($int) use ($eb) {
- return $eb->literal((int)$int, 'integer');
- }, $intArray);
- };
- $sanitizeItem = function($item) {
- $item['id'] = (int)$item['id'];
- $item['premissions'] = (int)$item['permissions'];
- return $item;
- };
-
- if ($rootItem = self::getItems($itemType, $itemSource, $shareType, $shareWith,
- \OC_User::getUser(), self::FORMAT_NONE, null, 1, false)) {
- // Check if this item is a reshare and verify that the permissions
- // granted don't exceed the parent shared item
- if (isset($rootItem['parent'])) {
- $qb = $connection->getQueryBuilder();
- $qb->select('permissions')
- ->from('share')
- ->where($qb->expr()->eq('id', $qb->createParameter('id')))
- ->setParameter(':id', $rootItem['parent']);
- $dbresult = $qb->execute();
-
- $result = $dbresult->fetch();
- $dbresult->closeCursor();
- if (~(int)$result['permissions'] & $permissions) {
- $message = 'Setting permissions for %s failed,'
- .' because the permissions exceed permissions granted to %s';
- $message_t = $l->t('Setting permissions for %s failed, because the permissions exceed permissions granted to %s', array($itemSource, \OC_User::getUser()));
- \OCP\Util::writeLog('OCP\Share', sprintf($message, $itemSource, \OC_User::getUser()), \OCP\Util::DEBUG);
- throw new \Exception($message_t);
- }
- }
- $qb = $connection->getQueryBuilder();
- $qb->update('share')
- ->set('permissions', $qb->createParameter('permissions'))
- ->where($qb->expr()->eq('id', $qb->createParameter('id')))
- ->setParameter(':id', $rootItem['id'])
- ->setParameter(':permissions', $permissions);
- $qb->execute();
- if ($itemType === 'file' || $itemType === 'folder') {
- \OC_Hook::emit('OCP\Share', 'post_update_permissions', array(
- 'itemType' => $itemType,
- 'itemSource' => $itemSource,
- 'shareType' => $shareType,
- 'shareWith' => $shareWith,
- 'uidOwner' => \OC_User::getUser(),
- 'permissions' => $permissions,
- 'path' => $rootItem['path'],
- 'share' => $rootItem
- ));
- }
-
- // Share id's to update with the new permissions
- $ids = [];
- $items = [];
-
- // Check if permissions were removed
- if ((int)$rootItem['permissions'] & ~$permissions) {
- // If share permission is removed all reshares must be deleted
- if (($rootItem['permissions'] & \OCP\Constants::PERMISSION_SHARE) && (~$permissions & \OCP\Constants::PERMISSION_SHARE)) {
- // delete all shares, keep parent and group children
- Helper::delete($rootItem['id'], true, null, null, true);
- }
-
- // Remove permission from all children
- $parents = [$rootItem['id']];
- while (!empty($parents)) {
- $parents = $intArrayToLiteralArray($parents, $qb->expr());
- $qb = $connection->getQueryBuilder();
- $qb->select('id', 'permissions', 'item_type')
- ->from('share')
- ->where($qb->expr()->in('parent', $parents));
- $result = $qb->execute();
- // Reset parents array, only go through loop again if
- // items are found that need permissions removed
- $parents = [];
- while ($item = $result->fetch()) {
- $item = $sanitizeItem($item);
-
- $items[] = $item;
- // Check if permissions need to be removed
- if ($item['permissions'] & ~$permissions) {
- // Add to list of items that need permissions removed
- $ids[] = $item['id'];
- $parents[] = $item['id'];
- }
- }
- $result->closeCursor();
- }
-
- // Remove the permissions for all reshares of this item
- if (!empty($ids)) {
- $ids = "'".implode("','", $ids)."'";
- // TODO this should be done with Doctrine platform objects
- if (\OC::$server->getConfig()->getSystemValue("dbtype") === 'oci') {
- $andOp = 'BITAND(`permissions`, ?)';
- } else {
- $andOp = '`permissions` & ?';
- }
- $query = \OC_DB::prepare('UPDATE `*PREFIX*share` SET `permissions` = '.$andOp
- .' WHERE `id` IN ('.$ids.')');
- $query->execute(array($permissions));
- }
-
- }
-
- /*
- * Permissions were added
- * Update all USERGROUP shares. (So group shares where the user moved their mountpoint).
- */
- if ($permissions & ~(int)$rootItem['permissions']) {
- $qb = $connection->getQueryBuilder();
- $qb->select('id', 'permissions', 'item_type')
- ->from('share')
- ->where($qb->expr()->eq('parent', $qb->createParameter('parent')))
- ->andWhere($qb->expr()->eq('share_type', $qb->createParameter('share_type')))
- ->andWhere($qb->expr()->neq('permissions', $qb->createParameter('shareDeleted')))
- ->setParameter(':parent', (int)$rootItem['id'])
- ->setParameter(':share_type', 2)
- ->setParameter(':shareDeleted', 0);
- $result = $qb->execute();
-
- $ids = [];
- while ($item = $result->fetch()) {
- $item = $sanitizeItem($item);
- $items[] = $item;
- $ids[] = $item['id'];
- }
- $result->closeCursor();
-
- // Add permssions for all USERGROUP shares of this item
- if (!empty($ids)) {
- $ids = $intArrayToLiteralArray($ids, $qb->expr());
-
- $qb = $connection->getQueryBuilder();
- $qb->update('share')
- ->set('permissions', $qb->createParameter('permissions'))
- ->where($qb->expr()->in('id', $ids))
- ->setParameter(':permissions', $permissions);
- $qb->execute();
- }
- }
-
- foreach ($items as $item) {
- \OC_Hook::emit('OCP\Share', 'post_update_permissions', ['share' => $item]);
- }
-
- return true;
- }
- $message = 'Setting permissions for %s failed, because the item was not found';
- $message_t = $l->t('Setting permissions for %s failed, because the item was not found', array($itemSource));
-
- \OCP\Util::writeLog('OCP\Share', sprintf($message, $itemSource), \OCP\Util::DEBUG);
- throw new \Exception($message_t);
- }
-
- /**
* validate expiration date if it meets all constraints
*
* @param string $expireDate well formatted date string, e.g. "DD-MM-YYYY"
@@ -1403,50 +786,6 @@ class Share extends Constants {
}
/**
- * Set expiration date for a share
- * @param string $itemType
- * @param string $itemSource
- * @param string $date expiration date
- * @param int $shareTime timestamp from when the file was shared
- * @return boolean
- * @throws \Exception when the expire date is not set, in the past or further in the future then the enforced date
- */
- public static function setExpirationDate($itemType, $itemSource, $date, $shareTime = null) {
- $user = \OC_User::getUser();
- $l = \OC::$server->getL10N('lib');
-
- if ($date == '') {
- if (\OCP\Util::isDefaultExpireDateEnforced()) {
- $warning = 'Cannot clear expiration date. Shares are required to have an expiration date.';
- $warning_t = $l->t('Cannot clear expiration date. Shares are required to have an expiration date.');
- \OCP\Util::writeLog('OCP\Share', $warning, \OCP\Util::WARN);
- throw new \Exception($warning_t);
- } else {
- $date = null;
- }
- } else {
- $date = self::validateExpireDate($date, $shareTime, $itemType, $itemSource);
- }
- $query = \OC_DB::prepare('UPDATE `*PREFIX*share` SET `expiration` = ? WHERE `item_type` = ? AND `item_source` = ? AND `uid_owner` = ? AND `share_type` = ?');
- $query->bindValue(1, $date, 'datetime');
- $query->bindValue(2, $itemType);
- $query->bindValue(3, $itemSource);
- $query->bindValue(4, $user);
- $query->bindValue(5, \OCP\Share::SHARE_TYPE_LINK);
-
- $query->execute();
-
- \OC_Hook::emit('OCP\Share', 'post_set_expiration_date', array(
- 'itemType' => $itemType,
- 'itemSource' => $itemSource,
- 'date' => $date,
- 'uidOwner' => $user
- ));
-
- return true;
- }
-
- /**
* Retrieve the owner of a connection
*
* @param IDBConnection $connection
@@ -1745,7 +1084,7 @@ class Share extends Constants {
public static function getItems($itemType, $item = null, $shareType = null, $shareWith = null,
$uidOwner = null, $format = self::FORMAT_NONE, $parameters = null, $limit = -1,
$includeCollections = false, $itemShareWithBySource = false, $checkExpireDate = true) {
- if (!self::isEnabled()) {
+ if (\OC::$server->getAppConfig()->getValue('core', 'shareapi_enabled', 'yes') != 'yes') {
return array();
}
$backend = self::getBackend($itemType);
@@ -2552,18 +1891,6 @@ class Share extends Constants {
}
/**
- * Delete all shares with type SHARE_TYPE_LINK
- */
- public static function removeAllLinkShares() {
- // Delete any link shares
- $query = \OC_DB::prepare('SELECT `id` FROM `*PREFIX*share` WHERE `share_type` = ?');
- $result = $query->execute(array(self::SHARE_TYPE_LINK));
- while ($item = $result->fetchRow()) {
- Helper::delete($item['id']);
- }
- }
-
- /**
* In case a password protected link is not yet authenticated this function will return false
*
* @param array $linkItem