Пример #1
0
 public function testGetters()
 {
     $exception = new CM_Exception('Foo bar', ['foo' => new SplFixedArray(), 'bar' => [1, 2, 3]]);
     $serializableException = new CM_ExceptionHandling_SerializableException($exception);
     $this->assertSame('Foo bar', $serializableException->getMessage());
     $this->assertSame('CM_Exception', $serializableException->getClass());
     $this->assertSame(__FILE__, $serializableException->getFile());
     $this->assertInternalType('int', $serializableException->getLine());
     $this->assertSame(['foo' => 'SplFixedArray', 'bar' => '[]'], $serializableException->getMeta());
 }
Пример #2
0
 /**
  * @param CM_Log_Record $record
  * @return array
  */
 protected function _formatRecord(CM_Log_Record $record)
 {
     $recordContext = $record->getContext();
     $computerInfo = $recordContext->getComputerInfo();
     $user = $recordContext->getUser();
     $extra = $recordContext->getExtra();
     $request = $recordContext->getHttpRequest();
     $createdAt = $record->getCreatedAt();
     $formattedContext = [];
     if (null !== $computerInfo) {
         $formattedContext['computerInfo'] = ['fqdn' => $computerInfo->getFullyQualifiedDomainName(), 'phpVersion' => $computerInfo->getPhpVersion()];
     }
     if (!isset($extra['type'])) {
         $extra['type'] = self::DEFAULT_TYPE;
     }
     $formattedContext['extra'] = $extra;
     if (null !== $user) {
         $formattedContext['user'] = ['id' => $user->getId(), 'name' => $user->getDisplayName()];
     }
     if (null !== $request) {
         $formattedContext['httpRequest'] = ['method' => $request->getMethodName(), 'uri' => $request->getUri(), 'query' => [], 'server' => $request->getServer(), 'headers' => $request->getHeaders()];
         $formattedContext['httpRequest']['query'] = $request->findQuery();
         if ($request instanceof CM_Http_Request_Post) {
             $formattedContext['httpRequest']['body'] = $request->getBody();
         }
         $formattedContext['httpRequest']['clientId'] = $request->getClientId();
     }
     if ($exception = $recordContext->getException()) {
         $serializableException = new CM_ExceptionHandling_SerializableException($exception);
         $formattedContext['exception'] = ['class' => $serializableException->getClass(), 'message' => $serializableException->getMessage(), 'line' => $serializableException->getLine(), 'file' => $serializableException->getFile(), 'trace' => $serializableException->getTrace(), 'traceString' => $serializableException->getTraceAsString(), 'meta' => $serializableException->getMeta()];
     }
     $formattedRecord = ['level' => (int) $record->getLevel(), 'message' => (string) $record->getMessage(), 'createdAt' => $createdAt, 'context' => $formattedContext];
     if (null !== $this->_recordTtl) {
         $expireAt = clone $createdAt;
         $expireAt->add(new DateInterval('PT' . $this->_recordTtl . 'S'));
         $formattedRecord['expireAt'] = $expireAt;
     }
     $formattedRecord = $this->_sanitizeRecord($formattedRecord);
     //TODO remove after investigation
     return $formattedRecord;
 }
Пример #3
0
 public function getHeader(CM_ExceptionHandling_SerializableException $exception)
 {
     return $exception->getClass() . ': ' . $exception->getMessage() . ' in ' . $exception->getFile() . ' on line ' . $exception->getLine() . PHP_EOL;
 }
Пример #4
0
 public function getHeader(CM_ExceptionHandling_SerializableException $exception)
 {
     return '<h1>' . $exception->getClass() . '</h1><h2>' . $exception->getMessage() . '</h2><pre>' . $exception->getFile() . ' on line ' . $exception->getLine() . '</pre>';
 }