* @copyright Since 2007 PrestaShop SA and Contributors * @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0) */ namespace PrestaShop\PrestaShop\Adapter\Domain; use Context; use Db; use ImageManager; use ObjectModel; use PrestaShopDatabaseException; use Shop; /** * Class AbstractObjectModelHandler is responsible for executing legacy code which is common for legacy ObjectModel. * * @internal */ abstract class AbstractObjectModelHandler { /** * This function assigns stores ids to the given object. It removes previously set shop ids and adds new ids instead. * * @param ObjectModel $objectModel * @param array $shopAssociation * * @throws PrestaShopDatabaseException */ protected function associateWithShops(ObjectModel $objectModel, array $shopAssociation) { if (empty($shopAssociation) || !Shop::isFeatureActive()) { return; } $tableName = (string) $objectModel::$definition['table']; $primaryKeyName = (string) $objectModel::$definition['primary']; $primaryKeyValue = (int) $objectModel->id; if (!Shop::isTableAssociated($tableName)) { return; } // Get list of shop id we want to exclude from asso deletion $excludeIds = $shopAssociation; foreach (Db::getInstance()->executeS('SELECT id_shop FROM ' . _DB_PREFIX_ . 'shop') as $row) { if (!Context::getContext()->employee->hasAuthOnShop($row['id_shop'])) { $excludeIds[] = $row['id_shop']; } } $excludeShopsCondtion = ' AND id_shop NOT IN (' . implode(', ', array_map('intval', $excludeIds)) . ')'; Db::getInstance()->delete( $tableName . '_shop', '`' . $primaryKeyName . '` = ' . $primaryKeyValue . $excludeShopsCondtion ); $insert = []; foreach ($shopAssociation as $shopId) { // Check if context employee has access to the shop before inserting shop association. if (Context::getContext()->employee->hasAuthOnShop($shopId)) { $insert[] = [ $primaryKeyName => $primaryKeyValue, 'id_shop' => (int) $shopId, ]; } } Db::getInstance()->insert( $tableName . '_shop', $insert, false, true, Db::INSERT_IGNORE ); } /** * @param ObjectModel $objectModel * @param array $multiStoreColumnAssociation - an array key contains shop id while values contains the mapping of * column and its value */ protected function updateMultiStoreColumns(ObjectModel $objectModel, array $multiStoreColumnAssociation) { $tableName = (string) $objectModel::$definition['table']; $primaryKey = (string) $objectModel::$definition['primary']; $primaryKeyValue = (int) $objectModel->id; foreach ($multiStoreColumnAssociation as $shopId => $items) { $shop = new Shop($shopId); if (0 >= $shop->id || !is_array($items)) { continue; } $update = []; foreach ($items as $columnName => $columnValue) { $update[$columnName] = pSQL($columnValue); } Db::getInstance()->update( $tableName . '_shop', $update, $primaryKey . '=' . $primaryKeyValue ); } } /** * @param string $imagePath the original image path * @param int $imageId * @param string $belongsTo object name to which image belongs (e.g. 'supplier', 'manufacturer') * * @return string */ protected function getTmpImageTag($imagePath, $imageId, $belongsTo) { return ImageManager::thumbnail( $imagePath, $belongsTo . '_' . $imageId . '.jpg', 350, 'jpg', true, true ); } /** * Calculates and returns image size in kb for provided image path. Returns null if image doesn't exist * * @param string $imagePath * * @return float|null */ protected function getImageSize($imagePath) { return file_exists($imagePath) ? filesize($imagePath) / 1000 : null; } }