Ejemplos
La propia clase Bootstrap suelen ser bastante mínima; a menudo,
será simplemente un talón vacío ampliando la clase base bootstrap:
Con el archivo de configuración coresspondiente:
Sin embargo, si debiera ser necesaria un inicialización personalizada,
usted tiene dos opciones. En primer lugar, usted puede escribir métodos
prefijados con _init para especificar códigos distintos de
arranque. Estos métodos pueden ser llamados por bootstrap(), y también
pueden ser llamados como si fueran métodos públicos:
bootstrap<resource>(). Deben aceptar opcionalmente un
array de opciones.
Si su método recurso devuelve un valor, será almacenado en un contenedor
en el bootstrap. Esto puede ser útil cuando diferentes recursos necesitan
interactuar (como un recurso inyectándose a sí mismo en otro).
Luego, el método getResource() puede ser utilizado para
recuperar esos valores.
El siguiente ejemplo muestra un recurso de método para inicializar el
objeto solicitado. Hace uso del segimiento de la dependencia
(que depende del recurso Front Controller), obteniendo un recurso
desde el bootstrap y devolver el valor para almacenar en el bootstrap.
bootstrap('FrontController');
$front = $this->getResource('FrontController');
// Inicializar el objeto requerido
$request = new Zend_Controller_Request_Http();
$request->setBaseUrl('/foo');
// Agregarlo al front controller
$front->setRequest($request);
// Bootstrap guardará este valor en la clave 'request' de su contenedor
return $request;
}
}
]]>
Nótese en este ejemplo la llamada a bootstrap();
esto asegura que el front controller ha sido inicializado antes de
llamar a este método. Esa llamada puede desencadenar tanto un recurso u
otro método de la clase.
La otra opción es usar plugins de recursos, estos son objetos que
realizan inicializaciones específicas, y pueden ser especificados:
Cuando se instancia un onbeto de Zend_Application
Durante la inicialización del objeto bootstrap (arranque)
Habilitándolos explícitamente a través del método de llamada
al objeto bootstrap
Los recursos de plugins implementan
Zend_Application_Bootstrap_Resource, que define
simplemente que permitirán la inyección del llamador y opciones,
y que tienen un método init() method.
Como ejemplo, un recurso de una Vista (View) personalizada de bootstrap
podría ser como lo siguiente:
getOptions());
Zend_Dojo::enableView($view);
$view->doctype('XHTML1_STRICT');
$view->headTitle()->setSeparator(' - ')->append('My Site');
$view->headMeta()->appendHttpEquiv('Content-Type',
'text/html; charset=utf-8');
$view->dojo()->setDjConfigOption('parseOnLoad', true)
->setLocalPath('/js/dojo/dojo.js')
->registerModulePath('../spindle', 'spindle')
->addStylesheetModule('spindle.themes.spindle')
->requireModule('spindle.main')
->disable();
$viewRenderer = Zend_Controller_Action_HelperBroker::getStaticHelper(
'ViewRenderer'
);
$viewRenderer->setView($view);
return $view;
}
}
]]>
Para decirle al bootstrap que utilice éste, usted tendría que proveer
ya sea el nombre de la clase de los recursos, o una combinación del
path de un prefijo de carga del plugin y el nombre corto del recurso
(por ejemplo, "view"):
array(
'My_Bootstrap_Resource_View' => array(), // full class name; OR
'view' => array(), // short name
'FrontController' => array(
'controllerDirectory' => APPLICATION_PATH . '/controllers',
),
),
// For short names, define resource paths:
'resourcePaths = array(
'My_Bootstrap_Resource' => 'My/Bootstrap/Resource',
)
)
);
]]>
Los recursos puede llamar a otros recursos e inicializadores accediendo
al bootstrap padre:
getBootstrap()->bootstrap('view');
// Get view object:
$view = $this->getBootstrap()->getResource('view');
// ...
}
}
]]>
En el uso normal, usted podría instanciar la aplicación, arrancarla,
y ejecutarla:
bootstrap()
->run();
]]>
Para un script personalizado, podría necesitar simplemente
inicializar recursos específicos:
getBootstrap()->bootstrap('db');
$service = new Zend_XmlRpc_Server();
$service->setClass('Foo'); // uses database...
echo $service->handle();
]]>
En lugar de utilizar el método bootstrap() para llamar
a los métodos internos o recursos, también puede usar sobrecarga:
getBootstrap()->bootstrapDb();
]]>