session.class.php 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. <?php
  2. /**
  3. * Classe session
  4. *
  5. * Cette classe gère les sessions utilisateur, y compris la création, la récupération,
  6. * la modification et la suppression des données de session.
  7. */
  8. class session
  9. {
  10. /**
  11. * Crée une session avec les données fournies.
  12. *
  13. * @param array $_array Données de la session.
  14. * @param string $_type Type de session (par défaut "user").
  15. */
  16. public static function createSession(array $_array, string $_type = "user")
  17. {
  18. $_SESSION[$_type] = $_array;
  19. }
  20. /**
  21. * Récupère l'identifiant de la session.
  22. *
  23. * @param string $_type Type de session (par défaut "user").
  24. * @return mixed Identifiant de la session.
  25. */
  26. public static function getId(string $_type = "user")
  27. {
  28. return $_SESSION[$_type]["id"];
  29. }
  30. /**
  31. * Récupère une valeur spécifique de la session.
  32. *
  33. * @param string $_val Clé de la valeur à récupérer.
  34. * @param string $_type Type de session (par défaut "user").
  35. * @return mixed Valeur correspondante dans la session.
  36. */
  37. public static function getValue(string $_val, string $_type = "user")
  38. {
  39. return $_SESSION[$_type][$_val];
  40. }
  41. /**
  42. * Définit une valeur spécifique dans la session.
  43. *
  44. * @param mixed $_vl Valeur à définir.
  45. * @param string $_val Clé de la valeur à définir.
  46. * @param string $_type Type de session (par défaut "user").
  47. */
  48. public static function setValue($_vl, string $_val, string $_type = "user")
  49. {
  50. $_SESSION[$_type][$_val] = $_vl;
  51. }
  52. /**
  53. * Récupère le nom complet de l'utilisateur dans la session.
  54. *
  55. * @param string $_type Type de session (par défaut "user").
  56. * @return string Nom complet de l'utilisateur.
  57. */
  58. public static function getName(string $_type = "user")
  59. {
  60. return $_SESSION[$_type]["prenom"] . " " . $_SESSION[$_type]["nom"];
  61. }
  62. /**
  63. * Récupère le type d'utilisateur dans la session.
  64. *
  65. * @param string $_type Type de session (par défaut "user").
  66. * @return mixed Type d'utilisateur.
  67. */
  68. public static function getType(string $_type = "user")
  69. {
  70. return $_SESSION[$_type]["idType"];
  71. }
  72. /**
  73. * Vérifie si l'utilisateur est connecté.
  74. *
  75. * @param string $_type Type de session (par défaut "user").
  76. * @return bool Vrai si l'utilisateur est connecté, faux sinon.
  77. */
  78. public static function isConnect(string $_type = "user")
  79. {
  80. return (isset($_SESSION[$_type]["id"])) ? TRUE : FALSE;
  81. }
  82. /**
  83. * Vérifie si l'utilisateur a accès à un type spécifique.
  84. *
  85. * @param array $_type Types d'accès autorisés.
  86. * @return bool Vrai si l'utilisateur a accès, faux sinon.
  87. */
  88. public static function access(array $_type){
  89. return (in_array($_SESSION["user"]["idType"], $_type)) ? TRUE : FALSE;
  90. }
  91. /**
  92. * Vérifie si l'utilisateur est dans l'espace des contrôleurs.
  93. *
  94. * @return bool Vrai si l'utilisateur est dans l'espace des contrôleurs, faux sinon.
  95. */
  96. public static function isEspaceControleurs(){
  97. return ($_SERVER['HTTP_HOST'] == DOMAIN_CONTROL) ? TRUE : FALSE;
  98. }
  99. /**
  100. * Vérifie si l'utilisateur est dans l'espace des salariés.
  101. *
  102. * @return bool Vrai si l'utilisateur est dans l'espace des salariés, faux sinon.
  103. */
  104. public static function isEspaceSalaries(){
  105. return ($_SERVER['HTTP_HOST'] == DOMAIN_EVENTS) ? TRUE : FALSE;
  106. }
  107. /**
  108. * Définit des données temporaires dans la session.
  109. *
  110. * @param array $_array Données temporaires à définir.
  111. * @param string|null $_name Nom de la clé temporaire (par défaut "tmp").
  112. */
  113. public static function setTemp(array $_array, ?string $_name = NULL){
  114. if($_name == NULL){
  115. $_SESSION["TEMP"]["tmp"] = $_array;
  116. } else {
  117. $_SESSION["TEMP"][$_name] = $_array;
  118. }
  119. }
  120. /**
  121. * Récupère des données temporaires de la session.
  122. *
  123. * @param string|null $_name Nom de la clé temporaire (par défaut "tmp").
  124. * @return mixed Données temporaires récupérées.
  125. */
  126. public static function getTemp(?string $_name = NULL){
  127. if(empty($_SESSION["TEMP"])){
  128. return NULL;
  129. } elseif($_name == NULL){
  130. $return = $_SESSION["TEMP"]["tmp"];
  131. } else {
  132. $return = $_SESSION["TEMP"][$_name];
  133. }
  134. self::resetTemp();
  135. return $return;
  136. }
  137. /**
  138. * Réinitialise les données temporaires dans la session.
  139. *
  140. * @param string|null $_name Nom de la clé temporaire à réinitialiser (par défaut toutes).
  141. */
  142. public static function resetTemp(?string $_name = NULL){
  143. unset($_SESSION["TEMP"]);
  144. }
  145. }