7 * This source file is subject to the new BSD license that is bundled
8 * with this package in the file LICENSE.txt.
9 * It is also available through the world-wide-web at this URL:
10 * http://framework.zend.com/license/new-bsd
11 * If you did not receive a copy of the license and are unable to
12 * obtain it through the world-wide-web, please send an email
13 * to license@zend.com so we can send you a copy immediately.
16 * @package Zend_Application
17 * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
18 * @license http://framework.zend.com/license/new-bsd New BSD License
24 * @package Zend_Application
25 * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
26 * @license http://framework.zend.com/license/new-bsd New BSD License
28 class Zend_Application
33 * @var Zend_Loader_Autoloader
35 protected $_autoloader;
40 * @var Zend_Application_Bootstrap_BootstrapAbstract
42 protected $_bootstrap;
45 * Application environment
49 protected $_environment;
52 * Flattened (lowercase) option keys
56 protected $_optionKeys = array();
59 * Options for Zend_Application
63 protected $_options = array();
68 * Initialize application. Potentially initializes include_paths, PHP
69 * settings, and bootstrap class.
71 * @param string $environment
72 * @param string|array|Zend_Config $options String path to configuration file, or array/Zend_Config of configuration options
73 * @throws Zend_Application_Exception When invalid options are provided
76 public function __construct($environment, $options = null)
78 $this->_environment
= (string) $environment;
80 require_once 'Zend/Loader/Autoloader.php';
81 $this->_autoloader
= Zend_Loader_Autoloader
::getInstance();
83 if (null !== $options) {
84 if (is_string($options)) {
85 $options = $this->_loadConfig($options);
86 } elseif ($options instanceof Zend_Config
) {
87 $options = $options->toArray();
88 } elseif (!is_array($options)) {
89 throw new Zend_Application_Exception('Invalid options provided; must be location of config file, a config object, or an array');
92 $this->setOptions($options);
97 * Retrieve current environment
101 public function getEnvironment()
103 return $this->_environment
;
107 * Retrieve autoloader instance
109 * @return Zend_Loader_Autoloader
111 public function getAutoloader()
113 return $this->_autoloader
;
117 * Set application options
119 * @param array $options
120 * @throws Zend_Application_Exception When no bootstrap path is provided
121 * @throws Zend_Application_Exception When invalid bootstrap information are provided
122 * @return Zend_Application
124 public function setOptions(array $options)
126 if (!empty($options['config'])) {
127 if (is_array($options['config'])) {
129 foreach ($options['config'] as $tmp) {
130 $_options = $this->mergeOptions($_options, $this->_loadConfig($tmp));
132 $options = $this->mergeOptions($_options, $options);
134 $options = $this->mergeOptions($this->_loadConfig($options['config']), $options);
138 $this->_options
= $options;
140 $options = array_change_key_case($options, CASE_LOWER
);
142 $this->_optionKeys
= array_keys($options);
144 if (!empty($options['phpsettings'])) {
145 $this->setPhpSettings($options['phpsettings']);
148 if (!empty($options['includepaths'])) {
149 $this->setIncludePaths($options['includepaths']);
152 if (!empty($options['autoloadernamespaces'])) {
153 $this->setAutoloaderNamespaces($options['autoloadernamespaces']);
156 if (!empty($options['autoloaderzfpath'])) {
157 $autoloader = $this->getAutoloader();
158 if (method_exists($autoloader, 'setZfPath')) {
159 $zfPath = $options['autoloaderzfpath'];
160 $zfVersion = !empty($options['autoloaderzfversion'])
161 ?
$options['autoloaderzfversion']
163 $autoloader->setZfPath($zfPath, $zfVersion);
167 if (!empty($options['bootstrap'])) {
168 $bootstrap = $options['bootstrap'];
170 if (is_string($bootstrap)) {
171 $this->setBootstrap($bootstrap);
172 } elseif (is_array($bootstrap)) {
173 if (empty($bootstrap['path'])) {
174 throw new Zend_Application_Exception('No bootstrap path provided');
177 $path = $bootstrap['path'];
180 if (!empty($bootstrap['class'])) {
181 $class = $bootstrap['class'];
184 $this->setBootstrap($path, $class);
186 throw new Zend_Application_Exception('Invalid bootstrap information provided');
194 * Retrieve application options (for caching)
198 public function getOptions()
200 return $this->_options
;
204 * Is an option present?
209 public function hasOption($key)
211 return in_array(strtolower($key), $this->_optionKeys
);
215 * Retrieve a single option
220 public function getOption($key)
222 if ($this->hasOption($key)) {
223 $options = $this->getOptions();
224 $options = array_change_key_case($options, CASE_LOWER
);
225 return $options[strtolower($key)];
231 * Merge options recursively
233 * @param array $array1
234 * @param mixed $array2
237 public function mergeOptions(array $array1, $array2 = null)
239 if (is_array($array2)) {
240 foreach ($array2 as $key => $val) {
241 if (is_array($array2[$key])) {
242 $array1[$key] = (array_key_exists($key, $array1) && is_array($array1[$key]))
243 ?
$this->mergeOptions($array1[$key], $array2[$key])
246 $array1[$key] = $val;
254 * Set PHP configuration settings
256 * @param array $settings
257 * @param string $prefix Key prefix to prepend to array values (used to map . separated INI values)
258 * @return Zend_Application
260 public function setPhpSettings(array $settings, $prefix = '')
262 foreach ($settings as $key => $value) {
263 $key = empty($prefix) ?
$key : $prefix . $key;
264 if (is_scalar($value)) {
265 ini_set($key, $value);
266 } elseif (is_array($value)) {
267 $this->setPhpSettings($value, $key . '.');
277 * @param array $paths
278 * @return Zend_Application
280 public function setIncludePaths(array $paths)
282 $path = implode(PATH_SEPARATOR
, $paths);
283 set_include_path($path . PATH_SEPARATOR
. get_include_path());
288 * Set autoloader namespaces
290 * @param array $namespaces
291 * @return Zend_Application
293 public function setAutoloaderNamespaces(array $namespaces)
295 $autoloader = $this->getAutoloader();
297 foreach ($namespaces as $namespace) {
298 $autoloader->registerNamespace($namespace);
305 * Set bootstrap path/class
307 * @param string $path
308 * @param string $class
309 * @return Zend_Application
311 public function setBootstrap($path, $class = null)
313 // setOptions() can potentially send a null value; specify default
315 if (null === $class) {
316 $class = 'Bootstrap';
319 if (!class_exists($class, false)) {
321 if (!class_exists($class, false)) {
322 throw new Zend_Application_Exception('Bootstrap class not found');
325 $this->_bootstrap
= new $class($this);
327 if (!$this->_bootstrap
instanceof Zend_Application_Bootstrap_Bootstrapper
) {
328 throw new Zend_Application_Exception('Bootstrap class does not implement Zend_Application_Bootstrap_Bootstrapper');
335 * Get bootstrap object
337 * @return Zend_Application_Bootstrap_BootstrapAbstract
339 public function getBootstrap()
341 if (null === $this->_bootstrap
) {
342 $this->_bootstrap
= new Zend_Application_Bootstrap_Bootstrap($this);
344 return $this->_bootstrap
;
348 * Bootstrap application
350 * @param null|string|array $resource
351 * @return Zend_Application
353 public function bootstrap($resource = null)
355 $this->getBootstrap()->bootstrap($resource);
360 * Run the application
364 public function run()
366 $this->getBootstrap()->run();
370 * Load configuration file of options
372 * @param string $file
373 * @throws Zend_Application_Exception When invalid configuration file is provided
376 protected function _loadConfig($file)
378 $environment = $this->getEnvironment();
379 $suffix = strtolower(pathinfo($file, PATHINFO_EXTENSION
));
383 $config = new Zend_Config_Ini($file, $environment);
387 $config = new Zend_Config_Xml($file, $environment);
392 $config = include $file;
393 if (!is_array($config)) {
394 throw new Zend_Application_Exception('Invalid configuration file provided; PHP file does not return array value');
400 throw new Zend_Application_Exception('Invalid configuration file provided; unknown config type');
403 return $config->toArray();