Zend_Acl を使用してロールとリソースごとに許可されたコンテンツをビューでチェックして、特定のコンテンツを表示しています。これは正常に機能していますが、リソースの親を確認するための hasParentResource() メソッドのようなものが必要です。
例:
$acl->add(new Zend_Acl_Resource('default'));
$acl->add(new Zend_Acl_Resource('admin'));
$acl->add(new Zend_Acl_Resource('admin::resource1'), 'admin');
$acl->add(new Zend_Acl_Resource('admin::resource2'), 'admin');
$acl->add(new Zend_Acl_Resource('admin::resource3'), 'admin');
/roles
$acl->addRole(new Zend_Acl_Role('guest'));
$acl->addRole(new Zend_Acl_Role('user'), 'guest');
$acl->addRole(new Zend_Acl_Role('admin'), 'user');
//deny/allow
$acl->deny();
$acl->allow('guest', 'default');
$acl->allow('user', array(
'admin::resource1',
'admin::resource3'
));
$acl->allow('admin');
ビューで:
<h1>Admin</h1>
Lorem ipsum dolor...
<?php if($this->acl->hasParentResource('admin')): ?>
<h2>Resources</h2>
<?php if($this->acl->isAllowed('admin::resource1')): ?>
Ressource 1 stuff
<?php endif; ?>
<?php if($this->acl->isAllowed('admin::resource2')): ?>
Ressource 2 stuff
<?php endif; ?>
<?php if($this->acl->isAllowed('admin::resource3')): ?>
Ressource 3 stuff
<?php endif; ?>
<?php endif; ?>
<h2>
ユーザーがリソース 1、2、または 3
にアクセスできない場合、タグを含むコンテンツを非表示にするという考え方です。
<?php if($this->acl->isAllowed('admin::resource1') || $this->acl->isAllowed('admin::resource2') || $this->acl->isAllowed('admin::resource3')): ?>
<h2>Resources</h2>
...
<?php endif; ?>
しかし、私はこれら 3 つのリソースしか持っていません。また、何かを変更したとしても、そのようなステートメントに新しいリソースを追加したくありません。