![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/magento/module-store/App/Config/Source/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ namespace Magento\Store\App\Config\Source; use Magento\Framework\App\Config\ConfigSourceInterface; use Magento\Framework\App\DeploymentConfig; use Magento\Framework\App\ResourceConnection; use Magento\Framework\DB\Adapter\AdapterInterface; use Magento\Framework\DB\Adapter\TableNotFoundException; /** * Config source. Retrieve all configuration for scopes from db */ class RuntimeConfigSource implements ConfigSourceInterface { /** * @var DeploymentConfig */ private $deploymentConfig; /** * @var ResourceConnection */ private $resourceConnection; /** * @var AdapterInterface */ private $connection; /** * @param DeploymentConfig $deploymentConfig * @param ResourceConnection $resourceConnection */ public function __construct( DeploymentConfig $deploymentConfig, ResourceConnection $resourceConnection ) { $this->deploymentConfig = $deploymentConfig; $this->resourceConnection = $resourceConnection; } /** * Return whole scopes config data from db. * * Ignore $path argument due to config source must return all config data * * @param string $path * @return array * @SuppressWarnings(PHPMD.UnusedFormalParameter) */ public function get($path = '') { $data = []; try { if ($this->canUseDatabase()) { $data = [ 'websites' => $this->getEntities('store_website', 'code'), 'groups' => $this->getEntities('store_group', 'group_id'), 'stores' => $this->getEntities('store', 'code'), ]; } } catch (TableNotFoundException $exception) { // database is empty or not setup $data = []; } return $data; } /** * Retrieve default connection * * @return AdapterInterface */ private function getConnection() { if (null === $this->connection) { $this->connection = $this->resourceConnection->getConnection(); } return $this->connection; } /** * Get entities from specified table in format [entityKeyField => [entity data], ...] * * @param string $table * @param string $keyField * @return array */ private function getEntities($table, $keyField) { $data = []; $tableName = $this->resourceConnection->getTableName($table); // Check if db table exists before fetch data $entities = $this->getConnection()->fetchAll( $this->getConnection()->select()->from($tableName) ); foreach ($entities as $entity) { $data[$entity[$keyField]] = $entity; } return $data; } /** * Check whether db connection is available and can be used * * @return bool */ private function canUseDatabase() { return $this->deploymentConfig->isDbAvailable(); } }