Пример #1
0
 public function initialize(Controller $controller)
 {
     $this->controller = $controller;
     if (1 == $controller->Auth->user('role_id') && isset($controller->params['admin'])) {
         $Model =& $controller->{$controller->modelClass};
         if ($Model->Behaviors->attached('SiteFilter')) {
             $Model->Behaviors->SiteFilter->disableFilter($Model);
         }
     }
     $site = Sites::currentSite();
 }
Пример #2
0
 public function initialize(Controller $controller, $settings = array())
 {
     if (1 == $controller->Auth->user('role_id') && isset($controller->params['admin'])) {
         if ($controller->{$controller->modelClass}) {
             $Model =& $controller->{$controller->modelClass};
             if ($Model instanceof Model && $Model->useTable && $Model->Behaviors->attached('SiteFilter')) {
                 $Model->Behaviors->SiteFilter->disableFilter($Model);
             }
         }
     }
     $site = Sites::currentSite();
 }
Пример #3
0
 public function beforeFind(Model $model, $query)
 {
     if ($this->settings[$model->alias]['enabled'] === false) {
         return $query;
     }
     $this->_setupRelationships($model, $this->settings[$model->alias]);
     $site = Sites::currentSite();
     $sites = array(Sites::ALL_SITES);
     if ($site) {
         $sites = array_unique(array(Sites::ALL_SITES, $site['Site']['id']));
     }
     $setting = Set::merge(array('relationship' => array(), 'joins' => array()), $this->settings[$model->alias]);
     extract($setting);
     if (!empty($joins)) {
         foreach ($joins as $join => &$joinConfig) {
             if (empty($joinConfig)) {
                 continue;
             }
             // link to Site model
             $foreignKey = $joinConfig['alias'] . '.site_id';
             if (empty($joinConfig['conditions'][$foreignKey])) {
                 $joinConfig['conditions'][$foreignKey] = $sites;
             }
             $foreignKey = $joinConfig['alias'] . '.' . Inflector::underscore($model->alias) . '_id';
             $condition = "{$model->alias}.{$model->primaryKey} = {$foreignKey}";
             if (!in_array($condition, $joinConfig['conditions'])) {
                 $joinConfig['conditions'][] = $condition;
             }
         }
     }
     if (!empty($query['joins'])) {
         $joins = Set::merge($query['joins'], $joins);
     }
     if (!empty($relationship) && $this->settings[$model->alias]['filter']) {
         $relation = key($relationship);
         $foreignKey = $model->{$relation}['Site']['foreignKey'];
         switch ($relation) {
             case 'belongsTo':
                 $query['conditions'][$model->alias . '.' . $foreignKey] = $sites;
                 break;
             case 'hasAndBelongsToMany':
             default:
                 $with = $model->{$relation}['Site']['with'];
                 if (strpos($with, '.') !== false) {
                     list($pluginName, $with) = pluginSplit($with);
                 }
                 $joinModel = $model->{$with};
                 $ds = $joinModel->getDataSource();
                 $associationForeignKey = $model->{$relation}['Site']['associationForeignKey'];
                 $currentJoins = Set::extract('{n}.alias', $joins);
                 if (!empty($currentJoins) && in_array($joinModel->alias, $currentJoins)) {
                     break;
                 }
                 $joins[] = array('type' => 'LEFT', 'table' => $ds->fullTableName($joinModel, true, true), 'alias' => $joinModel->alias, 'conditions' => array("{$model->alias}.{$model->primaryKey} = {$joinModel->alias}.{$foreignKey}"));
                 if (is_string($query['conditions'])) {
                     $query['conditions'] = array($query['conditions'], $joinModel->alias . '.' . $associationForeignKey => $sites);
                 } else {
                     $query['conditions'][$joinModel->alias . '.' . $associationForeignKey] = $sites;
                 }
                 break;
         }
     }
     $query['joins'] = $joins;
     unset($query['recursive']);
     return $query;
 }