2016-04-01 11:35:37 -04:00
|
|
|
<?php
|
2024-05-28 06:34:11 -04:00
|
|
|
|
2025-05-27 17:36:08 -04:00
|
|
|
declare(strict_types=1);
|
2016-05-26 13:56:05 -04:00
|
|
|
/**
|
2024-05-28 06:34:11 -04:00
|
|
|
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
|
|
|
|
|
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
|
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
2016-05-26 13:56:05 -04:00
|
|
|
*/
|
2016-05-25 10:04:15 -04:00
|
|
|
namespace OCA\DAV\Tests\unit\Connector;
|
2016-04-01 11:35:37 -04:00
|
|
|
|
2024-10-10 06:40:31 -04:00
|
|
|
use OCA\DAV\Connector\LegacyPublicAuth;
|
2016-04-01 11:35:37 -04:00
|
|
|
use OCP\IRequest;
|
|
|
|
|
use OCP\ISession;
|
2023-08-28 09:50:45 -04:00
|
|
|
use OCP\Security\Bruteforce\IThrottler;
|
2016-04-01 11:35:37 -04:00
|
|
|
use OCP\Share\Exceptions\ShareNotFound;
|
|
|
|
|
use OCP\Share\IManager;
|
2017-10-24 18:03:28 -04:00
|
|
|
use OCP\Share\IShare;
|
2025-05-27 17:36:08 -04:00
|
|
|
use PHPUnit\Framework\MockObject\MockObject;
|
2016-04-01 11:35:37 -04:00
|
|
|
|
2016-04-21 07:36:52 -04:00
|
|
|
/**
|
2022-10-28 09:05:07 -04:00
|
|
|
* Class LegacyPublicAuthTest
|
2016-04-21 07:36:52 -04:00
|
|
|
*
|
|
|
|
|
* @group DB
|
2017-05-04 05:20:20 -04:00
|
|
|
*
|
2016-05-25 10:04:15 -04:00
|
|
|
* @package OCA\DAV\Tests\unit\Connector
|
2016-04-21 07:36:52 -04:00
|
|
|
*/
|
2022-10-28 09:05:07 -04:00
|
|
|
class LegacyPublicAuthTest extends \Test\TestCase {
|
2025-05-27 17:36:08 -04:00
|
|
|
private ISession&MockObject $session;
|
|
|
|
|
private IRequest&MockObject $request;
|
|
|
|
|
private IManager&MockObject $shareManager;
|
|
|
|
|
private IThrottler&MockObject $throttler;
|
|
|
|
|
private LegacyPublicAuth $auth;
|
|
|
|
|
private string|false $oldUser;
|
2016-04-01 11:35:37 -04:00
|
|
|
|
2019-11-21 10:40:38 -05:00
|
|
|
protected function setUp(): void {
|
2016-04-01 11:35:37 -04:00
|
|
|
parent::setUp();
|
|
|
|
|
|
2025-05-27 17:36:08 -04:00
|
|
|
$this->session = $this->createMock(ISession::class);
|
|
|
|
|
$this->request = $this->createMock(IRequest::class);
|
|
|
|
|
$this->shareManager = $this->createMock(IManager::class);
|
|
|
|
|
$this->throttler = $this->createMock(IThrottler::class);
|
2016-04-01 11:35:37 -04:00
|
|
|
|
2024-10-10 06:40:31 -04:00
|
|
|
$this->auth = new LegacyPublicAuth(
|
2016-04-01 11:35:37 -04:00
|
|
|
$this->request,
|
|
|
|
|
$this->shareManager,
|
2021-06-22 13:54:13 -04:00
|
|
|
$this->session,
|
|
|
|
|
$this->throttler
|
2016-04-01 11:35:37 -04:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// Store current user
|
|
|
|
|
$this->oldUser = \OC_User::getUser();
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-21 10:40:38 -05:00
|
|
|
protected function tearDown(): void {
|
2016-04-01 11:35:37 -04:00
|
|
|
\OC_User::setIncognitoMode(false);
|
|
|
|
|
|
|
|
|
|
// Set old user
|
|
|
|
|
\OC_User::setUserId($this->oldUser);
|
2025-05-27 17:36:08 -04:00
|
|
|
if ($this->oldUser !== false) {
|
|
|
|
|
\OC_Util::setupFS($this->oldUser);
|
|
|
|
|
}
|
2016-04-01 11:35:37 -04:00
|
|
|
|
|
|
|
|
parent::tearDown();
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-20 02:38:43 -05:00
|
|
|
public function testNoShare(): void {
|
2016-04-01 11:35:37 -04:00
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('getShareByToken')
|
|
|
|
|
->willThrowException(new ShareNotFound());
|
|
|
|
|
|
|
|
|
|
$result = $this->invokePrivate($this->auth, 'validateUserPass', ['username', 'password']);
|
|
|
|
|
|
|
|
|
|
$this->assertFalse($result);
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-20 02:38:43 -05:00
|
|
|
public function testShareNoPassword(): void {
|
2025-05-27 17:36:08 -04:00
|
|
|
$share = $this->createMock(IShare::class);
|
2016-04-01 11:35:37 -04:00
|
|
|
$share->method('getPassword')->willReturn(null);
|
|
|
|
|
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('getShareByToken')
|
|
|
|
|
->willReturn($share);
|
|
|
|
|
|
|
|
|
|
$result = $this->invokePrivate($this->auth, 'validateUserPass', ['username', 'password']);
|
|
|
|
|
|
|
|
|
|
$this->assertTrue($result);
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-20 02:38:43 -05:00
|
|
|
public function testSharePasswordFancyShareType(): void {
|
2025-05-27 17:36:08 -04:00
|
|
|
$share = $this->createMock(IShare::class);
|
2016-04-01 11:35:37 -04:00
|
|
|
$share->method('getPassword')->willReturn('password');
|
|
|
|
|
$share->method('getShareType')->willReturn(42);
|
|
|
|
|
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('getShareByToken')
|
|
|
|
|
->willReturn($share);
|
|
|
|
|
|
|
|
|
|
$result = $this->invokePrivate($this->auth, 'validateUserPass', ['username', 'password']);
|
|
|
|
|
|
|
|
|
|
$this->assertFalse($result);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2023-01-20 02:38:43 -05:00
|
|
|
public function testSharePasswordRemote(): void {
|
2025-05-27 17:36:08 -04:00
|
|
|
$share = $this->createMock(IShare::class);
|
2016-04-01 11:35:37 -04:00
|
|
|
$share->method('getPassword')->willReturn('password');
|
2020-06-24 10:49:16 -04:00
|
|
|
$share->method('getShareType')->willReturn(IShare::TYPE_REMOTE);
|
2016-04-01 11:35:37 -04:00
|
|
|
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('getShareByToken')
|
|
|
|
|
->willReturn($share);
|
|
|
|
|
|
|
|
|
|
$result = $this->invokePrivate($this->auth, 'validateUserPass', ['username', 'password']);
|
|
|
|
|
|
|
|
|
|
$this->assertTrue($result);
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-20 02:38:43 -05:00
|
|
|
public function testSharePasswordLinkValidPassword(): void {
|
2025-05-27 17:36:08 -04:00
|
|
|
$share = $this->createMock(IShare::class);
|
2016-04-01 11:35:37 -04:00
|
|
|
$share->method('getPassword')->willReturn('password');
|
2020-06-24 10:49:16 -04:00
|
|
|
$share->method('getShareType')->willReturn(IShare::TYPE_LINK);
|
2016-04-01 11:35:37 -04:00
|
|
|
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('getShareByToken')
|
|
|
|
|
->willReturn($share);
|
|
|
|
|
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('checkPassword')->with(
|
|
|
|
|
$this->equalTo($share),
|
|
|
|
|
$this->equalTo('password')
|
|
|
|
|
)->willReturn(true);
|
|
|
|
|
|
|
|
|
|
$result = $this->invokePrivate($this->auth, 'validateUserPass', ['username', 'password']);
|
|
|
|
|
|
|
|
|
|
$this->assertTrue($result);
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-20 02:38:43 -05:00
|
|
|
public function testSharePasswordMailValidPassword(): void {
|
2025-05-27 17:36:08 -04:00
|
|
|
$share = $this->createMock(IShare::class);
|
2017-05-04 05:20:20 -04:00
|
|
|
$share->method('getPassword')->willReturn('password');
|
2020-06-24 10:49:16 -04:00
|
|
|
$share->method('getShareType')->willReturn(IShare::TYPE_EMAIL);
|
2017-05-04 05:20:20 -04:00
|
|
|
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('getShareByToken')
|
|
|
|
|
->willReturn($share);
|
|
|
|
|
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('checkPassword')->with(
|
|
|
|
|
$this->equalTo($share),
|
|
|
|
|
$this->equalTo('password')
|
|
|
|
|
)->willReturn(true);
|
|
|
|
|
|
|
|
|
|
$result = $this->invokePrivate($this->auth, 'validateUserPass', ['username', 'password']);
|
|
|
|
|
|
|
|
|
|
$this->assertTrue($result);
|
|
|
|
|
}
|
|
|
|
|
|
2022-10-28 09:05:07 -04:00
|
|
|
public function testInvalidSharePasswordLinkValidSession(): void {
|
2025-05-27 17:36:08 -04:00
|
|
|
$share = $this->createMock(IShare::class);
|
2016-04-01 11:35:37 -04:00
|
|
|
$share->method('getPassword')->willReturn('password');
|
2020-06-24 10:49:16 -04:00
|
|
|
$share->method('getShareType')->willReturn(IShare::TYPE_LINK);
|
2016-04-01 11:35:37 -04:00
|
|
|
$share->method('getId')->willReturn('42');
|
|
|
|
|
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('getShareByToken')
|
|
|
|
|
->willReturn($share);
|
|
|
|
|
|
|
|
|
|
$this->shareManager->method('checkPassword')
|
|
|
|
|
->with(
|
|
|
|
|
$this->equalTo($share),
|
|
|
|
|
$this->equalTo('password')
|
|
|
|
|
)->willReturn(false);
|
|
|
|
|
|
|
|
|
|
$this->session->method('exists')->with('public_link_authenticated')->willReturn(true);
|
|
|
|
|
$this->session->method('get')->with('public_link_authenticated')->willReturn('42');
|
|
|
|
|
|
|
|
|
|
$result = $this->invokePrivate($this->auth, 'validateUserPass', ['username', 'password']);
|
|
|
|
|
|
|
|
|
|
$this->assertTrue($result);
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-20 02:38:43 -05:00
|
|
|
public function testSharePasswordLinkInvalidSession(): void {
|
2025-05-27 17:36:08 -04:00
|
|
|
$share = $this->createMock(IShare::class);
|
2016-04-01 11:35:37 -04:00
|
|
|
$share->method('getPassword')->willReturn('password');
|
2020-06-24 10:49:16 -04:00
|
|
|
$share->method('getShareType')->willReturn(IShare::TYPE_LINK);
|
2016-04-01 11:35:37 -04:00
|
|
|
$share->method('getId')->willReturn('42');
|
|
|
|
|
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('getShareByToken')
|
|
|
|
|
->willReturn($share);
|
|
|
|
|
|
|
|
|
|
$this->shareManager->method('checkPassword')
|
|
|
|
|
->with(
|
|
|
|
|
$this->equalTo($share),
|
|
|
|
|
$this->equalTo('password')
|
|
|
|
|
)->willReturn(false);
|
|
|
|
|
|
|
|
|
|
$this->session->method('exists')->with('public_link_authenticated')->willReturn(true);
|
|
|
|
|
$this->session->method('get')->with('public_link_authenticated')->willReturn('43');
|
|
|
|
|
|
|
|
|
|
$result = $this->invokePrivate($this->auth, 'validateUserPass', ['username', 'password']);
|
|
|
|
|
|
|
|
|
|
$this->assertFalse($result);
|
|
|
|
|
}
|
2017-05-04 05:20:20 -04:00
|
|
|
|
|
|
|
|
|
2023-01-20 02:38:43 -05:00
|
|
|
public function testSharePasswordMailInvalidSession(): void {
|
2025-05-27 17:36:08 -04:00
|
|
|
$share = $this->createMock(IShare::class);
|
2017-05-04 05:20:20 -04:00
|
|
|
$share->method('getPassword')->willReturn('password');
|
2020-06-24 10:49:16 -04:00
|
|
|
$share->method('getShareType')->willReturn(IShare::TYPE_EMAIL);
|
2017-05-04 05:20:20 -04:00
|
|
|
$share->method('getId')->willReturn('42');
|
|
|
|
|
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('getShareByToken')
|
|
|
|
|
->willReturn($share);
|
|
|
|
|
|
|
|
|
|
$this->shareManager->method('checkPassword')
|
|
|
|
|
->with(
|
|
|
|
|
$this->equalTo($share),
|
|
|
|
|
$this->equalTo('password')
|
|
|
|
|
)->willReturn(false);
|
|
|
|
|
|
|
|
|
|
$this->session->method('exists')->with('public_link_authenticated')->willReturn(true);
|
|
|
|
|
$this->session->method('get')->with('public_link_authenticated')->willReturn('43');
|
|
|
|
|
|
|
|
|
|
$result = $this->invokePrivate($this->auth, 'validateUserPass', ['username', 'password']);
|
|
|
|
|
|
|
|
|
|
$this->assertFalse($result);
|
|
|
|
|
}
|
2016-04-01 11:35:37 -04:00
|
|
|
}
|