コード例 #1
0
 /**
  * Приводит название сущности к единому формату полного имени класса
  * Если используется наследование, то возвращается корневой класс
  * $sEntity может содержать как короткое имя сущности (без плагина и модуля), так и полное
  *
  * @param string|object|null $sEntity
  *
  * @return string
  */
 protected function _NormalizeEntityRootName($sEntity)
 {
     /**
      * Если передан объект сущности, то просто возвращаем ее корневой класс
      */
     if (is_object($sEntity)) {
         return $this->Plugin_GetRootDelegater('entity', get_class($sEntity));
     }
     /**
      * Разбиваем сущность на составляющие
      */
     if (is_null($sEntity)) {
         $sPluginPrefix = Engine::GetPluginPrefix($this);
         $sModuleName = Engine::GetModuleName($this);
         $sEntityName = Engine::GetEntityName($this) ?: $sModuleName;
     } elseif (substr_count($sEntity, '_')) {
         $sPluginPrefix = Engine::GetPluginPrefix($sEntity);
         $sModuleName = Engine::GetModuleName($sEntity);
         $sEntityName = Engine::GetEntityName($sEntity);
     } else {
         $sPluginPrefix = Engine::GetPluginPrefix($this);
         $sModuleName = Engine::GetModuleName($this);
         $sEntityName = $sEntity;
     }
     /**
      * Получаем корневой модуль
      */
     $sModuleRoot = $this->Plugin_GetRootDelegater('module', $sPluginPrefix . 'Module' . $sModuleName);
     /**
      * Возвращаем корневую сущность
      */
     return $this->Plugin_GetRootDelegater('entity', $sModuleRoot . '_Entity' . $sEntityName);
 }
コード例 #2
0
ファイル: ModuleORM.class.php プロジェクト: narush/livestreet
 /**
  * Получить число сущностей по связанной таблице
  *
  * @param unknown_type $aJoinData
  * @param unknown_type $sEntityFull
  * @return unknown
  */
 public function GetCountItemsByJoinTable($aJoinData = array(), $sEntityFull = null)
 {
     if (is_null($sEntityFull)) {
         $sEntityFull = Engine::GetPluginPrefix($this) . 'Module' . Engine::GetModuleName($this) . '_Entity' . Engine::GetModuleName(get_class($this));
     } elseif (!substr_count($sEntityFull, '_')) {
         $sEntityFull = Engine::GetPluginPrefix($this) . 'Module' . Engine::GetModuleName($this) . '_Entity' . $sEntityFull;
     }
     // Если параметр #cache указан и пуст, значит игнорируем кэширование для запроса
     if (array_key_exists('#cache', $aJoinData) && !$aJoinData['#cache']) {
         $iCount = $this->oMapperORM->GetCountItemsByJoinTable($aJoinData, $sEntityFull);
     } else {
         $sEntityFullRoot = $this->Plugin_GetRootDelegater('entity', $sEntityFull);
         $sCacheKey = $sEntityFullRoot . '_count_items_by_join_table_' . serialize($aJoinData);
         $aCacheTags = array();
         $iCacheTime = 60 * 60 * 24;
         // скорее лучше хранить в свойстве сущности, для возможности выборочного переопределения
         // переопределяем из параметров
         if (isset($aJoinData['#cache'][0])) {
             $sCacheKey = $aJoinData['#cache'][0];
         }
         if (isset($aJoinData['#cache'][1])) {
             $aCacheTags = $aJoinData['#cache'][1];
         }
         if (isset($aJoinData['#cache'][2])) {
             $iCacheTime = $aJoinData['#cache'][2];
         }
         $aCacheTags[] = 'm2m_' . $aJoinData['#relation_key'] . $aJoinData['#by_key'] . $aJoinData['#by_value'];
         if (false === ($iCount = $this->Cache_Get($sCacheKey))) {
             $iCount = $this->oMapperORM->GetCountItemsByJoinTable($aJoinData, $sEntityFull);
             $this->Cache_Set($iCount, $sCacheKey, $aCacheTags, $iCacheTime);
         }
     }
     return $iCount;
 }
