/
AddBlockBlockTypeAccess.php
105 lines (92 loc) · 4.84 KB
/
AddBlockBlockTypeAccess.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
<?php
namespace Concrete\Core\Permission\Access;
use Database;
use Concrete\Core\Page\Page;
use PermissionKey;
class AddBlockBlockTypeAccess extends BlockTypeAccess
{
public function duplicate($newPA = false)
{
$newPA = parent::duplicate($newPA);
$db = Database::connection();
$r = $db->executeQuery('select * from BlockTypePermissionBlockTypeAccessList where paID = ?', array($this->getPermissionAccessID()));
while ($row = $r->FetchRow()) {
$v = array($row['peID'], $newPA->getPermissionAccessID(), $row['permission']);
$db->executeQuery('insert into BlockTypePermissionBlockTypeAccessList (peID, paID, permission) values (?, ?, ?)', $v);
}
$r = $db->executeQuery('select * from BlockTypePermissionBlockTypeAccessListCustom where paID = ?', array($this->getPermissionAccessID()));
while ($row = $r->FetchRow()) {
$v = array($row['peID'], $newPA->getPermissionAccessID(), $row['btID']);
$db->executeQuery('insert into BlockTypePermissionBlockTypeAccessListCustom (peID, paID, btID) values (?, ?, ?)', $v);
}
return $newPA;
}
public function save($args = array())
{
parent::save();
$db = Database::connection();
$db->executeQuery('delete from BlockTypePermissionBlockTypeAccessList where paID = ?', array($this->getPermissionAccessID()));
$db->executeQuery('delete from BlockTypePermissionBlockTypeAccessListCustom where paID = ?', array($this->getPermissionAccessID()));
if (!empty($args['blockTypesIncluded']) && is_array($args['blockTypesIncluded'])) {
foreach ($args['blockTypesIncluded'] as $peID => $permission) {
$v = array($this->getPermissionAccessID(), $peID, $permission);
$db->executeQuery('insert into BlockTypePermissionBlockTypeAccessList (paID, peID, permission) values (?, ?, ?)', $v);
}
}
if (!empty($args['blockTypesExcluded']) && is_array($args['blockTypesExcluded'])) {
foreach ($args['blockTypesExcluded'] as $peID => $permission) {
$v = array($this->getPermissionAccessID(), $peID, $permission);
$db->executeQuery('insert into BlockTypePermissionBlockTypeAccessList (paID, peID, permission) values (?, ?, ?)', $v);
}
}
if (!empty($args['btIDInclude']) && is_array($args['btIDInclude'])) {
foreach ($args['btIDInclude'] as $peID => $btIDs) {
foreach ($btIDs as $btID) {
$v = array($this->getPermissionAccessID(), $peID, $btID);
$db->executeQuery('insert into BlockTypePermissionBlockTypeAccessListCustom (paID, peID, btID) values (?, ?, ?)', $v);
}
}
}
if (!empty($args['btIDExclude']) && is_array($args['btIDExclude'])) {
foreach ($args['btIDExclude'] as $peID => $btIDs) {
foreach ($btIDs as $btID) {
$v = array($this->getPermissionAccessID(), $peID, $btID);
$db->executeQuery('insert into BlockTypePermissionBlockTypeAccessListCustom (paID, peID, btID) values (?, ?, ?)', $v);
}
}
}
}
public function getAccessListItems($accessType = PermissionKey::ACCESS_TYPE_INCLUDE, $filterEntities = array(), $checkCache = true)
{
if ($checkCache) {
$cache = \Core::make('cache/request');
$item = $cache->getItem($this->getCacheIdentifier($accessType, $filterEntities));
if (!$item->isMiss()) {
return $item->get();
}
$item->lock();
}
$db = Database::connection();
$list = parent::getAccessListItems($accessType, $filterEntities, false);
foreach ($list as $l) {
$pe = $l->getAccessEntityObject();
if (isset($this->permissionObjectToCheck) && ($this->permissionObjectToCheck instanceof Page) && ($l->getAccessType() == PermissionKey::ACCESS_TYPE_INCLUDE)) {
$permission = 'A';
} else {
$permission = $db->fetchColumn('select permission from BlockTypePermissionBlockTypeAccessList where paID = ? and peID = ?', array($l->getPermissionAccessID(), $pe->getAccessEntityID()));
if ($permission != 'N' && $permission != 'C') {
$permission = 'A';
}
}
$l->setBlockTypesAllowedPermission($permission);
if ($permission == 'C') {
$btIDs = $db->GetCol('select btID from BlockTypePermissionBlockTypeAccessListCustom where paID = ? and peID = ?', array($l->getPermissionAccessID(), $pe->getAccessEntityID()));
$l->setBlockTypesAllowedArray($btIDs);
}
}
if ($checkCache) {
$cache->save($item->set($list));
}
return $list;
}
}