|
1 | 1 | <?php |
2 | 2 |
|
3 | | -namespace MonologPHPMailer; |
4 | | - |
5 | | -use Monolog\Formatter\FormatterInterface; |
6 | | -use Monolog\Formatter\LineFormatter; |
7 | | -use Monolog\Handler\MailHandler; |
8 | | -use Monolog\Logger; |
9 | | -use PHPMailer\PHPMailer\PHPMailer; |
10 | | - |
11 | 3 | /** |
12 | | - * PHPMailer handler for Monolog. |
| 4 | + * Loads required handler. |
13 | 5 | * |
14 | | - * It uses [PHPMailer](https://github.com/PHPMailer/PHPMailer/) to send emails. |
| 6 | + * It loads required handler class for Monolog 1.x or 2.x depending on its version. |
15 | 7 | * |
16 | 8 | * @since 1.0.0 |
17 | 9 | * |
|
21 | 13 | * |
22 | 14 | * @package MonologPHPMailer |
23 | 15 | */ |
24 | | -class PHPMailerHandler extends MailHandler |
25 | | -{ |
26 | | - /** |
27 | | - * A PHPMailer instance. |
28 | | - * |
29 | | - * @var PHPMailer $mailer |
30 | | - */ |
31 | | - protected $mailer; |
32 | | - |
33 | | - /** |
34 | | - * Constructs the PHPMailer handler. |
35 | | - * |
36 | | - * @param PHPMailer $mailer A PHPMailer instance to use. |
37 | | - * @param int|string $level The minimum logging level at which this handler will be triggered. |
38 | | - * @param bool $bubble Whether the messages that are handled can bubble up the stack or not. |
39 | | - * |
40 | | - * @return void |
41 | | - */ |
42 | | - public function __construct(PHPMailer $mailer, $level = Logger::ERROR, $bubble = true) |
43 | | - { |
44 | | - parent::__construct($level, $bubble); |
45 | | - $this->mailer = $mailer; |
46 | | - } |
47 | | - |
48 | | - /** |
49 | | - * Sends a mail with the given content. |
50 | | - * |
51 | | - * @param string $content Formatted email body to be sent. |
52 | | - * @param array $records The array of log records that formed this content. |
53 | | - * |
54 | | - * @return void |
55 | | - */ |
56 | | - protected function send($content, array $records) |
57 | | - { |
58 | | - $mailer = $this->buildMessage($content, $records); |
59 | | - $mailer->send(); |
60 | | - } |
61 | 16 |
|
62 | | - /** |
63 | | - * Builds a message to be sent. |
64 | | - * |
65 | | - * @param string $content Formatted email body to be sent. |
66 | | - * @param array $records The array of log records that formed this content. |
67 | | - * |
68 | | - * @return PHPMailer Builded message. |
69 | | - */ |
70 | | - public function buildMessage($content, $records) |
71 | | - { |
72 | | - $mailer = clone $this->mailer; |
73 | | - |
74 | | - if (substr($content, 0, 1) == '<') { |
75 | | - $mailer->isHTML(true); |
76 | | - } |
77 | | - |
78 | | - // @codingStandardsIgnoreStart |
79 | | - if ($records) { |
80 | | - $subjectFormatter = new LineFormatter($mailer->Subject); |
81 | | - $mailer->Subject = $subjectFormatter->format($this->getHighestRecord($records)); |
82 | | - } |
83 | | - // @codingStandardsIgnoreEnd |
84 | | - |
85 | | - // @codingStandardsIgnoreStart |
86 | | - $mailer->Body = $content; |
87 | | - // @codingStandardsIgnoreEnd |
| 17 | +use Monolog\Logger; |
88 | 18 |
|
89 | | - return $mailer; |
90 | | - } |
| 19 | +if (Logger::API == 1) { |
| 20 | + class_alias('MonologPHPMailer\PHPMailerHandler1', 'MonologPHPMailer\PHPMailerHandler'); |
| 21 | +} else { |
| 22 | + class_alias('MonologPHPMailer\PHPMailerHandler2', 'MonologPHPMailer\PHPMailerHandler'); |
91 | 23 | } |
0 commit comments