0

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 つのリソースしか持っていません。また、何かを変更したとしても、そのようなステートメントに新しいリソースを追加したくありません。

4

1 に答える 1

0

inheritsRole 関数を使用します。

そのような:

if($this->acl->inheritsRole('user', 'admin')) {
  /* display content for an admin */
}
于 2013-10-02T17:52:55.290 に答える