117 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <?php
 | |
| 
 | |
| /*
 | |
|  * This file is part of the Monolog package.
 | |
|  *
 | |
|  * (c) Jordi Boggiano <j.boggiano@seld.be>
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| 
 | |
| namespace Monolog\Formatter;
 | |
| 
 | |
| /**
 | |
|  * formats the record to be used in the FlowdockHandler
 | |
|  *
 | |
|  * @author Dominik Liebler <liebler.dominik@gmail.com>
 | |
|  */
 | |
| class FlowdockFormatter implements FormatterInterface
 | |
| {
 | |
|     /**
 | |
|      * @var string
 | |
|      */
 | |
|     private $source;
 | |
| 
 | |
|     /**
 | |
|      * @var string
 | |
|      */
 | |
|     private $sourceEmail;
 | |
| 
 | |
|     /**
 | |
|      * @param string $source
 | |
|      * @param string $sourceEmail
 | |
|      */
 | |
|     public function __construct($source, $sourceEmail)
 | |
|     {
 | |
|         $this->source = $source;
 | |
|         $this->sourceEmail = $sourceEmail;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritdoc}
 | |
|      */
 | |
|     public function format(array $record)
 | |
|     {
 | |
|         $tags = array(
 | |
|             '#logs',
 | |
|             '#' . strtolower($record['level_name']),
 | |
|             '#' . $record['channel'],
 | |
|         );
 | |
| 
 | |
|         foreach ($record['extra'] as $value) {
 | |
|             $tags[] = '#' . $value;
 | |
|         }
 | |
| 
 | |
|         $subject = sprintf(
 | |
|             'in %s: %s - %s',
 | |
|             $this->source,
 | |
|             $record['level_name'],
 | |
|             $this->getShortMessage($record['message'])
 | |
|         );
 | |
| 
 | |
|         $record['flowdock'] = array(
 | |
|             'source' => $this->source,
 | |
|             'from_address' => $this->sourceEmail,
 | |
|             'subject' => $subject,
 | |
|             'content' => $record['message'],
 | |
|             'tags' => $tags,
 | |
|             'project' => $this->source,
 | |
|         );
 | |
| 
 | |
|         return $record;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritdoc}
 | |
|      */
 | |
|     public function formatBatch(array $records)
 | |
|     {
 | |
|         $formatted = array();
 | |
| 
 | |
|         foreach ($records as $record) {
 | |
|             $formatted[] = $this->format($record);
 | |
|         }
 | |
| 
 | |
|         return $formatted;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param string $message
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public function getShortMessage($message)
 | |
|     {
 | |
|         static $hasMbString;
 | |
| 
 | |
|         if (null === $hasMbString) {
 | |
|             $hasMbString = function_exists('mb_strlen');
 | |
|         }
 | |
| 
 | |
|         $maxLength = 45;
 | |
| 
 | |
|         if ($hasMbString) {
 | |
|             if (mb_strlen($message, 'UTF-8') > $maxLength) {
 | |
|                 $message = mb_substr($message, 0, $maxLength - 4, 'UTF-8') . ' ...';
 | |
|             }
 | |
|         } else {
 | |
|             if (strlen($message) > $maxLength) {
 | |
|                 $message = substr($message, 0, $maxLength - 4) . ' ...';
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return $message;
 | |
|     }
 | |
| }
 |