2010-10-18 22:29:35 +00:00
|
|
|
<?php
|
2016-06-23 11:37:22 +12:00
|
|
|
|
|
|
|
use SilverStripe\Security\Member;
|
|
|
|
use SilverStripe\Security\Security;
|
|
|
|
use SilverStripe\Security\BasicAuth;
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Dev\FunctionalTest;
|
|
|
|
use SilverStripe\Dev\TestOnly;
|
|
|
|
use SilverStripe\Control\Director;
|
|
|
|
use SilverStripe\Control\Controller;
|
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
/**
|
2016-08-19 10:51:35 +12:00
|
|
|
* @skipUpgrade
|
2012-04-12 18:02:46 +12:00
|
|
|
* @package framework
|
2010-10-18 22:29:35 +00:00
|
|
|
* @subpackage tests
|
|
|
|
*/
|
|
|
|
class BasicAuthTest extends FunctionalTest {
|
2010-10-19 01:26:49 +00:00
|
|
|
|
|
|
|
static $original_unique_identifier_field;
|
|
|
|
|
2013-03-21 19:48:54 +01:00
|
|
|
protected static $fixture_file = 'BasicAuthTest.yml';
|
2010-10-19 01:26:49 +00:00
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function setUp() {
|
2010-10-19 01:26:49 +00:00
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
// Fixtures assume Email is the field used to identify the log in identity
|
2013-03-21 19:48:54 +01:00
|
|
|
Member::config()->unique_identifier_field = 'Email';
|
2013-06-21 10:32:08 +12:00
|
|
|
Security::$force_database_is_ready = true; // Prevents Member test subclasses breaking ready test
|
2014-10-24 13:43:39 +13:00
|
|
|
Member::config()->lock_out_after_incorrect_logins = 10;
|
2010-10-19 01:26:49 +00:00
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testBasicAuthEnabledWithoutLogin() {
|
2014-03-05 11:47:02 +13:00
|
|
|
$origUser = isset($_SERVER['PHP_AUTH_USER']) ? $_SERVER['PHP_AUTH_USER'] : null;
|
|
|
|
$origPw = isset($_SERVER['PHP_AUTH_PW']) ? $_SERVER['PHP_AUTH_PW'] : null;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
unset($_SERVER['PHP_AUTH_USER']);
|
|
|
|
unset($_SERVER['PHP_AUTH_PW']);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithPermission');
|
|
|
|
$this->assertEquals(401, $response->getStatusCode());
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = $origUser;
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = $origPw;
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testBasicAuthDoesntCallActionOrFurtherInitOnAuthFailure() {
|
2014-03-05 11:47:02 +13:00
|
|
|
$origUser = isset($_SERVER['PHP_AUTH_USER']) ? $_SERVER['PHP_AUTH_USER'] : null;
|
|
|
|
$origPw = isset($_SERVER['PHP_AUTH_PW']) ? $_SERVER['PHP_AUTH_PW'] : null;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
unset($_SERVER['PHP_AUTH_USER']);
|
|
|
|
unset($_SERVER['PHP_AUTH_PW']);
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithPermission');
|
|
|
|
$this->assertFalse(BasicAuthTest_ControllerSecuredWithPermission::$index_called);
|
|
|
|
$this->assertFalse(BasicAuthTest_ControllerSecuredWithPermission::$post_init_called);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = 'user-in-mygroup@test.com';
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = 'test';
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithPermission');
|
|
|
|
$this->assertTrue(BasicAuthTest_ControllerSecuredWithPermission::$index_called);
|
|
|
|
$this->assertTrue(BasicAuthTest_ControllerSecuredWithPermission::$post_init_called);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = $origUser;
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = $origPw;
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testBasicAuthEnabledWithPermission() {
|
2014-03-05 11:47:02 +13:00
|
|
|
$origUser = isset($_SERVER['PHP_AUTH_USER']) ? $_SERVER['PHP_AUTH_USER'] : null;
|
|
|
|
$origPw = isset($_SERVER['PHP_AUTH_PW']) ? $_SERVER['PHP_AUTH_PW'] : null;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = 'user-in-mygroup@test.com';
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = 'wrongpassword';
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithPermission');
|
|
|
|
$this->assertEquals(401, $response->getStatusCode(), 'Invalid users dont have access');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = 'user-without-groups@test.com';
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = 'test';
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithPermission');
|
|
|
|
$this->assertEquals(401, $response->getStatusCode(), 'Valid user without required permission has no access');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = 'user-in-mygroup@test.com';
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = 'test';
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithPermission');
|
|
|
|
$this->assertEquals(200, $response->getStatusCode(), 'Valid user with required permission has access');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = $origUser;
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = $origPw;
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testBasicAuthEnabledWithoutPermission() {
|
2014-03-05 11:47:02 +13:00
|
|
|
$origUser = isset($_SERVER['PHP_AUTH_USER']) ? $_SERVER['PHP_AUTH_USER'] : null;
|
|
|
|
$origPw = isset($_SERVER['PHP_AUTH_PW']) ? $_SERVER['PHP_AUTH_PW'] : null;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = 'user-without-groups@test.com';
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = 'wrongpassword';
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithoutPermission');
|
|
|
|
$this->assertEquals(401, $response->getStatusCode(), 'Invalid users dont have access');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = 'user-without-groups@test.com';
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = 'test';
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithoutPermission');
|
|
|
|
$this->assertEquals(200, $response->getStatusCode(), 'All valid users have access');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = 'user-in-mygroup@test.com';
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = 'test';
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithoutPermission');
|
|
|
|
$this->assertEquals(200, $response->getStatusCode(), 'All valid users have access');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
$_SERVER['PHP_AUTH_USER'] = $origUser;
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = $origPw;
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2014-10-24 13:43:39 +13:00
|
|
|
public function testBasicAuthFailureIncreasesFailedLoginCount() {
|
|
|
|
// Prior to login
|
|
|
|
$check = Member::get()->filter('Email', 'failedlogin@test.com')->first();
|
|
|
|
$this->assertEquals(0, $check->FailedLoginCount);
|
|
|
|
|
|
|
|
// First failed attempt
|
|
|
|
$_SERVER['PHP_AUTH_USER'] = 'failedlogin@test.com';
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = 'test';
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithoutPermission');
|
|
|
|
$check = Member::get()->filter('Email', 'failedlogin@test.com')->first();
|
|
|
|
$this->assertEquals(1, $check->FailedLoginCount);
|
|
|
|
|
|
|
|
// Second failed attempt
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = 'testwrong';
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithoutPermission');
|
|
|
|
$check = Member::get()->filter('Email', 'failedlogin@test.com')->first();
|
|
|
|
$this->assertEquals(2, $check->FailedLoginCount);
|
|
|
|
|
|
|
|
// successful basic auth should reset failed login count
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = 'Password';
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithoutPermission');
|
|
|
|
$check = Member::get()->filter('Email', 'failedlogin@test.com')->first();
|
|
|
|
$this->assertEquals(0, $check->FailedLoginCount);
|
|
|
|
}
|
2010-10-18 22:29:35 +00:00
|
|
|
}
|
|
|
|
|
2011-03-18 15:01:09 +13:00
|
|
|
class BasicAuthTest_ControllerSecuredWithPermission extends Controller implements TestOnly {
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
static $post_init_called = false;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
static $index_called = false;
|
2011-03-18 15:01:09 +13:00
|
|
|
|
2011-03-30 19:49:11 +13:00
|
|
|
protected $template = 'BlankPage';
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2015-02-23 13:46:00 +00:00
|
|
|
protected function init() {
|
2010-10-18 22:29:35 +00:00
|
|
|
self::$post_init_called = false;
|
|
|
|
self::$index_called = false;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
BasicAuth::protect_entire_site(true, 'MYCODE');
|
|
|
|
parent::init();
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
self::$post_init_called = true;
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function index() {
|
2010-10-18 22:29:35 +00:00
|
|
|
self::$index_called = true;
|
|
|
|
}
|
2011-03-18 15:01:09 +13:00
|
|
|
|
|
|
|
|
|
|
|
|
2010-10-18 22:29:35 +00:00
|
|
|
}
|
|
|
|
|
2011-03-18 15:01:09 +13:00
|
|
|
class BasicAuthTest_ControllerSecuredWithoutPermission extends Controller implements TestOnly {
|
|
|
|
|
2011-03-30 19:49:11 +13:00
|
|
|
protected $template = 'BlankPage';
|
2011-03-18 15:01:09 +13:00
|
|
|
|
2015-02-23 13:46:00 +00:00
|
|
|
protected function init() {
|
2010-10-18 22:29:35 +00:00
|
|
|
BasicAuth::protect_entire_site(true, null);
|
|
|
|
parent::init();
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|