bootstrap.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <?php
  2. // -- Environment setup --------------------------------------------------------
  3. // Load the core Kohana class
  4. require SYSPATH.'classes/Kohana/Core'.EXT;
  5. if (is_file(APPPATH.'classes/Kohana'.EXT))
  6. {
  7. // Application extends the core
  8. require APPPATH.'classes/Kohana'.EXT;
  9. }
  10. else
  11. {
  12. // Load empty core extension
  13. require SYSPATH.'classes/Kohana'.EXT;
  14. }
  15. /**
  16. * Set the default time zone.
  17. *
  18. * @link http://kohanaframework.org/guide/using.configuration
  19. * @link http://www.php.net/manual/timezones
  20. */
  21. date_default_timezone_set('America/Chicago');
  22. /**
  23. * Set the default locale.
  24. *
  25. * @link http://kohanaframework.org/guide/using.configuration
  26. * @link http://www.php.net/manual/function.setlocale
  27. */
  28. setlocale(LC_ALL, 'en_US.utf-8');
  29. /**
  30. * Enable the Kohana auto-loader.
  31. *
  32. * @link http://kohanaframework.org/guide/using.autoloading
  33. * @link http://www.php.net/manual/function.spl-autoload-register
  34. */
  35. spl_autoload_register(array('Kohana', 'auto_load'));
  36. /**
  37. * Optionally, you can enable a compatibility auto-loader for use with
  38. * older modules that have not been updated for PSR-0.
  39. *
  40. * It is recommended to not enable this unless absolutely necessary.
  41. */
  42. //spl_autoload_register(array('Kohana', 'auto_load_lowercase'));
  43. /**
  44. * Enable the Kohana auto-loader for unserialization.
  45. *
  46. * @link http://www.php.net/manual/function.spl-autoload-call
  47. * @link http://www.php.net/manual/var.configuration#unserialize-callback-func
  48. */
  49. ini_set('unserialize_callback_func', 'spl_autoload_call');
  50. /**
  51. * Enable composer autoload libraries
  52. */
  53. // require DOCROOT . '/vendor/autoload.php';
  54. /**
  55. * Set the mb_substitute_character to "none"
  56. *
  57. * @link http://www.php.net/manual/function.mb-substitute-character.php
  58. */
  59. mb_substitute_character('none');
  60. // -- Configuration and initialization -----------------------------------------
  61. /**
  62. * Set the default language
  63. */
  64. I18n::lang('en-us');
  65. if (isset($_SERVER['SERVER_PROTOCOL']))
  66. {
  67. // Replace the default protocol.
  68. HTTP::$protocol = $_SERVER['SERVER_PROTOCOL'];
  69. }
  70. /**
  71. * Set Kohana::$environment if a 'KOHANA_ENV' environment variable has been supplied.
  72. *
  73. * Note: If you supply an invalid environment name, a PHP warning will be thrown
  74. * saying "Couldn't find constant Kohana::<INVALID_ENV_NAME>"
  75. */
  76. if (isset($_SERVER['KOHANA_ENV']))
  77. {
  78. Kohana::$environment = constant('Kohana::'.strtoupper($_SERVER['KOHANA_ENV']));
  79. }
  80. /**
  81. * Initialize Kohana, setting the default options.
  82. *
  83. * The following options are available:
  84. *
  85. * - string base_url path, and optionally domain, of your application NULL
  86. * - string index_file name of your index file, usually "index.php", if set to FALSE uses clean URLS index.php
  87. * - string charset internal character set used for input and output utf-8
  88. * - string cache_dir set the internal cache directory APPPATH/cache
  89. * - integer cache_life lifetime, in seconds, of items cached 60
  90. * - boolean errors enable or disable error handling TRUE
  91. * - boolean profile enable or disable internal profiling TRUE
  92. * - boolean caching enable or disable internal caching FALSE
  93. * - boolean expose set the X-Powered-By header FALSE
  94. */
  95. Kohana::init(array(
  96. 'base_url' => '/kohana/',
  97. ));
  98. /**
  99. * Attach the file write to logging. Multiple writers are supported.
  100. */
  101. Kohana::$log->attach(new Log_File(APPPATH.'logs'));
  102. /**
  103. * Attach a file reader to config. Multiple readers are supported.
  104. */
  105. Kohana::$config->attach(new Config_File);
  106. /**
  107. * Enable modules. Modules are referenced by a relative or absolute path.
  108. */
  109. Kohana::modules(array(
  110. // 'encrypt' => MODPATH.'encrypt', // Encryption supprt
  111. // 'auth' => MODPATH.'auth', // Basic authentication
  112. // 'cache' => MODPATH.'cache', // Caching with multiple backends
  113. // 'codebench' => MODPATH.'codebench', // Benchmarking tool
  114. // 'database' => MODPATH.'database', // Database access
  115. // 'image' => MODPATH.'image', // Image manipulation
  116. // 'minion' => MODPATH.'minion', // CLI Tasks
  117. // 'orm' => MODPATH.'orm', // Object Relationship Mapping
  118. // 'pagination' => MODPATH.'pagination', // Pagination
  119. // 'unittest' => MODPATH.'unittest', // Unit testing
  120. // 'userguide' => MODPATH.'userguide', // User guide and API documentation
  121. ));
  122. /**
  123. * Cookie Salt
  124. * @see http://kohanaframework.org/3.3/guide/kohana/cookies
  125. *
  126. * If you have not defined a cookie salt in your Cookie class then
  127. * uncomment the line below and define a preferrably long salt.
  128. */
  129. // Cookie::$salt = NULL;
  130. /**
  131. * Cookie HttpOnly directive
  132. * If set to true, disallows cookies to be accessed from JavaScript
  133. * @see https://en.wikipedia.org/wiki/Session_hijacking
  134. */
  135. // Cookie::$httponly = TRUE;
  136. /**
  137. * If website runs on secure protocol HTTPS, allows cookies only to be transmitted
  138. * via HTTPS.
  139. * Warning: HSTS must also be enabled in .htaccess, otherwise first request
  140. * to http://www.example.com will still reveal this cookie
  141. */
  142. // Cookie::$secure = isset($_SERVER['HTTPS']) AND $_SERVER['HTTPS'] == 'on' ? TRUE : FALSE;
  143. /**
  144. * Set the routes. Each route must have a minimum of a name, a URI and a set of
  145. * defaults for the URI.
  146. */
  147. Route::set('default', '(<controller>(/<action>(/<id>)))')
  148. ->defaults(array(
  149. 'controller' => 'welcome',
  150. 'action' => 'index',
  151. ));