/
PageOwnerEntity.php
93 lines (82 loc) · 3.04 KB
/
PageOwnerEntity.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
<?php
namespace Concrete\Core\Permission\Access\Entity;
use Concrete\Core\Support\Facade\Application;
use Concrete\Core\Page\Page;
use Database;
use Concrete\Core\Permission\Access\Access as PermissionAccess;
use Config;
use UserInfo;
use Concrete\Core\Permission\Access\PageAccess as PagePermissionAccess;
use Concrete\Core\Permission\Access\AreaAccess as AreaPermissionAccess;
use Concrete\Core\Permission\Access\BlockAccess as BlockPermissionAccess;
use Concrete\Core\User\User;
class PageOwnerEntity extends Entity
{
public function getAccessEntityUsers(PermissionAccess $pae)
{
$c = null;
if ($pae instanceof PagePermissionAccess) {
$c = $pae->getPermissionObject();
} else {
if ($pae instanceof AreaPermissionAccess) {
$c = $pae->getPermissionObject()->getAreaCollectionObject();
} else {
if ($pae instanceof BlockPermissionAccess) {
$a = $pae->getPermissionObject()->getBlockAreaObject();
$c = $a->getAreaCollectionObject();
}
}
}
if (is_object($c) && ($c instanceof Page)) {
$ui = UserInfo::getByID($c->getCollectionUserID());
if ($ui) {
return [$ui];
}
}
}
public function validate(PermissionAccess $pae)
{
$users = $this->getAccessEntityUsers($pae);
if (empty($users)) {
return false;
} else {
$u = Application::getFacadeApplication()->make(User::class);
return $users[0]->getUserID() == $u->getUserID();
}
}
public function getAccessEntityTypeLinkHTML()
{
$html = '<a href="javascript:void(0)" class="dropdown-item " onclick="ccm_choosePermissionAccessEntityPageOwner()">' . tc('PermissionAccessEntityTypeName',
'Page Owner') . '</a>';
return $html;
}
public static function getAccessEntitiesForUser($user)
{
$entities = array();
if ($user->isRegistered()) {
$db = Database::connection();
$pae = static::getOrCreate();
$r = $db->fetchColumn('select cID from Pages where uID = ?', array($user->getUserID()));
if ($r > 0) {
$entities[] = $pae;
}
}
return $entities;
}
public static function getOrCreate()
{
$db = Database::connection();
$petID = $db->fetchColumn('select petID from PermissionAccessEntityTypes where petHandle = \'page_owner\'');
$peID = $db->fetchColumn('select peID from PermissionAccessEntities where petID = ?', array($petID));
if (!$peID) {
$db->executeQuery("insert into PermissionAccessEntities (petID) values(?)", array($petID));
$peID = $db->lastInsertId();
Config::save('concrete.misc.access_entity_updated', time());
}
return \Concrete\Core\Permission\Access\Entity\Entity::getByID($peID);
}
public function load()
{
$this->label = t('Page Owner');
}
}