Application log
2017-11-17T17:37:16+00:00 INFO (6): Event bootstrap
2017-11-17T17:37:16+00:00 INFO (6): Event configure
2017-11-17T17:37:16+00:00 INFO (6): Configuring application
2017-11-17T17:37:16+00:00 INFO (6): Attaching aggregate listener [object WebinoAppLib\Listener\DebuggerListener]
2017-11-17T17:37:16+00:00 INFO (6): Attaching aggregate listener [object WebinoAppLib\Listener\ContextListener]
2017-11-17T17:37:16+00:00 INFO (6): Event bootstrap
2017-11-17T17:37:16+00:00 INFO (6): Matching context WebinoAppLib\Context\HttpContext
2017-11-17T17:37:16+00:00 INFO (6): Attaching aggregate listener [object WebinoAppLib\Listener\Http\HttpRoutingListener]
2017-11-17T17:37:16+00:00 INFO (6): Attaching aggregate listener [object WebinoAppLib\Listener\Http\HttpRequestListener]
2017-11-17T17:37:16+00:00 INFO (6): Attaching aggregate listener [object WebinoAppLib\Listener\Http\HttpResponseListener]
2017-11-17T17:37:16+00:00 INFO (6): Event WebinoAppLib\Event\ContextEvent
2017-11-17T17:37:16+00:00 EMERG (0): Test emergency log message!
2017-11-17T17:37:16+00:00 INFO (6): Test info log message paramOne paramTwo
2017-11-17T17:37:16+00:00 INFO (6): Attaching [object Closure] to an event WebinoAppLib\Router\DefaultRoute with priority 1
2017-11-17T17:37:16+00:00 INFO (6): Event dispatch
2017-11-17T17:37:16+00:00 INFO (6): Attaching [object Closure] to an event routeMatch with priority 1
2017-11-17T17:37:16+00:00 INFO (6): Event routeMatch
2017-11-17T17:37:16+00:00 INFO (6): Event WebinoAppLib\Router\DefaultRoute
Source Preview
<?php
/**
 * Logger PSR-3
 * Webino Example
 */

use WebinoAppLib\Event\RouteEvent;
use 
WebinoAppLib\Response\Content\SourcePreview;
use 
WebinoAppLib\Router\DefaultRoute;
use 
WebinoExamplesLib\Html\FieldSetScrollBox;
use 
WebinoConfigLib\Feature\Log;

require 
__DIR__ '/../../vendor/autoload.php';

/**
 * Example logs
 */
abstract class MyLogs
{
    const 
APP 'app.log';
}

$config Webino::config([
    
/**
     * Configuring app
     * log file.
     */
    
new Log(MyLogs::APP),
]);

$app Webino::application($config)->bootstrap();

/**
 * Writing log message
 * PSR-3 style.
 */
$app->log()->emergency('Test emergency log message!');

/**
 * Writing log message PSR-3
 * style with arguments.
 */
$app->log()->info('Test info log message {0} {1}', ['paramOne''paramTwo']);

$app->bind(DefaultRoute::class, function (RouteEvent $event) {
    
/**
     * Obtaining log
     * file contents.
     */
    
$log $event->getApp()->file()->read(MyLogs::APP);

    
$event->setResponse([
        new 
FieldSetScrollBox('Application log'$log),
        new 
SourcePreview(__FILE__),
    ]);
});

$app->dispatch();