【发布时间】:2011-11-23 12:28:05
【问题描述】:
在我的管理模块中,我有一个名为 email 的控制器,我希望大多数操作只能由登录的管理员用户访问。但是,我希望任何人都可以访问一项操作。 (这是一个电子邮件功能,将通过 URL 远程触发。)。目前我正在使用 Zend_Auth 和 Zend_Acl,如下所示:
if ($request->getModuleName() == 'admin') {
// access resources (controllers)
$acl->addResource('index');
$acl->addResource('reports');
$acl->addResource('email');
$acl->addResource('error');
// access roles
$acl->addRole(new Zend_Acl_Role('visitor'));
$acl->addRole(new Zend_Acl_Role('user'));
$acl->addRole(new Zend_Acl_Role('admin'));
// access rules
$acl->deny('visitor');
$acl->deny('user');
$acl->allow('admin');
$resouce = $request->getControllerName();
$action = $request->getActionName();
$identity = $auth->getStorage()->read();
if (is_object($identity)) {
$role = $identity->role;
} else {
$role = 'visitor';
}
if (!$acl->isAllowed($role, $resouce, $action)) {
$request->setModuleName('default')
->setControllerName('auth')
->setActionName('login');
}
}
如何更改上面的代码以允许“访问者”执行 /admin/email/process 操作?
【问题讨论】:
标签: zend-framework