FrontController.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  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. Minz_Configuration::init ();
  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 ($txt == '') {
  97. $txt = 'See logs files';
  98. }
  99. exit ('### Application problem ###<br />'."\n".$txt);
  100. }
  101. }