Я работаю над плагином аутентификации, используя плагин контроллера. Я определяю свою конфигурацию навигации в файле application.ini, а затем использую ее и пользовательские записи базы данных, чтобы динамически загрузить ACL и применить его к Zend_Navigation. Этот бит работает, так как он успешно загружает меню и отображает только те страницы, которые пользователь может видеть.
Однако это не мешает пользователю перейти на страницу напрямую. Я хочу определить, когда пользователь переходит на страницу, к которой у него нет доступа, в плагине Controller, чтобы я мог перенаправить его запрос на страницу аутентификации.
Я думал, что должна быть функция для извлечения текущей страницы из Zend_Navigation, но я не могу ее найти ... так что, возможно, ее не существует.
Во всяком случае, это мой полный плагин контроллера. Кто-нибудь видит решение?
<?php
class Pog_Model_AuthPlugin extends Zend_Controller_Plugin_Abstract
{
public function preDispatch(Zend_Controller_Request_Abstract $oRequest)
{
/**
* Load user
*/
$oAuth = Zend_Auth::getInstance();
$oDbUsers = new Pog_Model_DbTable_Users();
if (!$oAuth->hasIdentity())
{
$oUser = $oDbUsers->createRow();
$oUser->name = "guest";
$oUser->setReadOnly(true);
}
else
{
$oUser = $oAuth->getIdentity();
$oUser->setTable($oDbUsers);
}
/**
* Load ACL
*/
$oAcl = new Zend_Acl();
$oAcl->addRole($oUser->name);
/**
* Add current user privileges
*/
$oPrivileges = $oUser->getPrivileges();
foreach ($oPrivileges as $oPrivilege)
{
if (!$oAcl->has($oPrivilege->resource))
$oAcl->addResource($oPrivilege->resource);
$oAcl->allow($oUser->name, $oPrivilege->resource, $oPrivilege->privilege);
}
/**
* Load Navigation view helper
*/
$oViewRenderer = Zend_Controller_Action_HelperBroker::getStaticHelper('ViewRenderer');
$oNavigation = $oViewRenderer->view->navigation();
/**
* Add remaining Navigation resources
*/
foreach ($oNavigation->getPages() as $oPage)
{
if (!is_null($oPage->getResource()) && !$oAcl->has($oPage->getResource()))
$oAcl->addResource($oPage->getResource());
}
/**
* Set ACL and Role
*/
$oNavigation->setAcl($oAcl)->setRole($oUser->name);
/**
* Check if use is allowed to be here
*/
...MAGIC GOES HERE...
}
}