105 lines
4.5 KiB
PHP
105 lines
4.5 KiB
PHP
<?php
|
|
/**
|
|
* 2007-2016 PrestaShop
|
|
*
|
|
* NOTICE OF LICENSE
|
|
*
|
|
* This source file is subject to the Open Software License (OSL 3.0)
|
|
* that is bundled with this package in the file LICENSE.txt.
|
|
* It is also available through the world-wide-web at this URL:
|
|
* http://opensource.org/licenses/osl-3.0.php
|
|
* If you did not receive a copy of the license and are unable to
|
|
* obtain it through the world-wide-web, please send an email
|
|
* to license@prestashop.com so we can send you a copy immediately.
|
|
*
|
|
* DISCLAIMER
|
|
*
|
|
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
|
|
* versions in the future. If you wish to customize PrestaShop for your
|
|
* needs please refer to http://www.prestashop.com for more information.
|
|
*
|
|
* @author PrestaShop SA <contact@prestashop.com>
|
|
* @copyright 2007-2016 PrestaShop SA
|
|
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
|
|
* International Registered Trademark & Property of PrestaShop SA
|
|
*/
|
|
|
|
class Adapter_EntityMapper
|
|
{
|
|
/**
|
|
* Load ObjectModel
|
|
* @param $id
|
|
* @param $id_lang
|
|
* @param $entity ObjectModel
|
|
* @param $entity_defs
|
|
* @param $id_shop
|
|
* @param $should_cache_objects
|
|
* @throws PrestaShopDatabaseException
|
|
*/
|
|
public function load($id, $id_lang, $entity, $entity_defs, $id_shop, $should_cache_objects)
|
|
{
|
|
// Load object from database if object id is present
|
|
$cache_id = 'objectmodel_' . $entity_defs['classname'] . '_' . (int)$id . '_' . (int)$id_shop . '_' . (int)$id_lang;
|
|
if (!$should_cache_objects || !Cache::isStored($cache_id)) {
|
|
$sql = new DbQuery();
|
|
$sql->from($entity_defs['table'], 'a');
|
|
$sql->where('a.`' . bqSQL($entity_defs['primary']) . '` = ' . (int)$id);
|
|
|
|
// Get lang informations
|
|
if ($id_lang && isset($entity_defs['multilang']) && $entity_defs['multilang']) {
|
|
$sql->leftJoin($entity_defs['table'] . '_lang', 'b', 'a.`' . bqSQL($entity_defs['primary']) . '` = b.`' . bqSQL($entity_defs['primary']) . '` AND b.`id_lang` = ' . (int)$id_lang);
|
|
if ($id_shop && !empty($entity_defs['multilang_shop'])) {
|
|
$sql->where('b.`id_shop` = ' . (int)$id_shop);
|
|
}
|
|
}
|
|
|
|
// Get shop informations
|
|
if (Shop::isTableAssociated($entity_defs['table'])) {
|
|
$sql->leftJoin($entity_defs['table'] . '_shop', 'c', 'a.`' . bqSQL($entity_defs['primary']) . '` = c.`' . bqSQL($entity_defs['primary']) . '` AND c.`id_shop` = ' . (int)$id_shop);
|
|
}
|
|
|
|
if ($object_datas = Db::getInstance()->getRow($sql)) {
|
|
if (!$id_lang && isset($entity_defs['multilang']) && $entity_defs['multilang']) {
|
|
$sql = 'SELECT *
|
|
FROM `' . bqSQL(_DB_PREFIX_ . $entity_defs['table']) . '_lang`
|
|
WHERE `' . bqSQL($entity_defs['primary']) . '` = ' . (int)$id
|
|
.(($id_shop && $entity->isLangMultishop()) ? ' AND `id_shop` = ' . (int)$id_shop : '');
|
|
|
|
if ($object_datas_lang = Db::getInstance()->executeS($sql)) {
|
|
foreach ($object_datas_lang as $row) {
|
|
foreach ($row as $key => $value) {
|
|
if ($key != $entity_defs['primary'] && array_key_exists($key, $entity)) {
|
|
if (!isset($object_datas[$key]) || !is_array($object_datas[$key])) {
|
|
$object_datas[$key] = array();
|
|
}
|
|
|
|
$object_datas[$key][$row['id_lang']] = $value;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
$entity->id = (int)$id;
|
|
foreach ($object_datas as $key => $value) {
|
|
if (array_key_exists($key, $entity)) {
|
|
$entity->{$key} = $value;
|
|
} else {
|
|
unset($object_datas[$key]);
|
|
}
|
|
}
|
|
if ($should_cache_objects) {
|
|
Cache::store($cache_id, $object_datas);
|
|
}
|
|
}
|
|
} else {
|
|
$object_datas = Cache::retrieve($cache_id);
|
|
if ($object_datas) {
|
|
$entity->id = (int)$id;
|
|
foreach ($object_datas as $key => $value) {
|
|
$entity->{$key} = $value;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|