summaryrefslogtreecommitdiffstats
path: root/apps/files
diff options
context:
space:
mode:
authorRoeland Jago Douma <roeland@famdouma.nl>2016-08-19 10:10:19 +0200
committerRoeland Jago Douma <roeland@famdouma.nl>2016-08-19 10:10:19 +0200
commitcc9b36131cf971f51d638501ef4da73c9fbedf18 (patch)
treef85000d79d6c8b05b03f68e163517a19f0849323 /apps/files
parent54f79a28f6650ec5cb4fbd9e152eb1d6fb0aa0cb (diff)
downloadnextcloud-server-cc9b36131cf971f51d638501ef4da73c9fbedf18.tar.gz
nextcloud-server-cc9b36131cf971f51d638501ef4da73c9fbedf18.zip
When requesting a permalink to an invalid file redirect
We need to do the redirect to update address bar.
Diffstat (limited to 'apps/files')
-rw-r--r--apps/files/lib/Controller/ViewController.php7
-rw-r--r--apps/files/tests/Controller/ViewControllerTest.php10
2 files changed, 10 insertions, 7 deletions
diff --git a/apps/files/lib/Controller/ViewController.php b/apps/files/lib/Controller/ViewController.php
index 9d26c048368..db8f32ddf73 100644
--- a/apps/files/lib/Controller/ViewController.php
+++ b/apps/files/lib/Controller/ViewController.php
@@ -143,15 +143,14 @@ class ViewController extends Controller {
* @param string $dir
* @param string $view
* @param string $fileid
- * @return TemplateResponse
+ * @return TemplateResponse|RedirectResponse
*/
- public function index($dir = '', $view = '', $fileid = null) {
- $fileNotFound = false;
+ public function index($dir = '', $view = '', $fileid = null, $fileNotFound = false) {
if ($fileid !== null) {
try {
return $this->showFile($fileid);
} catch (NotFoundException $e) {
- $fileNotFound = true;
+ return new RedirectResponse($this->urlGenerator->linkToRoute('files.view.index', ['fileNotFound' => true]));
}
}
diff --git a/apps/files/tests/Controller/ViewControllerTest.php b/apps/files/tests/Controller/ViewControllerTest.php
index 0ffe66c5592..b4b4bfa92fc 100644
--- a/apps/files/tests/Controller/ViewControllerTest.php
+++ b/apps/files/tests/Controller/ViewControllerTest.php
@@ -348,10 +348,14 @@ class ViewControllerTest extends TestCase {
->with(123)
->will($this->returnValue([]));
+ $this->urlGenerator->expects($this->once())
+ ->method('linkToRoute')
+ ->with('files.view.index', ['fileNotFound' => true])
+ ->willReturn('redirect.url');
+
$response = $this->viewController->index('MyDir', 'MyView', '123');
- $this->assertInstanceOf('OCP\AppFramework\Http\TemplateResponse', $response);
- $params = $response->getParams();
- $this->assertEquals(1, $params['fileNotFound']);
+ $this->assertInstanceOf('OCP\AppFramework\Http\RedirectResponse', $response);
+ $this->assertEquals('redirect.url', $response->getRedirectURL());
}
public function testShowFileRouteWithTrashedFile() {