2010-10-19 00:29:35 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @package sapphire
|
|
|
|
* @subpackage tests
|
|
|
|
*/
|
|
|
|
|
|
|
|
class BasicAuthTest extends FunctionalTest {
|
2010-10-19 03:26:49 +02:00
|
|
|
|
|
|
|
static $original_unique_identifier_field;
|
|
|
|
|
2010-10-19 00:29:35 +02:00
|
|
|
static $fixture_file = 'sapphire/tests/security/BasicAuthTest.yml';
|
2010-10-19 03:26:49 +02:00
|
|
|
|
|
|
|
function setUp() {
|
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
// Fixtures assume Email is the field used to identify the log in identity
|
|
|
|
self::$original_unique_identifier_field = Member::get_unique_identifier_field();
|
|
|
|
Member::set_unique_identifier_field('Email');
|
|
|
|
}
|
|
|
|
|
2010-10-19 00:29:35 +02:00
|
|
|
function tearDown() {
|
|
|
|
parent::tearDown();
|
|
|
|
|
|
|
|
BasicAuth::protect_entire_site(false);
|
2010-10-19 03:26:49 +02:00
|
|
|
Member::set_unique_identifier_field(self::$original_unique_identifier_field);
|
2010-10-19 00:29:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function testBasicAuthEnabledWithoutLogin() {
|
|
|
|
$origUser = @$_SERVER['PHP_AUTH_USER'];
|
|
|
|
$origPw = @$_SERVER['PHP_AUTH_PW'];
|
|
|
|
|
|
|
|
unset($_SERVER['PHP_AUTH_USER']);
|
|
|
|
unset($_SERVER['PHP_AUTH_PW']);
|
|
|
|
|
|
|
|
$response = Director::test('BasicAuthTest_ControllerSecuredWithPermission');
|
|
|
|
$this->assertEquals(401, $response->getStatusCode());
|
|
|
|
|
|
|
|
$_SERVER['PHP_AUTH_USER'] = $origUser;
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = $origPw;
|
|
|
|
}
|
|
|
|
|
|
|
|
function testBasicAuthDoesntCallActionOrFurtherInitOnAuthFailure() {
|
|
|
|
$origUser = @$_SERVER['PHP_AUTH_USER'];
|
|
|
|
$origPw = @$_SERVER['PHP_AUTH_PW'];
|
|
|
|
|
|
|
|
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);
|
|
|
|
|
|
|
|
$_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);
|
|
|
|
|
|
|
|
$_SERVER['PHP_AUTH_USER'] = $origUser;
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = $origPw;
|
|
|
|
}
|
|
|
|
|
|
|
|
function testBasicAuthEnabledWithPermission() {
|
|
|
|
$origUser = @$_SERVER['PHP_AUTH_USER'];
|
|
|
|
$origPw = @$_SERVER['PHP_AUTH_PW'];
|
|
|
|
|
|
|
|
$_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');
|
|
|
|
|
|
|
|
$_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');
|
|
|
|
|
|
|
|
$_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');
|
|
|
|
|
|
|
|
$_SERVER['PHP_AUTH_USER'] = $origUser;
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = $origPw;
|
|
|
|
}
|
|
|
|
|
|
|
|
function testBasicAuthEnabledWithoutPermission() {
|
|
|
|
$origUser = @$_SERVER['PHP_AUTH_USER'];
|
|
|
|
$origPw = @$_SERVER['PHP_AUTH_PW'];
|
|
|
|
|
|
|
|
$_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');
|
|
|
|
|
|
|
|
$_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');
|
|
|
|
|
|
|
|
$_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');
|
|
|
|
|
|
|
|
$_SERVER['PHP_AUTH_USER'] = $origUser;
|
|
|
|
$_SERVER['PHP_AUTH_PW'] = $origPw;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2011-03-18 03:01:09 +01:00
|
|
|
class BasicAuthTest_ControllerSecuredWithPermission extends Controller implements TestOnly {
|
2010-10-19 00:29:35 +02:00
|
|
|
|
|
|
|
static $post_init_called = false;
|
|
|
|
|
|
|
|
static $index_called = false;
|
2011-03-18 03:01:09 +01:00
|
|
|
|
|
|
|
protected $template = '../sapphire/templates/BlankPage.ss';
|
2010-10-19 00:29:35 +02:00
|
|
|
|
|
|
|
function init() {
|
|
|
|
self::$post_init_called = false;
|
|
|
|
self::$index_called = false;
|
|
|
|
|
|
|
|
BasicAuth::protect_entire_site(true, 'MYCODE');
|
|
|
|
parent::init();
|
2011-03-18 03:01:09 +01:00
|
|
|
|
2010-10-19 00:29:35 +02:00
|
|
|
self::$post_init_called = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
function index() {
|
|
|
|
self::$index_called = true;
|
|
|
|
}
|
2011-03-18 03:01:09 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
2010-10-19 00:29:35 +02:00
|
|
|
}
|
|
|
|
|
2011-03-18 03:01:09 +01:00
|
|
|
class BasicAuthTest_ControllerSecuredWithoutPermission extends Controller implements TestOnly {
|
|
|
|
|
|
|
|
protected $template = '../sapphire/templates/BlankPage.ss';
|
|
|
|
|
2010-10-19 00:29:35 +02:00
|
|
|
function init() {
|
|
|
|
BasicAuth::protect_entire_site(true, null);
|
|
|
|
parent::init();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|