Log.php 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. <?php
  2. /**
  3. * MINZ - Copyright 2011 Marien Fressinaud
  4. * Sous licence AGPL3 <http://www.gnu.org/licenses/>
  5. */
  6. /**
  7. * La classe Log permet de logger des erreurs
  8. */
  9. class Minz_Log {
  10. /**
  11. * Les différents niveau de log
  12. * ERROR erreurs bloquantes de l'application
  13. * WARNING erreurs pouvant géner le bon fonctionnement, mais non bloquantes
  14. * NOTICE erreurs mineures ou messages d'informations
  15. * DEBUG Informations affichées pour le déboggage
  16. */
  17. const ERROR = 2;
  18. const WARNING = 4;
  19. const NOTICE = 8;
  20. const DEBUG = 16;
  21. /**
  22. * Enregistre un message dans un fichier de log spécifique
  23. * Message non loggué si
  24. * - environment = SILENT
  25. * - level = WARNING et environment = PRODUCTION
  26. * - level = NOTICE et environment = PRODUCTION
  27. * @param $information message d'erreur / information à enregistrer
  28. * @param $level niveau d'erreur
  29. * @param $file_name fichier de log, par défaut LOG_PATH/application.log
  30. */
  31. public static function record ($information, $level, $file_name = null) {
  32. $env = Minz_Configuration::environment ();
  33. if (! ($env === Minz_Configuration::SILENT
  34. || ($env === Minz_Configuration::PRODUCTION
  35. && ($level >= Minz_Log::NOTICE)))) {
  36. if ($file_name === null) {
  37. $file_name = LOG_PATH . '/' . Minz_Configuration::currentUser() . '.log';
  38. }
  39. switch ($level) {
  40. case Minz_Log::ERROR :
  41. $level_label = 'error';
  42. break;
  43. case Minz_Log::WARNING :
  44. $level_label = 'warning';
  45. break;
  46. case Minz_Log::NOTICE :
  47. $level_label = 'notice';
  48. break;
  49. case Minz_Log::DEBUG :
  50. $level_label = 'debug';
  51. break;
  52. default :
  53. $level_label = 'unknown';
  54. }
  55. $log = '[' . date('r') . ']'
  56. . ' [' . $level_label . ']'
  57. . ' --- ' . $information . "\n";
  58. if (file_put_contents($file_name, $log, FILE_APPEND | LOCK_EX) === false) {
  59. throw new Minz_PermissionDeniedException($file_name, Minz_Exception::ERROR);
  60. }
  61. }
  62. }
  63. /**
  64. * Automatise le log des variables globales $_GET et $_POST
  65. * Fait appel à la fonction record(...)
  66. * Ne fonctionne qu'en environnement "development"
  67. * @param $file_name fichier de log, par défaut LOG_PATH/application.log
  68. */
  69. public static function recordRequest($file_name = null) {
  70. $msg_get = str_replace("\n", '', '$_GET content : ' . print_r($_GET, true));
  71. $msg_post = str_replace("\n", '', '$_POST content : ' . print_r($_POST, true));
  72. self::record($msg_get, Minz_Log::DEBUG, $file_name);
  73. self::record($msg_post, Minz_Log::DEBUG, $file_name);
  74. }
  75. }