2
0

git.class.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. /**
  3. * Classe git
  4. *
  5. * Cette classe fournit des méthodes pour interagir avec Git, telles que la récupération
  6. * des informations de commit, de branche et l'affichage des versions.
  7. */
  8. class git
  9. {
  10. /**
  11. * Vérifie si une chaîne contient une erreur Git.
  12. *
  13. * @param string|null $_string Chaîne à vérifier (facultatif).
  14. * @return bool Retourne TRUE si aucune erreur n'est détectée, FALSE sinon.
  15. */
  16. public static function checkError(?string $_string = NULL)
  17. {
  18. $return = NULL;
  19. if ($_string != NULL) {
  20. if (strpos($_string, '-// SUCCESS //-') === TRUE) {
  21. $return = TRUE;
  22. } else {
  23. return FALSE;
  24. }
  25. return $return;
  26. } else {
  27. return TRUE;
  28. }
  29. }
  30. /**
  31. * Récupère le hash du dernier commit pour une cible donnée.
  32. *
  33. * @param string|null $_target Cible Git (par défaut HEAD).
  34. * @return string Retourne les 10 premiers caractères du hash du commit.
  35. */
  36. public static function getCommitHash($_target = NULL)
  37. {
  38. if ($_target == NULL) {
  39. // Commit local HEAD
  40. $cmd = 'git log --pretty="%H" -n1 HEAD';
  41. $output = [];
  42. $retval = 0;
  43. $result = exec($cmd, $output, $retval);
  44. return substr(trim($result), 0, 10);
  45. } else {
  46. // Hash du commit distant en temps réel
  47. $cmd = 'git ls-remote origin "refs/heads/' . $_target . '"';
  48. $output = [];
  49. $retval = 0;
  50. $result = exec($cmd, $output, $retval);
  51. // $result ou $output[0] = "<hash>\trefs/heads/branch"
  52. $hash = '';
  53. if (!empty($output) && strpos($output[0], '\t') !== false) {
  54. $hash = explode("\t", $output[0])[0];
  55. }
  56. return substr(trim($hash), 0, 10);
  57. }
  58. }
  59. /**
  60. * Récupère la date du dernier commit pour une cible donnée.
  61. *
  62. * @param string|null $_target Cible Git (par défaut HEAD).
  63. * @return string Retourne la date du commit formatée (d/m/Y à H:i:s).
  64. */
  65. public static function getCommitDate($_target = NULL)
  66. {
  67. if ($_target == NULL) {
  68. $target = "HEAD";
  69. } else {
  70. $target = "origin/" . $_target;
  71. }
  72. $commitDate = new \DateTime(trim(exec('git log -n1 --pretty=%ci ' . $target)));
  73. $commitDate->setTimezone(new \DateTimeZone('Europe/Paris'));
  74. return $commitDate->format('d/m/Y à H:i:s');
  75. }
  76. /**
  77. * Récupère l'auteur du dernier commit pour une cible donnée.
  78. *
  79. * @param string|null $_target Cible Git (par défaut HEAD).
  80. * @return string Retourne le nom de l'auteur du commit.
  81. */
  82. public static function getCommitAuthor($_target = NULL)
  83. {
  84. if ($_target == NULL) {
  85. $target = "HEAD";
  86. } else {
  87. $target = "origin/" . $_target;
  88. }
  89. return exec('git log --pretty="%cn" -n1 ' . $target);
  90. }
  91. /**
  92. * Récupère le message du dernier commit pour une cible donnée.
  93. *
  94. * @param string|null $_target Cible Git (par défaut HEAD).
  95. * @return string Retourne le message du commit.
  96. */
  97. public static function getCommitName($_target = NULL)
  98. {
  99. if ($_target == NULL) {
  100. $target = "HEAD";
  101. } else {
  102. $target = "origin/" . $_target;
  103. }
  104. return exec('git log --pretty="%s" -n1 ' . $target);
  105. }
  106. /**
  107. * Récupère le nom de la branche actuelle ou d'une cible donnée.
  108. *
  109. * @param string|null $_target Cible Git (facultatif).
  110. * @return string Retourne le nom de la branche.
  111. */
  112. public static function getBranchName($_target = NULL)
  113. {
  114. if ($_target == NULL) {
  115. return exec('git rev-parse --abbrev-ref HEAD');
  116. } else {
  117. return $_target;
  118. }
  119. }
  120. /**
  121. * Affiche les informations de version pour une cible donnée.
  122. *
  123. * @param string|null $_target Cible Git (facultatif).
  124. * @return void
  125. */
  126. public static function printVersion($_target = NULL)
  127. {
  128. echo sprintf(
  129. '<h6>%s <span class="badge bg-info">%s</span> <span class="badge bg-success">%s</span></h6>
  130. <code>%s</code>
  131. <div class="media-body pb-3 mb-0 small lh-125">Le %s</div>',
  132. self::getCommitAuthor($_target),
  133. self::getBranchName($_target),
  134. self::getCommitHash($_target),
  135. self::getCommitName($_target),
  136. self::getCommitDate($_target)
  137. );
  138. }
  139. }