From 81761b87e4d29989329b398d4f797f0ccb47b144 Mon Sep 17 00:00:00 2001 From: Vincent Petry Date: Fri, 10 Jun 2016 11:03:19 +0200 Subject: DAV now returns file name with Content-Disposition header --- apps/dav/lib/connector/sabre/filesplugin.php | 29 +++++++++++++++++++--- apps/dav/lib/connector/sabre/serverfactory.php | 6 ++++- apps/dav/lib/server.php | 6 ++++- .../dav/tests/unit/connector/sabre/filesplugin.php | 13 ++++++++-- .../unit/connector/sabre/filesreportplugin.php | 6 ++++- 5 files changed, 51 insertions(+), 9 deletions(-) (limited to 'apps') diff --git a/apps/dav/lib/connector/sabre/filesplugin.php b/apps/dav/lib/connector/sabre/filesplugin.php index bf9bee02578..857c98247bd 100644 --- a/apps/dav/lib/connector/sabre/filesplugin.php +++ b/apps/dav/lib/connector/sabre/filesplugin.php @@ -76,16 +76,26 @@ class FilesPlugin extends \Sabre\DAV\ServerPlugin { */ private $fileView; + /** + * @var IRequest + */ + private $request; + /** * @param \Sabre\DAV\Tree $tree * @param \OC\Files\View $view + * @param \OCP\IRequest $request * @param bool $isPublic */ - public function __construct(\Sabre\DAV\Tree $tree, - \OC\Files\View $view, - $isPublic = false) { + public function __construct( + \Sabre\DAV\Tree $tree, + \OC\Files\View $view, + \OCP\IRequest $request, + $isPublic = false + ) { $this->tree = $tree; $this->fileView = $view; + $this->request = $request; $this->isPublic = $isPublic; } @@ -193,7 +203,18 @@ class FilesPlugin extends \Sabre\DAV\ServerPlugin { if (!($node instanceof IFile)) return; // adds a 'Content-Disposition: attachment' header - $response->addHeader('Content-Disposition', 'attachment'); + $filename = $node->getName(); + if ($this->request->isUserAgent( + [ + \OC\AppFramework\Http\Request::USER_AGENT_IE, + \OC\AppFramework\Http\Request::USER_AGENT_ANDROID_MOBILE_CHROME, + \OC\AppFramework\Http\Request::USER_AGENT_FREEBOX, + ])) { + $response->addHeader('Content-Disposition', 'attachment; filename="' . rawurlencode($filename) . '"'); + } else { + $response->addHeader('Content-Disposition', 'attachment; filename*=UTF-8\'\'' . rawurlencode($filename) + . '; filename="' . rawurlencode($filename) . '"'); + } if ($node instanceof \OCA\DAV\Connector\Sabre\File) { //Add OC-Checksum header diff --git a/apps/dav/lib/connector/sabre/serverfactory.php b/apps/dav/lib/connector/sabre/serverfactory.php index c0b45c36a00..8462f624552 100644 --- a/apps/dav/lib/connector/sabre/serverfactory.php +++ b/apps/dav/lib/connector/sabre/serverfactory.php @@ -137,7 +137,11 @@ class ServerFactory { } $objectTree->init($root, $view, $this->mountManager); - $server->addPlugin(new \OCA\DAV\Connector\Sabre\FilesPlugin($objectTree, $view)); + $server->addPlugin(new \OCA\DAV\Connector\Sabre\FilesPlugin( + $objectTree, + $view, + $this->request + )); $server->addPlugin(new \OCA\DAV\Connector\Sabre\QuotaPlugin($view)); if($this->userSession->isLoggedIn()) { diff --git a/apps/dav/lib/server.php b/apps/dav/lib/server.php index 4711a80800d..791bd1ba7e8 100644 --- a/apps/dav/lib/server.php +++ b/apps/dav/lib/server.php @@ -125,7 +125,11 @@ class Server { $user = \OC::$server->getUserSession()->getUser(); if (!is_null($user)) { $view = \OC\Files\Filesystem::getView(); - $this->server->addPlugin(new FilesPlugin($this->server->tree, $view)); + $this->server->addPlugin(new FilesPlugin( + $this->server->tree, + $view, + $this->request + )); $this->server->addPlugin( new \Sabre\DAV\PropertyStorage\Plugin( diff --git a/apps/dav/tests/unit/connector/sabre/filesplugin.php b/apps/dav/tests/unit/connector/sabre/filesplugin.php index 0a790ec6fc9..ecad56d004d 100644 --- a/apps/dav/tests/unit/connector/sabre/filesplugin.php +++ b/apps/dav/tests/unit/connector/sabre/filesplugin.php @@ -72,8 +72,13 @@ class FilesPlugin extends \Test\TestCase { $this->view = $this->getMockBuilder('\OC\Files\View') ->disableOriginalConstructor() ->getMock(); + $request = $this->getMock('\OCP\IRequest'); - $this->plugin = new \OCA\DAV\Connector\Sabre\FilesPlugin($this->tree, $this->view); + $this->plugin = new \OCA\DAV\Connector\Sabre\FilesPlugin( + $this->tree, + $this->view, + $request + ); $this->plugin->initialize($this->server); } @@ -237,7 +242,11 @@ class FilesPlugin extends \Test\TestCase { } public function testGetPublicPermissions() { - $this->plugin = new \OCA\DAV\Connector\Sabre\FilesPlugin($this->tree, $this->view, true); + $this->plugin = new \OCA\DAV\Connector\Sabre\FilesPlugin( + $this->tree, + $this->view, + $this->getMock('\OCP\IRequest'), + true); $this->plugin->initialize($this->server); $propFind = new \Sabre\DAV\PropFind( diff --git a/apps/dav/tests/unit/connector/sabre/filesreportplugin.php b/apps/dav/tests/unit/connector/sabre/filesreportplugin.php index 87973ef0071..c17cc0f30a3 100644 --- a/apps/dav/tests/unit/connector/sabre/filesreportplugin.php +++ b/apps/dav/tests/unit/connector/sabre/filesreportplugin.php @@ -336,7 +336,11 @@ class FilesReportPlugin extends \Test\TestCase { ->method('getSize') ->will($this->returnValue(1024)); - $this->server->addPlugin(new \OCA\DAV\Connector\Sabre\FilesPlugin($this->tree, $this->view)); + $this->server->addPlugin(new \OCA\DAV\Connector\Sabre\FilesPlugin( + $this->tree, + $this->view, + $this->getMock('\OCP\IRequest') + )); $this->plugin->initialize($this->server); $responses = $this->plugin->prepareResponses($requestedProps, [$node1, $node2]); -- cgit v1.2.3