Phalcon PHP - 获取所有允许的资源

时间:2015-06-09 15:03:58

标签: php acl phalcon

我在 Phalcon PHP (Phalcon \ Acl \ Adapter \ Memory)中使用 ACL 。 我想知道是否有可能让所有资源/行动允许特定角色进行访问?

此代码检查是否允许特定角色对特定资源执行特定操作:

$acl->isAllowed("Guests", "Customers", "create");

我不想运行所有资源和操作,并使用上面的代码检查权限。我马上就需要它。

有可能吗?

1 个答案:

答案 0 :(得分:0)

<?php
use \Phalcon\Acl\Adapter\Memory as Acl;

class CustomAcl extends Acl {

    public function getAllowed($role) {
        $accessList = array();
        foreach ($this->_access as $resource => $permission) {
            $resourceRole = explode("!", $resource);
            if ($resourceRole[0] != $role) {
                continue;
            }
            if ($permission == 1) {
                $accessList[] = $resource;
            }
        }
        return $accessList;
    }

}

这将以数组的形式返回所有角色:

array (
    0 => 'role!resource!action',
    1 => 'role!resource!action',
    ...
    n => 'role!resource!action'
)

与存储在acl中的方式相同。