PageRenderTime 43ms CodeModel.GetById 17ms RepoModel.GetById 1ms app.codeStats 0ms

/concrete/core/models/permission/keys/custom/access_user_search.php

https://bitbucket.org/selfeky/xclusivescardwebsite
PHP | 112 lines | 97 code | 15 blank | 0 comment | 36 complexity | 7caa2d7f770b552677bf4ba23dd16568 MD5 | raw file
  1. <?php
  2. defined('C5_EXECUTE') or die("Access Denied.");
  3. class Concrete5_Model_AccessUserSearchUserPermissionKey extends UserPermissionKey {
  4. protected function getAllowedGroupIDs($list = false) {
  5. if (!$list) {
  6. $u = new User();
  7. $accessEntities = $u->getUserAccessEntityObjects();
  8. $list = $this->getAccessListItems(PermissionKey::ACCESS_TYPE_ALL, $accessEntities);
  9. $list = PermissionDuration::filterByActive($list);
  10. }
  11. $db = Loader::db();
  12. $dsh = Loader::helper('concrete/dashboard');
  13. $allgIDs = $db->GetCol('select gID from Groups');
  14. $gIDs = array();
  15. foreach($list as $l) {
  16. if ($l->getGroupsAllowedPermission() == 'N') {
  17. $gIDs = array();
  18. }
  19. if ($l->getGroupsAllowedPermission() == 'C') {
  20. if ($l->getAccessType() == PermissionKey::ACCESS_TYPE_EXCLUDE) {
  21. $gIDs = array_values(array_diff($gIDs, $l->getGroupsAllowedArray()));
  22. } else {
  23. $gIDs = array_unique(array_merge($gIDs, $l->getGroupsAllowedArray()));
  24. }
  25. }
  26. if ($l->getGroupsAllowedPermission() == 'A') {
  27. $gIDs = $allgIDs;
  28. }
  29. }
  30. return $gIDs;
  31. }
  32. public function getMyAssignment() {
  33. $u = new User();
  34. $asl = new AccessUserSearchUserPermissionAccessListItem();
  35. if ($u->isSuperUser()) {
  36. $asl->setGroupsAllowedPermission('A');
  37. return $asl;
  38. }
  39. $pae = $this->getPermissionAccessObject();
  40. if (!is_object($pae)) {
  41. return $asl;
  42. }
  43. $accessEntities = $u->getUserAccessEntityObjects();
  44. $accessEntities = $pae->validateAndFilterAccessEntities($accessEntities);
  45. $list = $this->getAccessListItems(UserPermissionKey::ACCESS_TYPE_ALL, $accessEntities);
  46. $list = PermissionDuration::filterByActive($list);
  47. $u = new User();
  48. foreach($list as $l) {
  49. if ($l->getGroupsAllowedPermission() == 'N') {
  50. $asl->setGroupsAllowedPermission('N');
  51. }
  52. if ($l->getGroupsAllowedPermission() == 'C') {
  53. $asl->setGroupsAllowedPermission('C');
  54. }
  55. if ($l->getGroupsAllowedPermission() == 'A') {
  56. $asl->setGroupsAllowedPermission('A');
  57. }
  58. }
  59. if ($asl->getGroupsAllowedPermission() == 'C') {
  60. $asl->setGroupsAllowedArray($this->getAllowedGroupIDs());
  61. }
  62. return $asl;
  63. }
  64. public function validate($obj = false) {
  65. $u = new User();
  66. if ($u->isSuperUser()) {
  67. return true;
  68. }
  69. if (is_object($obj) && $obj instanceof UserInfo) {
  70. $db = Loader::db();
  71. $asl = $this->getMyAssignment();
  72. if ($asl->getGroupsAllowedPermission() == 'A') {
  73. return true;
  74. } else if ($asl->getGroupsAllowedPermission() == 'C') {
  75. if (in_array(REGISTERED_GROUP_ID, $asl->getGroupsAllowedArray())) {
  76. $cnt = $db->GetOne('select count(u.uID) from Users u left join UserGroups ug on u.uID = ug.uID where u.uID = ? and u.uID > ' . USER_SUPER_ID . ' and (gID is null or gID in (' . implode(',', $asl->getGroupsAllowedArray()) . '))', array($obj->getUserID()));
  77. } else {
  78. $cnt = $db->GetOne('select count(u.uID) from Users u left join UserGroups ug on u.uID = ug.uID where u.uID = ? and u.uID > ' . USER_SUPER_ID . ' and gID in (' . implode(',', $asl->getGroupsAllowedArray()) . ')', array($obj->getUserID()));
  79. }
  80. return $cnt > 0;
  81. } else {
  82. return false;
  83. }
  84. }
  85. $types = $this->getAllowedGroupIDs();
  86. if ($obj != false) {
  87. if (is_object($obj)) {
  88. $gID = $obj->getGroupID();
  89. } else {
  90. $gID = $obj;
  91. }
  92. return in_array($gID, $types);
  93. } else {
  94. return count($types) > 0;
  95. }
  96. }
  97. }