mirror of
https://github.com/Seldaek/monolog.git
synced 2025-10-24 10:06:08 +02:00
More cleanups
This commit is contained in:
62
phpstan-baseline.neon
Normal file
62
phpstan-baseline.neon
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
parameters:
|
||||||
|
ignoreErrors:
|
||||||
|
-
|
||||||
|
message: "#^Property Monolog\\\\ErrorHandler\\:\\:\\$reservedMemory is never read, only written\\.$#"
|
||||||
|
count: 1
|
||||||
|
path: src/Monolog/ErrorHandler.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Cannot access offset 'table' on array\\<array\\|bool\\|float\\|int\\|string\\|null\\>\\|bool\\|float\\|int\\|object\\|string\\|null\\.$#"
|
||||||
|
count: 1
|
||||||
|
path: src/Monolog/Formatter/WildfireFormatter.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Call to method setBody\\(\\) on an unknown class Swift_Message\\.$#"
|
||||||
|
count: 1
|
||||||
|
path: src/Monolog/Handler/MandrillHandler.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Call to method setDate\\(\\) on an unknown class Swift_Message\\.$#"
|
||||||
|
count: 1
|
||||||
|
path: src/Monolog/Handler/MandrillHandler.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Class Swift_Message not found\\.$#"
|
||||||
|
count: 2
|
||||||
|
path: src/Monolog/Handler/MandrillHandler.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Cloning object of an unknown class Swift_Message\\.$#"
|
||||||
|
count: 1
|
||||||
|
path: src/Monolog/Handler/MandrillHandler.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Parameter \\$message of method Monolog\\\\Handler\\\\MandrillHandler\\:\\:__construct\\(\\) has invalid type Swift_Message\\.$#"
|
||||||
|
count: 2
|
||||||
|
path: src/Monolog/Handler/MandrillHandler.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Property Monolog\\\\Handler\\\\MandrillHandler\\:\\:\\$message has unknown class Swift_Message as its type\\.$#"
|
||||||
|
count: 1
|
||||||
|
path: src/Monolog/Handler/MandrillHandler.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Comparison operation \"\\<\" between int\\<1, 32\\> and 1 is always false\\.$#"
|
||||||
|
count: 1
|
||||||
|
path: src/Monolog/Processor/UidProcessor.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Comparison operation \"\\>\" between int\\<1, 32\\> and 32 is always false\\.$#"
|
||||||
|
count: 1
|
||||||
|
path: src/Monolog/Processor/UidProcessor.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Method Monolog\\\\Processor\\\\UidProcessor\\:\\:generateUid\\(\\) should return non\\-empty\\-string but returns string\\.$#"
|
||||||
|
count: 1
|
||||||
|
path: src/Monolog/Processor/UidProcessor.php
|
||||||
|
|
||||||
|
-
|
||||||
|
message: "#^Parameter \\#1 \\$length of function random_bytes expects int\\<1, max\\>, int given\\.$#"
|
||||||
|
count: 1
|
||||||
|
path: src/Monolog/Processor/UidProcessor.php
|
||||||
|
|
@@ -2,7 +2,7 @@ parameters:
|
|||||||
level: 8
|
level: 8
|
||||||
|
|
||||||
treatPhpDocTypesAsCertain: false
|
treatPhpDocTypesAsCertain: false
|
||||||
reportUnmatchedIgnoredErrors: false
|
reportUnmatchedIgnoredErrors: true
|
||||||
|
|
||||||
paths:
|
paths:
|
||||||
- src/
|
- src/
|
||||||
@@ -19,19 +19,5 @@ parameters:
|
|||||||
paths:
|
paths:
|
||||||
- src/Monolog/Formatter/LineFormatter.php
|
- src/Monolog/Formatter/LineFormatter.php
|
||||||
|
|
||||||
# blocked until we only support php8+
|
includes:
|
||||||
- '#Parameter \#1 \$socket of function (socket_close|socket_sendto|socket_send) expects Socket, resource\|Socket(\|null)? given\.#'
|
- phpstan-baseline.neon
|
||||||
- '#Parameter \#1 \$handle of function (curl_exec|curl_close|curl_error|curl_errno|curl_setopt) expects CurlHandle, CurlHandle\|resource(\|null)? given\.#'
|
|
||||||
- message: '#Method Monolog\\Handler\\LogglyHandler::loadCurlHandle\(\) never returns resource so it can be removed from the return typehint.#'
|
|
||||||
paths:
|
|
||||||
- src/Monolog/Handler/LogglyHandler.php
|
|
||||||
|
|
||||||
# blocked by https://github.com/phpstan/phpstan/issues/5091
|
|
||||||
- '#has unknown class Monolog\\Handler\\Record#'
|
|
||||||
- '#::processRecord\(\) should return array#'
|
|
||||||
- '#::processRecord\(\) has invalid type#'
|
|
||||||
- '#::processRecord\(\) return type has no value type#'
|
|
||||||
- '#::processRecord\(\) has parameter \$record with no value type#'
|
|
||||||
- '#::popProcessor\(\) should return callable#'
|
|
||||||
- '#Parameter \#1 \$ of callable \(callable\(Monolog\\Handler\\Record\): Monolog\\Handler\\Record\)#'
|
|
||||||
- '#is incompatible with native type array.#'
|
|
||||||
|
@@ -70,6 +70,8 @@ class ElasticaFormatter extends NormalizerFormatter
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a log message into an Elastica Document
|
* Convert a log message into an Elastica Document
|
||||||
|
*
|
||||||
|
* @param mixed[] $record
|
||||||
*/
|
*/
|
||||||
protected function getDocument(array $record): Document
|
protected function getDocument(array $record): Document
|
||||||
{
|
{
|
||||||
|
@@ -136,16 +136,12 @@ class JsonFormatter extends NormalizerFormatter
|
|||||||
*/
|
*/
|
||||||
protected function formatBatchNewlines(array $records): string
|
protected function formatBatchNewlines(array $records): string
|
||||||
{
|
{
|
||||||
$instance = $this;
|
|
||||||
|
|
||||||
$oldNewline = $this->appendNewline;
|
$oldNewline = $this->appendNewline;
|
||||||
$this->appendNewline = false;
|
$this->appendNewline = false;
|
||||||
array_walk($records, function (&$value, $key) use ($instance) {
|
$formatted = array_map(fn (LogRecord $record) => $this->format($record), $records);
|
||||||
$value = $instance->format($value);
|
|
||||||
});
|
|
||||||
$this->appendNewline = $oldNewline;
|
$this->appendNewline = $oldNewline;
|
||||||
|
|
||||||
return implode("\n", $records);
|
return implode("\n", $formatted);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -48,14 +48,17 @@ class NormalizerFormatter implements FormatterInterface
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*
|
|
||||||
* @param mixed[] $record
|
|
||||||
*/
|
*/
|
||||||
public function format(LogRecord $record)
|
public function format(LogRecord $record)
|
||||||
{
|
{
|
||||||
return $this->normalizeRecord($record);
|
return $this->normalizeRecord($record);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Normalize an arbitrary value to a scalar|array|null
|
||||||
|
*
|
||||||
|
* @return null|scalar|array<mixed[]|scalar|null>
|
||||||
|
*/
|
||||||
public function normalizeValue(mixed $data): mixed
|
public function normalizeValue(mixed $data): mixed
|
||||||
{
|
{
|
||||||
return $this->normalize($data);
|
return $this->normalize($data);
|
||||||
@@ -134,15 +137,20 @@ class NormalizerFormatter implements FormatterInterface
|
|||||||
*
|
*
|
||||||
* Because normalize is called with sub-values of context data etc, normalizeRecord can be
|
* Because normalize is called with sub-values of context data etc, normalizeRecord can be
|
||||||
* extended when data needs to be appended on the record array but not to other normalized data.
|
* extended when data needs to be appended on the record array but not to other normalized data.
|
||||||
|
*
|
||||||
|
* @return array<mixed[]|scalar|null>
|
||||||
*/
|
*/
|
||||||
protected function normalizeRecord(LogRecord $record): array
|
protected function normalizeRecord(LogRecord $record): array
|
||||||
{
|
{
|
||||||
return $this->normalize($record->toArray());
|
/** @var array<mixed> $normalized */
|
||||||
|
$normalized = $this->normalize($record->toArray());
|
||||||
|
|
||||||
|
return $normalized;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param mixed $data
|
* @param mixed $data
|
||||||
* @return null|scalar|array<array|scalar|null>
|
* @return null|scalar|array<mixed[]|scalar|null>
|
||||||
*/
|
*/
|
||||||
protected function normalize(mixed $data, int $depth = 0): mixed
|
protected function normalize(mixed $data, int $depth = 0): mixed
|
||||||
{
|
{
|
||||||
@@ -189,14 +197,14 @@ class NormalizerFormatter implements FormatterInterface
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ($data instanceof \JsonSerializable) {
|
if ($data instanceof \JsonSerializable) {
|
||||||
/** @var null|scalar|array<array|scalar|null> $value */
|
/** @var null|scalar|array<mixed[]|scalar|null> $value */
|
||||||
$value = $data->jsonSerialize();
|
$value = $data->jsonSerialize();
|
||||||
} elseif (method_exists($data, '__toString')) {
|
} elseif (method_exists($data, '__toString')) {
|
||||||
/** @var string $value */
|
/** @var string $value */
|
||||||
$value = $data->__toString();
|
$value = $data->__toString();
|
||||||
} else {
|
} else {
|
||||||
// the rest is normalized by json encoding and decoding it
|
// the rest is normalized by json encoding and decoding it
|
||||||
/** @var null|scalar|array<array|scalar|null> $value */
|
/** @var null|scalar|array<mixed[]|scalar|null> $value */
|
||||||
$value = json_decode($this->toJson($data, true), true);
|
$value = json_decode($this->toJson($data, true), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -246,7 +254,7 @@ class NormalizerFormatter implements FormatterInterface
|
|||||||
|
|
||||||
$trace = $e->getTrace();
|
$trace = $e->getTrace();
|
||||||
foreach ($trace as $frame) {
|
foreach ($trace as $frame) {
|
||||||
if (isset($frame['file'])) {
|
if (isset($frame['file'], $frame['line'])) {
|
||||||
$data['trace'][] = $frame['file'].':'.$frame['line'];
|
$data['trace'][] = $frame['file'].':'.$frame['line'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -70,26 +70,24 @@ class WildfireFormatter extends NormalizerFormatter
|
|||||||
unset($record->extra['line']);
|
unset($record->extra['line']);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @var mixed[] $record */
|
|
||||||
$record = $this->normalize($record);
|
|
||||||
$message = ['message' => $record->message];
|
$message = ['message' => $record->message];
|
||||||
$handleError = false;
|
$handleError = false;
|
||||||
if ($record->context) {
|
if (count($record->context) > 0) {
|
||||||
$message['context'] = $record->context;
|
$message['context'] = $this->normalize($record->context);
|
||||||
$handleError = true;
|
$handleError = true;
|
||||||
}
|
}
|
||||||
if ($record->extra) {
|
if (count($record->extra) > 0) {
|
||||||
$message['extra'] = $record->extra;
|
$message['extra'] = $this->normalize($record->extra);
|
||||||
$handleError = true;
|
$handleError = true;
|
||||||
}
|
}
|
||||||
if (count($message) === 1) {
|
if (count($message) === 1) {
|
||||||
$message = reset($message);
|
$message = reset($message);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($record->context['table'])) {
|
if (is_array($message) && isset($message['context']['table'])) {
|
||||||
$type = 'TABLE';
|
$type = 'TABLE';
|
||||||
$label = $record->channel .': '. $record->message;
|
$label = $record->channel .': '. $record->message;
|
||||||
$message = $record->context['table'];
|
$message = $message['context']['table'];
|
||||||
} else {
|
} else {
|
||||||
$type = $this->logLevels[$record->level];
|
$type = $this->logLevels[$record->level];
|
||||||
$label = $record->channel;
|
$label = $record->channel;
|
||||||
@@ -127,7 +125,7 @@ class WildfireFormatter extends NormalizerFormatter
|
|||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*
|
*
|
||||||
* @return null|scalar|array<array|scalar|null>|object
|
* @return null|scalar|array<mixed[]|scalar|null>|object
|
||||||
*/
|
*/
|
||||||
protected function normalize(mixed $data, int $depth = 0): mixed
|
protected function normalize(mixed $data, int $depth = 0): mixed
|
||||||
{
|
{
|
||||||
|
@@ -81,9 +81,9 @@ class BrowserConsoleHandler extends AbstractProcessingHandler
|
|||||||
|
|
||||||
if (count(static::$records)) {
|
if (count(static::$records)) {
|
||||||
if ($format === self::FORMAT_HTML) {
|
if ($format === self::FORMAT_HTML) {
|
||||||
static::writeOutput('<script>' . static::generateScript() . '</script>');
|
static::writeOutput('<script>' . self::generateScript() . '</script>');
|
||||||
} elseif ($format === self::FORMAT_JS) {
|
} elseif ($format === self::FORMAT_JS) {
|
||||||
static::writeOutput(static::generateScript());
|
static::writeOutput(self::generateScript());
|
||||||
}
|
}
|
||||||
static::resetStatic();
|
static::resetStatic();
|
||||||
}
|
}
|
||||||
@@ -202,7 +202,7 @@ class BrowserConsoleHandler extends AbstractProcessingHandler
|
|||||||
|
|
||||||
foreach (array_reverse($matches) as $match) {
|
foreach (array_reverse($matches) as $match) {
|
||||||
$args[] = '"font-weight: normal"';
|
$args[] = '"font-weight: normal"';
|
||||||
$args[] = self::quote(static::handleCustomStyles($match[2][0], $match[1][0]));
|
$args[] = self::quote(self::handleCustomStyles($match[2][0], $match[1][0]));
|
||||||
|
|
||||||
$pos = $match[0][1];
|
$pos = $match[0][1];
|
||||||
$format = Utils::substr($format, 0, $pos) . '%c' . $match[1][0] . '%c' . Utils::substr($format, $pos + strlen($match[0][0]));
|
$format = Utils::substr($format, 0, $pos) . '%c' . $match[1][0] . '%c' . Utils::substr($format, $pos + strlen($match[0][0]));
|
||||||
|
@@ -23,9 +23,9 @@ use Monolog\LogRecord;
|
|||||||
*/
|
*/
|
||||||
class CubeHandler extends AbstractProcessingHandler
|
class CubeHandler extends AbstractProcessingHandler
|
||||||
{
|
{
|
||||||
/** @var resource|\Socket|null */
|
/** @var \Socket|null */
|
||||||
private $udpConnection = null;
|
private $udpConnection = null;
|
||||||
/** @var resource|\CurlHandle|null */
|
/** @var \CurlHandle|null */
|
||||||
private $httpConnection = null;
|
private $httpConnection = null;
|
||||||
/** @var string */
|
/** @var string */
|
||||||
private $scheme;
|
private $scheme;
|
||||||
@@ -143,6 +143,10 @@ class CubeHandler extends AbstractProcessingHandler
|
|||||||
$this->connectUdp();
|
$this->connectUdp();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (null === $this->udpConnection) {
|
||||||
|
throw new \LogicException('No UDP socket could be opened');
|
||||||
|
}
|
||||||
|
|
||||||
socket_send($this->udpConnection, $data, strlen($data), 0);
|
socket_send($this->udpConnection, $data, strlen($data), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -222,6 +222,7 @@ class SlackRecord
|
|||||||
*/
|
*/
|
||||||
public function stringify(array $fields): string
|
public function stringify(array $fields): string
|
||||||
{
|
{
|
||||||
|
/** @var array<mixed> $normalized */
|
||||||
$normalized = $this->normalizerFormatter->normalizeValue($fields);
|
$normalized = $this->normalizerFormatter->normalizeValue($fields);
|
||||||
|
|
||||||
$hasSecondDimension = count(array_filter($normalized, 'is_array'));
|
$hasSecondDimension = count(array_filter($normalized, 'is_array'));
|
||||||
@@ -342,6 +343,7 @@ class SlackRecord
|
|||||||
*/
|
*/
|
||||||
private function generateAttachmentFields(array $data): array
|
private function generateAttachmentFields(array $data): array
|
||||||
{
|
{
|
||||||
|
/** @var array<mixed> $normalized */
|
||||||
$normalized = $this->normalizerFormatter->normalizeValue($data);
|
$normalized = $this->normalizerFormatter->normalizeValue($data);
|
||||||
|
|
||||||
$fields = array();
|
$fields = array();
|
||||||
|
@@ -22,7 +22,7 @@ class UdpSocket
|
|||||||
protected $ip;
|
protected $ip;
|
||||||
/** @var int */
|
/** @var int */
|
||||||
protected $port;
|
protected $port;
|
||||||
/** @var resource|Socket|null */
|
/** @var Socket|null */
|
||||||
protected $socket;
|
protected $socket;
|
||||||
|
|
||||||
public function __construct(string $ip, int $port = 514)
|
public function __construct(string $ip, int $port = 514)
|
||||||
@@ -51,7 +51,7 @@ class UdpSocket
|
|||||||
|
|
||||||
public function close(): void
|
public function close(): void
|
||||||
{
|
{
|
||||||
if (is_resource($this->socket) || $this->socket instanceof Socket) {
|
if ($this->socket instanceof Socket) {
|
||||||
socket_close($this->socket);
|
socket_close($this->socket);
|
||||||
$this->socket = null;
|
$this->socket = null;
|
||||||
}
|
}
|
||||||
@@ -59,7 +59,7 @@ class UdpSocket
|
|||||||
|
|
||||||
protected function send(string $chunk): void
|
protected function send(string $chunk): void
|
||||||
{
|
{
|
||||||
if (!is_resource($this->socket) && !$this->socket instanceof Socket) {
|
if (!$this->socket instanceof Socket) {
|
||||||
throw new \RuntimeException('The UdpSocket to '.$this->ip.':'.$this->port.' has been closed and can not be written to anymore');
|
throw new \RuntimeException('The UdpSocket to '.$this->ip.':'.$this->port.' has been closed and can not be written to anymore');
|
||||||
}
|
}
|
||||||
socket_sendto($this->socket, $chunk, strlen($chunk), $flags = 0, $this->ip, $this->port);
|
socket_sendto($this->socket, $chunk, strlen($chunk), $flags = 0, $this->ip, $this->port);
|
||||||
|
@@ -21,9 +21,12 @@ use Monolog\LogRecord;
|
|||||||
*/
|
*/
|
||||||
class UidProcessor implements ProcessorInterface, ResettableInterface
|
class UidProcessor implements ProcessorInterface, ResettableInterface
|
||||||
{
|
{
|
||||||
/** @var string */
|
/** @var non-empty-string */
|
||||||
private $uid;
|
private string $uid;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param int<1, 32> $length
|
||||||
|
*/
|
||||||
public function __construct(int $length = 7)
|
public function __construct(int $length = 7)
|
||||||
{
|
{
|
||||||
if ($length > 32 || $length < 1) {
|
if ($length > 32 || $length < 1) {
|
||||||
@@ -53,6 +56,10 @@ class UidProcessor implements ProcessorInterface, ResettableInterface
|
|||||||
$this->uid = $this->generateUid(strlen($this->uid));
|
$this->uid = $this->generateUid(strlen($this->uid));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param positive-int $length
|
||||||
|
* @return non-empty-string
|
||||||
|
*/
|
||||||
private function generateUid(int $length): string
|
private function generateUid(int $length): string
|
||||||
{
|
{
|
||||||
return substr(bin2hex(random_bytes((int) ceil($length / 2))), 0, $length);
|
return substr(bin2hex(random_bytes((int) ceil($length / 2))), 0, $length);
|
||||||
|
Reference in New Issue
Block a user