Файл: concrete5.7.5.6/concrete/src/Permission/Access/Entity/FileUploaderEntity.php
Строк: 82
<?php
namespace ConcreteCorePermissionAccessEntity;
use Loader;
use PermissionAccess;
use URL;
use Config;
use UserInfo;
use User;
use ConcreteCorePermissionAccessFileSetAccess as FileSetPermissionAccess;
use ConcreteCorePermissionAccessFileAccess as FilePermissionAccess;
class FileUploaderEntity extends Entity {
public function getAccessEntityUsers(PermissionAccess $pa) {
$f = $pa->getPermissionObject();
if (is_object($f) && ($f instanceof File)) {
return UserInfo::getByID($f->getUserID());
}
}
public function validate(PermissionAccess $pae) {
if ($pae instanceof FileSetPermissionAccess) {
return true;
}
if ($pae instanceof FilePermissionAccess) {
$f = $pae->getPermissionObject();
if (is_object($f)) {
$u = new User();
return $u->getUserID() == $f->getUserID();
}
}
return false;
}
public function getAccessEntityTypeLinkHTML() {
$html = '<a href="javascript:void(0)" onclick="ccm_choosePermissionAccessEntityFileUploader()">' . tc('PermissionAccessEntityTypeName', 'File Uploader') . '</a>';
return $html;
}
public static function getAccessEntitiesForUser($user) {
$entities = array();
$db = Loader::db();
if ($user->isRegistered()) {
$pae = static::getOrCreate();
$r = $db->GetOne('select fID from Files where uID = ?', array($user->getUserID()));
if ($r > 0) {
$entities[] = $pae;
}
}
return $entities;
}
public static function getOrCreate() {
$db = Loader::db();
$petID = $db->GetOne('select petID from PermissionAccessEntityTypes where petHandle = 'file_uploader'');
$peID = $db->GetOne('select peID from PermissionAccessEntities where petID = ?',
array($petID));
if (!$peID) {
$db->Execute("insert into PermissionAccessEntities (petID) values(?)", array($petID));
$peID = $db->Insert_ID();
Config::save('concrete.misc.access_entity_updated', time());
}
return ConcreteCorePermissionAccessEntityEntity::getByID($peID);
}
public function load() {
$this->label = t('File Uploader');
}
}