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.

LuticatePermissionsBusiness.php 3.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. <?php
  2. namespace Luticate\Auth\Business;
  3. use Luticate\Utils\LuBusiness;
  4. use Luticate\Auth\DataAccess\LuticatePermissionsDataAccess;
  5. use Luticate\Auth\DBO\LuticatePermissionsDbo;
  6. class LuticatePermissionsBusiness extends LuBusiness {
  7. protected static function getDataAccess()
  8. {
  9. return new LuticatePermissionsDataAccess();
  10. }
  11. public static function checkPermissionName($permission_name)
  12. {
  13. $perm = LuticatePermissionsDataAccess::getByName($permission_name);
  14. if (is_null($perm)) {
  15. self::notFound("Permission not found");
  16. }
  17. return $perm;
  18. }
  19. public static function getEffectivePermission($user_id, $permission_name)
  20. {
  21. self::checkPermissionName($permission_name);
  22. $val = LuticatePermissionsDataAccess::getEffectivePermission($user_id, $permission_name);
  23. $perm = new LuticatePermissionsDbo();
  24. $perm->setValue($val);
  25. $perm->setName($permission_name);
  26. return $perm;
  27. }
  28. public static function getAllEffectivePermission($user_id)
  29. {
  30. return LuticatePermissionsDataAccess::getAllEffectivePermission($user_id);
  31. }
  32. public static function getEffectivePermissionMe($user, $permission_name)
  33. {
  34. return self::getEffectivePermission($user->getId(), $permission_name);
  35. }
  36. public static function getAllEffectivePermissionMe($user)
  37. {
  38. return self::getAllEffectivePermission($user->getId());
  39. }
  40. public static function getEffectiveDynamicPermission($user_id, $permission_name, $resource_id)
  41. {
  42. $dynamic_permission_name = "LU_DYN_" . $permission_name . "_" . $resource_id;
  43. $val = self::getEffectivePermission($user_id, $dynamic_permission_name);
  44. if (is_null($val->getValue())) {
  45. return self::getEffectivePermission($user_id, $permission_name);
  46. }
  47. return $val;
  48. }
  49. public static function get($permission_name)
  50. {
  51. $perm = LuticatePermissionsDataAccess::getByName($permission_name);
  52. if (is_null($perm)) {
  53. self::notFound("Permission not found");
  54. }
  55. return $perm;
  56. }
  57. public static function add($permission_name, $permission_value)
  58. {
  59. $perm = LuticatePermissionsDataAccess::getByName($permission_name);
  60. if (is_null($perm)) {
  61. $perm = new LuticatePermissionsDbo();
  62. $perm->setName($permission_name);
  63. $perm->setValue($permission_value);
  64. LuticatePermissionsDataAccess::add($perm);
  65. return true;
  66. }
  67. self::badInput("Permission name already exists");
  68. return false;
  69. }
  70. public static function del($permission_name)
  71. {
  72. LuticatePermissionsDataAccess::delete($permission_name);
  73. return true;
  74. }
  75. public static function edit($permission_name, $permission_value)
  76. {
  77. self::checkPermissionName($permission_name);
  78. LuticatePermissionsDataAccess::edit($permission_name, $permission_value);
  79. return true;
  80. }
  81. }