我在 Phalcon PHP (Phalcon \ Acl \ Adapter \ Memory)中使用 ACL 。 我想知道是否有可能让所有资源/行动允许特定角色进行访问?
此代码检查是否允许特定角色对特定资源执行特定操作:
$acl->isAllowed("Guests", "Customers", "create");
我不想运行所有资源和操作,并使用上面的代码检查权限。我马上就需要它。
有可能吗?
答案 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中的方式相同。