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
21 namespace MediaWiki\Mail
;
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
36 * - EmailNotification: Format and send emails to watchers about a recent change.
37 * - EmailUserFactory: Format and send emails between two wiki users.
42 class Emailer
implements IEmailer
{
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.
59 ?
string $bodyHtml = null,
62 $body = $bodyHtml ?
[ 'text' => $bodyText, 'html' => $bodyHtml ] : $bodyText;
63 return UserMailer
::send( $to, $from, $subject, $body, $options );