www.gusucode.com > KPPW众包威客PHP开源建站系统 v3.0源码程序 > KPPW/vendor/maximebf/debugbar/src/DebugBar/Bridge/SlimCollector.php

    <?php
/*
 * This file is part of the DebugBar package.
 *
 * (c) 2013 Maxime Bouroumeau-Fuseau
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace DebugBar\Bridge;

use DebugBar\DataCollector\MessagesCollector;
use Psr\Log\LogLevel;
use Slim\Log;
use Slim\Slim;

/**
 * Collects messages from a Slim logger
 *
 * http://slimframework.com
 */
class SlimCollector extends MessagesCollector
{
    protected $slim;

    protected $originalLogWriter;

    public function __construct(Slim $slim)
    {
        $this->slim = $slim;
        if ($log = $slim->getLog()) {
            $this->originalLogWriter = $log->getWriter();
            $log->setWriter($this);
            $log->setEnabled(true);
        }
    }

    public function write($message, $level)
    {
        if ($this->originalLogWriter) {
            $this->originalLogWriter->write($message, $level);
        }
        $this->addMessage($message, $this->getLevelName($level));
    }

    protected function getLevelName($level)
    {
        $map = array(
            Log::EMERGENCY => LogLevel::EMERGENCY,
            Log::ALERT => LogLevel::ALERT,
            Log::CRITICAL => LogLevel::CRITICAL,
            Log::ERROR => LogLevel::ERROR,
            Log::WARN => LogLevel::WARNING,
            Log::NOTICE => LogLevel::NOTICE,
            Log::INFO => LogLevel::INFO,
            Log::DEBUG => LogLevel::DEBUG
        );
        return $map[$level];
    }

    public function getName()
    {
        return 'slim';
    }
}