コード例 #3
0
ファイル: EntityORM.class.php プロジェクト: narush/livestreet
 /**
  * Вызов методов сущности
  *
  * @param unknown_type $sName
  * @param unknown_type $aArgs
  * @return unknown
  */
 public function __call($sName, $aArgs)
 {
     $sType = substr($sName, 0, strpos(func_underscore($sName), '_'));
     if (!strpos($sName, '_') and in_array($sType, array('get', 'set', 'reload'))) {
         $sKey = func_underscore(preg_replace('/' . $sType . '/', '', $sName, 1));
         if ($sType == 'get') {
             if (isset($this->_aData[$sKey])) {
                 return $this->_aData[$sKey];
             } else {
                 $sField = $this->_getField($sKey);
                 if ($sField != $sKey && isset($this->_aData[$sField])) {
                     return $this->_aData[$sField];
                 }
             }
             /**
              * Проверяем на связи
              */
             if (array_key_exists($sKey, $this->aRelations)) {
                 $sEntityRel = $this->aRelations[$sKey][1];
                 $sRelationType = $this->aRelations[$sKey][0];
                 $sRelationKey = $this->aRelations[$sKey][2];
                 $sRelationJoinTable = null;
                 $sRelationJoinTableKey = 0;
                 // foreign key в join-таблице для текущей сущности
                 if ($sRelationType == self::RELATION_TYPE_MANY_TO_MANY && array_key_exists(3, $this->aRelations[$sKey])) {
                     $sRelationJoinTable = $this->aRelations[$sKey][3];
                     $sRelationJoinTableKey = isset($this->aRelations[$sKey][4]) ? $this->aRelations[$sKey][4] : $this->_getPrimaryKey();
                 }
                 /**
                  * Если связь уже загруженна, то возвращаем сразу результат
                  */
                 if (array_key_exists($sKey, $this->aRelationsData)) {
                     return $this->aRelationsData[$sKey];
                 }
                 $sRelModuleName = Engine::GetModuleName($sEntityRel);
                 $sRelEntityName = Engine::GetEntityName($sEntityRel);
                 $sRelPluginPrefix = Engine::GetPluginPrefix($sEntityRel);
                 $sRelPrimaryKey = 'id';
                 if ($oRelEntity = Engine::GetEntity($sEntityRel)) {
                     $sRelPrimaryKey = $oRelEntity->_getPrimaryKey();
                 }
                 $iPrimaryKeyValue = $this->_getDataOne($this->_getPrimaryKey());
                 $sCmd = '';
                 $mCmdArgs = array();
                 switch ($sRelationType) {
                     case self::RELATION_TYPE_BELONGS_TO:
                         $sCmd = "{$sRelPluginPrefix}{$sRelModuleName}_get{$sRelEntityName}By" . func_camelize($sRelPrimaryKey);
                         $mCmdArgs = $this->_getDataOne($sRelationKey);
                         break;
                     case self::RELATION_TYPE_HAS_ONE:
                         $sCmd = "{$sRelPluginPrefix}{$sRelModuleName}_get{$sRelEntityName}By" . func_camelize($sRelationKey);
                         $mCmdArgs = $iPrimaryKeyValue;
                         break;
                     case self::RELATION_TYPE_HAS_MANY:
                         $sCmd = "{$sRelPluginPrefix}{$sRelModuleName}_get{$sRelEntityName}ItemsByFilter";
                         $mCmdArgs = array($sRelationKey => $iPrimaryKeyValue);
                         break;
                     case self::RELATION_TYPE_MANY_TO_MANY:
                         $sCmd = "{$sRelPluginPrefix}Module{$sRelModuleName}_get{$sRelEntityName}ItemsByJoinTable";
                         $mCmdArgs = array('#join_table' => Config::Get($sRelationJoinTable), '#relation_key' => $sRelationKey, '#by_key' => $sRelationJoinTableKey, '#by_value' => $iPrimaryKeyValue, '#index-from-primary' => true);
                         break;
                     default:
                         break;
                 }
                 // Нужно ли учитывать дополнительный фильтр
                 $bUseFilter = is_array($mCmdArgs) && array_key_exists(0, $aArgs) && is_array($aArgs[0]);
                 if ($bUseFilter) {
                     $mCmdArgs = array_merge($mCmdArgs, $aArgs[0]);
                 }
                 $res = Engine::GetInstance()->_CallModule($sCmd, array($mCmdArgs));
                 // Сохраняем данные только в случае "чистой" выборки
                 if (!$bUseFilter) {
                     $this->aRelationsData[$sKey] = $res;
                 }
                 // Создаём объекты-обёртки для связей MANY_TO_MANY
                 if ($sRelationType == self::RELATION_TYPE_MANY_TO_MANY) {
                     $this->_aManyToManyRelations[$sKey] = new LS_ManyToManyRelation($res);
                 }
                 return $res;
             }
             return null;
         } elseif ($sType == 'set' and array_key_exists(0, $aArgs)) {
             if (array_key_exists($sKey, $this->aRelations)) {
                 $this->aRelationsData[$sKey] = $aArgs[0];
             } else {
                 $this->_aData[$this->_getField($sKey)] = $aArgs[0];
             }
         } elseif ($sType == 'reload') {
             if (array_key_exists($sKey, $this->aRelationsData)) {
                 unset($this->aRelationsData[$sKey]);
                 return $this->__call('get' . func_camelize($sKey), $aArgs);
             }
         }
     } else {
         return Engine::getInstance()->_CallModule($sName, $aArgs);
     }
 }
