laravel-websockets/src/Server/Logger/Logger.php

70 lines
1.5 KiB
PHP
Raw Normal View History

2018-11-24 14:23:59 +00:00
<?php
namespace BeyondCode\LaravelWebSockets\Server\Logger;
use Symfony\Component\Console\Output\OutputInterface;
2018-11-26 21:25:52 +00:00
use Symfony\Component\Console\Formatter\OutputFormatterStyle;
2018-11-24 14:23:59 +00:00
class Logger
{
/** @var \Symfony\Component\Console\Output\OutputInterface */
protected $consoleOutput;
/** @var bool */
protected $enabled = false;
/** @var bool */
protected $verbose = false;
public static function isEnabled(): bool
{
return app(MessageLogger::class)->enabled;
}
public function __construct(OutputInterface $consoleOutput)
{
$this->consoleOutput = $consoleOutput;
}
public function enable($enabled = true)
{
$this->enabled = $enabled;
return $this;
}
public function verbose($verbose = false)
{
$this->verbose = $verbose;
return $this;
}
protected function info(string $message)
{
$this->line($message, 'info');
}
protected function warn(string $message)
{
2018-11-26 21:25:52 +00:00
if (! $this->consoleOutput->getFormatter()->hasStyle('warning')) {
$style = new OutputFormatterStyle('yellow');
$this->consoleOutput->getFormatter()->setStyle('warning', $style);
}
2018-11-24 14:23:59 +00:00
$this->line($message, 'warning');
}
protected function error(string $message)
{
$this->line($message, 'error');
}
protected function line(string $message, string $style)
{
$styled = $style ? "<$style>$message</$style>" : $message;
$this->consoleOutput->writeln($styled);
}
}