PageRenderTime 41ms CodeModel.GetById 15ms RepoModel.GetById 0ms app.codeStats 0ms

/web/concrete/core/models/permission/keys/custom/edit_page_theme.php

https://github.com/glockops/concrete5
PHP | 56 lines | 46 code | 10 blank | 0 comment | 14 complexity | 8479f39ddee43274e11c2930422c04e8 MD5 | raw file
Possible License(s): MIT, LGPL-2.1, BSD-3-Clause
  1. <?
  2. defined('C5_EXECUTE') or die("Access Denied.");
  3. class Concrete5_Model_EditPageThemePagePermissionKey extends PagePermissionKey {
  4. protected function getAllowedThemeIDs() {
  5. $u = new User();
  6. $pae = $this->getPermissionAccessObject();
  7. if (!is_object($pae)) {
  8. return array();
  9. }
  10. $accessEntities = $u->getUserAccessEntityObjects();
  11. $accessEntities = $pae->validateAndFilterAccessEntities($accessEntities);
  12. $list = $this->getAccessListItems(PagePermissionKey::ACCESS_TYPE_ALL, $accessEntities);
  13. $list = PermissionDuration::filterByActive($list);
  14. $db = Loader::db();
  15. $allptIDs = $db->GetCol('select ptID from PageThemes order by ptID asc');
  16. $ptIDs = array();
  17. foreach($list as $l) {
  18. if ($l->getThemesAllowedPermission() == 'N') {
  19. $ptIDs = array();
  20. }
  21. if ($l->getThemesAllowedPermission() == 'C') {
  22. if ($l->getAccessType() == PagePermissionKey::ACCESS_TYPE_EXCLUDE) {
  23. $ptIDs = array_values(array_diff($ptIDs, $l->getThemesAllowedArray()));
  24. } else {
  25. $ptIDs = array_unique(array_merge($ptIDs, $l->getThemesAllowedArray()));
  26. }
  27. }
  28. if ($l->getThemesAllowedPermission() == 'A') {
  29. $ptIDs = $allptIDs;
  30. }
  31. }
  32. return $ptIDs;
  33. }
  34. public function validate($theme = false) {
  35. $u = new User();
  36. if ($u->isSuperUser()) {
  37. return true;
  38. }
  39. $themes = $this->getAllowedThemeIDs();
  40. if ($theme != false) {
  41. return in_array($theme->getThemeID(), $themes);
  42. } else {
  43. return count($themes) > 0;
  44. }
  45. }
  46. }