Skip to content

Instantly share code, notes, and snippets.

@Nolwennig
Created April 24, 2018 07:37
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save Nolwennig/ccb4d79ab9924faaa3c9355a50b71ce8 to your computer and use it in GitHub Desktop.
Save Nolwennig/ccb4d79ab9924faaa3c9355a50b71ce8 to your computer and use it in GitHub Desktop.
magento2 layout logger
<!-- app/code/LayoutLogger/PageXml/etc/events.xml -->
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Event/etc/events.xsd">
<event name="layout_generate_blocks_after">
<observer name="layoutlogger_layout_generate_blocks_after" instance="LayoutLogger\PageXml\Model\Layout" />
</event>
</config>
<?php
// app/code/LayoutLogger/PageXml/Model/Layout.php
namespace LayoutLogger\PageXml\Model;
use Magento\Framework\Event\Observer;
use Magento\Framework\Event\ObserverInterface;
class Layout implements ObserverInterface {
protected $_logger;
public function __construct(\Psr\Log\LoggerInterface $logger ) {
$this->_logger = $logger;
}
public function execute(\Magento\Framework\Event\Observer $observer) {
$log_file = BP . '/var/log/page_layout.xml';
if (file_exists($log_file)) {
unlink($log_file);
}
$xml = $observer->getEvent()->getLayout()->getXmlString();
/*$this->_logger->debug($xml);*/
$writer = new \Zend\Log\Writer\Stream($log_file);
$logger = new \Zend\Log\Logger();
$logger->addWriter($writer);
$logger->info($xml);
return $this;
}
}
<!-- app/code/LayoutLogger/PageXml/etc/module.xml -->
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Module/etc/module.xsd">
<module name="LayoutLogger_PageXml" setup_version="1.0.0" schema_version="1.0.0">
<sequence>
<module name="Magento_Catalog"/>
<module name="Magento_Theme"/>
</sequence>
</module>
</config>
<?php
// app/code/LayoutLogger/PageXml/registration.php
\Magento\Framework\Component\ComponentRegistrar::register(
\Magento\Framework\Component\ComponentRegistrar::MODULE,
'LayoutLogger_PageXml',
__DIR__
);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment