summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristoph Wurst <ChristophWurst@users.noreply.github.com>2017-04-18 21:43:11 +0200
committerGitHub <noreply@github.com>2017-04-18 21:43:11 +0200
commit24f5c44e2b6ae949c6c592146ee8899b2a3add46 (patch)
tree90e4b587e1ee0547ddc6ada57c799b4c91a57c31
parentb072d2c49d6f61c2b55abf12e04bdf2166dbd4f4 (diff)
parent805419bb952b937ae980c198162f8f7dd30ff6d2 (diff)
downloadnextcloud-server-24f5c44e2b6ae949c6c592146ee8899b2a3add46.tar.gz
nextcloud-server-24f5c44e2b6ae949c6c592146ee8899b2a3add46.zip
Merge pull request #4376 from nextcloud/add-bruteforce-protection-to-change-self-password
Add bruteforce protection to changePersonalPassword
-rw-r--r--settings/Controller/ChangePasswordController.php5
-rw-r--r--tests/Core/Controller/ChangePasswordControllerTest.php70
2 files changed, 35 insertions, 40 deletions
diff --git a/settings/Controller/ChangePasswordController.php b/settings/Controller/ChangePasswordController.php
index b82751bcac2..2f61d36c3ff 100644
--- a/settings/Controller/ChangePasswordController.php
+++ b/settings/Controller/ChangePasswordController.php
@@ -85,6 +85,7 @@ class ChangePasswordController extends Controller {
/**
* @NoAdminRequired
* @NoSubadminRequired
+ * @BruteForceProtection(action=changePersonalPassword)
*
* @param string $oldpassword
* @param string $newpassword
@@ -95,12 +96,14 @@ class ChangePasswordController extends Controller {
/** @var IUser $user */
$user = $this->userManager->checkPassword($this->userId, $oldpassword);
if ($user === false) {
- return new JSONResponse([
+ $response = new JSONResponse([
'status' => 'error',
'data' => [
'message' => $this->l->t('Wrong password'),
],
]);
+ $response->throttle();
+ return $response;
}
try {
diff --git a/tests/Core/Controller/ChangePasswordControllerTest.php b/tests/Core/Controller/ChangePasswordControllerTest.php
index 869ef98b514..c426bae9974 100644
--- a/tests/Core/Controller/ChangePasswordControllerTest.php
+++ b/tests/Core/Controller/ChangePasswordControllerTest.php
@@ -25,45 +25,40 @@ use OC\HintException;
use OC\Settings\Controller\ChangePasswordController;
use OC\User\Session;
use OCP\App\IAppManager;
+use OCP\AppFramework\Http\JSONResponse;
use OCP\IGroupManager;
use OCP\IL10N;
+use OCP\IRequest;
use OCP\IUserManager;
class ChangePasswordControllerTest extends \Test\TestCase {
-
/** @var string */
private $userId = 'currentUser';
-
- /** @var IUserManager */
+ /** @var IUserManager|\PHPUnit_Framework_MockObject_MockObject */
private $userManager;
-
- /** @var Session */
+ /** @var Session|\PHPUnit_Framework_MockObject_MockObject */
private $userSession;
-
- /** @var IGroupManager */
+ /** @var IGroupManager|\PHPUnit_Framework_MockObject_MockObject */
private $groupManager;
-
- /** @var IAppManager */
+ /** @var IAppManager|\PHPUnit_Framework_MockObject_MockObject */
private $appManager;
-
- /** @var IL10N */
+ /** @var IL10N|\PHPUnit_Framework_MockObject_MockObject */
private $l;
-
/** @var ChangePasswordController */
private $controller;
public function setUp() {
parent::setUp();
- $this->userManager = $this->getMockBuilder('OCP\IUserManager')->getMock();
- $this->userSession = $this->getMockBuilder('OC\User\Session')->disableOriginalConstructor()->getMock();
- $this->groupManager = $this->getMockBuilder('OCP\IGroupManager')->getMock();
- $this->appManager = $this->getMockBuilder('OCP\App\IAppManager')->getMock();
- $this->l = $this->getMockBuilder('OCP\IL10N')->getMock();
-
+ $this->userManager = $this->createMock(IUserManager::class);
+ $this->userSession = $this->createMock(Session::class);
+ $this->groupManager = $this->createMock(IGroupManager::class);
+ $this->appManager = $this->createMock(IAppManager::class);
+ $this->l = $this->createMock(IL10N::class);
$this->l->method('t')->will($this->returnArgument(0));
- $request = $this->getMockBuilder('OCP\IRequest')->getMock();
+ /** @var IRequest|\PHPUnit_Framework_MockObject_MockObject $request */
+ $request = $this->createMock(IRequest::class);
$this->controller = new ChangePasswordController(
'core',
@@ -83,16 +78,16 @@ class ChangePasswordControllerTest extends \Test\TestCase {
->with($this->userId, 'old')
->willReturn(false);
- $expects = [
+ $expects = new JSONResponse([
'status' => 'error',
'data' => [
'message' => 'Wrong password',
],
- ];
-
- $res = $this->controller->changePersonalPassword('old', 'new');
+ ]);
+ $expects->throttle();
- $this->assertEquals($expects, $res->getData());
+ $actual = $this->controller->changePersonalPassword('old', 'new');
+ $this->assertEquals($expects, $actual);
}
public function testChangePersonalPasswordCommonPassword() {
@@ -107,16 +102,15 @@ class ChangePasswordControllerTest extends \Test\TestCase {
->with('new')
->will($this->throwException(new HintException('Common password')));
- $expects = [
+ $expects = new JSONResponse([
'status' => 'error',
'data' => [
'message' => 'Common password',
],
- ];
-
- $res = $this->controller->changePersonalPassword('old', 'new');
+ ]);
- $this->assertEquals($expects, $res->getData());
+ $actual = $this->controller->changePersonalPassword('old', 'new');
+ $this->assertEquals($expects, $actual);
}
public function testChangePersonalPasswordNoNewPassword() {
@@ -147,13 +141,12 @@ class ChangePasswordControllerTest extends \Test\TestCase {
->with('new')
->willReturn(false);
- $expects = [
+ $expects = new JSONResponse([
'status' => 'error',
- ];
+ ]);
- $res = $this->controller->changePersonalPassword('old', 'new');
-
- $this->assertEquals($expects, $res->getData());
+ $actual = $this->controller->changePersonalPassword('old', 'new');
+ $this->assertEquals($expects, $actual);
}
public function testChangePersonalPassword() {
@@ -172,15 +165,14 @@ class ChangePasswordControllerTest extends \Test\TestCase {
->method('updateSessionTokenPassword')
->with('new');
- $expects = [
+ $expects = new JSONResponse([
'status' => 'success',
'data' => [
'message' => 'Saved',
],
- ];
-
- $res = $this->controller->changePersonalPassword('old', 'new');
+ ]);
- $this->assertEquals($expects, $res->getData());
+ $actual = $this->controller->changePersonalPassword('old', 'new');
+ $this->assertEquals($expects, $actual);
}
}