|
Apache/2.4.41 (Ubuntu) Linux vmi616275.contaboserver.net 5.4.0-84-generic #94-Ubuntu SMP Thu Aug 26 20:27:37 UTC 2021 x86_64 uid=33(www-data) gid=33(www-data) groups=33(www-data) server ip : 62.171.164.128 | your ip : 127.0.0.1 safemode OFF > / home / dev2.destoffenstraat.com / setup / src / Magento / Setup / Model / |
Filename | /home/dev2.destoffenstraat.com/setup/src/Magento/Setup/Model/ConfigModel.php |
Size | 4.83 kb |
Permission | rw-r--r-- |
Owner | root : root |
Create time | 17-Aug-2025 10:26 |
Last modified | 28-Jan-2025 06:45 |
Last accessed | 23-Aug-2025 00:41 |
Actions | edit | rename | delete | download (gzip) |
View | text | code | image |
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
namespace Magento\Setup\Model;
use Magento\Framework\App\DeploymentConfig;
use Magento\Framework\Config\Data\ConfigData;
use Magento\Framework\App\DeploymentConfig\Writer;
use Magento\Framework\Setup\Option\AbstractConfigOption;
use Magento\Framework\Setup\FilePermissions;
class ConfigModel
{
/**
* @var \Magento\Setup\Model\ConfigOptionsListCollector
*/
protected $collector;
/**
* @var \Magento\Framework\App\DeploymentConfig\Writer
*/
protected $writer;
/**
* File permissions checker
*
* @var FilePermissions
*/
private $filePermissions;
/**
* @var \Magento\Framework\App\DeploymentConfig
*/
protected $deploymentConfig;
/**
* Constructor
*
* @param ConfigOptionsListCollector $collector
* @param Writer $writer
* @param DeploymentConfig $deploymentConfig
* @param FilePermissions $filePermissions
*/
public function __construct(
ConfigOptionsListCollector $collector,
Writer $writer,
DeploymentConfig $deploymentConfig,
FilePermissions $filePermissions
) {
$this->collector = $collector;
$this->writer = $writer;
$this->filePermissions = $filePermissions;
$this->deploymentConfig = $deploymentConfig;
}
/**
* Gets available config options
*
* @return AbstractConfigOption[]
*/
public function getAvailableOptions()
{
/** @var AbstractConfigOption[] $optionCollection */
$optionCollection = [];
$optionLists = $this->collector->collectOptionsLists();
foreach ($optionLists as $optionList) {
$optionCollection = array_merge($optionCollection, $optionList->getOptions());
}
foreach ($optionCollection as $option) {
$currentValue = $this->deploymentConfig->get($option->getConfigPath());
if ($currentValue !== null) {
$option->setDefault();
}
}
return $optionCollection;
}
/**
* Process input options
*
* @param array $inputOptions
* @return void
* @throws \Exception
*/
public function process($inputOptions)
{
$this->checkInstallationFilePermissions();
$options = $this->collector->collectOptionsLists();
foreach ($options as $moduleName => $option) {
$configData = $option->createConfig($inputOptions, $this->deploymentConfig);
foreach ($configData as $config) {
$fileConfigStorage = [];
if (!$config instanceof ConfigData) {
throw new \Exception(
'In module : '
. $moduleName
. 'ConfigOption::createConfig should return an array of ConfigData instances'
);
}
if (isset($fileConfigStorage[$config->getFileKey()])) {
$fileConfigStorage[$config->getFileKey()] = array_replace_recursive(
$fileConfigStorage[$config->getFileKey()],
$config->getData()
);
} else {
$fileConfigStorage[$config->getFileKey()] = $config->getData();
}
$this->writer->saveConfig($fileConfigStorage, $config->isOverrideWhenSave());
}
}
}
/**
* Validates Input Options
*
* @param array $inputOptions
* @return array
*/
public function validate(array $inputOptions)
{
$errors = [];
//Basic types validation
$options = $this->getAvailableOptions();
foreach ($options as $option) {
try {
if ($inputOptions[$option->getName()] !== null) {
$option->validate($inputOptions[$option->getName()]);
}
} catch (\InvalidArgumentException $e) {
$errors[] = $e->getMessage();
}
}
// validate ConfigOptionsList
$options = $this->collector->collectOptionsLists();
foreach ($options as $option) {
$errors = array_merge($errors, $option->validate($inputOptions, $this->deploymentConfig));
}
return $errors;
}
/**
* Check permissions of directories that are expected to be writable for installation
*
* @return void
* @throws \Exception
*/
private function checkInstallationFilePermissions()
{
$results = $this->filePermissions->getMissingWritablePathsForInstallation();
if ($results) {
$errorMsg = "Missing write permissions to the following paths:" . PHP_EOL . implode(PHP_EOL, $results);
throw new \Exception($errorMsg);
}
}
}
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
namespace Magento\Setup\Model;
use Magento\Framework\App\DeploymentConfig;
use Magento\Framework\Config\Data\ConfigData;
use Magento\Framework\App\DeploymentConfig\Writer;
use Magento\Framework\Setup\Option\AbstractConfigOption;
use Magento\Framework\Setup\FilePermissions;
class ConfigModel
{
/**
* @var \Magento\Setup\Model\ConfigOptionsListCollector
*/
protected $collector;
/**
* @var \Magento\Framework\App\DeploymentConfig\Writer
*/
protected $writer;
/**
* File permissions checker
*
* @var FilePermissions
*/
private $filePermissions;
/**
* @var \Magento\Framework\App\DeploymentConfig
*/
protected $deploymentConfig;
/**
* Constructor
*
* @param ConfigOptionsListCollector $collector
* @param Writer $writer
* @param DeploymentConfig $deploymentConfig
* @param FilePermissions $filePermissions
*/
public function __construct(
ConfigOptionsListCollector $collector,
Writer $writer,
DeploymentConfig $deploymentConfig,
FilePermissions $filePermissions
) {
$this->collector = $collector;
$this->writer = $writer;
$this->filePermissions = $filePermissions;
$this->deploymentConfig = $deploymentConfig;
}
/**
* Gets available config options
*
* @return AbstractConfigOption[]
*/
public function getAvailableOptions()
{
/** @var AbstractConfigOption[] $optionCollection */
$optionCollection = [];
$optionLists = $this->collector->collectOptionsLists();
foreach ($optionLists as $optionList) {
$optionCollection = array_merge($optionCollection, $optionList->getOptions());
}
foreach ($optionCollection as $option) {
$currentValue = $this->deploymentConfig->get($option->getConfigPath());
if ($currentValue !== null) {
$option->setDefault();
}
}
return $optionCollection;
}
/**
* Process input options
*
* @param array $inputOptions
* @return void
* @throws \Exception
*/
public function process($inputOptions)
{
$this->checkInstallationFilePermissions();
$options = $this->collector->collectOptionsLists();
foreach ($options as $moduleName => $option) {
$configData = $option->createConfig($inputOptions, $this->deploymentConfig);
foreach ($configData as $config) {
$fileConfigStorage = [];
if (!$config instanceof ConfigData) {
throw new \Exception(
'In module : '
. $moduleName
. 'ConfigOption::createConfig should return an array of ConfigData instances'
);
}
if (isset($fileConfigStorage[$config->getFileKey()])) {
$fileConfigStorage[$config->getFileKey()] = array_replace_recursive(
$fileConfigStorage[$config->getFileKey()],
$config->getData()
);
} else {
$fileConfigStorage[$config->getFileKey()] = $config->getData();
}
$this->writer->saveConfig($fileConfigStorage, $config->isOverrideWhenSave());
}
}
}
/**
* Validates Input Options
*
* @param array $inputOptions
* @return array
*/
public function validate(array $inputOptions)
{
$errors = [];
//Basic types validation
$options = $this->getAvailableOptions();
foreach ($options as $option) {
try {
if ($inputOptions[$option->getName()] !== null) {
$option->validate($inputOptions[$option->getName()]);
}
} catch (\InvalidArgumentException $e) {
$errors[] = $e->getMessage();
}
}
// validate ConfigOptionsList
$options = $this->collector->collectOptionsLists();
foreach ($options as $option) {
$errors = array_merge($errors, $option->validate($inputOptions, $this->deploymentConfig));
}
return $errors;
}
/**
* Check permissions of directories that are expected to be writable for installation
*
* @return void
* @throws \Exception
*/
private function checkInstallationFilePermissions()
{
$results = $this->filePermissions->getMissingWritablePathsForInstallation();
if ($results) {
$errorMsg = "Missing write permissions to the following paths:" . PHP_EOL . implode(PHP_EOL, $results);
throw new \Exception($errorMsg);
}
}
}