Completed
Pull Request — master (#64)
by Frederik
03:38 queued 01:09
created

PsrLogExceptionTransport   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 50
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Test Coverage

Coverage 93.33%

Importance

Changes 0
Metric Value
wmc 3
lcom 1
cbo 2
dl 0
loc 50
ccs 14
cts 15
cp 0.9333
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 6 1
A send() 0 17 2
1
<?php
2
declare(strict_types=1);
3
4
namespace Genkgo\Mail\Transport;
5
6
use Genkgo\Mail\MessageInterface;
7
use Genkgo\Mail\TransportInterface;
8
use Psr\Log\LoggerInterface;
9
use Psr\Log\LogLevel;
10
11
final class PsrLogExceptionTransport
12
{
13
    /**
14
     * @var TransportInterface
15
     */
16
    private $delegatedTransport;
17
18
    /**
19
     * @var LoggerInterface
20
     */
21
    private $logger;
22
23
    /**
24
     * @var string
25
     */
26
    private $logLevel;
27
28
    /**
29
     * @param TransportInterface $delegatedTransport
30
     * @param LoggerInterface $logger
31
     * @param string $logLevel
32
     */
33 1
    public function __construct(TransportInterface $delegatedTransport, LoggerInterface $logger, string $logLevel = LogLevel::INFO)
34
    {
35 1
        $this->delegatedTransport = $delegatedTransport;
36 1
        $this->logger = $logger;
37 1
        $this->logLevel = $logLevel;
38 1
    }
39
40
    /**
41
     * @param MessageInterface $message
42
     */
43 1
    public function send(MessageInterface $message): void
44
    {
45
        try {
46 1
            $this->delegatedTransport->send($message);
47 1
        } catch (\Throwable $e) {
48 1
            $this->logger->log($this->logLevel, 'Failed to send e-mail message. ' . $e->getMessage(), [
49
                'exception' => [
50 1
                    'class' => \get_class($e),
51 1
                    'file' => $e->getFile(),
52 1
                    'line' => $e->getLine(),
53 1
                    'message' => $e->getMessage(),
54
                ],
55
            ]);
56
57 1
            throw $e;
58
        }
59
    }
60
}
61