PageRenderTime 49ms CodeModel.GetById 20ms RepoModel.GetById 1ms app.codeStats 0ms

/concrete/core/models/permission/access/categories/custom/add_subpage.php

https://bitbucket.org/selfeky/xclusivescardwebsite
PHP | 95 lines | 86 code | 9 blank | 0 comment | 16 complexity | 05fec59d4df88a8f4a6c46bbc12d2607 MD5 | raw file
  1. <?php
  2. defined('C5_EXECUTE') or die("Access Denied.");
  3. class Concrete5_Model_AddSubpagePagePermissionAccess extends PagePermissionAccess {
  4. public function duplicate($newPA = false) {
  5. $newPA = parent::duplicate($newPA);
  6. $db = Loader::db();
  7. $r = $db->Execute('select * from PagePermissionPageTypeAccessList where paID = ?', array($this->getPermissionAccessID()));
  8. while ($row = $r->FetchRow()) {
  9. $v = array($row['peID'], $newPA->getPermissionAccessID(), $row['permission'], $row['externalLink']);
  10. $db->Execute('insert into PagePermissionPageTypeAccessList (peID, paID, permission, externalLink) values (?, ?, ?, ?)', $v);
  11. }
  12. $r = $db->Execute('select * from PagePermissionPageTypeAccessListCustom where paID = ?', array($this->getPermissionAccessID()));
  13. while ($row = $r->FetchRow()) {
  14. $v = array($row['peID'], $newPA->getPermissionAccessID(), $row['ctID']);
  15. $db->Execute('insert into PagePermissionPageTypeAccessListCustom (peID, paID, ctID) values (?, ?, ?)', $v);
  16. }
  17. return $newPA;
  18. }
  19. public function save($args) {
  20. parent::save();
  21. $db = Loader::db();
  22. $db->Execute('delete from PagePermissionPageTypeAccessList where paID = ?', array($this->getPermissionAccessID()));
  23. $db->Execute('delete from PagePermissionPageTypeAccessListCustom where paID = ?', array($this->getPermissionAccessID()));
  24. if (is_array($args['pageTypesIncluded'])) {
  25. foreach($args['pageTypesIncluded'] as $peID => $permission) {
  26. $ext = 0;
  27. if (!empty($args['allowExternalLinksIncluded'][$peID])) {
  28. $ext = $args['allowExternalLinksIncluded'][$peID];
  29. }
  30. $v = array($this->getPermissionAccessID(), $peID, $permission, $ext);
  31. $db->Execute('insert into PagePermissionPageTypeAccessList (paID, peID, permission, externalLink) values (?, ?, ?, ?)', $v);
  32. }
  33. }
  34. if (is_array($args['pageTypesExcluded'])) {
  35. foreach($args['pageTypesExcluded'] as $peID => $permission) {
  36. $ext = 0;
  37. if (!empty($args['allowExternalLinksExcluded'][$peID])) {
  38. $ext = $args['allowExternalLinksExcluded'][$peID];
  39. }
  40. $v = array($this->getPermissionAccessID(), $peID, $permission, $ext);
  41. $db->Execute('insert into PagePermissionPageTypeAccessList (paID, peID, permission, externalLink) values (?, ?, ?, ?)', $v);
  42. }
  43. }
  44. if (is_array($args['ctIDInclude'])) {
  45. foreach($args['ctIDInclude'] as $peID => $ctIDs) {
  46. foreach($ctIDs as $ctID) {
  47. $v = array($this->getPermissionAccessID(), $peID, $ctID);
  48. $db->Execute('insert into PagePermissionPageTypeAccessListCustom (paID, peID, ctID) values (?, ?, ?)', $v);
  49. }
  50. }
  51. }
  52. if (is_array($args['ctIDExclude'])) {
  53. foreach($args['ctIDExclude'] as $peID => $ctIDs) {
  54. foreach($ctIDs as $ctID) {
  55. $v = array($this->getPermissionAccessID(), $peID, $ctID);
  56. $db->Execute('insert into PagePermissionPageTypeAccessListCustom (paID, peID, ctID) values (?, ?, ?)', $v);
  57. }
  58. }
  59. }
  60. }
  61. public function getAccessListItems($accessType = PagePermissionKey::ACCESS_TYPE_INCLUDE, $filterEntities = array()) {
  62. $db = Loader::db();
  63. $list = parent::getAccessListItems($accessType, $filterEntities);
  64. $list = PermissionDuration::filterByActive($list);
  65. foreach($list as $l) {
  66. $pe = $l->getAccessEntityObject();
  67. $prow = $db->GetRow('select permission, externalLink from PagePermissionPageTypeAccessList where peID = ? and paID = ?', array($pe->getAccessEntityID(), $l->getPermissionAccessID()));
  68. if (is_array($prow) && $prow['permission']) {
  69. $l->setPageTypesAllowedPermission($prow['permission']);
  70. $l->setAllowExternalLinks($prow['externalLink']);
  71. $permission = $prow['permission'];
  72. } else if ($l->getAccessType() == PagePermissionKey::ACCESS_TYPE_INCLUDE) {
  73. $l->setPageTypesAllowedPermission('A');
  74. $l->setAllowExternalLinks(1);
  75. } else {
  76. $l->setPageTypesAllowedPermission('N');
  77. $l->setAllowExternalLinks(0);
  78. }
  79. if ($permission == 'C') {
  80. $ctIDs = $db->GetCol('select ctID from PagePermissionPageTypeAccessListCustom where peID = ? and paID = ?', array($pe->getAccessEntityID(), $l->getPermissionAccessID()));
  81. $l->setPageTypesAllowedArray($ctIDs);
  82. }
  83. }
  84. return $list;
  85. }
  86. }