historique.class.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <?php
  2. class historique
  3. {
  4. public static function recRef(string $_name) {
  5. db::query("INSERT IGNORE INTO " . DB_T_HISTORIQUE_REF . " (name) VALUES (:name)");
  6. db::bind(':name', $_name);
  7. try {
  8. db::execute();
  9. } catch (Exception $ex) {
  10. alert::recError("Erreur lors de l'enregistrement de la référence historique");
  11. }
  12. }
  13. public static function getIdRef(string $_name) {
  14. db::query("SELECT id FROM " . DB_T_HISTORIQUE_REF . " WHERE name = :name");
  15. db::bind(':name', $_name);
  16. return db::single()["id"];
  17. }
  18. public static function getAll() {
  19. db::query("SELECT "
  20. . "" . DB_T_HISTORIQUE . ".id, "
  21. . "" . DB_T_HISTORIQUE . ".idType ,"
  22. . "HISTO_TYPE.name AS type ,"
  23. . "" . DB_T_HISTORIQUE . ".idPage, "
  24. . "HISTO_PAGE.name AS page, "
  25. . "" . DB_T_HISTORIQUE . ".idUser ,"
  26. . "CONCAT (" . DB_T_USER . ".prenom, ' ', " . DB_T_USER . ".nom) AS 'user' ,"
  27. . "" . DB_T_HISTORIQUE . ".log, "
  28. . "" . DB_T_HISTORIQUE . ".addDate "
  29. . "FROM " . DB_T_HISTORIQUE . " "
  30. . "INNER JOIN " . DB_T_USER . " ON " . DB_T_HISTORIQUE . ".idUser = " . DB_T_USER . ".id "
  31. . "INNER JOIN " . DB_T_HISTORIQUE_REF . " HISTO_TYPE ON " . DB_T_HISTORIQUE . ".idType = HISTO_TYPE.id "
  32. . "INNER JOIN " . DB_T_HISTORIQUE_REF . " HISTO_PAGE ON " . DB_T_HISTORIQUE . ".idPage = HISTO_PAGE.id ");
  33. return db::resultset();
  34. }
  35. public static function getByPage(string $_idPage) {
  36. db::query("SELECT "
  37. . "" . DB_T_HISTORIQUE . ".id, "
  38. . "" . DB_T_HISTORIQUE . ".idType ,"
  39. . "HISTO_TYPE.name AS type ,"
  40. . "" . DB_T_HISTORIQUE . ".idPage, "
  41. . "HISTO_PAGE.name AS page, "
  42. . "" . DB_T_HISTORIQUE . ".idUser ,"
  43. . "CONCAT (" . DB_T_USER . ".prenom, ' ', " . DB_T_USER . ".nom) AS 'user' ,"
  44. . "" . DB_T_HISTORIQUE . ".log, "
  45. . "" . DB_T_HISTORIQUE . ".addDate "
  46. . "FROM " . DB_T_HISTORIQUE . " "
  47. . "INNER JOIN " . DB_T_USER . " ON " . DB_T_HISTORIQUE . ".idUser = " . DB_T_USER . ".id "
  48. . "INNER JOIN " . DB_T_HISTORIQUE_REF . " HISTO_TYPE ON " . DB_T_HISTORIQUE . ".idType = HISTO_TYPE.id "
  49. . "INNER JOIN " . DB_T_HISTORIQUE_REF . " HISTO_PAGE ON " . DB_T_HISTORIQUE . ".idPage = HISTO_PAGE.id "
  50. . "WHERE " . DB_T_HISTORIQUE . ".idPage = :idPage");
  51. db::bind(':idPage', $_idPage);
  52. return db::resultset();
  53. }
  54. public static function getByUser(int $_idUser) {
  55. db::query("SELECT "
  56. . "" . DB_T_HISTORIQUE . ".id, "
  57. . "" . DB_T_HISTORIQUE . ".type ,"
  58. . "" . DB_T_HISTORIQUE . ".idPage, "
  59. . "" . DB_T_HISTORIQUE . ".idUser ,"
  60. . "CONCAT (" . DB_T_USER . ".prenom, ' ', " . DB_T_USER . ".nom) AS 'user' ,"
  61. . "" . DB_T_HISTORIQUE . ".log, "
  62. . "" . DB_T_HISTORIQUE . ".addDate "
  63. . "FROM " . DB_T_HISTORIQUE . " "
  64. . "WHERE " . DB_T_HISTORIQUE . ".idUser = :idUser");
  65. db::bind(':idUser', $_idUser);
  66. return db::resultset();
  67. }
  68. public static function getByType(string $_type) {
  69. db::query("SELECT "
  70. . "" . DB_T_HISTORIQUE . ".id, "
  71. . "" . DB_T_HISTORIQUE . ".idType ,"
  72. . "HISTO_TYPE.name AS type ,"
  73. . "" . DB_T_HISTORIQUE . ".idPage, "
  74. . "HISTO_PAGE.name AS page, "
  75. . "" . DB_T_HISTORIQUE . ".idUser ,"
  76. . "CONCAT (" . DB_T_USER . ".prenom, ' ', " . DB_T_USER . ".nom) AS 'user' ,"
  77. . "" . DB_T_HISTORIQUE . ".log, "
  78. . "" . DB_T_HISTORIQUE . ".addDate "
  79. . "FROM " . DB_T_HISTORIQUE . " "
  80. . "INNER JOIN " . DB_T_USER . " ON " . DB_T_HISTORIQUE . ".idUser = " . DB_T_USER . ".id "
  81. . "INNER JOIN " . DB_T_HISTORIQUE_REF . " HISTO_TYPE ON " . DB_T_HISTORIQUE . ".idType = HISTO_TYPE.id "
  82. . "INNER JOIN " . DB_T_HISTORIQUE_REF . " HISTO_PAGE ON " . DB_T_HISTORIQUE . ".idPage = HISTO_PAGE.id "
  83. . "WHERE " . DB_T_HISTORIQUE . ".type = :type");
  84. db::bind(':type', $_type);
  85. return db::resultset();
  86. }
  87. public static function recordLogs(){
  88. if(session::isConnect() AND (alert::getSuccess() OR alert::getWarning() OR alert::getError())){
  89. if(alert::getSuccess() AND core::getConfig("LOG_SUCCESS") == 1){
  90. self::recordAlert("SUCCESS");
  91. }
  92. if(alert::getWarning() AND core::getConfig("LOG_WARNING") == 1){
  93. self::recordAlert("WARNING");
  94. }
  95. if(alert::getError() AND core::getConfig("LOG_ERROR") == 1){
  96. self::recordAlert("ERROR");
  97. }
  98. }
  99. }
  100. public static function recordAlert(string $_type){
  101. $log = NULL;
  102. switch ($_type) {
  103. case 'SUCCESS':
  104. $alert = alert::getSuccess();
  105. break;
  106. case 'WARNING':
  107. $alert = alert::getWarning();
  108. break;
  109. case 'ERROR':
  110. $alert = alert::getError();
  111. break;
  112. default:
  113. $alert = NULL;
  114. alert::recError("Erreur lors de l'enregistrement de l'historique");
  115. break;
  116. }
  117. if($alert != NULL){
  118. foreach ($alert as $value) {
  119. $log .= $value . "<br />";
  120. }
  121. self::recRef($_SERVER["REQUEST_URI"]);
  122. self::add(array(
  123. "idType" => self::getIdRef($_type),
  124. "idUser" => session::getId(),
  125. "idPage" => self::getIdRef($_SERVER["REQUEST_URI"]),
  126. "log" => $log
  127. ));
  128. }
  129. }
  130. public static function add(array $_input){
  131. db::query("INSERT INTO " . DB_T_HISTORIQUE . " (idType, idUser, idPage, log) VALUES (:idType, :idUser, :idPage, :log)");
  132. db::bind(':idType', $_input["idType"]);
  133. db::bind(':idUser', $_input["idUser"]);
  134. db::bind(':idPage', $_input["idPage"]);
  135. db::bind(':log', $_input["log"]);
  136. try {
  137. db::execute();
  138. } catch (Exception $ex) {
  139. alert::recError("Erreur lors de l'enregistrement de l'historique");
  140. }
  141. }
  142. }