Вход Регистрация
Файл: concrete5.7.5.6/concrete/src/Permission/Access/EditPageThemePageAccess.php
Строк: 107
<?php

namespace ConcreteCorePermissionAccess;

use 
ConcreteCorePermissionDuration as PermissionDuration;
use 
Database;
use 
ConcreteCorePermissionKeyPageKey as PagePermissionKey;

class 
EditPageThemePageAccess extends PageAccess
{
    public function 
duplicate($newPA false)
    {
        
$newPA parent::duplicate($newPA);
        
$db Database::connection();
        
$r $db->executeQuery('select * from PagePermissionThemeAccessList where paID = ?', array($this->getPermissionAccessID()));
        while (
$row $r->FetchRow()) {
            
$v = array($row['peID'], $newPA->getPermissionAccessID(), $row['permission']);
            
$db->executeQuery('insert into PagePermissionThemeAccessList (peID, paID, permission) values (?, ?, ?)'$v);
        }
        
$r $db->executeQuery('select * from PagePermissionThemeAccessListCustom where paID = ?', array($this->getPermissionAccessID()));
        while (
$row $r->FetchRow()) {
            
$v = array($row['peID'], $newPA->getPermissionAccessID(), $row['pThemeID']);
            
$db->executeQuery('insert into PagePermissionThemeAccessListCustom  (peID, paID, pThemeID) values (?, ?, ?)'$v);
        }

        return 
$newPA;
    }

    public function 
save($args = array())
    {
        
parent::save();
        
$db Database::connection();
        
$db->executeQuery('delete from PagePermissionThemeAccessList where paID = ?', array($this->getPermissionAccessID()));
        
$db->executeQuery('delete from PagePermissionThemeAccessListCustom where paID = ?', array($this->getPermissionAccessID()));
        if (
is_array($args['themesIncluded'])) {
            foreach (
$args['themesIncluded'] as $peID => $permission) {
                
$v = array($this->getPermissionAccessID(), $peID$permission);
                
$db->executeQuery('insert into PagePermissionThemeAccessList (paID, peID, permission) values (?, ?, ?)'$v);
            }
        }

        if (
is_array($args['themesExcluded'])) {
            foreach (
$args['themesExcluded'] as $peID => $permission) {
                
$v = array($this->getPermissionAccessID(), $peID$permission);
                
$db->executeQuery('insert into PagePermissionThemeAccessList (paID, peID, permission) values (?, ?, ?)'$v);
            }
        }

        if (
is_array($args['pThemeIDInclude'])) {
            foreach (
$args['pThemeIDInclude'] as $peID => $pThemeIDs) {
                foreach (
$pThemeIDs as $pThemeID) {
                    
$v = array($this->getPermissionAccessID(), $peID$pThemeID);
                    
$db->executeQuery('insert into PagePermissionThemeAccessListCustom (paID, peID, pThemeID) values (?, ?, ?)'$v);
                }
            }
        }

        if (
is_array($args['pThemeIDExclude'])) {
            foreach (
$args['pThemeIDExclude'] as $peID => $pThemeIDs) {
                foreach (
$pThemeIDs as $pThemeID) {
                    
$v = array($this->getPermissionAccessID(), $peID$pThemeID);
                    
$db->executeQuery('insert into PagePermissionThemeAccessListCustom (paID, peID, pThemeID) values (?, ?, ?)'$v);
                }
            }
        }
    }

    public function 
getAccessListItems($accessType PagePermissionKey::ACCESS_TYPE_INCLUDE$filterEntities = array())
    {
        
$db Database::connection();
        
$list parent::getAccessListItems($accessType$filterEntities);
        
$list PermissionDuration::filterByActive($list);
        foreach (
$list as $l) {
            
$pe $l->getAccessEntityObject();
            
$prow $db->GetRow('select permission from PagePermissionThemeAccessList where peID = ? and paID = ?', array($pe->getAccessEntityID(), $l->getPermissionAccessID()));
            if (
is_array($prow) && $prow['permission']) {
                
$l->setThemesAllowedPermission($prow['permission']);
                
$permission $prow['permission'];
                if (
$permission == 'C') {
                    
$pThemeIDs $db->GetCol('select pThemeID from PagePermissionThemeAccessListCustom where peID = ? and paID = ?', array($pe->getAccessEntityID(), $l->getPermissionAccessID()));
                    
$l->setThemesAllowedArray($pThemeIDs);
                }
            } elseif (
$l->getAccessType() == PagePermissionKey::ACCESS_TYPE_INCLUDE) {
                
$l->setThemesAllowedPermission('A');
            } else {
                
$l->setThemesAllowedPermission('N');
            }
        }

        return 
$list;
    }
}
Онлайн: 1
Реклама