La clase Yaf_Plugin_Abstract
(Yaf >=1.0.0)
Introducción
Los complementos permiten una extensibilidad y personalización sencillas del framework.
Los complementos son clases. La definición real de una clase variará según el componente -- se puede necesitar implementar esta interfaz, pero de hecho el complemento es en sí mismo una clase.
Un complemento podría cargarse dentro de Yaf utilizando el método Yaf_Dispatcher::registerPlugin(), después de registrarlo. Todos los métodos que implementa el complemento según esta interfaz, serán llamados a su debido tiempo.
Ejemplos
Ejemplo #1 Plugin example
<?php
/* la clase de arranque debería estar definida bajo ./application/Bootstrap.php */
class Bootstrap extends Yaf_Bootstrap_Abstract {
public function _initPlugin(Yaf_Dispatcher $dispatcher) {
/* register a plugin */
$dispatcher->registerPlugin(new TestPlugin());
}
}
/* la clase complemento debería estar ubicada bajo ./application/plugins/ */
class TestPlugin extends Yaf_Plugin_Abstract {
public function routerStartup(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
/* before router
in this hook, user can do some url rewrite */
var_dump("routerStartup");
}
public function routerShutdown(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
/* router complete
in this hook, user can do login check */
var_dump("routerShutdown");
}
public function dispatchLoopStartup(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
var_dump("dispatchLoopStartup");
}
public function preDispatch(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
var_dump("preDispatch");
}
public function postDispatch(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
var_dump("postDispatch");
}
public function dispatchLoopShutdown(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
/* final hoook
in this hook user can do loging or implement layout */
var_dump("dispatchLoopShutdown");
}
}
Class IndexController extends Yaf_Controller_Abstract {
public function indexAction() {
return FALSE; //prevent rendering
}
}
$config = array(
"application" => array(
"directory" => dirname(__FILE__) . "/application/",
),
);
$app = new Yaf_Application($config);
$app->bootstrap()->run();
?>
El resultado del ejemplo sería algo similar a:
string(13) "routerStartup" string(14) "routerShutdown" string(19) "dispatchLoopStartup" string(11) "preDispatch" string(12) "postDispatch" string(20) "dispatchLoopShutdown"
Sinopsis de la Clase
Yaf_Plugin_Abstract
{
/* Métodos */
public void dispatchLoopShutdown
( Yaf_Request_Abstract
}$request
, Yaf_Response_Abstract $response
)Tabla de contenidos
- Yaf_Plugin_Abstract::dispatchLoopShutdown — El propósito de dispatchLoopShutdown
- Yaf_Plugin_Abstract::dispatchLoopStartup — El propósito de dispatchLoopStartup
- Yaf_Plugin_Abstract::postDispatch — El propósito de postDispatch
- Yaf_Plugin_Abstract::preDispatch — El propósito de preDispatch
- Yaf_Plugin_Abstract::preResponse — El propósito de preResponse
- Yaf_Plugin_Abstract::routerShutdown — El propósito de routerShutdown
- Yaf_Plugin_Abstract::routerStartup — Enganche deEl propósito de routerStartup