Auth.php 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. <?php
  2. namespace Src\Auth;
  3. use Src\Session;
  4. class Auth
  5. {
  6. //Свойство для хранения любого класса, реализующего интерфейс IdentityInterface
  7. private static IdentityInterface $user;
  8. //Инициализация класса пользователя
  9. public static function init(IdentityInterface $user): void
  10. {
  11. self::$user = $user;
  12. if (self::user()) {
  13. self::login(self::user());
  14. }
  15. }
  16. //Вход пользователя по модели
  17. public static function login(IdentityInterface $user): void
  18. {
  19. self::$user = $user;
  20. Session::set('id', self::$user->getId());
  21. }
  22. //Аутентификация пользователя и вход по учетным данным
  23. public static function attempt(array $credentials): bool
  24. {
  25. if ($user = self::$user->attemptIdentity($credentials)) {
  26. self::login($user);
  27. return true;
  28. }
  29. return false;
  30. }
  31. //Возврат текущего аутентифицированного пользователя
  32. public static function user()
  33. {
  34. $id = Session::get('id') ?? 0;
  35. return self::$user->findIdentity($id);
  36. }
  37. public static function isAdmin(): bool {
  38. $id = Session::get('id') ?? 0;
  39. $currentUser = self::$user->findIdentity($id);
  40. return $currentUser->role === 'admin';
  41. }
  42. //Проверка является ли текущий пользователь аутентифицированным
  43. public static function check(): bool
  44. {
  45. if (self::user()) {
  46. return true;
  47. }
  48. return false;
  49. }
  50. //Выход текущего пользователя
  51. public static function logout(): bool
  52. {
  53. Session::clear('id');
  54. return true;
  55. }
  56. }