aboutsummaryrefslogtreecommitdiffstats
path: root/apps/files/controller
diff options
context:
space:
mode:
authorRoeland Jago Douma <roeland@famdouma.nl>2015-03-16 12:42:40 +0100
committerRoeland Jago Douma <roeland@famdouma.nl>2015-03-24 18:55:06 +0100
commit0ea387811151da1fc397fa876b8a59052388d6bc (patch)
tree1f3ba967cb5a286ce55ed8817f86f446671a26b2 /apps/files/controller
parent1bd141b65511983326f0076b676b14e1528ddd65 (diff)
downloadnextcloud-server-0ea387811151da1fc397fa876b8a59052388d6bc.tar.gz
nextcloud-server-0ea387811151da1fc397fa876b8a59052388d6bc.zip
No longer directly output OC_Image for thumbnails
* Only use public interfaces - Injected IPreview * Added unit tests
Diffstat (limited to 'apps/files/controller')
-rw-r--r--apps/files/controller/apicontroller.php26
1 files changed, 15 insertions, 11 deletions
diff --git a/apps/files/controller/apicontroller.php b/apps/files/controller/apicontroller.php
index de9fa20dde0..d6e62180df3 100644
--- a/apps/files/controller/apicontroller.php
+++ b/apps/files/controller/apicontroller.php
@@ -11,11 +11,11 @@ namespace OCA\Files\Controller;
use OCP\AppFramework\Http;
use OCP\AppFramework\Controller;
use OCP\IRequest;
-use OCP\AppFramework\Http\JSONResponse;
use OCP\AppFramework\Http\DataResponse;
+use OCP\AppFramework\Http\DataDisplayResponse;
use OCP\AppFramework\Http\DownloadResponse;
-use OC\Preview;
use OCA\Files\Service\TagService;
+use OCP\IPreview;
/**
* Class ApiController
@@ -25,17 +25,22 @@ use OCA\Files\Service\TagService;
class ApiController extends Controller {
/** @var TagService */
private $tagService;
+ /** @var IPreview */
+ private $previewManager;
/**
* @param string $appName
* @param IRequest $request
* @param TagService $tagService
+ * @param IPreview $previewManager
*/
public function __construct($appName,
IRequest $request,
- TagService $tagService){
+ TagService $tagService,
+ IPreview $previewManager){
parent::__construct($appName, $request);
$this->tagService = $tagService;
+ $this->previewManager = $previewManager;
}
/**
@@ -49,19 +54,18 @@ class ApiController extends Controller {
* @param int $x
* @param int $y
* @param string $file URL-encoded filename
- * @return JSONResponse|DownloadResponse
+ * @return DataResponse|DataDisplayResponse
*/
public function getThumbnail($x, $y, $file) {
if($x < 1 || $y < 1) {
- return new JSONResponse('Requested size must be numeric and a positive value.', Http::STATUS_BAD_REQUEST);
+ return new DataResponse(['message' => 'Requested size must be numeric and a positive value.'], Http::STATUS_BAD_REQUEST);
}
- try {
- $preview = new Preview('', 'files', urldecode($file), $x, $y, true);
- echo($preview->showPreview('image/png'));
- return new DownloadResponse(urldecode($file).'.png', 'image/png');
- } catch (\Exception $e) {
- return new JSONResponse('File not found.', Http::STATUS_NOT_FOUND);
+ $preview = $this->previewManager->createPreview('files/'.urldecode($file), $x, $y, true);
+ if ($preview->valid()) {
+ return new DataDisplayResponse($preview->data(), Http::STATUS_OK, ['Content-Type' => 'image/png']);
+ } else {
+ return new DataResponse(['message' => 'File not found.'], Http::STATUS_NOT_FOUND);
}
}