Jak uzyskać listę wszystkich zapisów klas?

23

Czy istnieje sposób, aby wyświetlić listę wszystkich przepisań i być może inne potencjalne konflikty oprócz przeglądania wszystkich plików konfiguracyjnych? Muszę przeanalizować niektóre projekty z wieloma rozszerzeniami i niestandardowymi modyfikacjami i chciałbym zautomatyzować jak najwięcej z tego.

Najważniejszą rzeczą jest wykrycie rozszerzeń, które przepisują tę samą klasę, ale chciałbym mieć również listę wszystkich przepisań, aby mieć przegląd. W tej chwili utrzymuję tę listę ręcznie w arkuszu kalkulacyjnym.

Znalazłem to rozszerzenie („Konflikt rozszerzeń”) na Magento Connect, ale sądząc po recenzjach i uwagach do wydania, wydaje się być nieaktualne.

Fabian Schmengler
źródło
Nie możesz po prostu użyćgrep
Ben Lessani - Sonassi

Odpowiedzi:

28

Spójrz na narzędzie n98-magerun :

Przepisz listę

Wyświetla listę wszystkich zapisanych zapisów klas:

$ n98-magerun.phar dev:module:rewrite:list

Przepisz konflikty

Wyświetla listę wszystkich powielonych przeróbek i informuje, która klasa jest ładowana przez Magento. Polecenie sprawdza dziedziczenie klas w kolejności zależności modułów. n98-magerun.phar dev:module:rewrite:conflicts [--log-junit="..."]

Jeśli ustawiona jest nazwa pliku z opcją --log-junit, narzędzie generuje plik XML i nie wyświetla danych wyjściowych na standardowe wyjście.

Możesz także zapisać konflikty w pliku XML JUnit Style w celu dalszej analizy, na przykład na serwerze kontynuacji integracji.

Uwaga: semi-self-link / Jestem zaangażowany w ten projekt

Alex
źródło
27

Oto mały jednowarstwowy, który zapewnia wszystkie aktywne przepisywania:

print_r(Mage::getConfig()->getNode()->xpath('//global//rewrite'));

Aby ograniczyć go według typu obiektu, dodaj odpowiednio modele, bloki lub pomocniki do ścieżki xpath.
Na przykład:

Mage::getConfig()->getNode()->xpath('//global/models//rewrite')
Vinai
źródło
W czym problem z magento.SE? W każdym razie podoba mi się to rozwiązanie, proste i jednoznaczne. Sam powinienem o tym pomyśleć ... Danke, Vinai!
Fabian Schmengler
2
Działa to z małym problemem. Jeśli masz 2 rozszerzenia przepisujące ten sam model, nie zobaczysz go, ponieważ Magento scala pliki konfiguracyjne. Zobaczysz tylko „ostatni”. Jest to jednak szybki i prosty sposób sprawdzenia, czy coś zostało przepisane
Marius
Tak, pokazuje tylko aktywne przepisywanie, to prawda. Jeśli chcesz bardziej zaawansowanej analityki, musisz sprawdzić każdy aktywny moduł etc / config.xml osobno (lub po prostu użyj n98-magerun)
Vinai
Witaj @ Vinai, czy możemy uzyskać wszystkie konflikty w magento2 przez ten kod?
akgola
Nie, nie możesz konfigurować DI działa zupełnie inaczej w Magento 2.
Vinai
22

oto mały skrypt, którego używam, aby sprawdzić, czy jakieś modele, bloki lub pomocniki są nadpisane. Niestety nie działa dla kontrolerów i uwzględnia również wyłączone moduły. Ale z mojego punktu widzenia nie jest to wielka sprawa.

Głównym pomysłem jest parsowanie plików konfiguracyjnych i poszukiwanie <rewrite>znacznika. Utwórz plik php na tym samym poziomie co index.php. Nazwijmy to rewrites.phpnastępującymi treściami:

<?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);

podczas wywoływania go w przeglądarce powinieneś zobaczyć coś takiego:

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] => ...

)

oznacza to, że model 'core/layout'zostanie zastąpiony przezNamespace_Module_Model_Core_Layout

Jeśli masz 2 lub więcej wartości w tablicy [„core / layout”], oznacza to, że wystąpił konflikt.

I możesz łatwo zidentyfikować moduł, który zastępuje coś na podstawie NamespaceiModule

Marius
źródło
1
Cześć, dzięki za skrypt. Użyłem go w jednym z moich projektów i stwierdziłem, że sprawdzanie modułów społeczności nie działa. Aby
działało, dodaliśmy
@ceckoslab. Tak. Masz rację. Zredagowałem odpowiedź. Dzięki.
Marius
3

Połączyłem obie odpowiedzi i otrzymałem fajne rozwiązanie

$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;
sunel
źródło
0

Może nieco narzut, ale miło jest pracować z gromadzeniem różnych danych ... kod z 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)
                    )
                )
            );
        }
    }
}

Do wydruku możesz użyć ...

foreach ($collection as $rewrite) {
    var_dump($rewrite->getData());
}
sv3n
źródło