summaryrefslogtreecommitdiffstats
path: root/apps/files/controller
diff options
context:
space:
mode:
authorLukas Reschke <lukas@owncloud.com>2015-02-17 00:47:29 +0100
committerLukas Reschke <lukas@owncloud.com>2015-02-17 17:08:23 +0100
commit3213b04aef30a66c7eebb750bfc4bbb6fe6cfa78 (patch)
tree09df95db40575fd9b325b199ae501e5ecd2572c7 /apps/files/controller
parentac13cf04ba83d42b0bf6c2955e08de10634095c2 (diff)
downloadnextcloud-server-3213b04aef30a66c7eebb750bfc4bbb6fe6cfa78.tar.gz
nextcloud-server-3213b04aef30a66c7eebb750bfc4bbb6fe6cfa78.zip
Check if the offset exists before accessing
This checks if the offset exists before accessing it and also adds unit tests to this function which would have catched this before :see_no_evil: Fixes https://github.com/owncloud/core/issues/14277
Diffstat (limited to 'apps/files/controller')
-rw-r--r--apps/files/controller/apicontroller.php50
1 files changed, 34 insertions, 16 deletions
diff --git a/apps/files/controller/apicontroller.php b/apps/files/controller/apicontroller.php
index 1bb07010a27..de9fa20dde0 100644
--- a/apps/files/controller/apicontroller.php
+++ b/apps/files/controller/apicontroller.php
@@ -1,6 +1,6 @@
<?php
/**
- * Copyright (c) 2014 Lukas Reschke <lukas@owncloud.com>
+ * Copyright (c) 2014-2015 Lukas Reschke <lukas@owncloud.com>
* This file is licensed under the Affero General Public License version 3 or
* later.
* See the COPYING-README file.
@@ -17,19 +17,27 @@ use OCP\AppFramework\Http\DownloadResponse;
use OC\Preview;
use OCA\Files\Service\TagService;
+/**
+ * Class ApiController
+ *
+ * @package OCA\Files\Controller
+ */
class ApiController extends Controller {
+ /** @var TagService */
+ private $tagService;
/**
- * @var TagService $tagService
+ * @param string $appName
+ * @param IRequest $request
+ * @param TagService $tagService
*/
- private $tagService;
-
- public function __construct($appName, IRequest $request, TagService $tagService){
+ public function __construct($appName,
+ IRequest $request,
+ TagService $tagService){
parent::__construct($appName, $request);
$this->tagService = $tagService;
}
-
/**
* Gets a thumbnail of the specified file
*
@@ -66,25 +74,31 @@ class ApiController extends Controller {
* @CORS
*
* @param string $path path
- * @param array $tags array of tags
+ * @param array|string $tags array of tags
* @return DataResponse
*/
public function updateFileTags($path, $tags = null) {
- $result = array();
+ $result = [];
// if tags specified or empty array, update tags
if (!is_null($tags)) {
try {
$this->tagService->updateFileTags($path, $tags);
} catch (\OCP\Files\NotFoundException $e) {
- return new DataResponse(['message' => $e->getMessage()], Http::STATUS_NOT_FOUND);
+ return new DataResponse([
+ 'message' => $e->getMessage()
+ ], Http::STATUS_NOT_FOUND);
} catch (\OCP\Files\StorageNotAvailableException $e) {
- return new DataResponse(['message' => $e->getMessage()], Http::STATUS_SERVICE_UNAVAILABLE);
+ return new DataResponse([
+ 'message' => $e->getMessage()
+ ], Http::STATUS_SERVICE_UNAVAILABLE);
} catch (\Exception $e) {
- return new DataResponse(['message' => $e->getMessage()], Http::STATUS_NOT_FOUND);
+ return new DataResponse([
+ 'message' => $e->getMessage()
+ ], Http::STATUS_NOT_FOUND);
}
$result['tags'] = $tags;
}
- return new DataResponse($result, Http::STATUS_OK);
+ return new DataResponse($result);
}
/**
@@ -93,7 +107,7 @@ class ApiController extends Controller {
* @NoAdminRequired
* @CORS
*
- * @param array $tagName tag name to filter by
+ * @param array|string $tagName tag name to filter by
* @return DataResponse
*/
public function getFilesByTag($tagName) {
@@ -102,11 +116,15 @@ class ApiController extends Controller {
foreach ($fileInfos as &$fileInfo) {
$file = \OCA\Files\Helper::formatFileInfo($fileInfo);
$parts = explode('/', dirname($fileInfo->getPath()), 4);
- $file['path'] = '/' . $parts[3];
- $file['tags'] = array($tagName);
+ if(isset($parts[3])) {
+ $file['path'] = '/' . $parts[3];
+ } else {
+ $file['path'] = '/';
+ }
+ $file['tags'] = [$tagName];
$files[] = $file;
}
- return new DataResponse(array('files' => $files), Http::STATUS_OK);
+ return new DataResponse(['files' => $files]);
}
}