summaryrefslogtreecommitdiffstats
path: root/lib/public/Share/IShareProvider.php
diff options
context:
space:
mode:
Diffstat (limited to 'lib/public/Share/IShareProvider.php')
-rw-r--r--lib/public/Share/IShareProvider.php149
1 files changed, 149 insertions, 0 deletions
diff --git a/lib/public/Share/IShareProvider.php b/lib/public/Share/IShareProvider.php
new file mode 100644
index 00000000000..d00b9da7b59
--- /dev/null
+++ b/lib/public/Share/IShareProvider.php
@@ -0,0 +1,149 @@
+<?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 OCP\Share;
+
+use OCP\Share\Exceptions\ShareNotFound;
+use OCP\Files\Node;
+
+/**
+ * Interface IShareProvider
+ *
+ * @package OCP\Share
+ * @since 9.0.0
+ */
+interface IShareProvider {
+
+ /**
+ * Return the identifier of this provider.
+ *
+ * @return string Containing only [a-zA-Z0-9]
+ * @since 9.0.0
+ */
+ public function identifier();
+
+ /**
+ * Create a share
+ *
+ * @param \OCP\Share\IShare $share
+ * @return \OCP\Share\IShare The share object
+ * @since 9.0.0
+ */
+ public function create(\OCP\Share\IShare $share);
+
+ /**
+ * Update a share
+ *
+ * @param \OCP\Share\IShare $share
+ * @return \OCP\Share\IShare The share object
+ * @since 9.0.0
+ */
+ public function update(\OCP\Share\IShare $share);
+
+ /**
+ * Delete a share
+ *
+ * @param \OCP\Share\IShare $share
+ * @since 9.0.0
+ */
+ public function delete(\OCP\Share\IShare $share);
+
+ /**
+ * Unshare a file from self as recipient.
+ * This may require special handling. If a user unshares a group
+ * share from their self then the original group share should still exist.
+ *
+ * @param \OCP\Share\IShare $share
+ * @param string $recipient UserId of the recipient
+ * @since 9.0.0
+ */
+ public function deleteFromSelf(\OCP\Share\IShare $share, $recipient);
+
+ /**
+ * Move a share as a recipient.
+ * This is updating the share target. Thus the mount point of the recipient.
+ * This may require special handling. If a user moves a group share
+ * the target should only be changed for them.
+ *
+ * @param \OCP\Share\IShare $share
+ * @param string $recipient userId of recipient
+ * @return \OCP\Share\IShare
+ * @since 9.0.0
+ */
+ public function move(\OCP\Share\IShare $share, $recipient);
+
+ /**
+ * Get all shares by the given user
+ *
+ * @param string $userId
+ * @param int $shareType
+ * @param Node|null $node
+ * @param bool $reshares Also get the shares where $user is the owner instead of just the shares where $user is the initiator
+ * @param int $limit The maximum number of shares to be returned, -1 for all shares
+ * @param int $offset
+ * @return \OCP\Share\IShare[]
+ * @since 9.0.0
+ */
+ public function getSharesBy($userId, $shareType, $node, $reshares, $limit, $offset);
+
+ /**
+ * Get share by id
+ *
+ * @param int $id
+ * @param string|null $recipientId
+ * @return \OCP\Share\IShare
+ * @throws ShareNotFound
+ * @since 9.0.0
+ */
+ public function getShareById($id, $recipientId = null);
+
+ /**
+ * Get shares for a given path
+ *
+ * @param Node $path
+ * @return \OCP\Share\IShare[]
+ * @since 9.0.0
+ */
+ public function getSharesByPath(Node $path);
+
+ /**
+ * Get shared with the given user
+ *
+ * @param string $userId get shares where this user is the recipient
+ * @param int $shareType
+ * @param Node|null $node
+ * @param int $limit The max number of entries returned, -1 for all
+ * @param int $offset
+ * @return \OCP\Share\IShare[]
+ * @since 9.0.0
+ */
+ public function getSharedWith($userId, $shareType, $node, $limit, $offset);
+
+ /**
+ * Get a share by token
+ *
+ * @param string $token
+ * @return \OCP\Share\IShare
+ * @throws ShareNotFound
+ * @since 9.0.0
+ */
+ public function getShareByToken($token);
+}