summaryrefslogtreecommitdiffstats
path: root/apps/dav
diff options
context:
space:
mode:
authorChristoph Wurst <christoph@winzerhof-wurst.at>2021-04-23 10:53:24 +0200
committerChristoph Wurst <christoph@winzerhof-wurst.at>2021-04-23 10:53:24 +0200
commit1722044992d8b8d5bcabcbd0b756f8564bf00d8a (patch)
tree1b0a21847a47eeb6064ece1bbb557c4ad54fc9b8 /apps/dav
parent513aba623ec02667629b8eb234507cd0feb3c4c3 (diff)
downloadnextcloud-server-1722044992d8b8d5bcabcbd0b756f8564bf00d8a.tar.gz
nextcloud-server-1722044992d8b8d5bcabcbd0b756f8564bf00d8a.zip
Only set copy etag if the destination source can be found
The etag is only set for files, but it's also possible that in edge cases the copy destination node can't be found. In that case we don't need to set any etag. Required for #26083 Signed-off-by: Christoph Wurst <christoph@winzerhof-wurst.at>
Diffstat (limited to 'apps/dav')
-rw-r--r--apps/dav/lib/Connector/Sabre/CopyEtagHeaderPlugin.php9
-rw-r--r--apps/dav/tests/unit/Connector/Sabre/CopyEtagHeaderPluginTest.php14
2 files changed, 22 insertions, 1 deletions
diff --git a/apps/dav/lib/Connector/Sabre/CopyEtagHeaderPlugin.php b/apps/dav/lib/Connector/Sabre/CopyEtagHeaderPlugin.php
index 9d58b25aa5a..0da15c113ee 100644
--- a/apps/dav/lib/Connector/Sabre/CopyEtagHeaderPlugin.php
+++ b/apps/dav/lib/Connector/Sabre/CopyEtagHeaderPlugin.php
@@ -25,6 +25,7 @@
namespace OCA\DAV\Connector\Sabre;
+use Sabre\DAV\Exception\NotFound;
use Sabre\HTTP\RequestInterface;
use Sabre\HTTP\ResponseInterface;
@@ -74,7 +75,13 @@ class CopyEtagHeaderPlugin extends \Sabre\DAV\ServerPlugin {
* @return void
*/
public function afterMove($source, $destination) {
- $node = $this->server->tree->getNodeForPath($destination);
+ try {
+ $node = $this->server->tree->getNodeForPath($destination);
+ } catch (NotFound $e) {
+ // Don't care
+ return;
+ }
+
if ($node instanceof File) {
$eTag = $node->getETag();
$this->server->httpResponse->setHeader('OC-ETag', $eTag);
diff --git a/apps/dav/tests/unit/Connector/Sabre/CopyEtagHeaderPluginTest.php b/apps/dav/tests/unit/Connector/Sabre/CopyEtagHeaderPluginTest.php
index 487fb2b6285..010d8af5a66 100644
--- a/apps/dav/tests/unit/Connector/Sabre/CopyEtagHeaderPluginTest.php
+++ b/apps/dav/tests/unit/Connector/Sabre/CopyEtagHeaderPluginTest.php
@@ -29,6 +29,7 @@ namespace OCA\DAV\Tests\unit\Connector\Sabre;
use OCA\DAV\Connector\Sabre\CopyEtagHeaderPlugin;
use OCA\DAV\Connector\Sabre\File;
+use Sabre\DAV\Exception\NotFound;
use Sabre\DAV\Server;
use Sabre\DAV\Tree;
use Test\TestCase;
@@ -73,6 +74,19 @@ class CopyEtagHeaderPluginTest extends TestCase {
$this->assertNull($response->getHeader('OC-Etag'));
}
+ public function testAfterMoveNodeNotFound(): void {
+ $tree = $this->createMock(Tree::class);
+ $tree->expects(self::once())
+ ->method('getNodeForPath')
+ ->with('test.txt')
+ ->willThrowException(new NotFound());
+
+ $this->server->tree = $tree;
+ $this->plugin->afterMove('', 'test.txt');
+
+ // Nothing to assert, we are just testing if the exception is handled
+ }
+
public function testAfterMove() {
$node = $this->getMockBuilder(File::class)
->disableOriginalConstructor()