Completed
Pull Request — master (#64)
by Frederik
01:41
created

PsrLogExceptionTransport   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 50
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Test Coverage

Coverage 0%

Importance

Changes 0
Metric Value
wmc 3
lcom 1
cbo 2
dl 0
loc 50
ccs 0
cts 15
cp 0
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
    public function __construct(TransportInterface $delegatedTransport, LoggerInterface $logger, string $logLevel = LogLevel::INFO)
34
    {
35
        $this->delegatedTransport = $delegatedTransport;
36
        $this->logger = $logger;
37
        $this->logLevel = $logLevel;
38
    }
39
40
    /**
41
     * @param MessageInterface $message
42
     */
43
    public function send(MessageInterface $message): void
44
    {
45
        try {
46
            $this->delegatedTransport->send($message);
47
        } catch (\Throwable $e) {
48
            $this->logger->log($this->logLevel, 'Failed to send e-mail message. ' . $e->getMessage(), [
49
                'exception' => [
50
                    'class' => \get_class($e),
51
                    'file' => $e->getFile(),
52
                    'line' => $e->getLine(),
53
                    'message' => $e->getMessage(),
54
                ],
55
            ]);
56
57
            throw $e;
58
        }
59
    }
60
}
61