MediaWiki REL1_41
UserMailer Class Reference

Collection of static functions for sending mail. More...

Static Public Member Functions

static quotedPrintable ( $string, $charset='')
 Converts a string into quoted-printable format.
 
static rfc822Phrase ( $phrase)
 Converts a string into a valid RFC 822 "phrase", such as is used for the sender name.
 
static sanitizeHeaderValue ( $val)
 Strips bad characters from a header value to prevent PHP mail header injection attacks.
 
static send ( $to, $from, $subject, $body, $options=[])
 This function will perform a direct (authenticated) login to a SMTP Server to use for mail relaying if 'wgSMTP' specifies an array of parameters.
 

Static Protected Member Functions

static sendInternal (array $to, MailAddress $from, $subject, $body, $options=[])
 Helper function fo UserMailer::send() which does the actual sending.
 
static sendWithPear ( $mailer, $dest, $headers, $body)
 Send mail using a PEAR mailer.
 

Detailed Description

Collection of static functions for sending mail.

Definition at line 39 of file UserMailer.php.

Member Function Documentation

◆ quotedPrintable()

static UserMailer::quotedPrintable ( $string,
$charset = '' )
static

Converts a string into quoted-printable format.

Since
1.17

From PHP5.3 there is a built in function quoted_printable_encode() This method does not duplicate that. This method is doing Q encoding inside encoded-words as defined by RFC 2047 This is for email headers. The built in quoted_printable_encode() is for email bodies

Parameters
string$string
string$charset
Returns
string

Definition at line 451 of file UserMailer.php.

References $matches.

◆ rfc822Phrase()

static UserMailer::rfc822Phrase ( $phrase)
static

Converts a string into a valid RFC 822 "phrase", such as is used for the sender name.

Parameters
string$phrase
Returns
string

Definition at line 430 of file UserMailer.php.

◆ sanitizeHeaderValue()

static UserMailer::sanitizeHeaderValue ( $val)
static

Strips bad characters from a header value to prevent PHP mail header injection attacks.

Parameters
string$valString to be sanitized
Returns
string

Definition at line 421 of file UserMailer.php.

◆ send()

static UserMailer::send ( $to,
$from,
$subject,
$body,
$options = [] )
static

This function will perform a direct (authenticated) login to a SMTP Server to use for mail relaying if 'wgSMTP' specifies an array of parameters.

It requires PEAR:Mail to do that. Otherwise it just uses the standard PHP 'mail' function.

Parameters
MailAddress | MailAddress[]$toRecipient's email (or an array of them)
MailAddress$fromSender's email
string$subjectEmail's subject.
string | string[]$bodyEmail's text or Array of two strings to be the text and html bodies
array$optionsKeys: 'replyTo' MailAddress 'contentType' string default 'text/plain; charset=UTF-8' 'headers' array Extra headers to set
Returns
Status

Definition at line 99 of file UserMailer.php.

References wfDebug().

◆ sendInternal()

static UserMailer::sendInternal ( array $to,
MailAddress $from,
$subject,
$body,
$options = [] )
staticprotected

Helper function fo UserMailer::send() which does the actual sending.

It expects a $to list which the UserMailerSplitTo hook would not split further.

Parameters
MailAddress[]$toArray of recipients' email addresses
MailAddress$fromSender's email
string$subjectEmail's subject.
string | string[]$bodyEmail's text or Array of two strings to be the text and html bodies
array$optionsKeys: 'replyTo' MailAddress 'contentType' string default 'text/plain; charset=UTF-8' 'headers' array Extra headers to set
Returns
Status

Definition at line 192 of file UserMailer.php.

References $mime, PROTO_CANONICAL, MailAddress\toString(), wfDebug(), and wfIsWindows().

◆ sendWithPear()

static UserMailer::sendWithPear ( $mailer,
$dest,
$headers,
$body )
staticprotected

Send mail using a PEAR mailer.

Parameters
Mail_smtp$mailer
string[] | string$dest
array$headers
string$body
Returns
Status

Definition at line 52 of file UserMailer.php.

References wfDebug().


The documentation for this class was generated from the following file: