Вопрос

Есть ли способ перечислить все переписывания и, возможно, другие потенциальные конфликты, помимо просмотра всех файлов конфигурации? Я должен проанализировать некоторые проекты с большим количеством расширений и пользовательских модификаций, и хотел бы как можно больше автоматизировать это.

Самое главное, чтобы обнаружить расширения, которые переписывают один и тот же класс, но я хотел бы также иметь список всех переписываний, чтобы сохранить обзор. На данный момент я храню этот список вручную в электронной таблице.

я нашел Это расширение («конфликт расширения») На 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());
}
Лицензировано под: CC-BY-SA с атрибуция
Не связан с magento.stackexchange
scroll top