Error.php 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. <?php
  2. /**
  3. * MINZ - Copyright 2011 Marien Fressinaud
  4. * Sous licence AGPL3 <http://www.gnu.org/licenses/>
  5. */
  6. /**
  7. * La classe Error permet de lancer des erreurs HTTP
  8. */
  9. class Minz_Error {
  10. public function __construct () { }
  11. /**
  12. * Permet de lancer une erreur
  13. * @param $code le type de l'erreur, par défaut 404 (page not found)
  14. * @param $logs logs d'erreurs découpés de la forme
  15. * > $logs['error']
  16. * > $logs['warning']
  17. * > $logs['notice']
  18. * @param $redirect indique s'il faut forcer la redirection (les logs ne seront pas transmis)
  19. */
  20. public static function error ($code = 404, $logs = array (), $redirect = true) {
  21. $logs = self::processLogs ($logs);
  22. $error_filename = APP_PATH . '/Controllers/errorController.php';
  23. if (file_exists ($error_filename)) {
  24. Minz_Session::_params([
  25. 'error_code' => $code,
  26. 'error_logs' => $logs,
  27. ]);
  28. Minz_Request::forward (array (
  29. 'c' => 'error'
  30. ), $redirect);
  31. } else {
  32. echo '<h1>An error occured</h1>' . "\n";
  33. if (!empty ($logs)) {
  34. echo '<ul>' . "\n";
  35. foreach ($logs as $log) {
  36. echo '<li>' . $log . '</li>' . "\n";
  37. }
  38. echo '</ul>' . "\n";
  39. }
  40. exit ();
  41. }
  42. }
  43. /**
  44. * Permet de retourner les logs de façon à n'avoir que
  45. * ceux que l'on veut réellement
  46. * @param $logs les logs rangés par catégories (error, warning, notice)
  47. * @return la liste des logs, sans catégorie,
  48. * > en fonction de l'environment
  49. */
  50. private static function processLogs ($logs) {
  51. $conf = Minz_Configuration::get('system');
  52. $env = $conf->environment;
  53. $logs_ok = array ();
  54. $error = array ();
  55. $warning = array ();
  56. $notice = array ();
  57. if (isset ($logs['error'])) {
  58. $error = $logs['error'];
  59. }
  60. if (isset ($logs['warning'])) {
  61. $warning = $logs['warning'];
  62. }
  63. if (isset ($logs['notice'])) {
  64. $notice = $logs['notice'];
  65. }
  66. if ($env == 'production') {
  67. $logs_ok = $error;
  68. }
  69. if ($env == 'development') {
  70. $logs_ok = array_merge ($error, $warning, $notice);
  71. }
  72. return $logs_ok;
  73. }
  74. }