コード例 #4
0
 /**
  * Ставим хук на вызов неизвестного метода и считаем что хотели вызвать метод какого либо модуля
  * Также производит обработку методов set* и get*
  * Учитывает связи и может возвращать связанные данные
  * @see Engine::_CallModule
  *
  * @param string $sName Имя метода
  * @param array $aArgs Аргументы
  * @return mixed
  */
 public function __call($sName, $aArgs)
 {
     $sType = substr($sName, 0, strpos(func_underscore($sName), '_'));
     if (!strpos($sName, '_') and in_array($sType, array('get', 'set', 'reload'))) {
         $sKey = func_underscore(preg_replace('/' . $sType . '/', '', $sName, 1));
         if ($sType == 'get') {
             if (isset($this->_aData[$sKey])) {
                 return $this->_aData[$sKey];
             } else {
                 $sField = $this->_getField($sKey);
                 if ($sField != $sKey && isset($this->_aData[$sField])) {
                     return $this->_aData[$sField];
                 }
             }
             /**
              * Проверяем на связи
              */
             $aRelations = $this->_getRelations();
             if (array_key_exists($sKey, $aRelations)) {
                 $sEntityRel = $aRelations[$sKey]['rel_entity'];
                 $sRelationType = $aRelations[$sKey]['type'];
                 $sRelationKey = $aRelations[$sKey]['rel_key'];
                 $sRelModuleName = Engine::GetModuleName($sEntityRel);
                 $sRelEntityName = Engine::GetEntityName($sEntityRel);
                 $sRelPluginPrefix = Engine::GetPluginPrefix($sEntityRel);
                 $sRelPrimaryKey = 'id';
                 if ($oRelEntity = Engine::GetEntity($sEntityRel)) {
                     $sRelPrimaryKey = $oRelEntity->_getPrimaryKey();
                 }
                 $iPrimaryKeyValue = $this->_getDataOne($this->_getPrimaryKey());
                 $bUseFilter = array_key_exists(0, $aArgs) && is_array($aArgs[0]);
                 $sCmd = '';
                 $mCmdArgs = array();
                 switch ($sRelationType) {
                     case self::RELATION_TYPE_BELONGS_TO:
                         $sKeyTo = $aRelations[$sKey]['rel_key_to'] ?: $sRelPrimaryKey;
                         $sCmd = "{$sRelPluginPrefix}{$sRelModuleName}_get{$sRelEntityName}By" . func_camelize($sKeyTo);
                         $mCmdArgs = array($this->_getDataOne($sRelationKey));
                         break;
                     case self::RELATION_TYPE_HAS_ONE:
                         $aFilterAdd = $aRelations[$sKey]['filter'];
                         $sCmd = "{$sRelPluginPrefix}{$sRelModuleName}_get{$sRelEntityName}ByFilter";
                         $aFilterAdd = array_merge(array($sRelationKey => $iPrimaryKeyValue), $aFilterAdd);
                         $mCmdArgs = array($aFilterAdd);
                         break;
                     case self::RELATION_TYPE_HAS_MANY:
                         if ($aRelations[$sKey]['key_from']) {
                             $sRelationKeyValue = $this->_getDataOne($aRelations[$sKey]['key_from']);
                         } else {
                             $sRelationKeyValue = $iPrimaryKeyValue;
                         }
                         $aFilterAdd = $aRelations[$sKey]['filter'];
                         $sCmd = "{$sRelPluginPrefix}{$sRelModuleName}_get{$sRelEntityName}ItemsByFilter";
                         $aFilterAdd = array_merge(array($sRelationKey => $sRelationKeyValue), $aFilterAdd);
                         if ($bUseFilter) {
                             $aFilterAdd = array_merge($aFilterAdd, $aArgs[0]);
                         }
                         $mCmdArgs = array($aFilterAdd);
                         break;
                     case self::RELATION_TYPE_MANY_TO_MANY:
                         $sEntityJoin = $aRelations[$sKey]['join_entity'];
                         $sKeyJoin = $aRelations[$sKey]['join_key'];
                         $aFilterAdd = $aRelations[$sKey]['filter'];
                         $sCmd = "{$sRelPluginPrefix}Module{$sRelModuleName}_get{$sRelEntityName}ItemsByJoinEntity";
                         if ($bUseFilter) {
                             $aFilterAdd = array_merge($aFilterAdd, $aArgs[0]);
                         }
                         $mCmdArgs = array($sEntityJoin, $sKeyJoin, $sRelationKey, $iPrimaryKeyValue, $aFilterAdd);
                         break;
                     default:
                         break;
                 }
                 /**
                  * Если связь уже загруженна, то возвращаем результат
                  */
                 if (!$bUseFilter and array_key_exists($sKey, $this->aRelationsData)) {
                     return $this->aRelationsData[$sKey];
                 }
                 // Нужно ли учитывать дополнительный фильтр
                 $res = Engine::GetInstance()->_CallModule($sCmd, $mCmdArgs);
                 // Сохраняем данные только в случае "чистой" выборки
                 if (!$bUseFilter) {
                     $this->aRelationsData[$sKey] = $res;
                 }
                 // Создаём объекты-обёртки для связей MANY_TO_MANY
                 if ($sRelationType == self::RELATION_TYPE_MANY_TO_MANY) {
                     $this->_aManyToManyRelations[$sKey] = new ORMRelationManyToMany($res);
                 }
                 return $res;
             }
             return null;
         } elseif ($sType == 'set' and array_key_exists(0, $aArgs)) {
             if (array_key_exists($sKey, $this->aRelations)) {
                 $this->aRelationsData[$sKey] = $aArgs[0];
             } else {
                 $this->_aData[$this->_getField($sKey)] = $aArgs[0];
             }
             return $this;
         } elseif ($sType == 'reload') {
             if (array_key_exists($sKey, $this->aRelationsData)) {
                 unset($this->aRelationsData[$sKey]);
                 return $this->__call('get' . func_camelize($sKey), $aArgs);
             }
         }
     } else {
         return parent::__call($sName, $aArgs);
     }
 }