Как получить список всех переписываний класса?
-
16-10-2019 - |
Вопрос
Есть ли способ перечислить все переписывания и, возможно, другие потенциальные конфликты, помимо просмотра всех файлов конфигурации? Я должен проанализировать некоторые проекты с большим количеством расширений и пользовательских модификаций, и хотел бы как можно больше автоматизировать это.
Самое главное, чтобы обнаружить расширения, которые переписывают один и тот же класс, но я хотел бы также иметь список всех переписываний, чтобы сохранить обзор. На данный момент я храню этот список вручную в электронной таблице.
я нашел Это расширение («конфликт расширения») На Magento Connect, но судя по обзорам и заметкам выпуска, это кажется устаревшим.
Решение
Взглянуть на N98-Magerun Utility:
Переписать список
Списки все зарегистрированные переписывания класса:
$ n98-magerun.phar dev:module:rewrite:list
Переписать конфликты
Перечисляет все дублированные переписывания и рассказывает вам, какой класс загружен Magento. Команда проверяет наследство класса в порядке вашего модуля зависимостей.
n98-magerun.phar dev:module:rewrite:conflicts [--log-junit="..."]
Если имя файла с опцией-log-junit установлен, инструмент генерирует XML-файл и без вывода в Stdout.
Вы также можете зарегистрировать конфликты в XML -файле Junit Style для дальнейшего анализа, например, на сервере Continues Integration.
Отказ от ответственности: полусвязано-лифт / я вовлечен в этот проект
Другие советы
Здесь маленький однострочный, который дает вам все активные переписывания:
print_r(Mage::getConfig()->getNode()->xpath('//global//rewrite'));
Чтобы ограничить его типом объекта, добавьте модели, блоки или помощники в XPath соответственно.
Например:
Mage::getConfig()->getNode()->xpath('//global/models//rewrite')
Вот небольшой скрипт, который я использую для проверки, перезаписываются ли какие -либо модели, блоки или помощники. К сожалению, он не работает для контроллеров, и он учитывает также модули отключений. Но с моей точки зрения это не имеет большого значения.
Основная идея состоит в том, чтобы анализировать файлы конфигурации и поиск <rewrite>
ярлык. Создайте файл PHP на том же уровне, что и index.php
. Анкет Назовем это rewrites.php
, с этим контентом:
<?php
$folders = array('app/code/local/', 'app/code/community/');//folders to parse
$configFiles = array();
foreach ($folders as $folder){
$files = glob($folder.'*/*/etc/config.xml');//get all config.xml files in the specified folder
$configFiles = array_merge($configFiles, $files);//merge with the rest of the config files
}
$rewrites = array();//list of all rewrites
foreach ($configFiles as $file){
$dom = new DOMDocument;
$dom->loadXML(file_get_contents($file));
$xpath = new DOMXPath($dom);
$path = '//rewrite/*';//search for tags named 'rewrite'
$text = $xpath->query($path);
foreach ($text as $rewriteElement){
$type = $rewriteElement->parentNode->parentNode->parentNode->tagName;//what is overwritten (model, block, helper)
$parent = $rewriteElement->parentNode->parentNode->tagName;//module identifier that is being rewritten (core, catalog, sales, ...)
$name = $rewriteElement->tagName;//element that is rewritten (layout, product, category, order)
foreach ($rewriteElement->childNodes as $element){
$rewrites[$type][$parent.'/'.$name][] = $element->textContent;//class that rewrites it
}
}
}
echo "<pre>";print_r($rewrites);
Призывая это в браузере, вы должны увидеть что -то вроде этого:
Array
(
[models] => Array
(
[core/layout] => Array
(
[0] => Namespace_Module_Model_Core_Layout
[1] => Namespace1_Module1_Model_Core_Layout //if the second element is present it means there is a possible conflict
)
[...] => ....
)
[blocks] => ...
[helpers] => ...
)
Это означает, что модель 'core/layout'
перезаписан Namespace_Module_Model_Core_Layout
Если у вас есть 2 или более значений в массиве ['Core/Mayout'], это означает, что есть конфликт.
И вы можете легко идентифицировать модуль, который перезаписывает что -то на основе Namespace
а также Module
Я объединил оба ответа и получил хорошее решение
$text = Mage::getConfig()->getNode()->xpath('//global//rewrite');
foreach ($text as $rewriteElement) {
if ($rewriteElement->getParent()->getParent()) {
# what is overwritten (model, block, helper)
$type = $rewriteElement->getParent()->getParent()->getName();
# module identifier that is being rewritten (core, catalog, sales, ...)
$parent = $rewriteElement->getParent()->getName();
# element that is rewritten (layout, product, category, order)
$name = $rewriteElement->getName();
foreach ($rewriteElement->children() as $element) {
# class that rewrites it
$rewrites[$type][$parent.'/'.$name][] = $element;
}
}
}
print_r($rewrites);
die;
Может быть, утомительно, но приятно работать с сбором данных Varien ... код из https://github.com/firegento/firegento-debug
$collection = new Varien_Data_Collection();
$fileName = 'config.xml';
$modules = Mage::getConfig()->getNode('modules')->children();
$rewrites = array();
foreach ($modules as $modName => $module) {
if ($module->is('active')) {
$configFile = Mage::getConfig()->getModuleDir('etc', $modName) . DS . $fileName;
if (file_exists($configFile)) {
$xml = file_get_contents($configFile);
$xml = simplexml_load_string($xml);
if ($xml instanceof SimpleXMLElement) {
$rewrites[$modName] = $xml->xpath('//rewrite');
}
}
}
}
foreach ($rewrites as $rewriteNodes) {
foreach ($rewriteNodes as $n) {
$nParent = $n->xpath('..');
$module = (string)$nParent[0]->getName();
$nSubParent = $nParent[0]->xpath('..');
$component = (string)$nSubParent[0]->getName();
if (!in_array($component, array('blocks', 'helpers', 'models'))) {
continue;
}
$pathNodes = $n->children();
foreach ($pathNodes as $pathNode) {
$path = (string)$pathNode->getName();
$completePath = $module . '/' . $path;
$rewriteClassName = (string)$pathNode;
$instance = Mage::getConfig()->getGroupedClassName(
substr($component, 0, -1),
$completePath
);
$collection->addItem(
new Varien_Object(
array(
'path' => $completePath,
'rewrite_class' => $rewriteClassName,
'active_class' => $instance,
'status' => ($instance == $rewriteClassName)
)
)
);
}
}
}
Для вывода вы можете использовать ...
foreach ($collection as $rewrite) {
var_dump($rewrite->getData());
}