mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-25 10:36:33 +02:00 
			
		
		
		
	Fix displaying anonymous classes
This commit is contained in:
		| @@ -12,6 +12,7 @@ | ||||
| namespace Monolog\Formatter; | ||||
|  | ||||
| use Exception; | ||||
| use Monolog\Registry; | ||||
| use Throwable; | ||||
|  | ||||
| /** | ||||
| @@ -179,11 +180,11 @@ class JsonFormatter extends NormalizerFormatter | ||||
|     { | ||||
|         // TODO 2.0 only check for Throwable | ||||
|         if (!$e instanceof Exception && !$e instanceof Throwable) { | ||||
|             throw new \InvalidArgumentException('Exception/Throwable expected, got '.gettype($e).' / '.get_class($e)); | ||||
|             throw new \InvalidArgumentException('Exception/Throwable expected, got '.gettype($e).' / '.Registry::getClass($e)); | ||||
|         } | ||||
|  | ||||
|         $data = array( | ||||
|             'class' => get_class($e), | ||||
|             'class' => Registry::getClass($e), | ||||
|             'message' => $e->getMessage(), | ||||
|             'code' => $e->getCode(), | ||||
|             'file' => $e->getFile().':'.$e->getLine(), | ||||
|   | ||||
| @@ -11,6 +11,8 @@ | ||||
|  | ||||
| namespace Monolog\Formatter; | ||||
|  | ||||
| use Monolog\Registry; | ||||
|  | ||||
| /** | ||||
|  * Formats incoming records into a one-line string | ||||
|  * | ||||
| @@ -129,17 +131,17 @@ class LineFormatter extends NormalizerFormatter | ||||
|     { | ||||
|         // TODO 2.0 only check for Throwable | ||||
|         if (!$e instanceof \Exception && !$e instanceof \Throwable) { | ||||
|             throw new \InvalidArgumentException('Exception/Throwable expected, got '.gettype($e).' / '.get_class($e)); | ||||
|             throw new \InvalidArgumentException('Exception/Throwable expected, got '.gettype($e).' / '.Registry::getClass($e)); | ||||
|         } | ||||
|  | ||||
|         $previousText = ''; | ||||
|         if ($previous = $e->getPrevious()) { | ||||
|             do { | ||||
|                 $previousText .= ', '.get_class($previous).'(code: '.$previous->getCode().'): '.$previous->getMessage().' at '.$previous->getFile().':'.$previous->getLine(); | ||||
|                 $previousText .= ', '.Registry::getClass($previous).'(code: '.$previous->getCode().'): '.$previous->getMessage().' at '.$previous->getFile().':'.$previous->getLine(); | ||||
|             } while ($previous = $previous->getPrevious()); | ||||
|         } | ||||
|  | ||||
|         $str = '[object] ('.get_class($e).'(code: '.$e->getCode().'): '.$e->getMessage().' at '.$e->getFile().':'.$e->getLine().$previousText.')'; | ||||
|         $str = '[object] ('.Registry::getClass($e).'(code: '.$e->getCode().'): '.$e->getMessage().' at '.$e->getFile().':'.$e->getLine().$previousText.')'; | ||||
|         if ($this->includeStacktraces) { | ||||
|             $str .= "\n[stacktrace]\n".$e->getTraceAsString()."\n"; | ||||
|         } | ||||
|   | ||||
| @@ -11,6 +11,8 @@ | ||||
|  | ||||
| namespace Monolog\Formatter; | ||||
|  | ||||
| use Monolog\Registry; | ||||
|  | ||||
| /** | ||||
|  * Formats a record for use with the MongoDBHandler. | ||||
|  * | ||||
| @@ -75,7 +77,7 @@ class MongoDBFormatter implements FormatterInterface | ||||
|     protected function formatObject($value, $nestingLevel) | ||||
|     { | ||||
|         $objectVars = get_object_vars($value); | ||||
|         $objectVars['class'] = get_class($value); | ||||
|         $objectVars['class'] = Registry::getClass($value); | ||||
|  | ||||
|         return $this->formatArray($objectVars, $nestingLevel); | ||||
|     } | ||||
| @@ -83,7 +85,7 @@ class MongoDBFormatter implements FormatterInterface | ||||
|     protected function formatException(\Exception $exception, $nestingLevel) | ||||
|     { | ||||
|         $formattedException = array( | ||||
|             'class' => get_class($exception), | ||||
|             'class' => Registry::getClass($exception), | ||||
|             'message' => $exception->getMessage(), | ||||
|             'code' => $exception->getCode(), | ||||
|             'file' => $exception->getFile() . ':' . $exception->getLine(), | ||||
|   | ||||
| @@ -12,6 +12,7 @@ | ||||
| namespace Monolog\Formatter; | ||||
|  | ||||
| use Exception; | ||||
| use Monolog\Registry; | ||||
|  | ||||
| /** | ||||
|  * Normalizes incoming records to remove objects/resources so it's easier to dump to various targets | ||||
| @@ -108,7 +109,7 @@ class NormalizerFormatter implements FormatterInterface | ||||
|                 $value = $this->toJson($data, true); | ||||
|             } | ||||
|  | ||||
|             return sprintf("[object] (%s: %s)", get_class($data), $value); | ||||
|             return sprintf("[object] (%s: %s)", Registry::getClass($data), $value); | ||||
|         } | ||||
|  | ||||
|         if (is_resource($data)) { | ||||
| @@ -122,11 +123,11 @@ class NormalizerFormatter implements FormatterInterface | ||||
|     { | ||||
|         // TODO 2.0 only check for Throwable | ||||
|         if (!$e instanceof Exception && !$e instanceof \Throwable) { | ||||
|             throw new \InvalidArgumentException('Exception/Throwable expected, got '.gettype($e).' / '.get_class($e)); | ||||
|             throw new \InvalidArgumentException('Exception/Throwable expected, got '.gettype($e).' / '.Registry::getClass($e)); | ||||
|         } | ||||
|  | ||||
|         $data = array( | ||||
|             'class' => get_class($e), | ||||
|             'class' => Registry::getClass($e), | ||||
|             'message' => $e->getMessage(), | ||||
|             'code' => $e->getCode(), | ||||
|             'file' => $e->getFile().':'.$e->getLine(), | ||||
| @@ -159,7 +160,7 @@ class NormalizerFormatter implements FormatterInterface | ||||
|                     // as a class name to avoid any unexpected leak of sensitive information | ||||
|                     $frame['args'] = array_map(function ($arg) { | ||||
|                         if (is_object($arg) && !($arg instanceof \DateTime || $arg instanceof \DateTimeInterface)) { | ||||
|                             return sprintf("[object] (%s)", get_class($arg)); | ||||
|                             return sprintf("[object] (%s)", Registry::getClass($arg)); | ||||
|                         } | ||||
|  | ||||
|                         return $arg; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user