2
0

session.class.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  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. {
  90. return (in_array($_SESSION["user"]["idType"], $_type)) ? TRUE : FALSE;
  91. }
  92. /**
  93. * Vérifie si l'utilisateur est dans l'espace des contrôleurs.
  94. *
  95. * @return bool Vrai si l'utilisateur est dans l'espace des contrôleurs, faux sinon.
  96. */
  97. public static function isEspaceControleurs()
  98. {
  99. return ($_SERVER['HTTP_HOST'] == DOMAIN_CONTROL) ? TRUE : FALSE;
  100. }
  101. /**
  102. * Vérifie si l'utilisateur est dans l'espace des salariés.
  103. *
  104. * @return bool Vrai si l'utilisateur est dans l'espace des salariés, faux sinon.
  105. */
  106. public static function isEspaceSalaries()
  107. {
  108. return ($_SERVER['HTTP_HOST'] == DOMAIN_EVENTS) ? TRUE : FALSE;
  109. }
  110. /**
  111. * Définit des données temporaires dans la session.
  112. *
  113. * @param array $_array Données temporaires à définir.
  114. * @param string|null $_name Nom de la clé temporaire (par défaut "tmp").
  115. */
  116. public static function setTemp(array $_array, ?string $_name = NULL)
  117. {
  118. if ($_name == NULL) {
  119. $_SESSION["TEMP"]["tmp"] = $_array;
  120. } else {
  121. $_SESSION["TEMP"][$_name] = $_array;
  122. }
  123. }
  124. /**
  125. * Récupère des données temporaires de la session.
  126. *
  127. * @param string|null $_name Nom de la clé temporaire (par défaut "tmp").
  128. * @return mixed Données temporaires récupérées.
  129. */
  130. public static function getTemp(?string $_name = NULL)
  131. {
  132. if (empty($_SESSION["TEMP"])) {
  133. return NULL;
  134. } elseif ($_name == NULL) {
  135. $return = $_SESSION["TEMP"]["tmp"];
  136. } else {
  137. $return = $_SESSION["TEMP"][$_name];
  138. }
  139. self::resetTemp();
  140. return $return;
  141. }
  142. /**
  143. * Réinitialise les données temporaires dans la session.
  144. *
  145. * @param string|null $_name Nom de la clé temporaire à réinitialiser (par défaut toutes).
  146. */
  147. public static function resetTemp(?string $_name = NULL)
  148. {
  149. unset($_SESSION["TEMP"]);
  150. }
  151. /**
  152. * Déconnexion sécurisée de l'utilisateur.
  153. * Détruit la session et régénère l'ID pour éviter la fixation de session.
  154. *
  155. * @param string $_type Type de session à détruire (par défaut "user").
  156. * @return bool True si la déconnexion a réussi.
  157. */
  158. public static function logout(string $_type = "user"): bool
  159. {
  160. // Supprimer les données de session de l'utilisateur
  161. if (isset($_SESSION[$_type])) {
  162. unset($_SESSION[$_type]);
  163. }
  164. // Si aucune autre donnée de session n'existe, détruire complètement la session
  165. $hasOtherSessions = false;
  166. foreach ($_SESSION as $key => $value) {
  167. if (!in_array($key, ['_session_created', '_session_ip', '_session_user_agent', '_session_last_activity', 'TEMP'])) {
  168. $hasOtherSessions = true;
  169. break;
  170. }
  171. }
  172. // Si pas d'autres sessions actives, détruire complètement
  173. if (!$hasOtherSessions) {
  174. return secureSession::destroy();
  175. }
  176. // Sinon, régénérer l'ID de session pour sécurité
  177. return secureSession::regenerateId();
  178. }
  179. /**
  180. * Force le timeout d'inactivité de la session.
  181. * À appeler au début de chaque requête pour vérifier l'activité.
  182. *
  183. * @param int $minutes Nombre de minutes d'inactivité avant expiration (par défaut 30).
  184. * @return bool True si la session est toujours valide, False si elle a expiré.
  185. */
  186. public static function checkTimeout(int $minutes = 30): bool
  187. {
  188. return secureSession::setInactivityTimeout($minutes);
  189. }
  190. }