Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to log something to Zend Developer Tools toolbar?

It's posible to log to Zend Developer Tools toolbar some variable in ZF2 controller?

like image 362
Ivan G Avatar asked Dec 20 '22 20:12

Ivan G


1 Answers

Well, I have created a Collector to add personal information on ZendDevelopersTool. You need info from a Controller, and that's I never had tried to do. :)

I gonna show you how I created the Collector, and maybe you can find some way to take info from the Controller.

In your MyModule\module.config.php

/* ZendDeveloperTools Configuration */
'service_manager' => array(
    'invokables' => array(
        'MyModule\ConfigCollector'   => 'MyModule\Collector\ConfigCollector',
    ),
),

'view_manager' => array(
    'template_map' => array(
        'zend-developer-tools/toolbar/mymodule-configs' => __DIR__ . '/../view/zend-developer-tools/toolbar/mymodule-configs.phtml',
    ),
),

'zenddevelopertools' => array(
    'profiler' => array(
        'collectors' => array(
            'mymodule_configs' => 'MyModule\ConfigCollector',
        ),
    ),
    'toolbar' => array(
        'entries' => array(
            'mymodule_configs' => 'zend-developer-tools/toolbar/mymodule-configs',
        ),
    ),
),

On MyModule\Module.php, you need to load your invokables, I'm doing this by adding the following method:

public function getServiceConfig()
{
    return include __DIR__ . '/config/module.config.php';
}

Add a .phtml file on the on your views:

MyModule/view/zend-developer-tools/toolbar/mymodule-configs.phtml

And add, for example:

<?php /* @var $collector \DoctrineORMModule\Collector\MappingCollector */ ?>
<div class="zdt-toolbar-entry">
    <div class="zdt-toolbar-preview">
        <img src="" alt="VnsDesenvolvimento">
        <span class="zdt-toolbar-info">
            Configurações Gerais
        </span>
    </div>
    <div class="zdt-toolbar-detail">
        <span class="zdt-toolbar-info">
            <span class="zdt-detail-label">Environment</span>
            <span class="zdt-detail-value">
                <?php echo $this->collector->getEnvironment(); ?>
            </span>
        </span>

        <span class="zdt-toolbar-info">
            <span class="zdt-detail-label">Default Locale</span>
            <span class="zdt-detail-value">
                <?php echo $this->collector->getDefaultLocale(); ?>
            </span>
        </span>
        
        <span class="zdt-toolbar-info">
            <span class="zdt-detail-label">Time Zone</span>
            <span class="zdt-detail-value">
                <?php echo $this->collector->getTimeZone(); ?>
            </span>
        </span>
        
    </div>
</div>

Now, the final part! We need to create a Collector, that gonna grab all teh information we wanna display:

<?php
namespace MyModule\Collector;

use ZendDeveloperTools\Collector;

use Zend\Mvc\MvcEvent;

/**
 * Collector to be used in ZendDeveloperTools to record and display personal information
 *
 * @license MIT
 * @author  Vinicius Garcia <vinigar[...].com>
 */
class ConfigCollector extends \ZendDeveloperTools\Collector\AbstractCollector
{

    /**
     * {@inheritDoc}
     */
    public function getName()
    {
        return 'mymodule_configs';
    }

    /**
     * {@inheritDoc}
     */
    public function getPriority()
    {
        return 10;
    }

    /**
     * {@inheritDoc}
     */
    public function collect(MvcEvent $mvcEvent)
    {
        $date = new \DateTime();
        
        $this->data = array(
            'environment' => ucfirst(getenv('APPLICATION_ENV') ?: 'production'),
            'timezone' => $date->getTimezone()->getName(),
            'defaultlocale' => \Locale::getDefault(),
        );
    }
    
    /**
     * Returns the environment
     *
     * @return string
     */
    public function getEnvironment()
    {
        return $this->data['environment'];
    }
    
    /**
     * Returns the timezone
     *
     * @return string
     */
    public function getTimeZone()
    {
        return $this->data['timezone'];
    }
    
    /**
     * Returns the default locale
     *
     * @return string
     */
    public function getDefaultLocale()
    {
        return $this->data['defaultlocale'];
    }
}

This Class have methods, like getDefaultLocale(), and we use them on zend-developer-tools/toolbar/mymodule-configs.phtml.

It should look like this:

My Configs on ZendDeveloperTool

You can try to adapt this piece of code, to fit your needs. And please, if you find out how to grab info from your controller, share with us!

Edit

In the ConfigCollector class, pay attention to the method collect(MvcEvent $mvcEvent).

As you can see, you have a MvcEvent object there. Maybe you can pass your personal info using it.

like image 115
Vinicius Garcia Avatar answered Dec 30 '22 10:12

Vinicius Garcia