]> source.dussan.org Git - nextcloud-server.git/commitdiff
Copy Etag header to OC-Etag for sabre calls
authorVincent Petry <pvince81@owncloud.com>
Thu, 26 Mar 2015 15:06:43 +0000 (16:06 +0100)
committerVincent Petry <pvince81@owncloud.com>
Thu, 26 Mar 2015 15:06:43 +0000 (16:06 +0100)
apps/files/appinfo/remote.php
lib/private/connector/sabre/copyetagheaderplugin.php [new file with mode: 0644]
tests/lib/connector/sabre/copyetagheaderplugintest.php [new file with mode: 0644]

index e260f85fdb045191e28365180baddc83d25ee538..bac372564b6d646ffb46a1f2d6103838a6faf5b0 100644 (file)
@@ -65,6 +65,7 @@ $server->on('beforeMethod', function () use ($server, $objectTree) {
                        )
                )
        );
+       $server->addPlugin(new \OC\Connector\Sabre\CopyEtagHeaderPlugin());
 }, 30); // priority 30: after auth (10) and acl(20), before lock(50) and handling the request
 
 // And off we go!
diff --git a/lib/private/connector/sabre/copyetagheaderplugin.php b/lib/private/connector/sabre/copyetagheaderplugin.php
new file mode 100644 (file)
index 0000000..9f5d746
--- /dev/null
@@ -0,0 +1,46 @@
+<?php
+
+/**
+ * ownCloud
+ *
+ * @author Vincent Petry
+ * @copyright 2015 Vincent Petry <pvince81@owncloud.com>
+ *
+ * @license AGPL3
+ */
+
+namespace OC\Connector\Sabre;
+
+use \Sabre\HTTP\RequestInterface;
+use \Sabre\HTTP\ResponseInterface;
+
+/**
+ * Copies the "Etag" header to "OC-Etag" after any request.
+ * This is a workaround for setups that automatically strip
+ * or mangle Etag headers.
+ */
+class CopyEtagHeaderPlugin extends \Sabre\DAV\ServerPlugin {
+       /**
+        * This initializes the plugin.
+        *
+        * @param \Sabre\DAV\Server $server Sabre server
+        *
+        * @return void
+        */
+       public function initialize(\Sabre\DAV\Server $server) {
+               $server->on('afterMethod', array($this, 'afterMethod'));
+       }
+
+       /**
+        * After method, copy the "Etag" header to "OC-Etag" header.
+        *
+        * @param RequestInterface $request request
+        * @param ResponseInterface $response response
+        */
+       public function afterMethod(RequestInterface $request, ResponseInterface $response) {
+               $eTag = $response->getHeader('Etag');
+               if (!empty($eTag)) {
+                       $response->setHeader('OC-ETag', $eTag);
+               }
+       }
+}
diff --git a/tests/lib/connector/sabre/copyetagheaderplugintest.php b/tests/lib/connector/sabre/copyetagheaderplugintest.php
new file mode 100644 (file)
index 0000000..176f9c8
--- /dev/null
@@ -0,0 +1,43 @@
+<?php
+
+namespace Tests\Connector\Sabre;
+
+/**
+ * Copyright (c) 2015 Vincent Petry <pvince81@owncloud.com>
+ * This file is licensed under the Affero General Public License version 3 or
+ * later.
+ * See the COPYING-README file.
+ */
+class CopyEtagPluginTest extends \Test\TestCase {
+
+       /**
+        * @var \OC\Connector\Sabre\CopyEtagHeaderPlugin
+        */
+       private $plugin;
+
+       public function setUp() {
+               parent::setUp();
+               $this->server = new \Sabre\DAV\Server();
+               $this->plugin = new \OC\Connector\Sabre\CopyEtagHeaderPlugin($this->tree);
+               $this->plugin->initialize($this->server);
+       }
+
+       public function testCopyEtag() {
+               $request = new \Sabre\Http\Request();
+               $response = new \Sabre\Http\Response();
+               $response->setHeader('Etag', 'abcd');
+
+               $this->plugin->afterMethod($request, $response);
+
+               $this->assertEquals('abcd', $response->getHeader('OC-Etag'));
+       }
+
+       public function testNoopWhenEmpty() {
+               $request = new \Sabre\Http\Request();
+               $response = new \Sabre\Http\Response();
+
+               $this->plugin->afterMethod($request, $response);
+
+               $this->assertNull($response->getHeader('OC-Etag'));
+       }
+}