139 lines
4.0 KiB
PHP
139 lines
4.0 KiB
PHP
<?php defined('SYSPATH') or die('No direct script access.');
|
|
|
|
// -- Environment setup --------------------------------------------------------
|
|
|
|
// Load the core Kohana class
|
|
require SYSPATH.'classes/kohana/core'.EXT;
|
|
|
|
if (is_file(APPPATH.'classes/kohana'.EXT))
|
|
{
|
|
// Application extends the core
|
|
require APPPATH.'classes/kohana'.EXT;
|
|
}
|
|
else
|
|
{
|
|
// Load empty core extension
|
|
require SYSPATH.'classes/kohana'.EXT;
|
|
}
|
|
|
|
/**
|
|
* Set the default time zone.
|
|
*
|
|
* @see http://kohanaframework.org/guide/using.configuration
|
|
* @see http://php.net/timezones
|
|
*/
|
|
date_default_timezone_set('Australia/Melbourne');
|
|
|
|
/**
|
|
* Set the default locale.
|
|
*
|
|
* @see http://kohanaframework.org/guide/using.configuration
|
|
* @see http://php.net/setlocale
|
|
*/
|
|
setlocale(LC_ALL, 'en_US.utf-8');
|
|
|
|
/**
|
|
* Enable the Kohana auto-loader.
|
|
*
|
|
* @see http://kohanaframework.org/guide/using.autoloading
|
|
* @see http://php.net/spl_autoload_register
|
|
*/
|
|
spl_autoload_register(array('Kohana', 'auto_load'));
|
|
|
|
/**
|
|
* Enable the Kohana auto-loader for unserialization.
|
|
*
|
|
* @see http://php.net/spl_autoload_call
|
|
* @see http://php.net/manual/var.configuration.php#unserialize-callback-func
|
|
*/
|
|
ini_set('unserialize_callback_func', 'spl_autoload_call');
|
|
|
|
// -- Configuration and initialization -----------------------------------------
|
|
|
|
/**
|
|
* Set the default language
|
|
*/
|
|
I18n::lang('en-us');
|
|
|
|
/**
|
|
* Set Kohana::$environment if a 'KOHANA_ENV' environment variable has been supplied.
|
|
*
|
|
* Note: If you supply an invalid environment name, a PHP warning will be thrown
|
|
* saying "Couldn't find constant Kohana::<INVALID_ENV_NAME>"
|
|
*/
|
|
if (isset($_SERVER['KOHANA_ENV']))
|
|
{
|
|
Kohana::$environment = constant('Kohana::'.strtoupper($_SERVER['KOHANA_ENV']));
|
|
}
|
|
|
|
/**
|
|
* Initialize Kohana, setting the default options.
|
|
*
|
|
* The following options are available:
|
|
*
|
|
* - string base_url path, and optionally domain, of your application NULL
|
|
* - string index_file name of your index file, usually "index.php" index.php
|
|
* - string charset internal character set used for input and output utf-8
|
|
* - string cache_dir set the internal cache directory APPPATH/cache
|
|
* - boolean errors enable or disable error handling TRUE
|
|
* - boolean profile enable or disable internal profiling TRUE
|
|
* - boolean caching enable or disable internal caching FALSE
|
|
*/
|
|
Kohana::init(array(
|
|
'base_url' => '/pta',
|
|
'index_file' => '',
|
|
'caching' => TRUE,
|
|
'cache_dir' => '/dev/shm/lnapp',
|
|
));
|
|
|
|
/**
|
|
* Attach the file write to logging. Multiple writers are supported.
|
|
*/
|
|
Kohana::$log->attach(new Log_File(APPPATH.'logs'));
|
|
|
|
/**
|
|
* Attach a file reader to config. Multiple readers are supported.
|
|
*/
|
|
Kohana::$config->attach(new Config_File);
|
|
|
|
/**
|
|
* Enable modules. Modules are referenced by a relative or absolute path.
|
|
*/
|
|
Kohana::modules(array(
|
|
'auth' => SMDPATH.'auth', // Basic authentication
|
|
'cache' => SMDPATH.'cache', // Caching with multiple backends
|
|
// 'codebench' => SMDPATH.'codebench', // Benchmarking tool
|
|
'database' => SMDPATH.'database', // Database access
|
|
// 'image' => SMDPATH.'image', // Image manipulation
|
|
'orm' => SMDPATH.'orm', // Object Relationship Mapping
|
|
// 'unittest' => SMDPATH.'unittest', // Unit testing
|
|
'userguide' => SMDPATH.'userguide', // User guide and API documentation
|
|
));
|
|
|
|
/**
|
|
* Enable specalised interfaces
|
|
*/
|
|
Route::set('sections', '<directory>/<controller>(/<action>(/<id>(/<sid>)))',
|
|
array(
|
|
'directory' => '('.implode('|',Kohana::config('config.method_directory')).')'
|
|
));
|
|
|
|
// Static file serving (CSS, JS, images)
|
|
Route::set('default/media', 'media(/<file>)', array('file' => '.+'))
|
|
->defaults(array(
|
|
'controller' => 'welcome',
|
|
'action' => 'media',
|
|
'file' => NULL,
|
|
));
|
|
|
|
/**
|
|
* Set the routes. Each route must have a minimum of a name, a URI and a set of
|
|
* defaults for the URI.
|
|
*/
|
|
Route::set('default', '(<controller>(/<action>(/<id>)))', array('id' => '[a-zA-Z0-9_.]+'))
|
|
->defaults(array(
|
|
'controller' => 'welcome',
|
|
'action' => 'index',
|
|
));
|
|
?>
|