Server : Apache System : Linux 145.162.205.92.host.secureserver.net 5.14.0-611.45.1.el9_7.x86_64 #1 SMP PREEMPT_DYNAMIC Wed Apr 1 05:56:53 EDT 2026 x86_64 User : tradze ( 1001) PHP Version : 8.1.34 Disable Function : NONE Directory : /home/tradze/public_html/vendor/psy/psysh/src/Logger/ |
<?php
/*
* This file is part of Psy Shell.
*
* (c) 2012-2026 Justin Hileman
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Psy\Logger;
/**
* Callback logger.
*
* A simple logger that calls a callback with the log kind and data.
*/
class CallbackLogger
{
private $callback;
/**
* @param callable $callback Callback to invoke with (string $kind, string $data)
*/
public function __construct(callable $callback)
{
$this->callback = $callback;
}
/**
* Log a message.
*
* @param string $level Log level
* @param string $message Log message
* @param array $context Context data
*/
public function log(string $level, string $message, array $context = []): void
{
// Determine the kind from the message
switch ($message) {
case 'PsySH input':
$kind = 'input';
break;
case 'PsySH command':
$kind = 'command';
break;
case 'PsySH execute':
$kind = 'execute';
break;
default:
$kind = 'unknown';
break;
}
// Extract the data from context
$data = $context[$kind] ?? $context['code'] ?? '';
\call_user_func($this->callback, $kind, $data);
}
}