FrontController.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. <?php
  2. # ***** BEGIN LICENSE BLOCK *****
  3. # MINZ - a free PHP Framework like Zend Framework
  4. # Copyright (C) 2011 Marien Fressinaud
  5. #
  6. # This program is free software: you can redistribute it and/or modify
  7. # it under the terms of the GNU Affero General Public License as
  8. # published by the Free Software Foundation, either version 3 of the
  9. # License, or (at your option) any later version.
  10. #
  11. # This program is distributed in the hope that it will be useful,
  12. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. # GNU Affero General Public License for more details.
  15. #
  16. # You should have received a copy of the GNU Affero General Public License
  17. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. #
  19. # ***** END LICENSE BLOCK *****
  20. /**
  21. * La classe FrontController est le Dispatcher du framework, elle lance l'application
  22. * Elle est appelée en général dans le fichier index.php à la racine du serveur
  23. */
  24. class Minz_FrontController {
  25. protected $dispatcher;
  26. /**
  27. * Constructeur
  28. * Initialise le dispatcher, met à jour la Request
  29. */
  30. public function __construct () {
  31. try {
  32. $this->setReporting();
  33. Minz_Request::init();
  34. $url = $this->buildUrl();
  35. $url['params'] = array_merge (
  36. $url['params'],
  37. Minz_Request::fetchPOST ()
  38. );
  39. Minz_Request::forward ($url);
  40. } catch (Minz_Exception $e) {
  41. Minz_Log::error($e->getMessage());
  42. $this->killApp ($e->getMessage());
  43. }
  44. $this->dispatcher = Minz_Dispatcher::getInstance();
  45. }
  46. /**
  47. * Retourne un tableau représentant l'url passée par la barre d'adresses
  48. * @return tableau représentant l'url
  49. */
  50. private function buildUrl() {
  51. $url = array();
  52. $url['c'] = Minz_Request::fetchGET(
  53. 'c',
  54. Minz_Request::defaultControllerName()
  55. );
  56. $url['a'] = Minz_Request::fetchGET(
  57. 'a',
  58. Minz_Request::defaultActionName()
  59. );
  60. $url['params'] = Minz_Request::fetchGET();
  61. // post-traitement
  62. unset($url['params']['c']);
  63. unset($url['params']['a']);
  64. return $url;
  65. }
  66. /**
  67. * Démarre l'application (lance le dispatcher et renvoie la réponse)
  68. */
  69. public function run() {
  70. try {
  71. $this->dispatcher->run();
  72. } catch (Minz_Exception $e) {
  73. try {
  74. Minz_Log::error($e->getMessage());
  75. } catch (Minz_PermissionDeniedException $e) {
  76. $this->killApp ($e->getMessage ());
  77. }
  78. if ($e instanceof Minz_FileNotExistException ||
  79. $e instanceof Minz_ControllerNotExistException ||
  80. $e instanceof Minz_ControllerNotActionControllerException ||
  81. $e instanceof Minz_ActionException) {
  82. Minz_Error::error (
  83. 404,
  84. array('error' => array ($e->getMessage ())),
  85. true
  86. );
  87. } else {
  88. $this->killApp();
  89. }
  90. }
  91. }
  92. /**
  93. * Permet d'arrêter le programme en urgence
  94. */
  95. private function killApp ($txt = '') {
  96. if (function_exists('errorMessage')) {
  97. //If the application has defined a custom error message function
  98. exit(errorMessage('Application problem', $txt));
  99. }
  100. exit('### Application problem ###<br />' . "\n" . $txt);
  101. }
  102. private function setReporting() {
  103. $envType = getenv('FRESHRSS_ENV');
  104. if ($envType == '') {
  105. $conf = Minz_Configuration::get('system');
  106. $envType = $conf->environment;
  107. }
  108. switch ($envType) {
  109. case 'development':
  110. error_reporting(E_ALL);
  111. ini_set('display_errors', 'On');
  112. ini_set('log_errors', 'On');
  113. break;
  114. case 'silent':
  115. error_reporting(0);
  116. break;
  117. case 'production':
  118. default:
  119. error_reporting(E_ALL);
  120. ini_set('display_errors', 'Off');
  121. ini_set('log_errors', 'On');
  122. break;
  123. }
  124. }
  125. }