2015-08-07 14:04:27 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Copyright (c) 2015 Robin Appelman <icewind@owncloud.com>
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Test\Connector\Sabre\RequestTest;
|
|
|
|
|
|
|
|
use OC\Connector\Sabre\Server;
|
2015-08-07 15:38:12 +00:00
|
|
|
use OC\Connector\Sabre\ServerFactory;
|
2015-08-07 14:04:27 +00:00
|
|
|
use OC\Files\Mount\MountPoint;
|
|
|
|
use OC\Files\Storage\Temporary;
|
|
|
|
use OC\Files\View;
|
|
|
|
use OCP\IUser;
|
|
|
|
use Sabre\HTTP\Request;
|
|
|
|
use Test\TestCase;
|
2015-08-20 12:38:51 +00:00
|
|
|
use Test\Traits\UserTrait;
|
2015-08-07 14:04:27 +00:00
|
|
|
|
|
|
|
abstract class RequestTest extends TestCase {
|
2015-08-20 12:38:51 +00:00
|
|
|
use UserTrait;
|
2015-08-07 14:04:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var \OCP\Files\Config\IMountProvider[]
|
|
|
|
*/
|
|
|
|
protected $mountProviders;
|
|
|
|
|
2015-08-07 15:38:12 +00:00
|
|
|
/**
|
|
|
|
* @var \OC\Connector\Sabre\ServerFactory
|
|
|
|
*/
|
|
|
|
protected $serverFactory;
|
|
|
|
|
2015-08-07 14:04:27 +00:00
|
|
|
protected function getStream($string) {
|
|
|
|
$stream = fopen('php://temp', 'r+');
|
|
|
|
fwrite($stream, $string);
|
|
|
|
fseek($stream, 0);
|
|
|
|
return $stream;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param $userId
|
|
|
|
* @param $storages
|
|
|
|
* @return \OCP\Files\Config\IMountProvider
|
|
|
|
*/
|
|
|
|
protected function getMountProvider($userId, $storages) {
|
|
|
|
$mounts = [];
|
|
|
|
foreach ($storages as $mountPoint => $storage) {
|
|
|
|
$mounts[] = new MountPoint($storage, $mountPoint);
|
|
|
|
}
|
|
|
|
$provider = $this->getMock('\OCP\Files\Config\IMountProvider');
|
|
|
|
$provider->expects($this->any())
|
|
|
|
->method('getMountsForUser')
|
|
|
|
->will($this->returnCallback(function (IUser $user) use ($userId, $mounts) {
|
|
|
|
if ($user->getUID() === $userId) {
|
|
|
|
return $mounts;
|
|
|
|
} else {
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
return $provider;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function setUp() {
|
2015-08-07 15:38:12 +00:00
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
$this->serverFactory = new ServerFactory(
|
|
|
|
\OC::$server->getConfig(),
|
|
|
|
\OC::$server->getLogger(),
|
|
|
|
\OC::$server->getDatabaseConnection(),
|
|
|
|
\OC::$server->getUserSession(),
|
|
|
|
\OC::$server->getMountManager(),
|
|
|
|
\OC::$server->getTagManager()
|
|
|
|
);
|
2015-08-07 14:04:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
protected function setupUser($name, $password) {
|
2015-08-20 12:38:51 +00:00
|
|
|
$this->createUser($name, $password);
|
2015-08-07 14:04:27 +00:00
|
|
|
\OC::$server->getMountProviderCollection()->registerProvider($this->getMountProvider($name, [
|
2015-08-20 12:38:51 +00:00
|
|
|
'/' . $name => '\OC\Files\Storage\Temporary'
|
2015-08-07 14:04:27 +00:00
|
|
|
]));
|
|
|
|
$this->loginAsUser($name);
|
|
|
|
return new View('/' . $name . '/files');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param \OC\Files\View $view the view to run the webdav server against
|
|
|
|
* @param string $user
|
|
|
|
* @param string $password
|
|
|
|
* @param string $method
|
|
|
|
* @param string $url
|
|
|
|
* @param resource|string|null $body
|
|
|
|
* @param array|null $headers
|
|
|
|
* @return \Sabre\HTTP\Response
|
|
|
|
*/
|
|
|
|
protected function request($view, $user, $password, $method, $url, $body = null, $headers = null) {
|
|
|
|
if (is_string($body)) {
|
|
|
|
$body = $this->getStream($body);
|
|
|
|
}
|
|
|
|
$this->logout();
|
|
|
|
$exceptionPlugin = new ExceptionPlugin('webdav', null);
|
|
|
|
$server = $this->getSabreServer($view, $user, $password, $exceptionPlugin);
|
|
|
|
$request = new Request($method, $url, $headers, $body);
|
|
|
|
|
|
|
|
// since sabre catches all exceptions we need to save them and throw them from outside the sabre server
|
|
|
|
|
|
|
|
$originalServer = $_SERVER;
|
|
|
|
|
|
|
|
if (is_array($headers)) {
|
|
|
|
foreach ($headers as $header => $value) {
|
|
|
|
$_SERVER['HTTP_' . strtoupper(str_replace('-', '_', $header))] = $value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$result = $this->makeRequest($server, $request);
|
|
|
|
|
|
|
|
foreach ($exceptionPlugin->getExceptions() as $exception) {
|
|
|
|
throw $exception;
|
|
|
|
}
|
|
|
|
$_SERVER = $originalServer;
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Server $server
|
|
|
|
* @param Request $request
|
|
|
|
* @return \Sabre\HTTP\Response
|
|
|
|
*/
|
|
|
|
protected function makeRequest(Server $server, Request $request) {
|
|
|
|
$sapi = new Sapi($request);
|
|
|
|
$server->sapi = $sapi;
|
|
|
|
$server->httpRequest = $request;
|
|
|
|
$server->exec();
|
|
|
|
return $sapi->getResponse();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param View $view
|
|
|
|
* @param string $user
|
|
|
|
* @param string $password
|
|
|
|
* @param ExceptionPlugin $exceptionPlugin
|
|
|
|
* @return Server
|
|
|
|
*/
|
|
|
|
protected function getSabreServer(View $view, $user, $password, ExceptionPlugin $exceptionPlugin) {
|
2015-08-07 15:36:14 +00:00
|
|
|
$authBackend = new Auth($user, $password);
|
2015-08-07 14:04:27 +00:00
|
|
|
|
2015-08-07 15:38:12 +00:00
|
|
|
$server = $this->serverFactory->createServer('/', 'dummy', $authBackend, function () use ($view) {
|
2015-08-07 15:36:14 +00:00
|
|
|
return $view;
|
|
|
|
});
|
2015-08-07 14:04:27 +00:00
|
|
|
$server->addPlugin($exceptionPlugin);
|
|
|
|
|
|
|
|
return $server;
|
|
|
|
}
|
|
|
|
}
|