2012-01-29 13:54:26 -05:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
|
2013-02-08 20:59:49 +09:00
|
|
|
* Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
2012-01-29 13:54:26 -05:00
|
|
|
*
|
|
|
|
* Licensed under The MIT License
|
2013-02-08 21:22:51 +09:00
|
|
|
* For full copyright and license information, please see the LICENSE.txt
|
2012-01-29 13:54:26 -05:00
|
|
|
* Redistributions of files must retain the above copyright notice.
|
|
|
|
*
|
2013-02-08 20:59:49 +09:00
|
|
|
* @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
2012-01-29 13:54:26 -05:00
|
|
|
* @link http://cakephp.org CakePHP(tm) Project
|
2012-12-04 03:16:52 +05:30
|
|
|
* @package Cake.Controller.Component.Acl
|
2012-01-29 13:54:26 -05:00
|
|
|
* @since CakePHP(tm) v 0.10.0.1076
|
2013-05-31 00:11:14 +02:00
|
|
|
* @license http://www.opensource.org/licenses/mit-license.php MIT License
|
2012-01-29 13:54:26 -05:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Access Control List interface.
|
|
|
|
* Implementing classes are used by AclComponent to perform ACL checks in Cake.
|
|
|
|
*
|
2012-12-04 03:16:52 +05:30
|
|
|
* @package Cake.Controller.Component.Acl
|
2012-01-29 13:54:26 -05:00
|
|
|
*/
|
|
|
|
interface AclInterface {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Empty method to be overridden in subclasses
|
|
|
|
*
|
|
|
|
* @param string $aro ARO The requesting object identifier.
|
|
|
|
* @param string $aco ACO The controlled object identifier.
|
|
|
|
* @param string $action Action (defaults to *)
|
2013-07-05 17:19:22 +02:00
|
|
|
* @return boolean Success
|
2012-01-29 13:54:26 -05:00
|
|
|
*/
|
|
|
|
public function check($aro, $aco, $action = "*");
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Allow methods are used to grant an ARO access to an ACO.
|
|
|
|
*
|
|
|
|
* @param string $aro ARO The requesting object identifier.
|
|
|
|
* @param string $aco ACO The controlled object identifier.
|
|
|
|
* @param string $action Action (defaults to *)
|
|
|
|
* @return boolean Success
|
|
|
|
*/
|
|
|
|
public function allow($aro, $aco, $action = "*");
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Deny methods are used to remove permission from an ARO to access an ACO.
|
|
|
|
*
|
|
|
|
* @param string $aro ARO The requesting object identifier.
|
|
|
|
* @param string $aco ACO The controlled object identifier.
|
|
|
|
* @param string $action Action (defaults to *)
|
|
|
|
* @return boolean Success
|
|
|
|
*/
|
|
|
|
public function deny($aro, $aco, $action = "*");
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Inherit methods modify the permission for an ARO to be that of its parent object.
|
|
|
|
*
|
|
|
|
* @param string $aro ARO The requesting object identifier.
|
|
|
|
* @param string $aco ACO The controlled object identifier.
|
|
|
|
* @param string $action Action (defaults to *)
|
|
|
|
* @return boolean Success
|
|
|
|
*/
|
|
|
|
public function inherit($aro, $aco, $action = "*");
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialization method for the Acl implementation
|
|
|
|
*
|
|
|
|
* @param AclComponent $component
|
2013-07-05 17:19:22 +02:00
|
|
|
* @return void
|
2012-01-29 13:54:26 -05:00
|
|
|
*/
|
2012-02-23 15:06:25 +01:00
|
|
|
public function initialize(Component $component);
|
2012-03-03 19:27:46 -05:00
|
|
|
|
2012-01-29 13:54:26 -05:00
|
|
|
}
|