2008-11-26 14:50:40 -08:00
|
|
|
<?php
|
2012-01-29 17:23:24 +11:00
|
|
|
|
2008-11-26 14:50:40 -08:00
|
|
|
/**
|
2012-01-29 17:23:24 +11:00
|
|
|
* The directory in which your application specific resources are located.
|
|
|
|
* The application directory must contain the bootstrap.php file.
|
2009-08-03 14:10:16 +10:00
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @link http://kohanaframework.org/guide/about.install#application
|
2012-01-29 17:23:24 +11:00
|
|
|
*/
|
|
|
|
$application = 'application';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The directory in which your modules are located.
|
2008-11-26 14:50:40 -08:00
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @link http://kohanaframework.org/guide/about.install#modules
|
2009-08-03 14:10:16 +10:00
|
|
|
*/
|
2012-01-29 17:23:24 +11:00
|
|
|
$modules = 'modules';
|
2009-08-03 14:10:16 +10:00
|
|
|
|
2012-11-10 10:13:57 +11:00
|
|
|
/**
|
|
|
|
* The directory in which upstream Kohana resources (modules) are located.
|
|
|
|
*/
|
|
|
|
$sysmodules = 'includes/kohana/modules';
|
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
/**
|
|
|
|
* The directory in which the Kohana resources are located. The system
|
|
|
|
* directory must contain the classes/kohana.php file.
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @link http://kohanaframework.org/guide/about.install#system
|
2012-01-29 17:23:24 +11:00
|
|
|
*/
|
2012-11-10 10:13:57 +11:00
|
|
|
$system = 'includes/kohana/system';
|
2010-11-30 09:41:08 +11:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
/**
|
|
|
|
* The default extension of resource files. If you change this, all resources
|
|
|
|
* must be renamed to use the new extension.
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @link http://kohanaframework.org/guide/about.install#ext
|
2012-01-29 17:23:24 +11:00
|
|
|
*/
|
|
|
|
define('EXT', '.php');
|
2009-08-03 14:10:16 +10:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
/**
|
|
|
|
* Set the PHP error reporting level. If you set this in php.ini, you remove this.
|
2012-11-09 23:18:50 +11:00
|
|
|
* @link http://www.php.net/manual/errorfunc.configuration#ini.error-reporting
|
2012-01-29 17:23:24 +11:00
|
|
|
*
|
|
|
|
* When developing your application, it is highly recommended to enable notices
|
|
|
|
* and strict warnings. Enable them by using: E_ALL | E_STRICT
|
|
|
|
*
|
|
|
|
* In a production environment, it is safe to ignore notices and strict warnings.
|
|
|
|
* Disable them by using: E_ALL ^ E_NOTICE
|
|
|
|
*
|
|
|
|
* When using a legacy application with PHP >= 5.3, it is recommended to disable
|
|
|
|
* deprecated notices. Disable with: E_ALL & ~E_DEPRECATED
|
|
|
|
*/
|
|
|
|
error_reporting(E_ALL | E_STRICT);
|
2010-11-30 09:41:08 +11:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
/**
|
|
|
|
* End of standard configuration! Changing any of the code below should only be
|
|
|
|
* attempted by those with a working knowledge of Kohana internals.
|
|
|
|
*
|
2012-11-09 23:18:50 +11:00
|
|
|
* @link http://kohanaframework.org/guide/using.configuration
|
2012-01-29 17:23:24 +11:00
|
|
|
*/
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
// Set the full path to the docroot
|
|
|
|
define('DOCROOT', realpath(dirname(__FILE__)).DIRECTORY_SEPARATOR);
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
// Make the application relative to the docroot, for symlink'd index.php
|
|
|
|
if ( ! is_dir($application) AND is_dir(DOCROOT.$application))
|
|
|
|
$application = DOCROOT.$application;
|
2009-08-03 14:10:16 +10:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
// Make the modules relative to the docroot, for symlink'd index.php
|
|
|
|
if ( ! is_dir($modules) AND is_dir(DOCROOT.$modules))
|
|
|
|
$modules = DOCROOT.$modules;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2012-11-10 10:13:57 +11:00
|
|
|
// Make the system relative to the docroot, for symlink'd index.php
|
|
|
|
if ( ! is_dir($sysmodules) AND is_dir(DOCROOT.$sysmodules))
|
|
|
|
$sysmodules = DOCROOT.$sysmodules;
|
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
// Make the system relative to the docroot, for symlink'd index.php
|
|
|
|
if ( ! is_dir($system) AND is_dir(DOCROOT.$system))
|
|
|
|
$system = DOCROOT.$system;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
// Define the absolute paths for configured directories
|
|
|
|
define('APPPATH', realpath($application).DIRECTORY_SEPARATOR);
|
|
|
|
define('MODPATH', realpath($modules).DIRECTORY_SEPARATOR);
|
2012-11-10 10:13:57 +11:00
|
|
|
define('SMDPATH', realpath($sysmodules).DIRECTORY_SEPARATOR);
|
2012-01-29 17:23:24 +11:00
|
|
|
define('SYSPATH', realpath($system).DIRECTORY_SEPARATOR);
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
// Clean up the configuration vars
|
2012-11-10 10:13:57 +11:00
|
|
|
unset($application, $modules, $sysmodules, $system);
|
2009-08-03 14:10:16 +10:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
if (file_exists('install'.EXT))
|
|
|
|
{
|
|
|
|
// Load the installation check
|
|
|
|
return include 'install'.EXT;
|
2009-08-03 14:10:16 +10:00
|
|
|
}
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
/**
|
|
|
|
* Define the start time of the application, used for profiling.
|
|
|
|
*/
|
|
|
|
if ( ! defined('KOHANA_START_TIME'))
|
|
|
|
{
|
|
|
|
define('KOHANA_START_TIME', microtime(TRUE));
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
/**
|
|
|
|
* Define the memory usage at the start of the application, used for profiling.
|
|
|
|
*/
|
|
|
|
if ( ! defined('KOHANA_START_MEMORY'))
|
|
|
|
{
|
|
|
|
define('KOHANA_START_MEMORY', memory_get_usage());
|
|
|
|
}
|
2009-08-03 14:10:16 +10:00
|
|
|
|
2012-01-29 17:23:24 +11:00
|
|
|
// Bootstrap the application
|
|
|
|
require APPPATH.'bootstrap'.EXT;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2012-11-09 23:18:50 +11:00
|
|
|
if (PHP_SAPI == 'cli') // Try and load minion
|
|
|
|
{
|
|
|
|
class_exists('Minion_Task') OR die('Please enable the Minion module for CLI support.');
|
|
|
|
set_exception_handler(array('Minion_Exception', 'handler'));
|
|
|
|
|
|
|
|
Minion_Task::factory(Minion_CLI::options())->execute();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Execute the main request. A source of the URI can be passed, eg: $_SERVER['PATH_INFO'].
|
|
|
|
* If no source is specified, the URI will be automatically detected.
|
|
|
|
*/
|
|
|
|
echo Request::factory(TRUE, array(), FALSE)
|
|
|
|
->execute()
|
|
|
|
->send_headers(TRUE)
|
|
|
|
->body();
|
|
|
|
}
|