* @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\Product; use PrestaShop\PrestaShop\Adapter\Configuration; use PrestaShop\PrestaShop\Adapter\Product\SpecificPrice\Update\SpecificPricePriorityUpdater; use PrestaShop\PrestaShop\Core\Configuration\DataConfigurationInterface; use PrestaShop\PrestaShop\Core\Domain\Product\SpecificPrice\Exception\SpecificPriceConstraintException; use PrestaShop\PrestaShop\Core\Domain\Product\SpecificPrice\ValueObject\PriorityList; use Symfony\Component\OptionsResolver\OptionsResolver; /** * This class loads and saves general configuration for product. */ class GeneralConfiguration implements DataConfigurationInterface { /** * @var Configuration */ private $configuration; /** * @var SpecificPricePriorityUpdater */ private $specificPricePriorityUpdater; /** * @param Configuration $configuration * @param SpecificPricePriorityUpdater $specificPricePriorityUpdater */ public function __construct( Configuration $configuration, SpecificPricePriorityUpdater $specificPricePriorityUpdater ) { $this->configuration = $configuration; $this->specificPricePriorityUpdater = $specificPricePriorityUpdater; } /** * {@inheritdoc} */ public function getConfiguration() { return [ 'catalog_mode' => $this->configuration->getBoolean('PS_CATALOG_MODE'), 'catalog_mode_with_prices' => $this->configuration->getBoolean('PS_CATALOG_MODE_WITH_PRICES'), 'new_days_number' => $this->configuration->get('PS_NB_DAYS_NEW_PRODUCT'), 'short_description_limit' => $this->configuration->get('PS_PRODUCT_SHORT_DESC_LIMIT'), 'quantity_discount' => $this->configuration->get('PS_QTY_DISCOUNT_ON_COMBINATION'), 'force_friendly_url' => $this->configuration->getBoolean('PS_FORCE_FRIENDLY_PRODUCT'), 'default_status' => $this->configuration->getBoolean('PS_PRODUCT_ACTIVATION_DEFAULT'), 'specific_price_priorities' => $this->getPrioritiesData(), 'disabled_products_behavior' => $this->configuration->get('PS_PRODUCT_REDIRECTION_DEFAULT'), ]; } /** * {@inheritdoc} */ public function updateConfiguration(array $config) { $errors = []; if ($this->validateConfiguration($config)) { $catalogMode = (int) $config['catalog_mode']; $this->configuration->set('PS_CATALOG_MODE', $catalogMode); $this->configuration->set('PS_CATALOG_MODE_WITH_PRICES', $catalogMode ? (int) $config['catalog_mode_with_prices'] : 0); $this->configuration->set('PS_NB_DAYS_NEW_PRODUCT', (int) $config['new_days_number']); $this->configuration->set('PS_PRODUCT_SHORT_DESC_LIMIT', (int) $config['short_description_limit']); $this->configuration->set('PS_QTY_DISCOUNT_ON_COMBINATION', (int) $config['quantity_discount']); $this->configuration->set('PS_FORCE_FRIENDLY_PRODUCT', (int) $config['force_friendly_url']); $this->configuration->set('PS_PRODUCT_ACTIVATION_DEFAULT', (int) $config['default_status']); $this->configuration->set('PS_PRODUCT_REDIRECTION_DEFAULT', (string) $config['disabled_products_behavior']); try { $this->specificPricePriorityUpdater->updateDefaultPriorities(new PriorityList($config['specific_price_priorities'])); } catch (SpecificPriceConstraintException $e) { if ($e->getCode() !== SpecificPriceConstraintException::DUPLICATE_PRIORITY) { throw $e; } $errors[] = [ 'key' => 'The selected condition must be different in each field to set an order of priority.', 'domain' => 'Admin.Notifications.Error', 'parameters' => [], ]; } } return $errors; } /** * {@inheritdoc} */ public function validateConfiguration(array $configuration) { $resolver = new OptionsResolver(); $resolver->setRequired([ 'catalog_mode', 'catalog_mode_with_prices', 'new_days_number', 'short_description_limit', 'quantity_discount', 'force_friendly_url', 'default_status', 'specific_price_priorities', 'disabled_products_behavior', ]); $resolver->resolve($configuration); return true; } /** * @return string[] */ private function getPrioritiesData(): array { if (!empty($this->configuration->get('PS_SPECIFIC_PRICE_PRIORITIES'))) { return explode(';', $this->configuration->get('PS_SPECIFIC_PRICE_PRIORITIES')); } return array_values(PriorityList::AVAILABLE_PRIORITIES); } }