Localisation updates from https://translatewiki.net.
[mediawiki.git] / includes / mail / Emailer.php
blobeeaa79f54776f755abb92c5a59a0bad63ce9bbb8
1 <?php
2 /**
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License as published by
5 * the Free Software Foundation; either version 2 of the License, or
6 * (at your option) any later version.
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
13 * You should have received a copy of the GNU General Public License along
14 * with this program; if not, write to the Free Software Foundation, Inc.,
15 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 * http://www.gnu.org/copyleft/gpl.html
18 * @file
21 namespace MediaWiki\Mail;
23 use MailAddress;
24 use StatusValue;
25 use UserMailer;
27 /**
28 * Send arbitrary emails.
30 * Obtain instance via ServiceWiring. This service is intended to eventually
31 * replace the stable (but static) functions of the UserMailer class.
33 * Use of this class is discouraged in favour of higher-level abstractions
34 * whenever possible:
36 * - EmailNotification: Format and send emails to watchers about a recent change.
37 * - EmailUserFactory: Format and send emails between two wiki users.
39 * @since 1.35
40 * @ingroup Mail
42 class Emailer implements IEmailer {
44 /**
45 * @since 1.35
47 * This function will perform a direct (authenticated) login to
48 * a SMTP Server to use for mail relaying if 'wgSMTP' specifies an
49 * array of parameters. It requires PEAR:Mail to do that.
50 * Otherwise it just uses the standard PHP 'mail' function.
52 * @inheritDoc
54 public function send(
55 $to,
56 MailAddress $from,
57 string $subject,
58 string $bodyText,
59 ?string $bodyHtml = null,
60 array $options = []
61 ): StatusValue {
62 $body = $bodyHtml ? [ 'text' => $bodyText, 'html' => $bodyHtml ] : $bodyText;
63 return UserMailer::send( $to, $from, $subject, $body, $options );