summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRoeland Jago Douma <roeland@famdouma.nl>2017-07-24 16:48:17 +0200
committerRoeland Jago Douma <roeland@famdouma.nl>2017-08-10 13:49:06 +0200
commit8a539ec0f6dc1650902a9340197d62688164d462 (patch)
tree88f29d4208711ec446afd998a3ec51924c7046d4
parent073216e8278983abef6ac51d6e0a900f95af0024 (diff)
downloadnextcloud-server-8a539ec0f6dc1650902a9340197d62688164d462.tar.gz
nextcloud-server-8a539ec0f6dc1650902a9340197d62688164d462.zip
Move shareinfo over to proper controller
Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
-rw-r--r--apps/files_sharing/appinfo/routes.php8
-rw-r--r--apps/files_sharing/lib/Controller/ShareInfoController.php130
2 files changed, 137 insertions, 1 deletions
diff --git a/apps/files_sharing/appinfo/routes.php b/apps/files_sharing/appinfo/routes.php
index 7a5f5650fc5..104c4167e84 100644
--- a/apps/files_sharing/appinfo/routes.php
+++ b/apps/files_sharing/appinfo/routes.php
@@ -48,6 +48,12 @@ $application->registerRoutes($this, [
'url' => '/ajax/publicpreview.php',
'verb' => 'GET',
],
+
+ [
+ 'name' => 'ShareInfo#info',
+ 'url' => '/shareinfo',
+ 'verb' => 'POST',
+ ],
],
'ocs' => [
/*
@@ -123,5 +129,5 @@ $application->registerRoutes($this, [
]);
/** @var $this \OCP\Route\IRouter */
-$this->create('sharing_external_shareinfo', '/shareinfo')
+$this->create('sharing_external_shareinfo', '/shareinfo3')
->actionInclude('files_sharing/ajax/shareinfo.php');
diff --git a/apps/files_sharing/lib/Controller/ShareInfoController.php b/apps/files_sharing/lib/Controller/ShareInfoController.php
new file mode 100644
index 00000000000..d926721f06c
--- /dev/null
+++ b/apps/files_sharing/lib/Controller/ShareInfoController.php
@@ -0,0 +1,130 @@
+<?php
+
+namespace OCA\Files_Sharing\Controller;
+
+use OCA\Files_External\NotFoundException;
+use OCP\AppFramework\ApiController;
+use OCP\AppFramework\Http;
+use OCP\AppFramework\Http\JSONResponse;
+use OCP\Constants;
+use OCP\Files\File;
+use OCP\Files\Folder;
+use OCP\Files\Node;
+use OCP\ILogger;
+use OCP\IRequest;
+use OCP\Share\Exceptions\ShareNotFound;
+use OCP\Share\IManager;
+
+class ShareInfoController extends ApiController {
+
+ /** @var IManager */
+ private $shareManager;
+
+ /** @var ILogger */
+ private $logger;
+
+ public function __construct($appName,
+ IRequest $request,
+ IManager $shareManager,
+ ILogger $logger) {
+ parent::__construct($appName, $request);
+
+ $this->shareManager = $shareManager;
+ $this->logger = $logger;
+ }
+
+ /**
+ * @PublicPage
+ * @NoCSRFRequired
+ *
+ * @param string $t
+ * @param null $password
+ * @param null $dir
+ * @return JSONResponse
+ */
+ public function info($t, $password = null, $dir = null) {
+ $this->logger->error('HERE!');
+ try {
+ $share = $this->shareManager->getShareByToken($t);
+ } catch (ShareNotFound $e) {
+ return new JSONResponse([], Http::STATUS_NOT_FOUND);
+ }
+
+ if ($share->getPassword() && !$this->shareManager->checkPassword($share, $password)) {
+ return new JSONResponse([], Http::STATUS_FORBIDDEN);
+ }
+
+ if (!($share->getPermissions() & Constants::PERMISSION_READ)) {
+ return new JSONResponse([], Http::STATUS_FORBIDDEN);
+ }
+
+ // TODO FIX!!!
+ $isWritable = $share->getPermissions() & (\OCP\Constants::PERMISSION_UPDATE | \OCP\Constants::PERMISSION_CREATE);
+ if (!$isWritable) {
+ // FIXME: should not add storage wrappers outside of preSetup, need to find a better way
+ $previousLog = \OC\Files\Filesystem::logWarningWhenAddingStorageWrapper(false);
+ \OC\Files\Filesystem::addStorageWrapper('readonly', function ($mountPoint, $storage) {
+ return new \OC\Files\Storage\Wrapper\PermissionsMask(array('storage' => $storage, 'mask' => \OCP\Constants::PERMISSION_READ + \OCP\Constants::PERMISSION_SHARE));
+ });
+ \OC\Files\Filesystem::logWarningWhenAddingStorageWrapper($previousLog);
+ }
+
+ $node = $share->getNode();
+
+ if ($dir !== null && $node instanceof Folder) {
+ try {
+ $node = $node->get($dir);
+ } catch (NotFoundException $e) {
+
+ }
+ }
+
+ $result = [
+ 'data' => $this->parseNode($node),
+ 'status' => 'success'
+ ];
+
+ return new JSONResponse($result);
+ }
+
+ private function parseNode(Node $node) {
+ if ($node instanceof File) {
+ return $this->parseFile($node);
+ }
+ return $this->parseFolder($node);
+ }
+
+ private function parseFile(File $file) {
+ return $this->format($file);
+ }
+
+ private function parseFolder(Folder $folder) {
+ $data = $this->format($folder);
+
+ $data['children'] = [];
+
+ $nodes = $folder->getDirectoryListing();
+ foreach ($nodes as $node) {
+ $data['children'][] = $this->parseNode($node);
+ }
+
+ return $data;
+ }
+
+ private function format(Node $node) {
+ $entry = [];
+
+ $entry['id'] = $node->getId();
+ $entry['parentId'] = $node->getParent()->getId();
+ $entry['mtime'] = $node->getMTime();
+
+ $entry['name'] = $node->getName();
+ $entry['permissions'] = $node->getPermissions();
+ $entry['mimetype'] = $node->getMimetype();
+ $entry['size'] = $node->getSize();
+ $entry['type'] = $node->getType();
+ $entry['etag'] = $node->getEtag();
+
+ return $entry;
+ }
+}