debug.class.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346
  1. <?php
  2. class debug
  3. {
  4. private static $logs = [];
  5. private static $startTime;
  6. private static $closeTime;
  7. private static function typeFile(string $_string){
  8. switch ($_string) {
  9. case 'debug':
  10. return FILE_DEBUG;
  11. break;
  12. case 'maintenance':
  13. return FILE_MAINTENANCE;
  14. break;
  15. case 'submit':
  16. return FILE_DEBUG_SUBMIT;
  17. break;
  18. case 'sql':
  19. return FILE_DEBUG_SQL;
  20. break;
  21. default:
  22. return NULL;
  23. break;
  24. }
  25. }
  26. public static function addFile(string $_string = NULL)
  27. {
  28. if($_string != NULL){
  29. $myfile = fopen(DOCUMENT_ROOT . self::typeFile($_string), "w");
  30. fclose($myfile);
  31. }
  32. }
  33. public static function removeFile(string $_string = NULL)
  34. {
  35. unlink(DOCUMENT_ROOT . self::typeFile($_string));
  36. }
  37. public static function isFile(string $_string = NULL)
  38. {
  39. return (file_exists(DOCUMENT_ROOT . self::typeFile($_string))) ? TRUE : FALSE;
  40. }
  41. public static function isSubmit()
  42. {
  43. return (file_exists(DOCUMENT_ROOT . FILE_DEBUG_SUBMIT)) ? TRUE : FALSE;
  44. }
  45. public static function includeDebug()
  46. {
  47. if (debug::isFile("debug")) {
  48. echo '<link rel="stylesheet" href="css/debug.css">';
  49. }
  50. }
  51. public static function dump($var, $label = 'Dump', $echo = true)
  52. {
  53. // Start output buffering
  54. ob_start();
  55. echo "<pre class='debug-dump'>";
  56. echo "<strong>$label:</strong> ";
  57. // Convert array or object to string
  58. if (is_array($var)) {
  59. print_r($var);
  60. } elseif (is_object($var)) {
  61. echo self::objectToString($var);
  62. } else {
  63. var_dump($var);
  64. }
  65. echo "</pre>";
  66. // Get the contents of the buffer
  67. $output = ob_get_clean();
  68. // If echo is true, print the output
  69. if ($echo) {
  70. echo $output;
  71. } else {
  72. return $output;
  73. }
  74. }
  75. public static function objectToString($object, $_tab = NULL) {
  76. ob_start();
  77. $tab = "&nbsp;&nbsp;&nbsp;&nbsp;" . $_tab;
  78. echo "<span class='debug-console-capsule'>Object (" . get_class($object) . ")\n</span>";
  79. echo $_tab . "<span class='debug-console-capsule'>{\n</span>";
  80. foreach (get_object_vars($object) as $property => $value) {
  81. echo $tab . "<span class='debug-console-capsule'>[<span class='debug-console-key'>$property</span>] => </span>";
  82. if (is_array($value)) {
  83. echo self::arrayToString($value, $tab);
  84. } elseif (is_object($value)) {
  85. echo self::objectToString($value, $tab);
  86. } else {
  87. echo "<span class='debug-console-value'>" . var_export($value, true) . "</span>\n";
  88. }
  89. }
  90. echo $_tab . "<span class='debug-console-capsule'>}\n</span>";
  91. return ob_get_clean();
  92. }
  93. public static function arrayToString($array, $_tab = NULL)
  94. {
  95. ob_start();
  96. $tab = "&nbsp;&nbsp;&nbsp;&nbsp;".$_tab;
  97. echo "<span class='debug-console-capsule'>Array\n</span>";
  98. echo $_tab . "<span class='debug-console-capsule'>(\n</span>";
  99. foreach ($array as $key => $value) {
  100. echo $tab . "<span class='debug-console-capsule'>[<span class='debug-console-key'>$key</span>] => </span>";
  101. if (is_array($value)) {
  102. echo self::arrayToString($value, $tab);
  103. } elseif (is_object($value)) {
  104. echo self::objectToString($value, $tab);
  105. } else {
  106. echo "<span class='debug-console-value'>" . var_export($value, true) . "</span>\n";
  107. }
  108. }
  109. echo $_tab . "<span class='debug-console-capsule'>)\n</span>";
  110. return ob_get_clean();
  111. }
  112. private static function variableToString($var, $label)
  113. {
  114. ob_start();
  115. echo "$label: ";
  116. if (is_array($var) || is_object($var)) {
  117. print_r($var);
  118. } else {
  119. var_dump($var);
  120. }
  121. return ob_get_clean();
  122. }
  123. public static function getTraces(){
  124. $return = "Trace : ";
  125. // Obtenir la trace d'exécution
  126. $backtrace = debug_backtrace();
  127. $nb = count($backtrace)-1;
  128. for ($i=$nb; $i > 0; $i--) {
  129. $return .= ($i != 0) ? "[".$backtrace[$i]["function"]."] " : NULL;
  130. $return .= str_replace(DOCUMENT_ROOT, '', $backtrace[$i]["file"]).":".$backtrace[$i]["line"];
  131. $return .= ($i != 1) ? " >> " : NULL;
  132. }
  133. return $return;
  134. }
  135. public static function print_r(array $_array, int $_exit = NULL)
  136. {
  137. echo "<div>".debug::getTraces() . "</div>";
  138. echo "<pre>";
  139. print_r($_array);
  140. echo "</pre>";
  141. ($_exit != NULL) ? exit() : NULL;
  142. }
  143. public static function log($_message, $_mark = NULL)
  144. {
  145. $mark = "<div class='debug-head-console'>";
  146. $mark .= ($_mark != NULL) ? "<div style='font-weight: bold;'>". $_mark . "</div>" : NULL;
  147. $mark .= self::getTraces();
  148. $mark .= "</div>";
  149. if($_message != NULL) {
  150. if(is_array($_message)){
  151. self::$logs[] = $mark ."<div class='debug-console'>" . self::arrayToString($_message) . "</div>";
  152. } elseif(is_object($_message)){
  153. self::$logs[] = $mark ."<div class='debug-console'>" . self::objectToString($_message) . "</div>";
  154. } elseif($mark != NULL){
  155. self::$logs[] = $mark ."<div class='debug-console' style='color:blue;'>" . $_message . "</div>";
  156. } else {
  157. self::$logs[] = $_message;
  158. }
  159. }
  160. }
  161. public static function logSession($_message, $_mark = NULL)
  162. {
  163. $mark = "<div class='debug-head-console'>";
  164. $mark .= ($_mark != NULL) ? "<div style='font-weight: bold;'>". $_mark . "</div>" : NULL;
  165. $mark .= self::getTraces();
  166. $mark .= "</div>";
  167. if($_message != NULL) {
  168. if(is_array($_message)){
  169. self::setSession($mark ."<div class='debug-console'>" . self::arrayToString($_message) . "</div>");
  170. } elseif(is_object($_message)){
  171. self::setSession($mark ."<div class='debug-console'>" . self::objectToString($_message) . "</div>");
  172. } elseif($mark != NULL){
  173. self::setSession($mark ."<div class='debug-console' style='color:blue;'>" . $_message . "</div>");
  174. } else {
  175. self::setSession($_message);
  176. }
  177. }
  178. }
  179. public static function renderLogs()
  180. {
  181. echo "<div id='debugger-logs'>";
  182. echo "<div class='debug-renderLogs-header'>";
  183. echo "PHP ". phpversion() . " | MYSQL " . db::version() . " | " . number_format(self::$closeTime, 4) . " secondes ";
  184. echo "</div>";
  185. echo "<div class=\"form-check form-switch\" style=\"margin-top: -30px;\">
  186. <div>
  187. <input class=\"form-check-input\" type=\"checkbox\" id=\"checkIsSubmit\" " . core::checkboxSelecter(self::isFile("submit"), 0) . " >
  188. <label class=\"form-check-label\" for=\"checkIsSubmit\">Intercepter les Submit</label>
  189. </div>
  190. <div>
  191. <input class=\"form-check-input\" type=\"checkbox\" id=\"checkIsSql\" " . core::checkboxSelecter(self::isFile("sql"), 0) . " >
  192. <label class=\"form-check-label\" for=\"checkIsSql\">Intercepter les requêtes SQL</label>
  193. </div>
  194. </div>";
  195. foreach (self::$logs as $log) {
  196. echo ($log != NULL) ? "<div class='debug-renderLogs-print'>".nl2br($log)."</div>" : NULL;
  197. }
  198. if(self::ifSession()){
  199. foreach (self::getSession() as $logSession) {
  200. echo ($logSession != NULL) ? "<div class='debug-renderLogs-print'>".nl2br($logSession)."</div>" : NULL;
  201. }
  202. }
  203. echo "</div>";
  204. get::javascript("debug");
  205. }
  206. public static function init()
  207. {
  208. // Register shutdown function to render logs at the end of the script execution
  209. register_shutdown_function(function () {
  210. self::renderLogs();
  211. });
  212. }
  213. public static function startTimer()
  214. {
  215. self::$startTime = microtime(true);
  216. }
  217. public static function endTimer()
  218. {
  219. self::$closeTime = microtime(true) - self::$startTime;
  220. }
  221. public static function getBadge(string $_link,string $_label){
  222. return '<a href="'. $_link .'" target="_blank" class="badge debug-badge">'. $_label .'</a>';
  223. }
  224. public static function printEnvironnement(){
  225. echo (ENVIRONNEMENT != "PROD") ? " [" . ENVIRONNEMENT . "]" : NULL;
  226. }
  227. private static function buildBadge(array $_data){
  228. $color = empty($_data["color"]) ? "balck" : $_data["color"];
  229. $backgroundColor = empty($_data["background-color"]) ? "orangered" : $_data["background-color"];
  230. $class = empty($_data["class"]) ? NULL : $_data["class"];
  231. $link = empty($_data["link"]) ? "#" : $_data["link"];
  232. $txt = empty($_data["txt"]) ? NULL : $_data["txt"];
  233. $icon = empty($_data["icon"]) ? NULL : "<i class=\"" . $_data["icon"] . "\"></i> ";
  234. return "<a href=\"" . $link . "\"><span class=\"badge " . $class . "\" style=\"background-color:" . $backgroundColor . "; color:" . $color . "; padding: 3px 5px 2px 5px; margin-right: 5px;\">" . $icon . $txt . "</span></a>";
  235. }
  236. public static function getBadges(){
  237. $return = "";
  238. if(debug::isFile("maintenance")){
  239. $return .= self::buildBadge([
  240. "icon" => "bi bi-exclamation-diamond-fill",
  241. "link" => "/parametres.html#parametres-debug",
  242. "background-color" => "red",
  243. "color" => "white",
  244. "txt" => "MODE MAINTENANCE"
  245. ]);
  246. }
  247. if(debug::isFile("debug")){
  248. $return .= self::buildBadge([
  249. "icon" => "bi bi-bug-fill",
  250. "class" => "toggle-logs",
  251. "link" => "#",
  252. "background-color" => "orangered",
  253. "color" => "white",
  254. "txt" => "MODE DEBUG"
  255. ]);
  256. }
  257. if(self::isFile("sql")){
  258. $return .= self::buildBadge([
  259. "icon" => "bi bi-database-fill",
  260. "class" => "toggle-logs",
  261. "link" => "#",
  262. "background-color" => "orange",
  263. "color" => "black",
  264. "txt" => "DEBUG SQL"
  265. ]);
  266. }
  267. if(self::isFile("submit")){
  268. $return .= self::buildBadge([
  269. "icon" => "bi bi-send-fill",
  270. "class" => "toggle-logs",
  271. "link" => "#",
  272. "background-color" => "orange",
  273. "color" => "black",
  274. "txt" => "DEBUG SUBMIT"
  275. ]);
  276. }
  277. return $return;
  278. }
  279. public static function setSession($_data){
  280. $_SESSION["DEBUG"][] = $_data;
  281. }
  282. public static function getSession(){
  283. $return = $_SESSION["DEBUG"];
  284. self::resetSession();
  285. return $return;
  286. }
  287. public static function ifSession(){
  288. return empty($_SESSION["DEBUG"]) ? FALSE : TRUE;
  289. }
  290. public static function resetSession(){
  291. unset($_SESSION["DEBUG"]);
  292. }
  293. }