mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-19 02:56:15 +00:00
updating AuthTest and AclComponent to work with it.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@5545 3807eeeb-6ff5-0310-8944-8be069107fe0
This commit is contained in:
parent
fa73554781
commit
4529f428d0
2 changed files with 152 additions and 28 deletions
|
@ -282,16 +282,16 @@ class DB_ACL extends AclBase {
|
||||||
for ($i = count($aroPath) - 1; $i >= 0; $i--) {
|
for ($i = count($aroPath) - 1; $i >= 0; $i--) {
|
||||||
$perms = $this->Aro->Permission->findAll(
|
$perms = $this->Aro->Permission->findAll(
|
||||||
array(
|
array(
|
||||||
'Permission.aro_id' => $aroPath[$i]['Aro']['id'],
|
$this->Aro->Permission->name . '.aro_id' => $aroPath[$i][$this->Aro->name]['id'],
|
||||||
'Permission.aco_id' => $acoPath->extract('{n}.Aco.id')
|
$this->Aro->Permission->name . '.aco_id' => $acoPath->extract('{n}.' . $this->Aco->name . '.id')
|
||||||
),
|
),
|
||||||
null, array('Aco.lft' => 'desc'), null, null, 0
|
null, array($this->Aco->name .'.lft' => 'desc'), null, null, 0
|
||||||
);
|
);
|
||||||
|
|
||||||
if (empty($perms)) {
|
if (empty($perms)) {
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
foreach (Set::extract($perms, '{n}.Permission') as $perm) {
|
foreach (Set::extract($perms, '{n}.' . $this->Aro->Permission->name) as $perm) {
|
||||||
if ($action == '*') {
|
if ($action == '*') {
|
||||||
// ARO must be cleared for ALL ACO actions
|
// ARO must be cleared for ALL ACO actions
|
||||||
foreach ($permKeys as $key) {
|
foreach ($permKeys as $key) {
|
||||||
|
@ -335,7 +335,7 @@ class DB_ACL extends AclBase {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($perms[0])) {
|
if (isset($perms[0])) {
|
||||||
$save = $perms[0]['Permission'];
|
$save = $perms[0][$this->Aro->Permission->name];
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($actions == "*") {
|
if ($actions == "*") {
|
||||||
|
@ -365,7 +365,7 @@ class DB_ACL extends AclBase {
|
||||||
$save['aco_id'] = $perms['aco'];
|
$save['aco_id'] = $perms['aco'];
|
||||||
|
|
||||||
if ($perms['link'] != null && count($perms['link']) > 0) {
|
if ($perms['link'] != null && count($perms['link']) > 0) {
|
||||||
$save['id'] = $perms['link'][0]['Permission']['id'];
|
$save['id'] = $perms['link'][0][$this->Aro->Permission->name]['id'];
|
||||||
}
|
}
|
||||||
$this->Aro->Permission->create($save);
|
$this->Aro->Permission->create($save);
|
||||||
return $this->Aro->Permission->save();
|
return $this->Aro->Permission->save();
|
||||||
|
@ -439,11 +439,11 @@ class DB_ACL extends AclBase {
|
||||||
}
|
}
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'aro' => Set::extract($obj, 'Aro.0.Aro.id'),
|
'aro' => Set::extract($obj, 'Aro.0.'.$this->Aro->name.'.id'),
|
||||||
'aco' => Set::extract($obj, 'Aco.0.Aco.id'),
|
'aco' => Set::extract($obj, 'Aco.0.'.$this->Aco->name.'.id'),
|
||||||
'link' => $this->Aro->Permission->findAll(array(
|
'link' => $this->Aro->Permission->findAll(array(
|
||||||
'Permission.aro_id' => Set::extract($obj, 'Aro.0.Aro.id'),
|
$this->Aro->Permission->name . '.aro_id' => Set::extract($obj, 'Aro.0.'.$this->Aro->name.'.id'),
|
||||||
'Permission.aco_id' => Set::extract($obj, 'Aco.0.Aco.id')
|
$this->Aro->Permission->name . '.aco_id' => Set::extract($obj, 'Aco.0.'.$this->Aco->name.'.id')
|
||||||
))
|
))
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,10 +26,95 @@
|
||||||
* @lastmodified $Date$
|
* @lastmodified $Date$
|
||||||
* @license http://www.opensource.org/licenses/opengroup.php The Open Group Test Suite License
|
* @license http://www.opensource.org/licenses/opengroup.php The Open Group Test Suite License
|
||||||
*/
|
*/
|
||||||
uses('controller' . DS . 'components' . DS .'auth');
|
uses('controller' . DS . 'components' . DS .'auth', 'controller' . DS . 'components' . DS .'acl');
|
||||||
|
|
||||||
|
uses('controller'.DS.'components'.DS.'acl', 'model'.DS.'db_acl');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Short description for class.
|
||||||
|
*
|
||||||
|
* @package cake.tests
|
||||||
|
* @subpackage cake.tests.cases.libs.controller.components
|
||||||
|
*/
|
||||||
|
class AclNodeTestBase extends AclNode {
|
||||||
|
var $useDbConfig = 'test_suite';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Short description for class.
|
||||||
|
*
|
||||||
|
* @package cake.tests
|
||||||
|
* @subpackage cake.tests.cases.libs.controller.components
|
||||||
|
*/
|
||||||
|
class AroTest extends AclNodeTestBase {
|
||||||
|
var $name = 'AroTest';
|
||||||
|
var $useTable = 'aros';
|
||||||
|
var $hasAndBelongsToMany = array('AcoTest' => array('with' => 'PermissionTest'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Short description for class.
|
||||||
|
*
|
||||||
|
* @package cake.tests
|
||||||
|
* @subpackage cake.tests.cases.libs.controller.components
|
||||||
|
*/
|
||||||
|
class AcoTest extends AclNodeTestBase {
|
||||||
|
var $name = 'AcoTest';
|
||||||
|
var $useTable = 'acos';
|
||||||
|
var $hasAndBelongsToMany = array('AroTest' => array('with' => 'PermissionTest'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Short description for class.
|
||||||
|
*
|
||||||
|
* @package cake.tests
|
||||||
|
* @subpackage cake.tests.cases.libs.controller.components
|
||||||
|
*/
|
||||||
|
class PermissionTest extends CakeTestModel {
|
||||||
|
var $name = 'PermissionTest';
|
||||||
|
var $useTable = 'aros_acos';
|
||||||
|
var $cacheQueries = false;
|
||||||
|
var $belongsTo = array('AroTest' => array('foreignKey' => 'aro_id'),
|
||||||
|
'AcoTest' => array('foreignKey' => 'aco_id')
|
||||||
|
);
|
||||||
|
var $actsAs = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Short description for class.
|
||||||
|
*
|
||||||
|
* @package cake.tests
|
||||||
|
* @subpackage cake.tests.cases.libs.controller.components
|
||||||
|
*/
|
||||||
|
class AcoActionTest extends CakeTestModel {
|
||||||
|
var $name = 'AcoActionTest';
|
||||||
|
var $useTable = 'aco_actions';
|
||||||
|
var $belongsTo = array('AcoTest' => array('foreignKey' => 'aco_id'));
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Short description for class.
|
||||||
|
*
|
||||||
|
* @package cake.tests
|
||||||
|
* @subpackage cake.tests.cases.libs.controller.components
|
||||||
|
*/
|
||||||
|
class DB_ACL_TEST extends DB_ACL {
|
||||||
|
|
||||||
|
function __construct() {
|
||||||
|
$this->Aro =& new AroTest();
|
||||||
|
$this->Aro->Permission =& new PermissionTest();
|
||||||
|
$this->Aco =& new AcoTest();
|
||||||
|
$this->Aro->Permission =& new PermissionTest();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Short description for class.
|
||||||
|
*
|
||||||
|
* @package cake.tests
|
||||||
|
* @subpackage cake.tests.cases.libs.controller.components
|
||||||
|
*/
|
||||||
class AuthUser extends CakeTestModel {
|
class AuthUser extends CakeTestModel {
|
||||||
var $name = 'AuthUser';
|
var $name = 'AuthUser';
|
||||||
|
var $useDbConfig = 'test_suite';
|
||||||
|
|
||||||
function parentNode() {
|
function parentNode() {
|
||||||
return true;
|
return true;
|
||||||
|
@ -46,7 +131,12 @@ class AuthUser extends CakeTestModel {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/**
|
||||||
|
* Short description for class.
|
||||||
|
*
|
||||||
|
* @package cake.tests
|
||||||
|
* @subpackage cake.tests.cases.libs.controller.components
|
||||||
|
*/
|
||||||
class AuthTestController extends Controller {
|
class AuthTestController extends Controller {
|
||||||
var $name = 'AuthTest';
|
var $name = 'AuthTest';
|
||||||
var $uses = array('AuthUser');
|
var $uses = array('AuthUser');
|
||||||
|
@ -82,14 +172,16 @@ class AuthTestController extends Controller {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/**
|
||||||
|
* Short description for class.
|
||||||
|
*
|
||||||
|
* @package cake.tests
|
||||||
|
* @subpackage cake.tests.cases.libs.controller.components
|
||||||
|
*/
|
||||||
class AuthTest extends CakeTestCase {
|
class AuthTest extends CakeTestCase {
|
||||||
var $name = 'Auth';
|
var $name = 'Auth';
|
||||||
var $fixtures = array('core.auth_user', 'core.aco', 'core.aro', 'core.aros_aco');
|
|
||||||
|
|
||||||
function skip() {
|
var $fixtures = array('core.auth_user', 'core.aro', 'core.aco', 'core.aros_aco', 'core.aco_action');
|
||||||
$this->skipif (true, 'Auth tests currently disabled, to test use a clean database with tables needed for acl and comment out this line');
|
|
||||||
}
|
|
||||||
|
|
||||||
function setUp() {
|
function setUp() {
|
||||||
$this->Controller =& new AuthTestController();
|
$this->Controller =& new AuthTestController();
|
||||||
|
@ -98,9 +190,6 @@ class AuthTest extends CakeTestCase {
|
||||||
set_error_handler('simpleTestErrorHandler');
|
set_error_handler('simpleTestErrorHandler');
|
||||||
ClassRegistry::addObject('view', new View($this->Controller));
|
ClassRegistry::addObject('view', new View($this->Controller));
|
||||||
}
|
}
|
||||||
function testIt(){
|
|
||||||
$this->assertTrue(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
function testNoAuth() {
|
function testNoAuth() {
|
||||||
$this->assertFalse($this->Controller->Auth->isAuthorized());
|
$this->assertFalse($this->Controller->Auth->isAuthorized());
|
||||||
|
@ -184,22 +273,33 @@ class AuthTest extends CakeTestCase {
|
||||||
$this->Controller->params['controller'] = 'auth_test';
|
$this->Controller->params['controller'] = 'auth_test';
|
||||||
$this->Controller->params['action'] = 'add';
|
$this->Controller->params['action'] = 'add';
|
||||||
|
|
||||||
|
$this->Controller->Acl->name = 'DB_ACL_TEST';
|
||||||
$this->Controller->Acl->startup($this->Controller);
|
$this->Controller->Acl->startup($this->Controller);
|
||||||
|
|
||||||
$this->Controller->Acl->Aro->id = null;
|
$this->Controller->Acl->Aro->id = null;
|
||||||
$this->Controller->Acl->Aro->create(array('alias'=>'Roles'));
|
$this->Controller->Acl->Aro->create(array('alias'=>'Roles'));
|
||||||
$this->Controller->Acl->Aro->save();
|
$result = $this->Controller->Acl->Aro->save();
|
||||||
|
$this->assertTrue($result);
|
||||||
|
|
||||||
$this->Controller->Acl->Aro->create(array('alias'=>'Admin'));
|
$this->Controller->Acl->Aro->create(array('alias'=>'Admin'));
|
||||||
$this->Controller->Acl->Aro->save();
|
$result = $this->Controller->Acl->Aro->save();
|
||||||
|
$this->assertTrue($result);
|
||||||
|
|
||||||
$this->Controller->Acl->Aro->create(array('model'=>'AuthUser', 'foreign_key'=>'1', 'alias'=> 'mariano'));
|
$this->Controller->Acl->Aro->create(array('model'=>'AuthUser', 'foreign_key'=>'1', 'alias'=> 'mariano'));
|
||||||
$this->Controller->Acl->Aro->save();
|
$result = $this->Controller->Acl->Aro->save();
|
||||||
|
$this->assertTrue($result);
|
||||||
|
|
||||||
$this->Controller->Acl->Aro->setParent(1, 2);
|
$this->Controller->Acl->Aro->setParent(1, 2);
|
||||||
$this->Controller->Acl->Aro->setParent(2, 3);
|
$this->Controller->Acl->Aro->setParent(2, 3);
|
||||||
|
|
||||||
$this->Controller->Acl->Aco->create(array('alias'=>'Root'));
|
$this->Controller->Acl->Aco->create(array('alias'=>'Root'));
|
||||||
$this->Controller->Acl->Aco->save();
|
$result = $this->Controller->Acl->Aco->save();
|
||||||
|
$this->assertTrue($result);
|
||||||
|
|
||||||
$this->Controller->Acl->Aco->create(array('alias'=>'AuthTest'));
|
$this->Controller->Acl->Aco->create(array('alias'=>'AuthTest'));
|
||||||
$this->Controller->Acl->Aco->save();
|
$result = $this->Controller->Acl->Aco->save();
|
||||||
|
$this->assertTrue($result);
|
||||||
|
|
||||||
$this->Controller->Acl->Aco->setParent(1, 2);
|
$this->Controller->Acl->Aco->setParent(1, 2);
|
||||||
|
|
||||||
$this->Controller->Acl->allow('Roles/Admin', 'Root');
|
$this->Controller->Acl->allow('Roles/Admin', 'Root');
|
||||||
|
@ -218,9 +318,9 @@ class AuthTest extends CakeTestCase {
|
||||||
|
|
||||||
|
|
||||||
$this->Controller->Session->del('Auth');
|
$this->Controller->Session->del('Auth');
|
||||||
$this->Controller->Acl->Aro->execute('truncate aros;');
|
//$this->Controller->Acl->Aro->execute('truncate aros;');
|
||||||
$this->Controller->Acl->Aro->execute('truncate acos;');
|
//$this->Controller->Acl->Aro->execute('truncate acos;');
|
||||||
$this->Controller->Acl->Aro->execute('truncate aros_acos;');
|
//$this->Controller->Acl->Aro->execute('truncate aros_acos;');
|
||||||
}
|
}
|
||||||
|
|
||||||
function testLoginRedirect() {
|
function testLoginRedirect() {
|
||||||
|
@ -255,6 +355,30 @@ class AuthTest extends CakeTestCase {
|
||||||
$_SERVER['HTTP_REFERER'] = $backup;
|
$_SERVER['HTTP_REFERER'] = $backup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function testEmptyUsernameOrPassword() {
|
||||||
|
$this->AuthUser =& new AuthUser();
|
||||||
|
$user['id'] = 1;
|
||||||
|
$user['username'] = 'mariano';
|
||||||
|
$user['password'] = Security::hash(CAKE_SESSION_STRING . 'cake');
|
||||||
|
$this->AuthUser->save($user, false);
|
||||||
|
|
||||||
|
$authUser = $this->AuthUser->find();
|
||||||
|
|
||||||
|
$this->Controller->data['AuthUser']['username'] = '';
|
||||||
|
$this->Controller->data['AuthUser']['password'] = '';
|
||||||
|
|
||||||
|
$this->Controller->params['url']['url'] = 'auth_test/login';
|
||||||
|
|
||||||
|
$this->Controller->Auth->initialize($this->Controller);
|
||||||
|
|
||||||
|
$this->Controller->Auth->loginAction = 'auth_test/login';
|
||||||
|
$this->Controller->Auth->userModel = 'AuthUser';
|
||||||
|
|
||||||
|
$this->Controller->Auth->startup($this->Controller);
|
||||||
|
$user = $this->Controller->Auth->user();
|
||||||
|
$this->assertEqual($user, false);
|
||||||
|
$this->Controller->Session->del('Auth');
|
||||||
|
}
|
||||||
|
|
||||||
function tearDown() {
|
function tearDown() {
|
||||||
unset($this->Controller, $this->AuthUser);
|
unset($this->Controller, $this->AuthUser);
|
||||||
|
|
Loading…
Add table
Reference in a new issue