mirror of
https://github.com/nextcloud/server.git
synced 2025-01-04 11:13:20 +00:00
8c0f8db6ca
Signed-off-by: skjnldsv <skjnldsv@protonmail.com>
181 lines
5.9 KiB
PHP
181 lines
5.9 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
/**
|
|
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
namespace OCA\DAV\Tests\unit\Connector\Sabre;
|
|
|
|
use OCA\DAV\Connector\Sabre\BlockLegacyClientPlugin;
|
|
use OCA\Theming\ThemingDefaults;
|
|
use OCP\IConfig;
|
|
use PHPUnit\Framework\MockObject\MockObject;
|
|
use Sabre\HTTP\RequestInterface;
|
|
use Test\TestCase;
|
|
|
|
enum ERROR_TYPE {
|
|
case MIN_ERROR;
|
|
case MAX_ERROR;
|
|
case NONE;
|
|
}
|
|
|
|
/**
|
|
* Class BlockLegacyClientPluginTest
|
|
*
|
|
* @package OCA\DAV\Tests\unit\Connector\Sabre
|
|
*/
|
|
class BlockLegacyClientPluginTest extends TestCase {
|
|
|
|
private IConfig&MockObject $config;
|
|
private ThemingDefaults&MockObject $themingDefaults;
|
|
private BlockLegacyClientPlugin $blockLegacyClientVersionPlugin;
|
|
|
|
protected function setUp(): void {
|
|
parent::setUp();
|
|
|
|
$this->config = $this->createMock(IConfig::class);
|
|
$this->themingDefaults = $this->createMock(ThemingDefaults::class);
|
|
$this->blockLegacyClientVersionPlugin = new BlockLegacyClientPlugin(
|
|
$this->config,
|
|
$this->themingDefaults,
|
|
);
|
|
}
|
|
|
|
public static function oldDesktopClientProvider(): array {
|
|
return [
|
|
['Mozilla/5.0 (Windows) mirall/1.5.0', ERROR_TYPE::MIN_ERROR],
|
|
['Mozilla/5.0 (Bogus Text) mirall/1.6.9', ERROR_TYPE::MIN_ERROR],
|
|
['Mozilla/5.0 (Windows) mirall/2.5.0', ERROR_TYPE::MAX_ERROR],
|
|
['Mozilla/5.0 (Bogus Text) mirall/2.0.1', ERROR_TYPE::MAX_ERROR],
|
|
['Mozilla/5.0 (Windows) mirall/2.0.0', ERROR_TYPE::NONE],
|
|
['Mozilla/5.0 (Bogus Text) mirall/2.0.0', ERROR_TYPE::NONE],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @dataProvider oldDesktopClientProvider
|
|
*/
|
|
public function testBeforeHandlerException(string $userAgent, ERROR_TYPE $errorType): void {
|
|
$this->themingDefaults
|
|
->expects($this->atMost(1))
|
|
->method('getSyncClientUrl')
|
|
->willReturn('https://nextcloud.com/install/#install-clients');
|
|
|
|
$this->config
|
|
->expects($this->exactly(2))
|
|
->method('getSystemValueString')
|
|
->willReturnCallback(function (string $key) {
|
|
if ($key === 'minimum.supported.desktop.version') {
|
|
return '1.7.0';
|
|
}
|
|
return '2.0.0';
|
|
});
|
|
|
|
if ($errorType !== ERROR_TYPE::NONE) {
|
|
$errorString = $errorType === ERROR_TYPE::MIN_ERROR
|
|
? 'This version of the client is unsupported. Upgrade to <a href="https://nextcloud.com/install/#install-clients">version 1.7.0 or later</a>.'
|
|
: 'This version of the client is unsupported. Downgrade to <a href="https://nextcloud.com/install/#install-clients">version 2.0.0 or earlier</a>.';
|
|
$this->expectException(\Sabre\DAV\Exception\Forbidden::class);
|
|
$this->expectExceptionMessage($errorString);
|
|
}
|
|
|
|
/** @var RequestInterface|MockObject $request */
|
|
$request = $this->createMock('\Sabre\HTTP\RequestInterface');
|
|
$request
|
|
->expects($this->once())
|
|
->method('getHeader')
|
|
->with('User-Agent')
|
|
->willReturn($userAgent);
|
|
|
|
$this->blockLegacyClientVersionPlugin->beforeHandler($request);
|
|
}
|
|
|
|
/**
|
|
* Ensure that there is no room for XSS attack through configured URL / version
|
|
* @dataProvider oldDesktopClientProvider
|
|
*/
|
|
public function testBeforeHandlerExceptionPreventXSSAttack(string $userAgent, ERROR_TYPE $errorType): void {
|
|
$this->expectException(\Sabre\DAV\Exception\Forbidden::class);
|
|
|
|
$this->themingDefaults
|
|
->expects($this->atMost(1))
|
|
->method('getSyncClientUrl')
|
|
->willReturn('https://example.com"><script>alter("hacked");</script>');
|
|
|
|
$this->config
|
|
->expects($this->exactly(2))
|
|
->method('getSystemValueString')
|
|
->willReturnCallback(function (string $key) {
|
|
if ($key === 'minimum.supported.desktop.version') {
|
|
return '1.7.0 <script>alert("unsafe")</script>';
|
|
}
|
|
return '2.0.0 <script>alert("unsafe")</script>';
|
|
});
|
|
|
|
$errorString = $errorType === ERROR_TYPE::MIN_ERROR
|
|
? 'This version of the client is unsupported. Upgrade to <a href="https://example.com"><script>alter("hacked");</script>">version 1.7.0 <script>alert("unsafe")</script> or later</a>.'
|
|
: 'This version of the client is unsupported. Downgrade to <a href="https://example.com"><script>alter("hacked");</script>">version 2.0.0 <script>alert("unsafe")</script> or earlier</a>.';
|
|
$this->expectExceptionMessage($errorString);
|
|
|
|
/** @var RequestInterface|MockObject $request */
|
|
$request = $this->createMock('\Sabre\HTTP\RequestInterface');
|
|
$request
|
|
->expects($this->once())
|
|
->method('getHeader')
|
|
->with('User-Agent')
|
|
->willReturn($userAgent);
|
|
|
|
$this->blockLegacyClientVersionPlugin->beforeHandler($request);
|
|
}
|
|
|
|
public static function newAndAlternateDesktopClientProvider(): array {
|
|
return [
|
|
['Mozilla/5.0 (Windows) mirall/1.7.0'],
|
|
['Mozilla/5.0 (Bogus Text) mirall/1.9.3'],
|
|
['Mozilla/5.0 (Not Our Client But Old Version) LegacySync/1.1.0'],
|
|
['Mozilla/5.0 (Windows) mirall/4.7.0'],
|
|
['Mozilla/5.0 (Bogus Text) mirall/3.9.3'],
|
|
['Mozilla/5.0 (Not Our Client But Old Version) LegacySync/45.0.0'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @dataProvider newAndAlternateDesktopClientProvider
|
|
*/
|
|
public function testBeforeHandlerSuccess(string $userAgent): void {
|
|
/** @var RequestInterface|MockObject $request */
|
|
$request = $this->createMock(RequestInterface::class);
|
|
$request
|
|
->expects($this->once())
|
|
->method('getHeader')
|
|
->with('User-Agent')
|
|
->willReturn($userAgent);
|
|
|
|
$this->config
|
|
->expects($this->exactly(2))
|
|
->method('getSystemValueString')
|
|
->willReturnCallback(function (string $key) {
|
|
if ($key === 'minimum.supported.desktop.version') {
|
|
return '1.7.0';
|
|
}
|
|
return '10.0.0';
|
|
});
|
|
|
|
$this->blockLegacyClientVersionPlugin->beforeHandler($request);
|
|
}
|
|
|
|
public function testBeforeHandlerNoUserAgent(): void {
|
|
/** @var RequestInterface|MockObject $request */
|
|
$request = $this->createMock(RequestInterface::class);
|
|
$request
|
|
->expects($this->once())
|
|
->method('getHeader')
|
|
->with('User-Agent')
|
|
->willReturn(null);
|
|
|
|
$this->blockLegacyClientVersionPlugin->beforeHandler($request);
|
|
}
|
|
}
|