From 9339f891ad30344daadc8124bdb93d1268505997 Mon Sep 17 00:00:00 2001 From: Justin Beaty Date: Fri, 6 Dec 2024 13:33:47 -0800 Subject: [PATCH] Prevent local.xml from being loaded from installed packages --- app/code/core/Mage/Core/Model/Config.php | 30 ++++++++++++++---------- 1 file changed, 18 insertions(+), 12 deletions(-) diff --git a/app/code/core/Mage/Core/Model/Config.php b/app/code/core/Mage/Core/Model/Config.php index 8c6d19140..5795d7e59 100644 --- a/app/code/core/Mage/Core/Model/Config.php +++ b/app/code/core/Mage/Core/Model/Config.php @@ -206,6 +206,11 @@ class Mage_Core_Model_Config extends Mage_Core_Model_Config_Base */ protected $_prototype; + /** + * Reference to the Varien_Simplexml_Config object where local.xml was loaded in to + */ + protected Mage_Core_Model_Config_Base $_refLocalConfigObject; + /** * Flag which identify what local configuration is loaded * @@ -323,6 +328,11 @@ public function init($options = []) */ public function loadBase() { + // Prevent double loading of base config + if ($this->getNode() !== false) { + return; + } + $files = []; foreach (Maho::getInstalledPackages() as $package => $info) { @@ -336,17 +346,17 @@ public function loadBase() } // Merge all config files - $this->loadFile(current($files)); - while ($file = next($files)) { + $this->loadString(''); + foreach ($files as $basename => $file) { $merge = clone $this->_prototype; $merge->loadFile($file); + if ($basename === 'local.xml') { + $this->_isLocalConfigLoaded = true; + $this->_refLocalConfigObject = $merge; + } $this->extend($merge); } - if (isset($files['local.xml'])) { - $this->_isLocalConfigLoaded = true; - } - return $this; } @@ -382,13 +392,9 @@ public function loadModules() $resourceConfig = sprintf('config.%s.xml', $this->_getResourceConnectionModel('core')); $this->loadModulesConfiguration(['config.xml', $resourceConfig], $this); - /** - * Prevent local.xml directives overwriting - */ - $mergeConfig = clone $this->_prototype; - $this->_isLocalConfigLoaded = $mergeConfig->loadFile($this->getOptions()->getEtcDir() . DS . 'local.xml'); + // Prevent local.xml directives overwriting if ($this->_isLocalConfigLoaded) { - $this->extend($mergeConfig); + $this->extend($this->_refLocalConfigObject); } $this->applyExtends();