You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

LuticateUsersBusiness.php 1.4KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <?php
  2. namespace Luticate\Auth\Business;
  3. use Illuminate\Http\Request;
  4. use Luticate\Utils\LuBusiness;
  5. use Luticate\Auth\DataAccess\LuticateUsersDataAccess;
  6. use Luticate\Auth\DBO\LuticateUsersDbo;
  7. class LuticateUsersBusiness extends LuBusiness {
  8. /**
  9. * @var LuticateUsersDbo
  10. */
  11. private static $_currentUser;
  12. const TOKEN_HEADER = "X-Authentication";
  13. public function __construct()
  14. {
  15. $this->dataAccess = new LuticateUsersDataAccess();
  16. }
  17. public static function getCurrentUser()
  18. {
  19. return self::$_currentUser;
  20. }
  21. /**
  22. * @param $permissions string[]
  23. * @param $request Request
  24. * @return bool
  25. */
  26. public static function authFilter($permissions, $request)
  27. {
  28. $token = $request->header(self::TOKEN_HEADER);
  29. if ($token != null && $token != "") {
  30. $data = JwtHelper::decode($token);
  31. if ($data != null) {
  32. $user_id = $data[JwtHelper::USER_KEY];
  33. self::$_currentUser = LuticateUsersBusiness::getById($user_id);
  34. }
  35. }
  36. if (self::$_currentUser == null && count($permissions) != 0) {
  37. return false;
  38. }
  39. foreach ($permissions as $permission) {
  40. if (!LuticatePermissionsBusiness::getUserPermission(self::$_currentUser->getId(), $permission)) {
  41. return false;
  42. }
  43. }
  44. return true;
  45. }
  46. }