Вход Регистрация
Файл: base-sys/base/bol/authorization_role_dao.php
Строк: 95
<?php

class BOL_AuthorizationRoleDao extends PEEP_BaseDao
{
    const 
GUEST 'guest';

    
/**
     * Constructor.
     *
     */
    
protected function __construct()
    {
        
parent::__construct();
    }
    
/**
     * Singleton instance.
     *
     * @var BOL_AuthorizationRoleDao
     */
    
private static $classInstance;

    
/**
     * Returns an instance of class (singleton pattern implementation).
     *
     * @return BOL_AuthorizationRoleDao
     */
    
public static function getInstance()
    {
        if ( 
self::$classInstance === null )
        {
            
self::$classInstance = new self();
        }

        return 
self::$classInstance;
    }

    
/**
     * @see PEEP_BaseDao::getDtoClassName()
     *
     */
    
public function getDtoClassName()
    {
        return 
'BOL_AuthorizationRole';
    }

    
/**
     * @see PEEP_BaseDao::getTableName()
     *
     */
    
public function getTableName()
    {
        return 
PEEP_DB_PREFIX 'base_authorization_role';
    }

    public function 
getGuestRoleId()
    {
        
$ex = new PEEP_Example();
        
$ex->andFieldEqual('name'self::GUEST);

        return 
$this->findIdByExample($ex);
    }

    public function 
findNonGuestRoleList()
    {
        
$ex = new PEEP_Example();
        
$ex->andFieldNotEqual('id'$this->getGuestRoleId())
            ->
setOrder('sortOrder ASC');

        return 
$this->findListByExample($ex);
    }

    public function 
findDefault()
    {
        
$query "SELECT * FROM `{$this->getTableName()}` WHERE `sortOrder` != 0 ORDER BY `sortOrder` ASC limit 1";

        return 
$this->dbo->queryForObject($query$this->getDtoClassName());
    }

    public function 
findMaxOrder()
    {
        
$query "SELECT MAX(`sortOrder`) FROM `{$this->getTableName()}`";

        return 
$this->dbo->queryForColumn($query);
    }

    public function 
findUserRoleList$userId )
    {
        
$query "SELECT `r`.* FROM `{$this->getTableName()}` as `r`
        INNER JOIN `" 
BOL_AuthorizationUserRoleDao::getInstance()->getTableName() . "` as `ur`
            ON(`r`.`id` = `ur`.`roleId`)
        WHERE `ur`.`userId` = ? ORDER BY `sortOrder` ASC
        "
;

        return 
$this->dbo->queryForObjectList($query$this->getDtoClassName(), array($userId));
    }

    protected function 
clearCache()
    {
        
PEEP::getCacheManager()->clean(array(BOL_AuthorizationActionDao::CACHE_TAG_AUTHORIZATION));
    }

    public function 
findAll$cacheLifeTime 0$tags = array() )
    {
        
$example = new PEEP_Example();
        
$example->setOrder('`sortOrder` ASC');
        
        return 
$this->findListByExample($example3600 24, array(BOL_AuthorizationActionDao::CACHE_TAG_AUTHORIZATIONPEEP_CacheManager::TAG_OPTION_INSTANT_LOAD));
    }
}
Онлайн: 0
Реклама